{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "import math\n",
    "import sys\n",
    "import numpy as np\n",
    "from scipy.integrate import simps\n",
    "import matplotlib\n",
    "import matplotlib.colors as colors\n",
    "import matplotlib.cm as cmx\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.figure as figure\n",
    "import matplotlib.patches as mpatches\n",
    "from matplotlib.ticker import FormatStrFormatter\n",
    "from six.moves import cPickle as pickle\n",
    "from scipy.spatial.distance import cosine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['k', 'C0', 'C1', 'C2', 'C3', 'C4', 'C5', 'C6', 'C7', 'C8', 'C9', 'b', 'r']\n",
      "['MULTI-TASK', 'VAN', 'EWC', 'PI', 'MAS', 'RWALK', 'GEM', 'ICARL', 'PROG-NN', 'A-GEM', 'MER', 'MEGA-I', 'MEGA-II']\n"
     ]
    }
   ],
   "source": [
    "from matplotlib import rc\n",
    "rc('font',**{'family':'sans-serif','sans-serif':['Helvetica']})\n",
    "\n",
    "\n",
    "colors = ['k', 'C0', 'C1', 'C2', 'C3', 'C4', 'C5', 'C6', 'C7', 'C8', 'C9', 'b', 'r']\n",
    "\n",
    "plt.clf()\n",
    "labels = ['MULTI-TASK', 'VAN', 'EWC', 'PI', 'MAS', 'RWALK', 'GEM', 'ICARL', 'PROG-NN','A-GEM','MER', 'MEGA-I', 'MEGA-II']\n",
    "\n",
    "fig = plt.figure(figsize=(12,1))\n",
    "patches = []\n",
    "print (colors)\n",
    "print (labels)\n",
    "for i in range(len(labels)):\n",
    "        patches.append(mpatches.Patch(color=colors[i], label=labels[i]))\n",
    "        plt.legend(handles=patches, loc=2, borderaxespad=0.6, \n",
    "                   fontsize='x-large', ncol=len(colors))\n",
    "plt.axis('off')\n",
    "#plt.show()\n",
    "plt.savefig('../iclr_plots/all_legend.pdf', bbox_inches='tight')\n",
    "colors = {'MULTI-TASK': 'k', 'VAN': 'C0', 'ICARL':'C1', 'EWC': 'C2', 'PI': 'C3', 'MAS': 'C4',  'RWALK':'C5', 'PROG-NN':'C6', 'GEM':'C7', 'A-GEM':'C8', 'MER': 'C9', 'MEGA': 'r', 'MEGAD': 'b'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Helper functions\n",
    "def unpickle_data(pickle_file):\n",
    "    \"\"\"\n",
    "    Unpickles the data from a pickle file\n",
    "    \"\"\"\n",
    "    f = open(pickle_file, 'rb')\n",
    "    return pickle.load(f)\n",
    "\n",
    "def populate_data_dict(data_dict, key, pickle_file):\n",
    "    \"\"\"\n",
    "    Given a key populates a dictionary\n",
    "    \"\"\"\n",
    "    data_dict[key] = unpickle_data(pickle_file)\n",
    "    \n",
    "    \n",
    "def min_(a, b):\n",
    "    if a < b:\n",
    "        return a\n",
    "    else:\n",
    "        return b\n",
    "\n",
    "    \n",
    "def populate_k_shot_acc_dict(data_dict, key, k_shot_dict):\n",
    "    num_runs = data_dict[key]['mean'].shape[0]\n",
    "    k_shot_dict[key] = []\n",
    "    for run in range(num_runs):\n",
    "        key_acc = data_dict[key]['mean'][run]\n",
    "        num_batches = key_acc.shape[1]\n",
    "        num_tasks = key_acc.shape[0]\n",
    "        k_shot_acc = np.zeros([num_batches], dtype=np.float32)\n",
    "        for i in range(num_batches):\n",
    "            acc = 0.0\n",
    "            for j in range(num_tasks):\n",
    "                acc += key_acc[j,i,j]\n",
    "            k_shot_acc[i] = acc/ num_tasks\n",
    "        \n",
    "        k_shot_dict[key].append(k_shot_acc)\n",
    "        \n",
    "    k_shot_dict[key] = np.array(k_shot_dict[key])\n",
    "\n",
    "def populate_k_shot_acc_dict_with_varying_batches(data_dict, key, k_shot_dict):\n",
    "    num_runs = data_dict[key]['mean'].shape[0]\n",
    "    k_shot_dict[key] = []\n",
    "    for run in range(num_runs):\n",
    "        key_acc = data_dict[key]['mean'][run]\n",
    "        num_tasks = key_acc.shape[0]\n",
    "        # First compute the number of batches for each task (as total number of examples per task is different)\n",
    "        batches_per_task = []\n",
    "        for i in range(num_tasks):\n",
    "            batches_per_task.append(np.max(np.nonzero(np.sum(key_acc[i], axis=1))))\n",
    "\n",
    "        # Since the code above returned an index, so add '1' to get the count of batches for each task\n",
    "        batches_per_task = np.array(batches_per_task) + 1\n",
    "        max_batches = np.max(batches_per_task)\n",
    "        k_shot_acc = np.zeros([max_batches], dtype=np.float32)\n",
    "    \n",
    "        for i in range(max_batches):\n",
    "            acc = 0.0\n",
    "            task_count_with_this_batch = 0\n",
    "            for j in range(num_tasks):\n",
    "                if i < batches_per_task[j]: # Only add accuracy if current task has that many batches\n",
    "                    acc += key_acc[j,i,j]\n",
    "                    task_count_with_this_batch += 1\n",
    "                else:\n",
    "                    acc += key_acc[j,batches_per_task[j]-1,j]\n",
    "            k_shot_acc[i] = acc/ num_tasks\n",
    "        \n",
    "        # Store the average accuracy in the dictionary\n",
    "        k_shot_dict[key].append(k_shot_acc)\n",
    "    \n",
    "    k_shot_dict[key] = np.array(k_shot_dict[key])\n",
    "    \n",
    "    return batches_per_task    \n",
    "\n",
    "\n",
    "def compute_fgt(acc, key):\n",
    "    num_tasks = acc.shape[0] # Number of tasks\n",
    "    last_batch_dim = acc.shape[1] - 1 # Last batch dimension\n",
    "    fgt_msr = np.zeros([num_tasks-1]) # Not defined for first task. Store forgetting after each task\n",
    "    worst_case_fgt = np.zeros([num_tasks-1]) # Not defined for first task. Store forgetting after each task\n",
    "    for i in range(num_tasks):\n",
    "        if i == 0:\n",
    "            pass\n",
    "        else:\n",
    "            wst_fgt_i = []\n",
    "            fgt_i = 0.0\n",
    "            for j in range(i):\n",
    "                if key == 'GEM' or key == 'ICARL':\n",
    "                    fgt_per_task = np.amax(acc[:i,j]) - acc[i,j]\n",
    "                else:\n",
    "                    fgt_per_task = np.amax(acc[:i,last_batch_dim,j]) - acc[i,last_batch_dim,j]\n",
    "                        \n",
    "                fgt_i += fgt_per_task\n",
    "                wst_fgt_i.append(fgt_per_task)\n",
    "            fgt_msr[i-1] = fgt_i/ (j+1)\n",
    "            wst_fgt_i = np.array(wst_fgt_i)\n",
    "            worst_case_fgt[i-1] = np.max(wst_fgt_i)\n",
    "                \n",
    "    return fgt_msr, worst_case_fgt  \n",
    "\n",
    "\n",
    "def compute_ltr(data, key):\n",
    "    \"\"\"\n",
    "    Plot the average accuracy along the training path\n",
    "    \"\"\"    \n",
    "    ltr = 0\n",
    "\n",
    "    num_tasks = data.shape[0]\n",
    "\n",
    "    for j in range(num_tasks-1):\n",
    "        ltr +=  (num_tasks - 1- j)*min_(0, data[-1, -1, j] - data[j, -1, j] )\n",
    "    ltr = ltr / (num_tasks-1)\n",
    "\n",
    "    return -ltr\n",
    "\n",
    "\n",
    "def compute_fgt_with_varying_batches(data_dict, batches_per_task):\n",
    "    fgt_msr = dict()\n",
    "    for key in data_dict:\n",
    "        acc = data_dict[key]\n",
    "        num_tasks = acc.shape[0] # Number of tasks\n",
    "        last_batch_acc_for_all_tasks = np.zeros([num_tasks, num_tasks])\n",
    "        \n",
    "        # Compute the last batch performance for each task\n",
    "        for i in range(num_tasks):\n",
    "            last_batch_acc_for_all_tasks[i] = acc[i][batches_per_task[i]-1]\n",
    "        \n",
    "        fgt_msr[key] = np.zeros([num_tasks-1]) # Not defined for first task. Store forgetting after each task\n",
    "        for i in range(num_tasks):\n",
    "            if i == 0:\n",
    "                pass\n",
    "            else:\n",
    "                fgt_i = 0.0\n",
    "                for j in range(i):\n",
    "                    fgt_i += (np.amax(last_batch_acc_for_all_tasks[:i,j]) - last_batch_acc_for_all_tasks[i,j])\n",
    "                fgt_msr[key][i-1] = fgt_i/ (j+1)\n",
    "                \n",
    "    return fgt_msr\n",
    "\n",
    "def average_acc_stats_across_runs(data, key):\n",
    "    \"\"\"\n",
    "    Compute the average accuracy statistics (mean and std) across runs\n",
    "    \"\"\"\n",
    "    num_runs = data.shape[0]\n",
    "    avg_acc = np.zeros(num_runs)\n",
    "    for i in range(num_runs):\n",
    "        if key == 'GEM':\n",
    "            avg_acc[i] = np.mean(data[i][-1])\n",
    "        else:\n",
    "            avg_acc[i] = np.mean(data[i][-1, -1])\n",
    "        \n",
    "    return avg_acc.mean()*100, avg_acc.std()*100\n",
    "\n",
    "def average_fgt_stats_across_runs(data, key):\n",
    "    \"\"\"\n",
    "    Compute the forgetting statistics (mean and std) across runs\n",
    "    \"\"\"\n",
    "    num_runs = data.shape[0]\n",
    "    fgt = np.zeros(num_runs)\n",
    "    wst_fgt = np.zeros(num_runs)\n",
    "    for i in range(num_runs):\n",
    "        fgt_i, wst_fgt_i = compute_fgt(data[i], key)\n",
    "        #print('{}, {}'.format(i, fgt_i))\n",
    "        fgt[i] = fgt_i[-1]\n",
    "        wst_fgt[i] = wst_fgt_i[-1]\n",
    "        \n",
    "    return fgt.mean(), fgt.std(), wst_fgt.mean(), wst_fgt.std()\n",
    "        \n",
    "    \n",
    "def average_ltr_across_runs(data, key):\n",
    "    \"\"\"\n",
    "    Compute the forgetting statistics (mean and std) across runs\n",
    "    \"\"\"\n",
    "    num_runs = data.shape[0]\n",
    "    ltr = np.zeros(num_runs)\n",
    "\n",
    "    for i in range(num_runs):\n",
    "        ltr_i = compute_ltr(data[i], key)\n",
    "        #print('{}, {}'.format(i, fgt_i))\n",
    "        ltr[i] = ltr_i\n",
    "        \n",
    "    return ltr.mean(), ltr.std()\n",
    "\n",
    "\n",
    "def plot_k_shot_performance_task_view(n, data_dict, keys, plt_name):\n",
    "    plt.figure(figsize=(14, 7))\n",
    "    num_windows = len(keys)\n",
    "    for i, key in enumerate(keys):\n",
    "        data = data_dict[key]\n",
    "        num_tasks = data.shape[0]\n",
    "        plt.subplot(math.ceil((num_windows+1)/2), math.ceil((num_windows+1)/2), (i+1))\n",
    "        for k in range(n):\n",
    "            acc = np.zeros([num_tasks])\n",
    "            for task in range(num_tasks):\n",
    "                acc[task] = data[task, k, task]\n",
    "            plt.plot(np.arange(1,num_tasks+1), acc, label='%d-shot'%(k))\n",
    "        plt.xlabel('Tasks-%s'%(key))\n",
    "        plt.ylabel('Avg_Acc')\n",
    "        plt.xticks(np.arange(1, num_tasks+1))\n",
    "    plt.tight_layout()\n",
    "    #plt.legend(loc='best')\n",
    "    plt.legend(loc=6, bbox_to_anchor=(1, 0.5))\n",
    "    plt.savefig(plt_name)\n",
    "    \n",
    "def plot_k_shot_performance_method_view(n, data_dict, plt_name):\n",
    "    plt.figure(figsize=(14, 7))\n",
    "    for k in range(n):\n",
    "        plt.subplot(n//2, n//2, (k+1))\n",
    "        for i, key in enumerate(data_dict):\n",
    "            num_tasks = data_dict[key].shape[0]\n",
    "            acc = np.zeros(num_tasks)\n",
    "            for task in range(num_tasks):\n",
    "                acc[task] = data_dict[key][task, k, task]\n",
    "            plt.plot(np.arange(1,num_tasks+1), acc, label=key)\n",
    "        plt.xlabel('Tasks(%d-shot)'%(k))\n",
    "        plt.ylabel('Avg_Acc')\n",
    "        plt.xticks(np.arange(1, num_tasks+1))\n",
    "    plt.tight_layout()\n",
    "    plt.legend(loc='best')\n",
    "    #plt.savefig(plt_name)    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def plot_average_accuracy_along_training_path(dataset, data_mean, batches_per_task_ohot=None, plot_name=None, legend=False):\n",
    "    \"\"\"\n",
    "    Plot the average accuracy along the training path\n",
    "    \"\"\"\n",
    "    print (data_mean['MEGA']['mean'].shape)\n",
    "    \n",
    "    plt.clf()\n",
    "    K_FOR_CROSS_VAL = 3\n",
    "    avg_acc_dict = dict()\n",
    "    for key in data_mean:\n",
    "        if key == 'ICARL':\n",
    "            data = data_mean[key]\n",
    "            num_tasks = data.shape[0] - K_FOR_CROSS_VAL\n",
    "        else:\n",
    "            if batches_per_task_ohot is None:\n",
    "                data = data_mean[key]['mean'].mean(0)\n",
    "            else:\n",
    "                data = data_mean[key]['mean'][:,:,:batches_per_task_ohot[key][-1],:].mean(0)\n",
    "            \n",
    "            num_tasks = data.shape[0]\n",
    "        avg_acc = np.zeros(num_tasks)\n",
    "        \n",
    "        for i in range(num_tasks):\n",
    "            if key == 'MULTI-TASK':\n",
    "                avg_acc[i] = np.mean(data)\n",
    "            elif key == 'ICARL':\n",
    "                avg_acc[i] = np.mean(data[i,:i+1])\n",
    "            else:\n",
    "                avg_acc[i] = np.mean(data[i,-1,:i+1])\n",
    "       \n",
    "    \n",
    "        print(key, avg_acc[-1])\n",
    "        avg_acc_dict[key] = avg_acc\n",
    "\n",
    "    \n",
    "    fig = plt.figure(figsize=(8,2.5))\n",
    "    ax = fig.add_axes([0.15, 0.21, 0.6, 0.75])\n",
    "    tasks = np.arange(1, num_tasks+1)\n",
    "\n",
    "    colors = {'MULTI-TASK': '-k', 'VAN': 'C0', 'ICARL':'C1', 'EWC': '-C2', 'PI': '-C3', 'MAS': '-C4',  'RWALK':'-C5', 'PROG-NN':'C6--', 'GEM':'C7', 'A-GEM':'-C8', 'MER': 'C9', 'MEGA': '-r', 'MEGAD': '-b'}\n",
    "    \n",
    "    for i, key in enumerate(data_mean):\n",
    "        if key == 'MULTI-TASK':\n",
    "            continue\n",
    "        else:\n",
    "            if key == 'MEGA':\n",
    "                ax.plot(tasks, avg_acc_dict[key],'%s'%(colors[key]), marker='^', markersize=7, lw=2, label=key)\n",
    "            elif key == 'MEGAD':\n",
    "                ax.plot(tasks, avg_acc_dict[key],'%s'%(colors[key]), marker='*', markersize=7, lw=2, label=key)\n",
    "            else:\n",
    "                ax.plot(tasks, avg_acc_dict[key],'%s'%(colors[key]), lw=2, label=key)\n",
    "                \n",
    "    if dataset == \"mnist\":\n",
    "        avg_acc_dict['MULTI-TASK'] = 0.953\n",
    "    elif dataset == \"cifar\":\n",
    "        avg_acc_dict['MULTI-TASK'] = 0.683\n",
    "    elif dataset == \"cub\":\n",
    "        avg_acc_dict['MULTI-TASK'] = 0.656\n",
    "    elif dataset == \"awa\":\n",
    "        avg_acc_dict['MULTI-TASK'] = 0.648     \n",
    "        \n",
    "    line, =  ax.plot(tasks , np.repeat(avg_acc_dict['MULTI-TASK'], len(tasks)) ,'%s'%(colors['MULTI-TASK']), lw=2, label='MULTI-TASK')\n",
    "    line.set_dashes([2, 2, 10, 2])\n",
    "        \n",
    "    if legend:\n",
    "        ax.legend(bbox_to_anchor=(1, 1), loc=2, borderaxespad=0.2)\n",
    "    \n",
    "    ax.set_xlabel('Tasks', size=20)\n",
    "    ax.set_ylabel('Avg Accuracy', size=20)\n",
    "    plt.xticks(tasks)\n",
    "    plt.grid()\n",
    "\n",
    "    \n",
    "    if plot_name is not None:\n",
    "        plt.savefig(plot_name, format='pdf', dpi=1000, bbox_inches = 'tight')\n",
    "    else:\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "def get_zero_shot_perf(data_mean_ohot, data_mean_je):\n",
    "    \"\"\"\n",
    "    Plot the zero-shot performance against the number of tasks\n",
    "    \"\"\"\n",
    "    zero_shot_ohot_perf = dict()\n",
    "    zero_shot_je_perf = dict()\n",
    "    \n",
    "    for key in data_mean_ohot:\n",
    "        if key == 'MULTI-TASK' or key == 'GEM':\n",
    "            continue\n",
    "        \n",
    "        data_ohot = data_mean_ohot[key]['mean'].mean(0)\n",
    "        #data_je = data_mean_je[key]['mean'].mean(0)\n",
    "        num_tasks = data_ohot.shape[0] \n",
    "        \n",
    "        zst_ohot_perf = np.zeros(num_tasks)\n",
    "        zst_je_perf = np.zeros(num_tasks)\n",
    "        \n",
    "        #if (data_ohot.shape[0] != num_tasks) or (data_je.shape[0] != num_tasks):\n",
    "        #    continue\n",
    "            \n",
    "        for i in range(num_tasks):\n",
    "            zst_ohot_perf[i] = data_ohot[i,0,i]\n",
    "            #zst_je_perf[i] = data_je[i,0,i]\n",
    "            \n",
    "        zero_shot_ohot_perf[key] = zst_ohot_perf\n",
    "        #zero_shot_je_perf[key] = zst_je_perf\n",
    "    \n",
    "    return zero_shot_ohot_perf, zero_shot_je_perf\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "def bar_plot_k_shot_performance(data_dict, shot, is_cifar=False, plt_name=None):\n",
    "    num_tasks = data_dict['VAN'].shape[0]\n",
    "    ind = np.arange(1, num_tasks+1) # the x locations for the groups\n",
    "    width = 0.15 # the width of the bars\n",
    "    colors = ['r', 'g', 'b', 'c', 'y']\n",
    "    plt.clf()\n",
    "    for col_ind, key in enumerate(data_dict):\n",
    "        acc = np.zeros([num_tasks])\n",
    "        for task in range(num_tasks):\n",
    "            acc[task] = data_dict[key][task,shot,task]\n",
    "        p1 = plt.bar(ind+width*col_ind, acc, width, color='%s'%(colors[col_ind]), bottom=0, label=key)\n",
    "    \n",
    "    plt.xticks(np.arange(1, num_tasks+1)) # add loads of ticks\n",
    "\n",
    "    plt.gca().margins(x=0)\n",
    "    plt.gcf().canvas.draw()\n",
    "    tl = plt.gca().get_xticklabels()\n",
    "    maxsize = max([t.get_window_extent().width for t in tl])\n",
    "    m = 0.5 # inch margin\n",
    "    s = maxsize/plt.gcf().dpi*num_tasks+10*m\n",
    "    margin = m/plt.gcf().get_size_inches()[0]\n",
    "\n",
    "    plt.gcf().subplots_adjust(left=margin, right=1.-margin)\n",
    "    plt.gcf().set_size_inches(s, plt.gcf().get_size_inches()[1])\n",
    "    \n",
    "    if is_cifar:\n",
    "        plt.title('%d-Shot Performance'%(shot*5))\n",
    "    else:\n",
    "        plt.title('%d-Shot Performance'%(shot))\n",
    "    plt.legend(loc=6, bbox_to_anchor=(1, 0.8))\n",
    "    plt.xlabel('Tasks')\n",
    "    plt.ylabel('Avg_Acc')    \n",
    "    #plt.show()\n",
    "    plt.savefig(plt_name)\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PERMUTE MNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "PREFIX = '../mnist/'\n",
    "van_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.03_True_VAN_0_0_10_25-19-07-31-21-48.pickle'\n",
    "ewc_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.03_True_EWC_10_0_10_25-19-07-31-23-28.pickle'\n",
    "mas_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.1_True_MAS_0_1_10_25-19-08-01-09-00.pickle'\n",
    "rwalk_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.1_True_RWALK_1_0_10_25-19-08-01-10-56.pickle'\n",
    "pnn_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.1_True_PNN_0_0_10_25-19-08-02-09-04.pickle'\n",
    "a_gem_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.1_True_A-GEM_0_0_10_25-19-08-01-17-59.pickle'\n",
    "mega_pickle = PREFIX+'PERMUTE_MNIST_HERDING_FC-S_0.1_True_MEGA_0_0_10_25-19-08-01-20-10.pickle'\n",
    "megad_pickle = '/Users/henry/Desktop/eccv_rebuttal/mega_L_and_replay/results/mnist/PERMUTE_MNIST_HERDING_FC-S_0.1_True_MEGAD_0_0_10_25-20-05-25-00-00.pickle'\n",
    "\n",
    "NUM_RUNS = 5\n",
    "MODELS = ['MULTI-TASK', 'VAN', 'EWC', 'MAS', 'RWALK', 'PNN', 'GEM', 'A-GEM', 'MEGA']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "data_mean = dict()\n",
    "\n",
    "populate_data_dict(data_mean, 'MEGA', mega_pickle)\n",
    "populate_data_dict(data_mean, 'MEGAD', megad_pickle)\n",
    "\n",
    "populate_data_dict(data_mean, 'VAN', van_pickle)\n",
    "populate_data_dict(data_mean, 'EWC', ewc_pickle)\n",
    "populate_data_dict(data_mean, 'MAS', mas_pickle)\n",
    "populate_data_dict(data_mean, 'RWALK', rwalk_pickle)\n",
    "populate_data_dict(data_mean, 'PROG-NN', pnn_pickle)\n",
    "populate_data_dict(data_mean, 'A-GEM', a_gem_pickle)\n",
    "\n",
    "\n",
    "avg_k_shot_acc = dict()\n",
    "populate_k_shot_acc_dict(data_mean, 'MEGA', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'MEGAD', avg_k_shot_acc)\n",
    "\n",
    "populate_k_shot_acc_dict(data_mean, 'VAN', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'EWC', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'MAS', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'RWALK', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'PROG-NN', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'A-GEM', avg_k_shot_acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(5, 17, 74, 17)\n",
      "('MAS', 0.702981173992157)\n",
      "('VAN', 0.47553181648254395)\n",
      "('PROG-NN', 0.935455322265625)\n",
      "('MEGA', 0.912092924118042)\n",
      "('MEGAD', 0.9110764265060425)\n",
      "('EWC', 0.6868187785148621)\n",
      "('A-GEM', 0.8932164907455444)\n",
      "('RWALK', 0.8560070991516113)\n"
     ]
    }
   ],
   "source": [
    "#plot_average_accuracy_along_training_path(data_mean, 'iclr_plots/mnist_average_accuracy.pdf')\n",
    "plot_average_accuracy_along_training_path(\"mnist\", data_mean, plot_name='../iclr_plots/mnist_average_accuracy.pdf', legend=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Average Accuracy and Forgetting Measure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MAS=> Acc: 70.2981162071 (+-1.67382483355), LTR: 3.07751998231 (+-0.198589069282), Fgt: 0.264376252145 (+-0.017920328191), Wst Fgt: 0.594880008698 (+-0.038297128472)\n",
      "VAN=> Acc: 47.553178072 (+-2.379821893), LTR: 5.37534128428 (+-0.194282624275), Fgt: 0.515132504702 (+-0.0255773676522), Wst Fgt: 0.785800004005 (+-0.0230036653673)\n",
      "PROG-NN=> Acc: 93.5455310345 (+-0.0671211570642), LTR: 0.0 (+-0.0), Fgt: 0.0 (+-0.0), Wst Fgt: 0.0 (+-0.0)\n",
      "MEGA=> Acc: 91.2092936039 (+-0.102357696167), LTR: 0.524813756347 (+-0.0171017819206), Fgt: 0.0492162510753 (+-0.00136636393917), Wst Fgt: 0.091739988327 (+-0.00302958697167)\n",
      "MEGAD=> Acc: 91.107647419 (+-0.0829836400468), LTR: 0.541152518243 (+-0.00950347079116), Fgt: 0.0500100024045 (+-0.000619203317258), Wst Fgt: 0.0982800006866 (+-0.00709518447949)\n",
      "EWC=> Acc: 68.6818826199 (+-0.984597634892), LTR: 3.29165122844 (+-0.135180407244), Fgt: 0.284868749604 (+-0.0104478246396), Wst Fgt: 0.599559998512 (+-0.0316094095056)\n",
      "A-GEM=> Acc: 89.3216502666 (+-0.464811266785), LTR: 0.716423734277 (+-0.0485633004611), Fgt: 0.0693162478507 (+-0.0048394609047), Wst Fgt: 0.123680007458 (+-0.010467755777)\n",
      "RWALK=> Acc: 85.6007063389 (+-0.718854655126), LTR: 0.821201258153 (+-0.0817989329981), Fgt: 0.0842487491667 (+-0.00734027212816), Wst Fgt: 0.164920008183 (+-0.0128316097394)\n"
     ]
    }
   ],
   "source": [
    "for key in data_mean:\n",
    "    acc_mean, acc_std = average_acc_stats_across_runs(data_mean[key]['mean'], key)\n",
    "    ltr_mean, ltr_std = average_ltr_across_runs(data_mean[key]['mean'], key)\n",
    "    fgt_mean, fgt_std, wst_fgt_mean, wst_fgt_std = average_fgt_stats_across_runs(data_mean[key]['mean'], key)\n",
    "    print('{}=> Acc: {} (+-{}), LTR: {} (+-{}), Fgt: {} (+-{}), Wst Fgt: {} (+-{})'.format(key, acc_mean, \n",
    "                                                                           acc_std, ltr_mean, ltr_std ,fgt_mean, \n",
    "                                                                           fgt_std, wst_fgt_mean, \n",
    "                                                                           wst_fgt_std))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### LCA Measure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LCA_10 classification models:\n",
      "MAS: 0.298288644552 (+-0.00631860095996)\n",
      "VAN: 0.258991705328 (+-0.00584054979001)\n",
      "MEGA: 0.283412646949 (+-0.00439713889582)\n",
      "PROG-NN: 0.197896528393 (+-0.00618755975804)\n",
      "MEGAD: 0.281137765348 (+-0.00575011769372)\n",
      "EWC: 0.276265529692 (+-0.00257639864571)\n",
      "A-GEM: 0.277259589583 (+-0.00815996274613)\n",
      "RWALK: 0.319406587481 (+-0.0034139445267)\n",
      "GEM: 0.233861469)\n"
     ]
    }
   ],
   "source": [
    "num_iters = 55000/ 10\n",
    "num_batches = []\n",
    "for iters in range(num_iters):\n",
    "    if (iters < 10) or (iters < 100 and iters % 10 == 0) or (iters % 100 == 0):\n",
    "        num_batches.append(iters)\n",
    "num_batches.append(num_iters)\n",
    "gem_avg_k_shot = np.array([ 0.09812353,  0.1610647 ,  0.17345884,  0.20008238,  0.19457644,\n",
    "        0.23791176,  0.26005882,  0.27361766,  0.30264702,  0.32512945,\n",
    "        0.32201171])\n",
    "\n",
    "BATCHES_WE_CARE = 10\n",
    "num_runs = avg_k_shot_acc['VAN'].shape[0]\n",
    "area_trapz = dict()\n",
    "area_trapz['VAN'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['EWC'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['RWALK'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['MAS'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['PROG-NN'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['GEM'] = np.zeros(BATCHES_WE_CARE+1)\n",
    "area_trapz['A-GEM'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['MEGA'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['MEGAD'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "\n",
    "for run in range(num_runs):\n",
    "    for measure_upto in range(1, BATCHES_WE_CARE+2):\n",
    "        batches_upto = num_batches[:measure_upto]\n",
    "        if measure_upto == 1:\n",
    "            area_trapz['VAN'][run][measure_upto-1] = avg_k_shot_acc['VAN'][run][0]\n",
    "            area_trapz['EWC'][run][measure_upto-1] = avg_k_shot_acc['EWC'][run][0]\n",
    "            area_trapz['RWALK'][run][measure_upto-1] = avg_k_shot_acc['RWALK'][run][0]\n",
    "            area_trapz['MAS'][run][measure_upto-1] = avg_k_shot_acc['MAS'][run][0]\n",
    "            area_trapz['PROG-NN'][run][measure_upto-1] = avg_k_shot_acc['PROG-NN'][run][0]\n",
    "            area_trapz['GEM'][measure_upto-1] = gem_avg_k_shot[0]\n",
    "            area_trapz['A-GEM'][run][measure_upto-1] = avg_k_shot_acc['A-GEM'][run][0]\n",
    "            area_trapz['MEGA'][run][measure_upto-1] = avg_k_shot_acc['MEGA'][run][0]\n",
    "            area_trapz['MEGAD'][run][measure_upto-1] = avg_k_shot_acc['MEGAD'][run][0]\n",
    "        else:\n",
    "            # Using trapezoidal rule\n",
    "            max_acc = np.ones_like(batches_upto)\n",
    "            max_area_trapz = np.trapz(max_acc, batches_upto)\n",
    "            area_trapz['VAN'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['VAN'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['EWC'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['EWC'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['RWALK'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['RWALK'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['MAS'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['MAS'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['PROG-NN'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['PROG-NN'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['GEM'][measure_upto-1] = np.trapz(gem_avg_k_shot[:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['A-GEM'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['A-GEM'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['MEGA'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['MEGA'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['MEGAD'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['MEGAD'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "print('LCA_10 classification models:')\n",
    "for key in area_trapz:\n",
    "    if key == 'GEM':\n",
    "        print('{}: {})'.format(key, area_trapz[key][10]))\n",
    "    else:\n",
    "        lca_10 = area_trapz[key][:, 10]\n",
    "        print('{}: {} (+-{})'.format(key, lca_10.mean(), lca_10.std()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x111655490>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x111655ad0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x1136d6e90>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAG0AAAD8CAYAAAB9wiqwAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAC/hJREFUeJztnWuMHXUVwH+nS1mQIl22L0oNy0rb0Kpgd2PdlC88GvAR\nJJFaE00kPtpgCOoH2q4hFQyxLNQQEv3Q+ESJiq2JQQR1G1uhRZvebSwCDZa2YndDW/pALKmFbo8f\nZu529u7ce2fu3tmdc/f8kknuzPzP7H/v75553Tn3L6qKY4tJ490BJz0uzSAuzSAuzSAuzSAuzSAu\nzSAuzSAuzSAuzSDnjXcHikybNk3b2trGuxvjRl9f31FVnZ6kbW6ktbW1USgUxrsb44aIvJa0re8e\nDeLSDOLSDOLSDOLSDJKbs0cLiEjs8rH+9t8zzSCeaSkoZlQx48br+RrPNIO4NIO4NIO4NIP4iUjG\nZHGZ4JlmEM+0jMniMsEzzSAuzSAuzSAuLQmzZoHIualIdJlI0G4McGlJOHy4vu1GiUszSFVpItIj\nIr0i0ici7WXabAjX94nITWlinfRUlCYii4BFqroU+AqwIabNTUC7qnaEbXqSxjq1US3TbgJ6AVR1\nF9AZ0+Z45PWlQPHhxSSxTg1UuyPSCuys1EBVd4kIIrIPaAeWJY0VkRXACoDZs2ezdetWANrb27n4\n4ovZvXt3sKHWVhYuXMizzz4bdPq887juuuvYtWsXb731FgCdnZ0cPnyYgwcPAjB37lyam5t58cUX\nAZgxYwbz5s1j27ZtADQ3N9PV1UWhUODkyZMALF68mP7+fgYGBgCYP38+TU1NvLx+PQCzdu7kymee\ngfBv7ujuZvG6dezo7uZUaysAXadPc+DAAQ4dOgTAggULGBwcHPqf9+7dy5w5c9ixYwcAU6ZMobMz\n5edZVctOwCpgVWRey7TpCV+3AyeSxkanjo4OzS0wbCKcSpdr8D+W2UQYU359QSu8P9Gp2u5xM7AU\nho5Rm2PatALHwtfRXWWSWKcGKu4eNdj17RKR3nDRSoDwTLBPVVuAdcBGEVketllWKXaiMGtW/GVb\n9Np85kwI96KpEM3Jj790dnZqbgswSr4TK87FvnNDd/VHbCQ2qvj2i0ifqiY6uPlXMyko9VBRXob4\nHRGDeKalIB8HEs80k7g0g7g0g7g0g7g0g7g0g7g0g7g0g/jFdebU/+aXZ5pBPNMyp/43vzzTDOLS\nDOLSDOLSDOLSDOLSDOLSDOLSDOLSDOLSDOLSDDLqokIRWRUpKOwTES22E5ETkeVen1YvKlVnAIuA\n3tLXFdq3AxtLXyeZLFXNVJxShpxrX7+qmbSFgRsIqj6L0tpFZGOYqYvSfqCceEZdVFhERG4nyMQ3\nw0XHgXWquikUthF4f0mMyaLCv65dC8CFx46VLSpcvz4oh3n88QVMnjzI8uWvALB9++U899wc1qwJ\nigoLhXEoKoys6wOmVlh/otJ63z2ObVFhsV4NPZdlxROUVZH1x6PrndqpR1EhwO3AEyWxD4XHs75w\n0TKculD1cQNVXR2zbD/QEpl/qEysi8oAv7g2iEsziEsziEsziEsziEsziEsziEsziEsziEsziEsz\niEsziEsziEsziEsziEsziEsziEsziEsziEsziEsziEsziEsziEszSNb1aT7oXRZUetCf0dWnpYr1\nAozkBRjVHgsfVp8mIknq04qPgqeNdRKSZX1aww5617D1aWli1XeP+ahPSxrrpCfL+rQJPehdlmRd\nnzYi1hk9fnFtEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdm\nEJdmEJdmEJdmEJdmEJdmEJdmEJdmEJdmkFEXFYZtVoRt9kWH3PJB77Kh4mPhoYBFqro0fL2BsKgi\n0qYdWKmqHeHrjUDx9Wb1oUvqTj0GvRsqvgif8b8xXJ77Qe9EJHbKO/UoKmwlkNMLXAqsJihryv2g\nd+Uo9qNhiwqBHs7VWU8FTpTZVm4HvQOUaIXfyAYNV1TYS5BVw/BB77Jj1EWFqrpZRJaGg9tNJRzI\nVX3Qu8yoV1FhbPGg+pljJvjFtUFcmkFcmkFcmkFcmkFcmkFcmkFcmkFcmkFcmkFcmkFcmkFcmkFc\nmkGqfjXTkDw8F94+MnL5fZcMn79oBtyzd2z6lIKJmWlxwkbTboyZmNKM49IM4tIM4tIM4tIM4tIM\n4tIM4tIMknV9mg96lwEVpUXr0wge9x5RGBipT1tK8Nz/D5LGOrWRZX1aklinBrKsT8vvoHfz76f5\nzH/p2reeQttXgQcBODX5UvpbPspAy2IA5r/+W5qOHMldfZoEpVFl39RVcG7UJhFRVZWSNj1Au6ou\nE5GpwAFVbUkSG6Wzs1MLhUKqztdMyd18uT8Qr996b0zb/0Ca6tDw/UwaUnz7RaRPVRPZy6w+LWGs\nUwNZ1qf5oHcZkXV9mg96lwF+cW2Qifm4QUjxBKR0PvaEJEd4phlkQmda3jOqHJ5pBnFpBnFpBnFp\nBnFpBnFpBnFpBnFpBnFpBnFpBnFpBnFpBnFpBnFpBnFpBnFpBnFpBsntN9flhg+p9HDtRCG30mph\noojOrTQderxahs07CY9pInKLiLwiIq+KyJqY9XeIyBsi8vdw+nJk3WBk+ZP17HwpxbFYys03ClUz\nTUSagO8TPJffD+wUkSdV9eWSpk+o6l0xmzilqteOvqtOkSSZ9hHgVVXdr6rvAL8CPpVtt5xKJJF2\nOXAwMt8fLivl0yLygohsEpH3RZZfICIFEfmbiNw2ms46AfU6Efkd8EtVPS0iK4HHgBvCdVeo6kBY\nafNnEfmHqu6D5EWFAGfPnk1VVAhw9OjRREWFJ5tnArB4/6P2iwrDN7YLuE9Vbw7nuwFUdV2Z9k0E\nY6VdErPup8BTqrqpdF25osJazh6rxpT+RGAlDBYVQlCCO1dErhSR84HPAsPOAkXkssjsrcCecHmL\niDSHr6cBS4DSExgnJUnq086IyF3AH4Em4Meq+pKIfJtgSMQngbtF5FbgDEFV6B1h+NXABhE5S/AB\neTDmrNNJSaJjmqo+DTxdsmxt5HU30B0T9zzwwVH20SnBbxgbxKUZJJf3Hjsf6OXoyXeGLWtb8/th\n89OmnE/h3mBw++2ztvPu4XdHbGerbB02P3nmZJYcWlLfzo4Ducy0UmHV2sQJiyNpu7yTS2lOZVya\nQVyaQVyaQVyaQVyaQVyaQVyaQXJ5R6RWruf62PktbBmP7mSGZ5pBcptpr/V8Mnb+itVPlY1ptIwq\nh2eaQXKbaZUyaqLjmWYQl2YQl2YQl2YQl2aQqk8YjxUi8gbw2nj3Yxy5QlWnJ2mYG2lOchp29xgO\ntqci8rGUcRIWQH4ho359T0R+NJptNKQ0EbmBYPw2gIUpwz9DMKTYLxL+rUdEZEBE5ifc/nrgcyJy\nVcp+DdGQ0oDvAP8kqKX7QMrYu4Gfq2rV5+1E5BHg68BsYIuIzKsWo6r/ArYBd6bs17CNNNQE3AYo\nsAx4BtiZIvaqMPbDCdp+FzgJ/JDgw/EbYAC4KkHsncAhYFIt/2NDZZqITAIeAPqATQQlV1dLud+q\nGMmNwNvA7moNwzYfJ8iaMwQlYI8BRxPEPg/MpMbilNzeMK6RzxMcw25WVRWRPcBFwJXA/gTxHcAe\nVT1braGq/gyGxpIj3J1+M2E/XwIGCerZk3xAhtEw0sKCx/uBLar6p3BxsRZuIaG08KzwG+Hyq4ED\nwP8I3sQjJMuUURHW/L0JzKolvpF2jyuANqBHRKaG45O+Hq4bOoNU1cc0+ImMRQS7tSWqeq2qdhAU\nTZ4eo/6eBi6oJbAhMk1ELgLuDWf/ENMk7gxyLnBCVY9Flh2nxk9/DUwlfizVqjSENOBrwHRgOcEu\nLso64q/VrmHk8eQVoKvuvStBRKYD7yG4LEmNeWki0gLcA/xEVX8ds34HsFJEJpWcYFwDvFDSfDuw\nVkSmq+obmXU6GKhdCc4iU9MIx7TVBB++e8usf4ng2FF6B+JDjMy0rQS7rFvq2L84bgH+UrJrTsyE\nvWEsIv8muDTYU7L8UYIL5E9k9HebCL7NWKOqj9eyjUbItNSEu9TpxB9THgauT3JLqkaWAacIfmOs\nJiakNFU9oaoXqupgzLp+4IvAZSMj64IAX1LVMzVvYKLuHi0zITPNOi7NIC7NIC7NIC7NIC7NIC7N\nIP8HzsHAF42wpHIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x107e5c050>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x113949cd0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAG0AAAD8CAYAAAB9wiqwAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAC7lJREFUeJztnU9oHOcZh5/Pf6K4OK1sJalIDZHXJAKbXlYbFEEOCawu\nbS8BOb4XLEFuvUh2DmlzKI6Keig9yTm1BJrGhraQkoMEMU6CEV4tTXENxZVUY5tGaS2pqoOS2M7b\nw3yzmh3NaP9n95XeBwbtfPt9u7P77Dt/tb91IoKhiz3tXgCjdkyaQkyaQkyaQkyaQkyaQkyaQkya\nQkyaQkyaQva1ewFCHn/8cenr62v3YrSN+fn5/4jIE9X07RhpfX19FAqFdi9G23DO3ay2r60eFdIx\nlbZTcc4ltjdydcUqTSFWaS0mrKiw4ppx/dIqTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEm\nTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEVpTnnJp1zM865eedcJqXPhUifbKR9\n2rcvOOdGmrngu5ltpXkBWREZBk4D0wl9RoHFSJ9J354H8O0DwFvNXfTdS6V/Vs0DMwAiUnTO5RL6\nzPopZM3/XcQLFJE159xKg8tqeCpJ6wGubtdBRBYhWBUCowRVFW3PABfwAo3GqSTtLhDdjnWndRSR\nMefcJEFlHgNwzo0Dp4DTIlKMj/Gr1lGAp556ikuXLgGQyWR47LHH+OSTTwDo6enhxIkTXL58OVjo\nfft44YUXKBaLrK+vA5DL5VheXubWrVsAPPPMM3R1dXHt2jUAnnzySZ599lk++ugjALq6uhgaGqJQ\nKHDv3j0ABgcHuX37Nnfu3AGgv7+fvXv3cv36dQB6e3s5evQoV65cAeDAgQMMDg4yNzfHxsYGAEND\nQywtLfHpp58CcPz4cR4+fFh6zTdu3ODIkSPMzc0BcPDgQXK5pBXYNohI6gRkgZn47VifSWDU3+4G\nVv3tfFL/tGlgYEB2MoAEb3fq/QWp8r3attIk2I4VnXMzvmkMSqu8eRE5BJwDLjjnxnyfk/7vMJBz\nzi1EHu9YbR8pIwknHZJCl8vlpNO/CdrId80qfWvGOTcvIlWtJ+3gWiH2/bQaCKukmd81qwerNIWY\nNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYNIWYtBbR2wvObU4h0bbe\n3voe26S1iOXl5vRJwqQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQpxKQp\nxKQpxKQppKWBZv6+UR8CYzSJlgWa+ftmksYYjdHKQDNEZNhLTY1naiet+A3qb4KWBZpVQ7uzsdII\nl6OUjfXOO3D/Pr1Xr3L0/fdL/eZee43Bc+eYO3uWjZ4e2L+fobExlpaWmJoKsrHefvs4+/c/5Kp/\nF19++QYffniEM2eCbKxCofnZWOPAeGReKvTPAAuxttHoY6RN7czGokJulUDZVOqfNCUPKY1J6V5T\nNlalHZFZgoyrcPs2G+/gd1RG/ewKcLi2j41RK60MNDNaRMWYJRGZSGhbBA7522v4akwZf76RBTS2\nYgfXCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFpCjFp\nCjFpCjFpCrEfvWs58X89D+fr/9dzqzSFWKW1nOZ/mcMqTSEmTSEmTSEmTSEmTSEmTSEmTSEmTSEm\nTSEmTSEmTSF27rEGmn++vj6s0hTS0kCzasZqQlKmb5qWBZpVM9aoj1YGmlUz1qiDVgaaVRzbtkCz\n5Wt0fbXK0MIUhb5XS8uz8fOj3D70PHcODQLQv/oBe0fe4vrUFEAp0OzK668DcODu3fJAM2Doyy8T\nA81Onfo7AB9//L2GA82cbBOTF4Zrisgv/LyISHLeHqX4pRkROVbr2FwuJ4VCoaaFr5uffads1r0R\niJeffjuh73/Lf9SzEv79rHZI+PY75+ZFpCp7rQw0qzjWqI+WBZqljTUap6WBZkljW4nWpNRasYNr\nheyo01hS2glwZfM7Das0hXRspe2W7VM9WKUppGMrbbdsn+rBKk0hJk0hJk0hJk0hJk0hJk0hJk0h\nJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0hJk0h\nJk0hJk0hJk0hJk0hJk0hzQo0m/Z9FpxzIwntMzsh0KxT2PZLhdFQMn97mlj8hHMuD+D7dANLwMUw\nECYy9gKbEUxGAzQj0GwRnzwnImvOuRXfPhAbm00Y21bCeKX4fGLcUgfRzECzDEE1Tfq75oFTBFU3\nkjQ2LdDst9c2+MfaQ04efVjqmznzHj/5fjD/1dfwu5vf4vwPelhfX+fzv37Oo28+yoPsA+6/dL80\nZvbELF/8+Ivghf5lHwcvH+TBbx5A/xt0Pfgf8Hria7rU/wYA/f/6I3s/+2xnBpr5fqeA0yJSjLRP\nAlmCanzFxzIlEg006zvz51L7zckfAfD0xHtbxvzzzR8CcMldKmt/iZcA+IAPtox5UV7cEmi2LTs0\n0CwPDIvIQExYmEg3TLAttECzJtGMQLNhIOecW4iMOyYii37Pc4IguPN0a17C7qMZgWYTQGJwmYic\nbHQBja3YwbVCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpC\nTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCTJpCOvbXd8NvgMbnk74RutuwSlNI\nx1aaVVQ6VmkKMWkK6djVYz2EURTx+aRoCs1YpSmkYqVFAlwOAyfDhJ5Yn2kg46cJEbkYaQ8DTSZE\npKVZIjutotJoZaBZHsiIyIAf+xYWaNYUKq0eywLN2KyaKGWBZkAYaLYS6XMYKDS0pEaJlgWa+bQf\nfJJPBtgSBJMWaPbcE1+zvOFKgWaL644/3dxTFmj267/to1gssr6+zr2pexz45YGyQLNH/vAIe1b3\nlAWadV3sCp7DB5oNLUxR6HuVe13fBWBw8VfcPvQ8dw4NArsw0My39YjIRCyWKZG0QLPtSAs02w4L\nNCM90IygSu/62yvxcUb9tCzQDDgHXHDOnfLNlpPVJFoWaOZ3Sobj7UbjbLtN+yZxzv0buNnu5Wgj\nT4vIE9V07BhpRvV09Gks59yIj41f9YGfqTHxzrmM7zPpnBv3U3f4t8JzJGYs17isWyLw48/rnMtG\n9g/qR0Q6eiI4uB+t0GeU4BixO9Y+CSxUGLsKTDa4jKPAhYT2pGWaB0Yaer52S6niDRGCU2lp948n\nvWH+vjwwXYXs1D5VLuNCfBkJztdK/AMBjBDsedf9fJ2+esxC6RRa0v0Z4Czp+cgr+NNwKWMhOA1X\n969zRM69FmNtY8B5YMafdMf3uwhkGvmdgo6WRlAp210ZmAbeleDwYgsiUvRvUhJjInKeoEoON7CM\nw9Fl9KfmMiIy5pdhFpj2P+ESbuMKBK+tLjr9IuhzpFdKN8ELr/lY0FdC+LgrJFSacy4bq54RgtTz\nrPjTep48wYcHAP9BKEOC49qxSFOR4LXVhYZKS1w1svlG13P14KRsXttbBOJ7eXmCbV04nwUO+zHF\n8Hd0PN3UfpouPIleFx0rzW9zuiV24dTvxucJPvWkrRoj/eLto8BaeFhAcKK7bPfcP2f0Ym+eTTGL\ntPlMTyevHrMkV9kr4SrIObfmnMtIwtX0aL8QL6ZbYqfmvLzD+A9CAsciy7JCeWWuUfs28RjlH4qa\n6NhKI/g0l636/GoqevX7NJHtSaTfKPBuwmOejW2PQtaofnUVFzRL7VfkM1S4TrkdHVdpvhrOEhxD\nzYbX5Qhe6AiRVZOIXPTVNk2wnQhXmfEKy/rHzDvnfi9bf8SoG5hwzq2kHF4ssLW6QmZI+OBUIE9w\nFaQ+2n3w3KkTwY8bRQ+Ux2XzgH001neVhBMAJBy0s9MPrtuF373PhOctffWt+R2bbMJu/QRBJVfD\nWRqpMrBKa2JlzhMcVEfbxmPzWSIVXO9kl2YUYqtHhZg0hZg0hZg0hZg0hZg0hZg0hZg0hfwfMe3u\nkWqvDBgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x114cd1e10>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x114b64550>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x1141f05d0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\nEUIIYZv/Dzf9up7kQRvZAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x111377c90>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\nSUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x11577be50>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "batches_we_care = np.arange(BATCHES_WE_CARE+1)\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "ax = fig.add_axes([0.15, 0.21, 0.6, 0.75])\n",
    "\n",
    "\n",
    "\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['VAN'], axis=0),colors['VAN'], lw=2, label='VAN')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['EWC'], axis=0),colors['EWC'], lw=2, label='EWC')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['RWALK'], axis=0),colors['RWALK'], lw=2, label='RWALK')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['MAS'], axis=0),colors['MAS'], lw=2, label='MAS')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['PROG-NN'], axis=0),colors['PROG-NN'], lw=2, label='PROG-NN')\n",
    "ax.plot(batches_we_care, area_trapz['GEM'],colors['GEM'], lw=2, label='GEM')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['A-GEM'], axis=0),colors['A-GEM'], lw=2, label='A-GEM')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['MEGA'], axis=0),'-r', marker='^', markersize=7, lw=2, label='MEGA')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['MEGAD'], axis=0),'-b', marker='*', markersize=7, lw=2, label='MEGAD')\n",
    "\n",
    "\n",
    "ax.set_xlabel('Batches', size=20)\n",
    "ax.set_ylabel('LCA', size=20)\n",
    "plt.xticks(batches_we_care)\n",
    "#ax.legend(bbox_to_anchor=(1, 1), loc=2, borderaxespad=0.2)\n",
    "#ax.legend(loc='best', borderaxespad=0.2)\n",
    "plt.grid()\n",
    "plt.show()\n",
    "#plt.savefig('../iclr_plots/fam_mnist.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CIFAR-100 (ResNet-18)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "PREFIX = '../cifar/'\n",
    "\n",
    "van_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_VAN_0_0_0_01_10_13-19-07-28-11-38.pickle'\n",
    "ewc_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_EWC_10_0_0_03_10_13-19-07-28-12-05.pickle'\n",
    "pi_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_PI_0_1_0_01_10_13-19-07-28-12-46.pickle'\n",
    "mas_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_MAS_0_1_0_03_10_13-19-07-28-13-24.pickle'\n",
    "rwalk_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_RWALK_1_0_0_03_10_13-19-07-28-14-04.pickle'\n",
    "pnn_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_PNN_0_0_0_03_10_13-19-07-28-14-51.pickle'\n",
    "\n",
    "a_gem_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_A-GEM_0_0_0_03_10_13-19-07-28-16-55.pickle'\n",
    "mega_pickle = PREFIX+'SPLIT_CIFAR_HERDING_RESNET-S_True_MEGA_0_0_0_03_10_13-19-07-28-17-53.pickle'\n",
    "\n",
    "megad_pickle = '/Users/henry/Desktop/eccv_rebuttal/mega_L_and_replay/results/cifar/SPLIT_CIFAR_HERDING_RESNET-S_True_MEGAD_0_0_0_03_10_13-20-05-24-03-09.pickle'\n",
    "\n",
    "\n",
    "\n",
    "MODELS = ['MULTI-TASK', 'VAN', 'EWC', 'PI', 'MAS', 'RWALK', 'GEM', 'ICARL', 'PNN','A-GEM', 'MEGA', 'MEGAD' ,'MER']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "data_mean = dict()\n",
    "populate_data_dict(data_mean, 'VAN', van_pickle)\n",
    "populate_data_dict(data_mean, 'EWC', ewc_pickle)\n",
    "populate_data_dict(data_mean, 'PI', pi_pickle)\n",
    "populate_data_dict(data_mean, 'RWALK', rwalk_pickle)\n",
    "populate_data_dict(data_mean, 'MAS', mas_pickle)\n",
    "populate_data_dict(data_mean, 'PROG-NN', pnn_pickle)\n",
    "populate_data_dict(data_mean, 'A-GEM', a_gem_pickle)\n",
    "populate_data_dict(data_mean, 'MEGA', mega_pickle)\n",
    "populate_data_dict(data_mean, 'MEGAD', megad_pickle)\n",
    "\n",
    "avg_k_shot_acc = dict()\n",
    "populate_k_shot_acc_dict(data_mean, 'VAN', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'PROG-NN', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'EWC', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'PI', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'RWALK', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'MAS', avg_k_shot_acc)\n",
    "\n",
    "populate_k_shot_acc_dict(data_mean, 'A-GEM', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'MEGA', avg_k_shot_acc)\n",
    "populate_k_shot_acc_dict(data_mean, 'MEGAD', avg_k_shot_acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(5, 17, 26, 17)\n",
      "('MAS', 0.4235294108881669)\n",
      "('VAN', 0.4044235292602988)\n",
      "('MEGA', 0.6612470584757187)\n",
      "('PROG-NN', 0.5979294100228478)\n",
      "('MEGAD', 0.6610823522595798)\n",
      "('EWC', 0.426729410536149)\n",
      "('A-GEM', 0.6128000006956213)\n",
      "('RWALK', 0.4210823513129178)\n",
      "('PI', 0.48992941081523894)\n"
     ]
    }
   ],
   "source": [
    "plot_average_accuracy_along_training_path(\"cifar\", data_mean, plot_name='../iclr_plots/cifar_average_accuracy.pdf', legend=False)\n",
    "\n",
    "#plot_average_accuracy_along_training_path(data_mean, is_cifar=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Average Accuracy and Forgetting Measure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MAS=> Acc: 42.3529410888 (+-3.51641519117), LTR: 2.51327503286 (+-0.330177538443), Fgt: 0.261175004207 (+-0.0304883791199), Wst Fgt: 0.458800011873 (+-0.0723613160023)\n",
      "VAN=> Acc: 40.442352926 (+-1.0161218445), LTR: 2.61304997765 (+-0.174101299614), Fgt: 0.271249997988 (+-0.00669048014318), Wst Fgt: 0.447600001097 (+-0.0485864056877)\n",
      "MEGA=> Acc: 66.1247058476 (+-1.9371094336), LTR: 0.355775004625 (+-0.114462741524), Fgt: 0.0568500012159 (+-0.0150624526285), Wst Fgt: 0.110000002384 (+-0.0340117650041)\n",
      "PROG-NN=> Acc: 59.7929410023 (+-1.23082878472), LTR: 0.0 (+-0.0), Fgt: 0.0 (+-0.0), Wst Fgt: 0.0 (+-0.0)\n",
      "MEGAD=> Acc: 66.108235226 (+-1.67813357131), LTR: 0.348249996454 (+-0.113181196861), Fgt: 0.0529500003904 (+-0.0143630572252), Wst Fgt: 0.117200016975 (+-0.0203410852856)\n",
      "EWC=> Acc: 42.6729410536 (+-4.23804717634), LTR: 2.49347499516 (+-0.427512733571), Fgt: 0.256224998087 (+-0.0396056648477), Wst Fgt: 0.434400001168 (+-0.0695861949392)\n",
      "A-GEM=> Acc: 61.2800000696 (+-1.88694141024), LTR: 0.643224970251 (+-0.124609001682), Fgt: 0.0884999990463 (+-0.017716519506), Wst Fgt: 0.173200005293 (+-0.0334089920851)\n",
      "RWALK=> Acc: 42.1082351313 (+-3.69530441349), LTR: 2.63955001738 (+-0.379074951614), Fgt: 0.271825001203 (+-0.0326324818174), Wst Fgt: 0.479199999571 (+-0.0691155438365)\n",
      "PI=> Acc: 48.9929410815 (+-3.42362706951), LTR: 1.51255002096 (+-0.296011778672), Fgt: 0.153425000422 (+-0.0311310304404), Wst Fgt: 0.295600003004 (+-0.0346040399999)\n"
     ]
    }
   ],
   "source": [
    "for key in data_mean:\n",
    "    acc_mean, acc_std = average_acc_stats_across_runs(data_mean[key]['mean'], key)\n",
    "    ltr_mean, ltr_std = average_ltr_across_runs(data_mean[key]['mean'], key)\n",
    "    fgt_mean, fgt_std, wst_fgt_mean, wst_fgt_std = average_fgt_stats_across_runs(data_mean[key]['mean'], key)\n",
    "    print('{}=> Acc: {} (+-{}), LTR: {} (+-{}), Fgt: {} (+-{}), Wst Fgt: {} (+-{})'.format(key, acc_mean, \n",
    "                                                                           acc_std, ltr_mean, ltr_std ,fgt_mean, \n",
    "                                                                           fgt_std, wst_fgt_mean, \n",
    "                                                                           wst_fgt_std))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### LCA Measure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LCA_10 classification models:\n",
      "MAS: 0.331914121211 (+-0.0106895051337)\n",
      "VAN: 0.308788233995 (+-0.0110549337352)\n",
      "MEGA: 0.374775295854 (+-0.0121899702259)\n",
      "PROG-NN: 0.208408239782 (+-0.00237930917224)\n",
      "MEGAD: 0.36682117939 (+-0.00906781992807)\n",
      "EWC: 0.336034116745 (+-0.0107448068129)\n",
      "A-GEM: 0.349764707983 (+-0.0130918566648)\n",
      "RWALK: 0.33408706218 (+-0.012930511806)\n",
      "PI: 0.309302355647 (+-0.0113032327696)\n",
      "GEM: 0.3614294105)\n"
     ]
    }
   ],
   "source": [
    "num_iters = 2500/10\n",
    "num_batches = []\n",
    "for iters in range(num_iters):\n",
    "    if (iters <= 20) or (iters > 20 and iters % 50 == 0):\n",
    "        num_batches.append(iters)\n",
    "num_batches.append(num_iters)\n",
    "\n",
    "gem_avg_k_shot = np.array([0.20129414,  0.27117646,  0.3057647 ,  0.35011765,  \n",
    "                           0.368, 0.38694119,  0.36729413,  0.40600002,  0.4105882 ,  0.43294117, \n",
    "                             0.42964703])\n",
    "BATCHES_WE_CARE = 10\n",
    "num_runs = avg_k_shot_acc['VAN'].shape[0]\n",
    "area_trapz = dict()\n",
    "area_trapz['VAN'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['EWC'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['PI'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['RWALK'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['MAS'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "\n",
    "area_trapz['PROG-NN'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['GEM'] = np.zeros(BATCHES_WE_CARE+1)\n",
    "area_trapz['A-GEM'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['MEGA'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_trapz['MEGAD'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "\n",
    "\n",
    "for run in range(num_runs):\n",
    "    for measure_upto in range(1, BATCHES_WE_CARE+2):\n",
    "        batches_upto = num_batches[:measure_upto]\n",
    "        if measure_upto == 1:\n",
    "            area_trapz['VAN'][run][measure_upto-1] = avg_k_shot_acc['VAN'][run][0]\n",
    "            area_trapz['EWC'][run][measure_upto-1] = avg_k_shot_acc['EWC'][run][0]\n",
    "            area_trapz['PI'][run][measure_upto-1] = avg_k_shot_acc['PI'][run][0]\n",
    "            area_trapz['RWALK'][run][measure_upto-1] = avg_k_shot_acc['RWALK'][run][0]\n",
    "            area_trapz['MAS'][run][measure_upto-1] = avg_k_shot_acc['MAS'][run][0]\n",
    "            area_trapz['PROG-NN'][run][measure_upto-1] = avg_k_shot_acc['PROG-NN'][run][0]\n",
    "            area_trapz['GEM'][measure_upto-1] = gem_avg_k_shot[0]\n",
    "            area_trapz['A-GEM'][run][measure_upto-1] = avg_k_shot_acc['A-GEM'][run][0]\n",
    "            area_trapz['MEGA'][run][measure_upto-1] = avg_k_shot_acc['MEGA'][run][0]\n",
    "            area_trapz['MEGAD'][run][measure_upto-1] = avg_k_shot_acc['MEGAD'][run][0]\n",
    "        else:\n",
    "            # Using trapezoidal rule\n",
    "            max_acc = np.ones_like(batches_upto)\n",
    "            max_area_trapz = np.trapz(max_acc, batches_upto)\n",
    "            area_trapz['VAN'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['VAN'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['EWC'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['EWC'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['PI'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['PI'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['RWALK'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['RWALK'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['MAS'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['MAS'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['PROG-NN'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['PROG-NN'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['GEM'][measure_upto-1] = np.trapz(gem_avg_k_shot[:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['A-GEM'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['A-GEM'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['MEGA'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['MEGA'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_trapz['MEGAD'][run][measure_upto-1] = np.trapz(avg_k_shot_acc['MEGAD'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            \n",
    "print('LCA_10 classification models:')\n",
    "for key in area_trapz:\n",
    "    if key == 'GEM':\n",
    "        print('{}: {})'.format(key, area_trapz[key][10]))\n",
    "    else:\n",
    "        lca_10 = area_trapz[key][:, 10]\n",
    "        print('{}: {} (+-{})'.format(key, lca_10.mean(), lca_10.std()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x1150c6950>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x11418c890>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x11437ec10>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "batches_we_care = np.arange(BATCHES_WE_CARE+1)\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "ax = fig.add_axes([0.15, 0.21, 0.6, 0.75])\n",
    "\n",
    "\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['VAN'], axis=0),colors['VAN'], lw=2, label='VAN')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['EWC'], axis=0),colors['EWC'], lw=2, label='EWC')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['RWALK'], axis=0),colors['RWALK'], lw=2, label='RWALK')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['MAS'], axis=0),colors['MAS'], lw=2, label='MAS')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['PROG-NN'], axis=0),colors['PROG-NN'], lw=2, label='PROG-NN')\n",
    "ax.plot(batches_we_care, area_trapz['GEM'],colors['GEM'], lw=2, label='GEM')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['A-GEM'], axis=0),colors['A-GEM'], lw=2, label='A-GEM')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['MEGA'], axis=0),'-r', marker='^', markersize=7, lw=2, label='MEGA')\n",
    "ax.plot(batches_we_care, np.mean(area_trapz['MEGAD'], axis=0),'-b', marker='*', markersize=7, lw=2, label='MEGAD')\n",
    "\n",
    "\n",
    "#colors = {'MULTI-TASK':'-k', 'VAN': 'C0', 'ICARL':'C1', 'EWC': '-m', 'PI': '-C1', 'MAS': '-y', \n",
    "#          'RWALK':'-g', 'PROG-NN':'C5--', 'GEM':'C1', 'A-GEM':'-C9', 'MEGA': '-r', 'MER': 'r', 'MEGAD': '-b'}\n",
    "\n",
    "\n",
    "ax.set_xlabel('Batches', size=20)\n",
    "ax.set_ylabel('LCA', size=20)\n",
    "plt.xticks(batches_we_care)\n",
    "#plt.legend(loc=\"lower left\")\n",
    "plt.grid()\n",
    "plt.show()\n",
    "#plt.savefig('../iclr_plots/fam_cifar.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# SPLIT CUB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# 10 runs\n",
    "PREFIX = PREFIX = '../cub/ohot/'\n",
    "\n",
    "van_ohot_pickle = PREFIX+'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_VAN_0_0_03_10_False_5-19-07-30-22-09.pickle'\n",
    "ewc_ohot_pickle = PREFIX+'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_EWC_1_0_03_10_False_5-19-07-31-07-38.pickle'\n",
    "pi_ohot_pickle = PREFIX+'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_PI_0_1_0_03_10_False_5-19-07-31-20-36.pickle'\n",
    "mas_ohot_pickle = PREFIX+'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_MAS_0_1_0_03_10_False_5-19-08-01-04-18.pickle'\n",
    "rwalk_ohot_pickle = PREFIX+'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_MAS_0_1_0_03_10_False_5-19-08-01-04-18.pickle'\n",
    "a_gem_ohot_pickle = PREFIX+ 'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_A-GEM_0_0_03_10_False_5-19-07-29-11-25.pickle'\n",
    "mega_ohot_pickle = PREFIX+ 'SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_MEGA_0_0_03_10_False_5-19-07-30-09-25.pickle'\n",
    "\n",
    "megad_ohot_pickle = '/Users/henry/Desktop/eccv_rebuttal/mega_L_and_replay/results/cub/ohot/SPLIT_CUB_ONE_HOT_HERDING_False_RESNET-B_True_MEGAD_0_0_03_10_False_5-20-05-24-03-11.pickle'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "MODELS = ['VAN', 'EWC', 'PI', 'RWALK', 'MAS', 'A-GEM', 'MEGA', 'MEGAD']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "collapsed": true,
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Dicts to store experiments data\n",
    "data_ohot_mean = dict()\n",
    "data_zst_mean = dict()\n",
    "data_hybrid_mean = dict()\n",
    "\n",
    "populate_data_dict(data_ohot_mean, 'VAN', van_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'EWC', ewc_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'PI', pi_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'RWALK', rwalk_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'MAS', mas_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'A-GEM', a_gem_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'MEGA', mega_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'MEGAD', megad_ohot_pickle)\n",
    "\n",
    "\n",
    "# Dicts to store the average k-shot acc\n",
    "avg_k_shot_ohot_acc = dict()\n",
    "avg_k_shot_zst_acc = dict()\n",
    "avg_k_shot_hybrid_acc = dict()\n",
    "\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'VAN', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'EWC', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'PI', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'RWALK', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'MAS', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'A-GEM', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'MEGA', avg_k_shot_ohot_acc)\n",
    "populate_k_shot_acc_dict(data_ohot_mean, 'MEGAD', avg_k_shot_ohot_acc)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(10, 17, 15, 17)\n",
      "('MAS', 0.5510913743127354)\n",
      "('VAN', 0.5463094481580406)\n",
      "('MEGA', 0.8053345630482345)\n",
      "('MEGAD', 0.7979008674760493)\n",
      "('EWC', 0.5435683268677961)\n",
      "('A-GEM', 0.6216536351308133)\n",
      "('RWALK', 0.5510913743127354)\n",
      "('PI', 0.5548973909292219)\n"
     ]
    }
   ],
   "source": [
    "plot_average_accuracy_along_training_path(\"cub\", data_ohot_mean,  plot_name='../iclr_plots/cub_average_accuracy.pdf', legend=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Average Accuracy and Forgetting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Acc forsimple classification models:\n",
      "MAS=> Acc: 54.1173307478 (+-1.71729727393), LTR: 0.889688641571 (+-0.126232615563), Fgt: 0.125488829152 (+-0.0136532316107), Wst Fgt: 0.27411189906 (+-0.0549213456617)\n",
      "VAN=> Acc: 53.8878406653 (+-1.99855134701), LTR: 0.976319991699 (+-0.215620332754), Fgt: 0.133043928549 (+-0.0204560501655), Wst Fgt: 0.291942694392 (+-0.0315631810685)\n",
      "MEGA=> Acc: 80.581514361 (+-1.94378694553), LTR: 0.00225289614554 (+-0.00280834460726), Fgt: 0.0118459829927 (+-0.0170205462299), Wst Fgt: 0.0636865104701 (+-0.0209076088226)\n",
      "MEGAD=> Acc: 79.6752934873 (+-2.1520558438), LTR: 0.00717816774457 (+-0.00634860479281), Fgt: 0.0149785385235 (+-0.0190254405125), Wst Fgt: 0.0631283316666 (+-0.0200770944315)\n",
      "EWC=> Acc: 53.5550989645 (+-1.67465808556), LTR: 1.02113733175 (+-0.210049382087), Fgt: 0.140220570822 (+-0.0248126340315), Wst Fgt: 0.280522560162 (+-0.0543765164306)\n",
      "A-GEM=> Acc: 61.8202094222 (+-3.71660284403), LTR: 0.456462024892 (+-0.174070458769), Fgt: 0.0769848975306 (+-0.0208790179242), Wst Fgt: 0.196427203498 (+-0.0365842171811)\n",
      "RWALK=> Acc: 54.1173307478 (+-1.71729727393), LTR: 0.889688641571 (+-0.126232615563), Fgt: 0.125488829152 (+-0.0136532316107), Wst Fgt: 0.27411189906 (+-0.0549213456617)\n",
      "PI=> Acc: 55.0359825843 (+-3.0481571472), LTR: 0.888102712896 (+-0.198732920747), Fgt: 0.119541103859 (+-0.0268557784542), Wst Fgt: 0.283225883288 (+-0.0875913624279)\n"
     ]
    }
   ],
   "source": [
    "print('Average Acc forsimple classification models:')\n",
    "for key in data_ohot_mean:\n",
    "    acc_mean, acc_std = average_acc_stats_across_runs(data_ohot_mean[key]['mean'][:-1], key)\n",
    "    ltr_mean, ltr_std = average_ltr_across_runs(data_ohot_mean[key]['mean'][:-1], key)\n",
    "    fgt_mean, fgt_std, wst_fgt_mean, wst_fgt_std = average_fgt_stats_across_runs(data_ohot_mean[key]['mean'][:-1], key)\n",
    "    print('{}=> Acc: {} (+-{}), LTR: {} (+-{}), Fgt: {} (+-{}), Wst Fgt: {} (+-{})'.format(key, acc_mean, \n",
    "                                                                           acc_std, ltr_mean, ltr_std ,fgt_mean, \n",
    "                                                                           fgt_std, wst_fgt_mean, \n",
    "                                                                           wst_fgt_std))    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### LCA Measure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LCA_10 classification models:\n",
      "MAS: 0.29250893116 (+-0.00869412065463)\n",
      "VAN: 0.29209871918 (+-0.00801996103074)\n",
      "MEGA: 0.310836722702 (+-0.00993455058314)\n",
      "MEGAD: 0.315124677867 (+-0.0114866039777)\n",
      "EWC: 0.29182506457 (+-0.00980059373231)\n",
      "A-GEM: 0.301859001368 (+-0.0109489103926)\n",
      "RWALK: 0.29250893116 (+-0.00869412065463)\n",
      "PI: 0.292470855713 (+-0.0100817599249)\n"
     ]
    }
   ],
   "source": [
    "# Using trapezoidal rule\n",
    "EXAMPLES_PER_TASK = 300\n",
    "BATCH_SIZE = 10\n",
    "num_iters = (EXAMPLES_PER_TASK + BATCH_SIZE - 1) // BATCH_SIZE\n",
    "num_batches = []\n",
    "for iters in range(num_iters):\n",
    "    if (iters < 10) or (iters % 5 == 0):\n",
    "        num_batches.append(iters)\n",
    "num_batches.append(num_iters)\n",
    "    \n",
    "BATCHES_WE_CARE = 10\n",
    "\n",
    "num_runs = avg_k_shot_ohot_acc['VAN'].shape[0]\n",
    "\n",
    "area_ohot_trapz = dict()\n",
    "area_zst_trapz = dict()\n",
    "\n",
    "area_ohot_trapz['VAN'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['EWC'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['PI'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['RWALK'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['MAS'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['A-GEM'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['MEGA'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['MEGAD'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "\n",
    "\n",
    "for run in range(num_runs):\n",
    "    for measure_upto in range(1, BATCHES_WE_CARE+2):\n",
    "        batches_upto = num_batches[:measure_upto]\n",
    "        max_acc = np.ones_like(batches_upto)\n",
    "        max_area_trapz = np.trapz(max_acc, batches_upto)\n",
    "        if measure_upto == 1:\n",
    "            area_ohot_trapz['VAN'][run][measure_upto-1] = avg_k_shot_ohot_acc['VAN'][run][0]\n",
    "            area_ohot_trapz['EWC'][run][measure_upto-1] = avg_k_shot_ohot_acc['EWC'][run][0]\n",
    "            area_ohot_trapz['PI'][run][measure_upto-1] = avg_k_shot_ohot_acc['PI'][run][0]\n",
    "            area_ohot_trapz['MAS'][run][measure_upto-1] = avg_k_shot_ohot_acc['MAS'][run][0]\n",
    "            area_ohot_trapz['RWALK'][run][measure_upto-1] = avg_k_shot_ohot_acc['RWALK'][run][0]\n",
    "            area_ohot_trapz['A-GEM'][run][measure_upto-1] = avg_k_shot_ohot_acc['A-GEM'][run][0]\n",
    "            area_ohot_trapz['MEGA'][run][measure_upto-1] = avg_k_shot_ohot_acc['MEGA'][run][0] \n",
    "            area_ohot_trapz['MEGAD'][run][measure_upto-1] = avg_k_shot_ohot_acc['MEGAD'][run][0] \n",
    "\n",
    "        else:\n",
    "            area_ohot_trapz['VAN'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['VAN'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['PI'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['PI'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['RWALK'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['RWALK'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['EWC'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['EWC'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['MAS'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['MAS'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['A-GEM'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['A-GEM'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['MEGA'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['MEGA'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['MEGAD'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['MEGAD'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            \n",
    "            \n",
    "print('LCA_10 classification models:')\n",
    "for key in area_ohot_trapz:\n",
    "    lca_10 = area_ohot_trapz[key][:, 10]\n",
    "    print('{}: {} (+-{})'.format(key, lca_10.mean(), lca_10.std()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.figure.Figure at 0x115871c10>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x1157ace10>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\ngg==\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x116becd50>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "batches_we_care = np.arange(BATCHES_WE_CARE+1)\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "ax = fig.add_axes([0.15, 0.21, 0.6, 0.75])\n",
    "\n",
    "\n",
    "\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['VAN'], axis=0),colors['VAN'], lw=2, label='VAN')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['EWC'], axis=0),colors['EWC'], lw=2, label='EWC')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['RWALK'], axis=0),colors['RWALK'], lw=2, label='RWALK')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['A-GEM'], axis=0),colors['A-GEM'], lw=2, label='A-GEM')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['MEGA'], axis=0),'-r', marker='^', markersize=7, lw=2, label='MEGA')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['MEGAD'], axis=0),'-b', marker='*', markersize=7, lw=2, label='MEGAD')\n",
    "\n",
    "\n",
    "\n",
    "ax.set_xlabel('Batches', size=20)\n",
    "ax.set_ylabel('LCA', size=20)\n",
    "plt.xticks(batches_we_care)\n",
    "\n",
    "plt.grid()\n",
    "plt.show()\n",
    "#plt.savefig('../iclr_plots/fam_cub.pdf')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# SPLIT AWA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# 20 Tasks, 10 runs\n",
    "PREFIX = '../awa/ohot/'\n",
    "van_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_VAN_0_0_001_10_False_20-19-07-31-09-20.pickle'\n",
    "ewc_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_EWC_100_0_003_10_False_20-19-07-31-09-54.pickle'\n",
    "pi_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_PI_1_0_003_10_False_20-19-07-31-20-54.pickle'\n",
    "rwalk_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_RWALK_10_0_003_10_False_20-19-08-01-09-27.pickle'\n",
    "mas_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_MAS_1_0_003_10_False_20-19-08-02-11-26.pickle'\n",
    "a_gem_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_A-GEM_0_0_01_10_False_20-19-07-29-19-39.pickle'\n",
    "mega_ohot_pickle = PREFIX + 'SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_MEGA_0_0_01_10_False_20-19-07-30-10-10.pickle'\n",
    "\n",
    "megad_ohot_pickle = '/Users/henry/Desktop/eccv_rebuttal/mega_L_and_replay/results/awa/ohot/SPLIT_AWA_ONE_HOT_HERDING_False_RESNET-B_True_MEGAD_0_0_01_10_False_20-20-05-24-03-18.pickle'\n",
    "\n",
    "\n",
    "MODELS = ['VAN', 'EWC', 'PI', 'RWALK', 'MAS', 'A-GEM', 'MEGA', 'MEGAD']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Dicts to store experiments data\n",
    "data_ohot_mean = dict()\n",
    "\n",
    "populate_data_dict(data_ohot_mean, 'VAN', van_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'EWC', ewc_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'PI', pi_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'RWALK', rwalk_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'MAS', mas_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'A-GEM', a_gem_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'MEGA', mega_ohot_pickle)\n",
    "populate_data_dict(data_ohot_mean, 'MEGAD', megad_ohot_pickle)\n",
    "\n",
    "\n",
    "# Dicts to store the average k-shot acc\n",
    "avg_k_shot_ohot_acc = dict()\n",
    "batches_per_task_ohot = dict()\n",
    "\n",
    "\n",
    "batches_per_task_ohot['VAN'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'VAN', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['EWC'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'EWC', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['PI'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'PI', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['RWALK'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'RWALK', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['MAS'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'MAS', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['A-GEM'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'A-GEM', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['MEGA'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'MEGA', avg_k_shot_ohot_acc)\n",
    "batches_per_task_ohot['MEGAD'] = populate_k_shot_acc_dict_with_varying_batches(data_ohot_mean, 'MEGAD', avg_k_shot_ohot_acc)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Average Accuracy and Forgetting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Acc for simple classification models:\n",
      "MAS=> Acc: 33.8319197778 (+-2.98589429797), LTR: 0.6257161997 (+-0.174848117865), Fgt: 0.0789228233842 (+-0.0217119292602), Wst Fgt: 0.21476511671 (+-0.0393422565315)\n",
      "VAN=> Acc: 30.3490062335 (+-2.80888674262), LTR: 0.202084127985 (+-0.0909760383752), Fgt: 0.0356290374569 (+-0.013157100214), Wst Fgt: 0.129925007354 (+-0.054408829161)\n",
      "MEGA=> Acc: 54.2814933362 (+-4.84501292078), LTR: 0.0700410454205 (+-0.114916267456), Fgt: 0.0465692789508 (+-0.0400338655987), Wst Fgt: 0.138391403397 (+-0.0756776163523)\n",
      "MEGAD=> Acc: 54.8214040863 (+-4.9710364806), LTR: 0.0286111729043 (+-0.0336066952374), Fgt: 0.0386714145954 (+-0.0340400598184), Wst Fgt: 0.120467140563 (+-0.0863992243761)\n",
      "EWC=> Acc: 33.4296538341 (+-3.06574558785), LTR: 0.674526152235 (+-0.214237870613), Fgt: 0.0842008617925 (+-0.0208006809725), Wst Fgt: 0.229391548929 (+-0.0413503221868)\n",
      "A-GEM=> Acc: 44.9479897367 (+-2.97105998704), LTR: 0.177771025642 (+-0.0821859372901), Fgt: 0.0459449704193 (+-0.0143333721467), Wst Fgt: 0.138727479631 (+-0.0421760222108)\n",
      "RWALK=> Acc: 33.6270861228 (+-2.63946212766), LTR: 0.641605800739 (+-0.202097518723), Fgt: 0.0813354140028 (+-0.0229590851742), Wst Fgt: 0.218123469084 (+-0.0546570927468)\n",
      "PI=> Acc: 33.8564121315 (+-2.76805736619), LTR: 0.6259009926 (+-0.179738066824), Fgt: 0.0790923952877 (+-0.0217516637645), Wst Fgt: 0.215844938233 (+-0.0418785446026)\n"
     ]
    }
   ],
   "source": [
    "print('Average Acc for simple classification models:')\n",
    "for key in data_ohot_mean:\n",
    "    acc_mean, acc_std = average_acc_stats_across_runs(data_ohot_mean[key]['mean'][:,:,:batches_per_task_ohot[key][-1],:], key)\n",
    "    ltr_mean, ltr_std = average_ltr_across_runs(data_ohot_mean[key]['mean'][:,:,:batches_per_task_ohot[key][-1],:], key)\n",
    "    fgt_mean, fgt_std, wst_fgt_mean, wst_fgt_std = average_fgt_stats_across_runs(data_ohot_mean[key]['mean'][:,:,:batches_per_task_ohot[key][-1],:], key)\n",
    "    print('{}=> Acc: {} (+-{}), LTR: {} (+-{}), Fgt: {} (+-{}), Wst Fgt: {} (+-{})'.format(key, acc_mean, \n",
    "                                                                           acc_std, ltr_mean, ltr_std ,fgt_mean, \n",
    "                                                                           fgt_std, wst_fgt_mean, \n",
    "                                                                           wst_fgt_std))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(10, 17, 501, 17)\n",
      "('MAS', 0.3383191977776036)\n",
      "('VAN', 0.3034900623350177)\n",
      "('MEGA', 0.5428149333615991)\n",
      "('MEGAD', 0.5482140408626013)\n",
      "('EWC', 0.3342965383411561)\n",
      "('A-GEM', 0.4494798973671809)\n",
      "('RWALK', 0.33627086122756317)\n",
      "('PI', 0.33856412131504027)\n"
     ]
    }
   ],
   "source": [
    "plot_average_accuracy_along_training_path(\"awa\", data_ohot_mean, batches_per_task_ohot=batches_per_task_ohot,  plot_name='../iclr_plots/awa_average_accuracy.pdf', legend=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### LCA Measure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LCA_10 classification models:\n",
      "MAS: 0.257147023976 (+-0.010907028345)\n",
      "VAN: 0.214251398742 (+-0.00821455885745)\n",
      "MEGA: 0.304956278801 (+-0.0151167778487)\n",
      "MEGAD: 0.307516539693 (+-0.0141903524507)\n",
      "EWC: 0.257042901069 (+-0.0111783567681)\n",
      "A-GEM: 0.287053715438 (+-0.0120634800104)\n",
      "RWALK: 0.257573325783 (+-0.0109304621229)\n",
      "PI: 0.258598431945 (+-0.0105415626996)\n"
     ]
    }
   ],
   "source": [
    "# Using trapezoidal rule\n",
    "f = open('../dataset_lists/AWA_train_list.txt', 'rb').readlines()\n",
    "NUM_CLASSES = 50\n",
    "NUM_TASKS = 10\n",
    "BATCH_SIZE = 10\n",
    "examples_per_task = np.zeros([NUM_TASKS], dtype=np.int32)\n",
    "for line in f:\n",
    "    img, label = line.split()\n",
    "    label = int(label)\n",
    "    examples_per_task[label//(NUM_CLASSES/ NUM_TASKS)] += 1\n",
    "    \n",
    "num_batches = []\n",
    "for task in examples_per_task:\n",
    "    num_batches_per_task = []\n",
    "    num_iters = (task + BATCH_SIZE - 1)// BATCH_SIZE\n",
    "    for iters in range(num_iters):\n",
    "        if (iters < 20) or (iters % 50 == 0):\n",
    "            num_batches_per_task.append(iters)\n",
    "    num_batches_per_task.append(iters)\n",
    "    if (len(num_batches_per_task) > len(num_batches)):\n",
    "        num_batches = num_batches_per_task\n",
    "        \n",
    "num_runs = avg_k_shot_ohot_acc['VAN'].shape[0]\n",
    "\n",
    "BATCHES_WE_CARE = 10\n",
    "\n",
    "area_ohot_trapz = dict()\n",
    "area_zst_trapz = dict()\n",
    "\n",
    "area_ohot_trapz['VAN'] = np.zeros([num_runs, BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['EWC'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['PI'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['RWALK'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['MAS'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['A-GEM'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['MEGA'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_ohot_trapz['MEGAD'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "\n",
    "\n",
    "area_zst_trapz['VAN'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_zst_trapz['EWC'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_zst_trapz['MAS'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_zst_trapz['PI'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_zst_trapz['RWALK'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "area_zst_trapz['A-GEM'] = np.zeros([num_runs,BATCHES_WE_CARE+1])\n",
    "\n",
    "for run in range(num_runs):\n",
    "    for measure_upto in range(1, BATCHES_WE_CARE+2):\n",
    "        batches_upto = num_batches[:measure_upto]\n",
    "        max_acc = np.ones_like(batches_upto)\n",
    "        max_area_trapz = np.trapz(max_acc, batches_upto)\n",
    "        if measure_upto == 1:\n",
    "            area_ohot_trapz['VAN'][run][measure_upto-1] = avg_k_shot_ohot_acc['VAN'][run][0]\n",
    "            area_ohot_trapz['EWC'][run][measure_upto-1] = avg_k_shot_ohot_acc['EWC'][run][0]\n",
    "            area_ohot_trapz['PI'][run][measure_upto-1] = avg_k_shot_ohot_acc['PI'][run][0]\n",
    "            area_ohot_trapz['MAS'][run][measure_upto-1] = avg_k_shot_ohot_acc['MAS'][run][0]\n",
    "            area_ohot_trapz['RWALK'][run][measure_upto-1] = avg_k_shot_ohot_acc['RWALK'][run][0]\n",
    "            area_ohot_trapz['A-GEM'][run][measure_upto-1] = avg_k_shot_ohot_acc['A-GEM'][run][0]\n",
    "            area_ohot_trapz['MEGA'][run][measure_upto-1] = avg_k_shot_ohot_acc['MEGA'][run][0]\n",
    "            area_ohot_trapz['MEGAD'][run][measure_upto-1] = avg_k_shot_ohot_acc['MEGAD'][run][0]\n",
    "    \n",
    "        else:\n",
    "            area_ohot_trapz['VAN'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['VAN'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['PI'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['PI'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['RWALK'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['RWALK'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['MAS'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['MAS'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['EWC'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['EWC'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['A-GEM'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['A-GEM'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['MEGA'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['MEGA'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            area_ohot_trapz['MEGAD'][run][measure_upto-1] = np.trapz(avg_k_shot_ohot_acc['MEGAD'][run][:measure_upto], batches_upto)/ max_area_trapz\n",
    "            \n",
    "            \n",
    "print('LCA_10 classification models:')\n",
    "for key in area_ohot_trapz:\n",
    "    lca_10 = area_ohot_trapz[key][:, 10]\n",
    "    print('{}: {} (+-{})'.format(key, lca_10.mean(), lca_10.std()))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "batches_we_care = np.arange(BATCHES_WE_CARE+1)\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "ax = fig.add_axes([0.15, 0.21, 0.6, 0.75])\n",
    "\n",
    "\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['VAN'], axis=0),colors['VAN'], lw=2, label='VAN')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['EWC'], axis=0),colors['EWC'], lw=2, label='EWC')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['RWALK'], axis=0),colors['RWALK'], lw=2, label='RWALK')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['A-GEM'], axis=0),colors['A-GEM'], lw=2, label='A-GEM')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['MEGA'], axis=0),'-r', marker='^', markersize=7, lw=2, label='MEGA')\n",
    "ax.plot(batches_we_care, np.mean(area_ohot_trapz['MEGAD'], axis=0),'-b', marker='*', markersize=7, lw=2, label='MEGAD')\n",
    "\n",
    "\n",
    "ax.set_xlabel('Batches', size=20)\n",
    "ax.set_ylabel('LCA', size=20)\n",
    "plt.xticks(batches_we_care)\n",
    "\n",
    "#ax.legend(bbox_to_anchor=(1, 1), loc=2, borderaxespad=0.2)\n",
    "plt.grid()\n",
    "#plt.show()\n",
    "plt.savefig('../iclr_plots/fam_awa_20.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Bar Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def autolabel(rects):\n",
    "    \"\"\"\n",
    "    Attach a text label above each bar displaying its height\n",
    "    \"\"\"\n",
    "    for rect in rects:\n",
    "        height = rect.get_height()\n",
    "        ax.text(rect.get_x() + rect.get_width()/2.0, 1.05*height,\n",
    "                '%d' % int(height),\n",
    "                ha='center', va='bottom')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# MNIST\n",
    "# metadata method = [Avg_Acc, Forgetting, LCA_10, Time, Mem]\n",
    "\n",
    "plt.clf()\n",
    "metric_name = ['acc', 'fgt', 'lca10', 'time', 'memory']\n",
    "\n",
    "ticks = ['$A_T$($\\uparrow$)', '$F_T$($\\downarrow$)', '$LCA_{10}$($\\uparrow$)', 'Time($\\downarrow$)', \n",
    "         'Mem($\\downarrow$)']\n",
    "\n",
    "labels = ['VAN', 'EWC', 'PROG-NN', 'GEM', 'A-GEM', 'MEGA', 'MEGAD']\n",
    "colors = ['C0', 'm', 'C5', 'c', 'C1', 'r', 'b']\n",
    "bar_data = dict()\n",
    "bar_error = dict()\n",
    "    \n",
    "bar_data['VAN'] = np.array([0.475, 0.51, 0.26,  0.05, 0.03])\n",
    "bar_data['EWC'] = np.array([0.686, 0.28, 0.27, 0.117, 0.1])\n",
    "bar_data['PROG-NN'] = np.array([0.935, 0.0, 0.19, 0.0, 1])\n",
    "bar_data['GEM'] = np.array([0.895, 0.06, 0.23, 1, 0.49])\n",
    "bar_data['A-GEM'] = np.array([0.893, 0.07, 0.27, 0.138, 0.12])\n",
    "bar_data['MEGA'] = np.array([0.912, 0.05, 0.28, 0.145, 0.12])\n",
    "bar_data['MEGAD'] = np.array([0.9110, 0.0500, 0.281, 0.142, 0.12])\n",
    "\n",
    "bar_error['VAN'] = np.array([0.0237, 0.02, 0.006, 0, 0])\n",
    "bar_error['EWC'] = np.array([0.0098, 0.01, 0.003, 0, 0])\n",
    "bar_error['PROG-NN'] = np.array([0.06, 0, 0.006, 0, 0])\n",
    "bar_error['GEM'] = np.array([0.0048, 0.004, 0.005, 0, 0])\n",
    "bar_error['A-GEM'] = np.array([0.0046, 0.001, 0.004, 0, 0])\n",
    "bar_error['MEGA'] = np.array([0.0010, 0.001, 0.004, 0, 0])\n",
    "bar_error['MEGAD'] = np.array([0.0829, 0.0006, 0.0057, 0, 0])\n",
    "\n",
    "total_metrics = 4\n",
    "for metric in range(total_metrics):\n",
    "    \n",
    "    if metric <=2:\n",
    "        fig = plt.figure(figsize=(1.5, 4))\n",
    "        #fig, axes = plt.subplots(1, 5)\n",
    "        ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "        plt.rc('text', usetex=True)\n",
    "        plt.rc('font', family='serif')\n",
    "\n",
    "        num_methods = len(bar_data)\n",
    "        r = np.arange(0, num_methods)\n",
    "        data = np.zeros(num_methods)\n",
    "        yerror = np.zeros(num_methods)\n",
    "        \n",
    "        data[0] = bar_data['VAN'][metric]\n",
    "        data[1] = bar_data['EWC'][metric]\n",
    "        data[2] = bar_data['PROG-NN'][metric]\n",
    "        data[3] = bar_data['GEM'][metric]\n",
    "        data[4] = bar_data['A-GEM'][metric]\n",
    "        data[5] = bar_data['MEGA'][metric] \n",
    "        data[6] = bar_data['MEGAD'][metric] \n",
    "\n",
    "        yerror[0] = bar_error['VAN'][metric]\n",
    "        yerror[1] = bar_error['EWC'][metric]\n",
    "        yerror[2] = bar_error['PROG-NN'][metric]\n",
    "        yerror[3] = bar_error['GEM'][metric]\n",
    "        yerror[4] = bar_error['A-GEM'][metric]\n",
    "        yerror[5] = bar_error['MEGA'][metric]\n",
    "        yerror[6] = bar_error['MEGAD'][metric]\n",
    "    \n",
    "        low = min(data)\n",
    "        high = max(data)\n",
    "        if metric == 1:\n",
    "            ax.set_ylim(low, high+np.max(yerror)+0.001)\n",
    "        else:\n",
    "            ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "\n",
    "        barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "\n",
    "        for i in range(num_methods):\n",
    "            barlist[i].set_color(colors[i])\n",
    "    \n",
    "        ax.set_xlabel(ticks[metric], size=15)\n",
    "        plt.tick_params(\n",
    "            axis='x',          # changes apply to the x-axis\n",
    "            which='both',      # both major and minor ticks are affected\n",
    "            bottom=False,      # ticks along the bottom edge are off\n",
    "            top=False,         # ticks along the top edge are off\n",
    "            labelbottom=False)\n",
    "        #ax.spines['right'].set_visible(False)\n",
    "        ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "        ax.yaxis.grid(linestyle='--')\n",
    "        #plt.show()\n",
    "        plt.savefig('../iclr_plots/grouped_lll_mnist_%s.pdf'%(metric_name[metric]))\n",
    "    else:\n",
    "        # Metric 3        \n",
    "        fig = plt.figure(figsize=(2.5, 4))\n",
    "        ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "        sub_data1 = np.zeros(2)\n",
    "        sub_data2 = np.zeros(2)\n",
    "        sub_data3 = np.zeros(2)\n",
    "        sub_data4 = np.zeros(2)\n",
    "        sub_data5 = np.zeros(2)\n",
    "        sub_data6 = np.zeros(2)\n",
    "        sub_data7 = np.zeros(2)\n",
    "        \n",
    "        sub_data1 = bar_data['VAN'][3:]\n",
    "        sub_data2 = bar_data['EWC'][3:]\n",
    "        sub_data3 = bar_data['PROG-NN'][3:]\n",
    "        sub_data4 = bar_data['GEM'][3:]\n",
    "        sub_data5 = bar_data['A-GEM'][3:]\n",
    "        sub_data6 = bar_data['MEGA'][3:]\n",
    "        sub_data7 = bar_data['MEGAD'][3:]\n",
    "        \n",
    "        barWidth = 0.15\n",
    "        r1 = np.arange(len(sub_data1))\n",
    "        r2 = [x + barWidth for x in r1]\n",
    "        r3 = [x + barWidth for x in r2]\n",
    "        r4 = [x + barWidth for x in r3]\n",
    "        r5 = [x + barWidth for x in r4]\n",
    "        r6 = [x + barWidth for x in r5]\n",
    "        r7 = [x + barWidth for x in r6]\n",
    "        \n",
    "        plt.bar(r1, sub_data1, width=barWidth, color=colors[0])\n",
    "        plt.bar(r2, sub_data2, width=barWidth, color=colors[1])\n",
    "        plt.bar(r3, sub_data3, width=barWidth, color=colors[2])\n",
    "        plt.bar(r4, sub_data4, width=barWidth, color=colors[3])\n",
    "        plt.bar(r5, sub_data5, width=barWidth, color=colors[4])\n",
    "        plt.bar(r6, sub_data6, width=barWidth, color=colors[5]) \n",
    "        plt.bar(r7, sub_data7, width=barWidth, color=colors[6]) \n",
    "        \n",
    "        plt.xticks([r + barWidth for r in range(len(sub_data1))], [ticks[3], ticks[4]], size=13)\n",
    "        ax.yaxis.grid(linestyle='--')\n",
    "        #plt.show()\n",
    "        plt.savefig('../iclr_plots/grouped_lll_mnist_time_memory.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Library/Python/2.7/site-packages/matplotlib/pyplot.py:524: 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",
      "  max_open_warning, RuntimeWarning)\n"
     ]
    }
   ],
   "source": [
    "# CIFAR\n",
    "# metadata method = [Avg_Acc, Forgetting, LCA_10, Time, Mem]\n",
    "plt.clf()\n",
    "metric_name = ['acc', 'fgt', 'lca10', 'time', 'memory']\n",
    "ticks = ['$A_T$($\\uparrow$)', '$F_T$($\\downarrow$)', '$LCA_{10}$($\\uparrow$)', 'Time($\\downarrow$)', \n",
    "         'Mem($\\downarrow$)']\n",
    "labels = ['VAN', 'EWC', 'PROG-NN', 'GEM', 'A-GEM', 'MEGA', 'MEGAD']\n",
    "colors = ['C0', 'm', 'C5', 'c', 'C1', 'r', 'b']\n",
    "bar_data = dict()\n",
    "bar_error = dict()\n",
    "\n",
    "\n",
    "bar_data['VAN'] = np.array([0.404, 0.27, 0.30, 0.02, 0.04])\n",
    "bar_data['EWC'] = np.array([0.427, 0.26, 0.33, 0.05, 0.09])\n",
    "bar_data['PROG-NN'] = np.array([0.598, 0, 0.21, 0.08, 1])\n",
    "bar_data['GEM'] = np.array([0.612, 0.06, 0.36, 1, 0.47])\n",
    "bar_data['A-GEM'] = np.array([0.613, 0.08, 0.35, 0.08, 0.2])\n",
    "bar_data['MEGA'] = np.array([0.661, 0.05, 0.37, 0.086, 0.2])\n",
    "\n",
    "\n",
    "#MEGAD=> Acc: 66.108235226 (+-1.67813357131), LTR: 0.348249996454 (+-0.113181196861), Fgt: 0.0529500003904 (+-0.0143630572252), Wst Fgt: 0.117200016975 (+-0.0203410852856)\n",
    "bar_data['MEGAD'] = np.array([0.661, 0.05, 0.36682, 0.079, 0.2])\n",
    "\n",
    "\n",
    "bar_error['VAN'] = np.array([0.0101, 0.006, 0.01, 0, 0])\n",
    "bar_error['EWC'] = np.array([0.0423, 0.03, 0.01, 0, 0])\n",
    "bar_error['PROG-NN'] = np.array([0.0123, 0.0, 0.002, 0, 0])\n",
    "bar_error['GEM'] = np.array([0.0078, 0.007, 0.007, 0, 0])\n",
    "bar_error['A-GEM'] = np.array([0.0188, 0.01, 0.01, 0, 0])\n",
    "bar_error['MEGA'] = np.array([0.01, 0.01, 0.01, 0, 0])\n",
    "\n",
    "bar_error['MEGAD'] = np.array([0.0167, 0.01, 0.009, 0, 0])\n",
    "\n",
    "total_metrics = 4\n",
    "for metric in range(total_metrics):\n",
    "    \n",
    "    if metric <=2:\n",
    "        fig = plt.figure(figsize=(1.5, 4))\n",
    "        #fig, axes = plt.subplots(1, 5)\n",
    "        ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "        plt.rc('text', usetex=True)\n",
    "        plt.rc('font', family='serif')\n",
    "\n",
    "        num_methods = len(bar_data)\n",
    "        r = np.arange(0, num_methods)\n",
    "        data = np.zeros(num_methods)\n",
    "        yerror = np.zeros(num_methods)\n",
    "        \n",
    "        data[0] = bar_data['VAN'][metric]\n",
    "        data[1] = bar_data['EWC'][metric]\n",
    "        data[2] = bar_data['PROG-NN'][metric]\n",
    "        data[3] = bar_data['GEM'][metric]\n",
    "        data[4] = bar_data['A-GEM'][metric]\n",
    "        data[5] = bar_data['MEGA'][metric]\n",
    "        data[6] = bar_data['MEGAD'][metric]\n",
    "    \n",
    "        \n",
    "        yerror[0] = bar_error['VAN'][metric]\n",
    "        yerror[1] = bar_error['EWC'][metric]\n",
    "        yerror[2] = bar_error['PROG-NN'][metric]\n",
    "        yerror[3] = bar_error['GEM'][metric]\n",
    "        yerror[4] = bar_error['A-GEM'][metric]\n",
    "        yerror[5] = bar_error['MEGA'][metric]\n",
    "        yerror[6] = bar_error['MEGAD'][metric]\n",
    "        \n",
    "        \n",
    "        low = min(data)\n",
    "        high = max(data)\n",
    "        if metric == 1:\n",
    "            ax.set_ylim(low, high+np.max(yerror)+0.001)\n",
    "        else:\n",
    "            ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "            \n",
    "        barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "\n",
    "        for i in range(num_methods):\n",
    "            barlist[i].set_color(colors[i])\n",
    "    \n",
    "        ax.set_xlabel(ticks[metric], size=15)\n",
    "        plt.tick_params(\n",
    "            axis='x',          # changes apply to the x-axis\n",
    "            which='both',      # both major and minor ticks are affected\n",
    "            bottom=False,      # ticks along the bottom edge are off\n",
    "            top=False,         # ticks along the top edge are off\n",
    "            labelbottom=False)\n",
    "        #ax.spines['right'].set_visible(False)\n",
    "        ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "        ax.yaxis.grid(linestyle='--')\n",
    "        #plt.show()\n",
    "        plt.savefig('../iclr_plots/grouped_lll_cifar_%s.pdf'%(metric_name[metric]))\n",
    "    else:\n",
    "        # Metric 3        \n",
    "        fig = plt.figure(figsize=(2.5, 4))\n",
    "        ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "        sub_data1 = np.zeros(2)\n",
    "        sub_data2 = np.zeros(2)\n",
    "        sub_data3 = np.zeros(2)\n",
    "        sub_data4 = np.zeros(2)\n",
    "        sub_data5 = np.zeros(2)\n",
    "        sub_data6 = np.zeros(2)\n",
    "        sub_data7 = np.zeros(2)\n",
    "        \n",
    "        sub_data1 = bar_data['VAN'][3:]\n",
    "        sub_data2 = bar_data['EWC'][3:]\n",
    "        sub_data3 = bar_data['PROG-NN'][3:]\n",
    "        sub_data4 = bar_data['GEM'][3:]\n",
    "        sub_data5 = bar_data['A-GEM'][3:]\n",
    "        sub_data6 = bar_data['MEGA'][3:]\n",
    "        sub_data7 = bar_data['MEGAD'][3:]\n",
    "        \n",
    "        barWidth = 0.1\n",
    "        r1 = np.arange(len(sub_data1))\n",
    "        r2 = [x + barWidth for x in r1]\n",
    "        r3 = [x + barWidth for x in r2]\n",
    "        r4 = [x + barWidth for x in r3]\n",
    "        r5 = [x + barWidth for x in r4]\n",
    "        r6 = [x + barWidth for x in r5]\n",
    "        r7 = [x + barWidth for x in r6]\n",
    "        \n",
    "        plt.bar(r1, sub_data1, width=barWidth, color=colors[0])\n",
    "        plt.bar(r2, sub_data2, width=barWidth, color=colors[1])\n",
    "        plt.bar(r3, sub_data3, width=barWidth, color=colors[2])\n",
    "        plt.bar(r4, sub_data4, width=barWidth, color=colors[3])\n",
    "        plt.bar(r5, sub_data5, width=barWidth, color=colors[4])\n",
    "        plt.bar(r6, sub_data6, width=barWidth, color=colors[5])\n",
    "        plt.bar(r7, sub_data7, width=barWidth, color=colors[6])\n",
    "        \n",
    "        plt.xticks([r + barWidth for r in range(len(sub_data1))], [ticks[3], ticks[4]], size=13)\n",
    "        ax.yaxis.grid(linestyle='--')\n",
    "        #plt.show()\n",
    "        plt.savefig('../iclr_plots/grouped_lll_cifar_time_memory.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['C0', 'm', 'C5', 'c', 'C1', 'b', 'r']\n",
      "['VAN', 'EWC', 'PROG-NN', 'GEM', 'A-GEM', 'MEGA-I', 'MEGA-II']\n"
     ]
    }
   ],
   "source": [
    "plt.clf()\n",
    "labels = ['VAN', 'EWC', 'PROG-NN', 'GEM', 'A-GEM', 'MEGA-I', 'MEGA-II']\n",
    "colors = ['C0', 'm', 'C5', 'c', 'C1', 'b', 'r']\n",
    "\n",
    "fig = plt.figure(figsize=(12,1))\n",
    "patches = []\n",
    "print (colors)\n",
    "print (labels)\n",
    "for i in range(len(labels)):\n",
    "        patches.append(mpatches.Patch(color=colors[i], label=labels[i]))\n",
    "        plt.legend(handles=patches, loc=2, borderaxespad=0.6, \n",
    "                   fontsize='x-large', ncol=len(labels))\n",
    "plt.axis('off')\n",
    "#plt.show()\n",
    "plt.savefig('../iclr_plots/mnist_cifar_legend.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.2  0.23]\n"
     ]
    }
   ],
   "source": [
    "# CUB\n",
    "# metadata method = [Avg_Acc, Forgetting, LCA_10, Time, Mem]\n",
    "plt.clf()\n",
    "metric_name = ['acc', 'fgt', 'lca10', 'time', 'memory']\n",
    "\n",
    "ticks = ['$A_T$($\\uparrow$)', '$F_T$($\\downarrow$)', '$LCA_{10}$($\\uparrow$)', 'Time($\\downarrow$)', \n",
    "         'Mem($\\downarrow$)']\n",
    "labels = ['VAN',  'EWC',  'A-GEM', 'MEGA', 'MEGAD']\n",
    "colors = ['C0', 'm', 'C1',  'r', 'b']\n",
    "\n",
    "bar_data = dict()\n",
    "bar_error = dict()\n",
    "\n",
    "\n",
    "bar_data['VAN'] = np.array([0.539, 0.13, 0.29, 0.2, 0.23])\n",
    "bar_data['EWC'] = np.array([0.54, 0.14, 0.29, 0.3, 0.85])\n",
    "bar_data['A-GEM'] = np.array([0.62, 0.07, 0.30, 1, 1])\n",
    "bar_data['MEGA'] = np.array([0.81, 0.01, 0.31, 0.97, 1])        \n",
    "bar_data['MEGAD'] = np.array([0.7967, 0.0149, 0.3151, 0.95, 1 ])\n",
    "\n",
    "bar_error['VAN'] = np.array([0.020, 0.02, 0.008])\n",
    "bar_error['EWC'] = np.array([0.017, 0.02, 0.009])\n",
    "bar_error['A-GEM'] = np.array([0.03, 0.02, 0.01])\n",
    "bar_error['MEGA'] = np.array([0.019, 0.005, 0.009])\n",
    "bar_error['MEGAD'] = np.array([0.02152,0.0190, 0.011 ])\n",
    "\n",
    "# Metric 0        \n",
    "fig = plt.figure(figsize=(1.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "metric=0\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "num_methods = len(bar_data)\n",
    "r = np.arange(0, num_methods)\n",
    "data = np.zeros(num_methods)\n",
    "yerror = np.zeros(num_methods)\n",
    "\n",
    "data[0] = bar_data['VAN'][metric]\n",
    "data[1] = bar_data['EWC'][metric]\n",
    "data[2] = bar_data['A-GEM'][metric]\n",
    "data[3] = bar_data['MEGA'][metric]\n",
    "data[4] = bar_data['MEGAD'][metric]\n",
    "\n",
    "yerror[0] = bar_error['VAN'][metric]\n",
    "yerror[1] = bar_error['EWC'][metric]\n",
    "yerror[2] = bar_error['A-GEM'][metric]\n",
    "yerror[3] = bar_error['MEGA'][metric]\n",
    "yerror[4] = bar_error['MEGAD'][metric]\n",
    "\n",
    "low = min(data)\n",
    "high = max(data)\n",
    "#ax.set_ylim(low-0.005, high+0.005)\n",
    "ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "for i in range(num_methods):\n",
    "    barlist[i].set_color(colors[i])\n",
    "    \n",
    "ax.set_xlabel(ticks[metric], size=15)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False)\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "plt.savefig('../iclr_plots/grouped_lll_cub_%s.pdf'%(metric_name[metric]))\n",
    "\n",
    "# Metric 1        \n",
    "fig = plt.figure(figsize=(1.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "metric=1\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "num_methods = len(bar_data)\n",
    "r = np.arange(0, num_methods)\n",
    "data = np.zeros(num_methods)\n",
    "yerror = np.zeros(num_methods)\n",
    "\n",
    "data[0] = bar_data['VAN'][metric]\n",
    "data[1] = bar_data['EWC'][metric]\n",
    "data[2] = bar_data['A-GEM'][metric]\n",
    "data[3] = bar_data['MEGA'][metric]\n",
    "data[4] = bar_data['MEGAD'][metric]\n",
    "\n",
    "yerror[0] = bar_error['VAN'][metric]\n",
    "yerror[1] = bar_error['EWC'][metric]\n",
    "yerror[2] = bar_error['A-GEM'][metric]\n",
    "yerror[3] = bar_error['MEGA'][metric]\n",
    "yerror[4] = bar_error['MEGAD'][metric]\n",
    "\n",
    "low = min(data)\n",
    "high = max(data)\n",
    "#ax.set_ylim(low-0.003, high+0.001)\n",
    "#ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "for i in range(num_methods):\n",
    "    barlist[i].set_color(colors[i])\n",
    "    \n",
    "ax.set_xlabel(ticks[metric], size=15)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False)\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "plt.savefig('../iclr_plots/grouped_lll_cub_%s.pdf'%(metric_name[metric]))\n",
    "\n",
    "# Metric 2        \n",
    "fig = plt.figure(figsize=(1.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "metric=2\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "num_methods = len(bar_data)\n",
    "r = np.arange(0, num_methods)\n",
    "data = np.zeros(num_methods)\n",
    "yerror = np.zeros(num_methods)\n",
    "\n",
    "data[0] = bar_data['VAN'][metric]\n",
    "data[1] = bar_data['EWC'][metric]\n",
    "data[2] = bar_data['A-GEM'][metric]\n",
    "data[3] = bar_data['MEGA'][metric]\n",
    "data[4] = bar_data['MEGAD'][metric]\n",
    "\n",
    "yerror[0] = bar_error['VAN'][metric]\n",
    "yerror[1] = bar_error['EWC'][metric]\n",
    "yerror[2] = bar_error['A-GEM'][metric]\n",
    "yerror[3] = bar_error['MEGA'][metric]\n",
    "yerror[4] = bar_error['MEGAD'][metric]\n",
    "\n",
    "low = min(data)\n",
    "high = max(data)\n",
    "ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "for i in range(num_methods):\n",
    "    barlist[i].set_color(colors[i])\n",
    "    \n",
    "ax.set_xlabel(ticks[metric], size=15)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False)\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "plt.savefig('../iclr_plots/grouped_lll_cub_%s.pdf'%(metric_name[metric]))\n",
    "\n",
    "# Metric 3        \n",
    "fig = plt.figure(figsize=(2.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "sub_data1 = np.zeros(2)\n",
    "sub_data2 = np.zeros(2)\n",
    "sub_data3 = np.zeros(2)\n",
    "sub_data4 = np.zeros(2)\n",
    "sub_data5 = np.zeros(2)\n",
    "\n",
    "sub_data1 = bar_data['VAN'][3:]\n",
    "sub_data2 = bar_data['EWC'][3:]\n",
    "sub_data3 = bar_data['A-GEM'][3:]\n",
    "sub_data4 = bar_data['MEGA'][3:]\n",
    "sub_data5 = bar_data['MEGAD'][3:]\n",
    "\n",
    "print(sub_data1)\n",
    "barWidth = 0.20\n",
    "r1 = np.arange(len(sub_data1))\n",
    "r2 = [x + barWidth for x in r1]\n",
    "r3 = [x + barWidth for x in r2]\n",
    "r4 = [x + barWidth for x in r3]\n",
    "r5 = [x + barWidth for x in r4]\n",
    "\n",
    "#ax.set_ylim(0.2-0.01, 1)\n",
    "\n",
    "plt.bar(r1, sub_data1, width=barWidth, color=colors[0])\n",
    "plt.bar(r2, sub_data2, width=barWidth, color=colors[1])\n",
    "plt.bar(r3, sub_data3, width=barWidth, color=colors[2])\n",
    "plt.bar(r4, sub_data4, width=barWidth, color=colors[3])\n",
    "plt.bar(r5, sub_data5, width=barWidth, color=colors[4])\n",
    "\n",
    "plt.xticks([r + barWidth for r in range(len(sub_data1))], [ticks[3], ticks[4]], size=13)\n",
    "#ax = plt.axes()        \n",
    "ax.yaxis.grid(linestyle='--')\n",
    "plt.savefig('../iclr_plots/grouped_lll_cub_time_memory.pdf')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# AWA\n",
    "# metadata method = [Avg_Acc, Forgetting, LCA_10, Mem]\n",
    "plt.clf()\n",
    "metric = 4\n",
    "metric_name = ['acc', 'fgt', 'lca10', 'time', 'memory']\n",
    "ticks = ['$A_T$($\\uparrow$)', '$F_T$($\\downarrow$)', '$LCA_{10}$($\\uparrow$)', 'Time($\\downarrow$)', \n",
    "         'Mem($\\downarrow$)']\n",
    "\n",
    "labels = ['VAN',  'EWC',  'A-GEM', 'MEGA', 'MEGAD']\n",
    "colors = ['C0', 'm', 'C1',  'r', 'b']\n",
    "bar_data = dict()\n",
    "bar_error = dict()\n",
    "\n",
    "\n",
    "bar_data['VAN'] = np.array([0.303, 0.04, 0.21, 0.04, 0.08])\n",
    "bar_data['EWC'] = np.array([0.334, 0.08, 0.26, 0.04, 0.26])\n",
    "bar_data['A-GEM'] = np.array([0.45, 0.05, 0.29, 0.05, 0.32])\n",
    "bar_data['MEGA'] = np.array([0.54, 0.05, 0.30, 0.0504, 0.32])\n",
    "bar_data['MEGAD'] = np.array([0.548, 0.0386, 0.3075, 0.048, 0.32])\n",
    "\n",
    "bar_error['VAN'] = np.array([0.0284, 0.01, 0.008])\n",
    "bar_error['EWC'] = np.array([0.0306, 0.02, 0.01])\n",
    "bar_error['A-GEM'] = np.array([0.03, 0.01, 0.01])\n",
    "bar_error['MEGA'] = np.array([0.05, 0.02, 0.01])\n",
    "bar_error['MEGAD'] = np.array([0.0497, 0.033 , 0.014])\n",
    "\n",
    "# Metric 0        \n",
    "fig = plt.figure(figsize=(1.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "metric=0\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "num_methods = len(bar_data)\n",
    "r = np.arange(0, num_methods)\n",
    "data = np.zeros(num_methods)\n",
    "yerror = np.zeros(num_methods)\n",
    "data[0] = bar_data['VAN'][metric]\n",
    "data[1] = bar_data['EWC'][metric]\n",
    "data[2] = bar_data['A-GEM'][metric]\n",
    "data[3] = bar_data['MEGA'][metric]\n",
    "data[4] = bar_data['MEGAD'][metric]\n",
    "\n",
    "yerror[0] = bar_error['VAN'][metric]\n",
    "yerror[1] = bar_error['EWC'][metric]\n",
    "yerror[2] = bar_error['A-GEM'][metric]\n",
    "yerror[3] = bar_error['MEGA'][metric]\n",
    "yerror[4] = bar_error['MEGAD'][metric]\n",
    "\n",
    "low = min(data)\n",
    "high = max(data)\n",
    "#ax.set_ylim(low-0.005, high+0.005)\n",
    "ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "for i in range(num_methods):\n",
    "    barlist[i].set_color(colors[i])\n",
    "    \n",
    "ax.set_xlabel(ticks[metric], size=15)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False)\n",
    "ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "plt.savefig('../iclr_plots/grouped_lll_awa_%s.pdf'%(metric_name[metric]))\n",
    "\n",
    "# Metric 1        \n",
    "fig = plt.figure(figsize=(1.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "metric=1\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "num_methods = len(bar_data)\n",
    "r = np.arange(0, num_methods)\n",
    "data = np.zeros(num_methods)\n",
    "yerror = np.zeros(num_methods)\n",
    "data[0] = bar_data['VAN'][metric]\n",
    "data[1] = bar_data['EWC'][metric]\n",
    "data[2] = bar_data['A-GEM'][metric]\n",
    "data[3] = bar_data['MEGA'][metric]\n",
    "data[4] = bar_data['MEGAD'][metric]\n",
    "\n",
    "yerror[0] = bar_error['VAN'][metric]\n",
    "yerror[1] = bar_error['EWC'][metric]\n",
    "yerror[2] = bar_error['A-GEM'][metric]\n",
    "yerror[3] = bar_error['MEGA'][metric]\n",
    "yerror[4] = bar_error['MEGAD'][metric]\n",
    "\n",
    "low = min(data)\n",
    "high = max(data)\n",
    "#ax.set_ylim(low-0.003, high+0.001)\n",
    "ax.set_ylim(0.01, high+np.max(yerror)+0.001)\n",
    "#ax.set_ylim(low, high+np.max(yerror)+0.001)\n",
    "barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "for i in range(num_methods):\n",
    "    barlist[i].set_color(colors[i])\n",
    "    \n",
    "ax.set_xlabel(ticks[metric], size=15)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False)\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "plt.savefig('../iclr_plots/grouped_lll_awa_%s.pdf'%(metric_name[metric]))\n",
    "\n",
    "# Metric 2        \n",
    "fig = plt.figure(figsize=(1.5, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "metric=2\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "num_methods = len(bar_data)\n",
    "r = np.arange(0, num_methods)\n",
    "data = np.zeros(num_methods)\n",
    "yerror = np.zeros(num_methods)\n",
    "data[0] = bar_data['VAN'][metric]\n",
    "data[1] = bar_data['EWC'][metric]\n",
    "data[2] = bar_data['A-GEM'][metric]\n",
    "data[3] = bar_data['MEGA'][metric]\n",
    "data[4] = bar_data['MEGAD'][metric]\n",
    "\n",
    "yerror[0] = bar_error['VAN'][metric]\n",
    "yerror[1] = bar_error['EWC'][metric]\n",
    "yerror[2] = bar_error['A-GEM'][metric]\n",
    "yerror[3] = bar_error['MEGA'][metric]\n",
    "yerror[4] = bar_error['MEGAD'][metric]\n",
    "\n",
    "low = min(data)\n",
    "high = max(data)\n",
    "#ax.set_ylim(low-0.005, high+0.005)\n",
    "ax.set_ylim(low-np.max(yerror), high+np.max(yerror)+0.001)\n",
    "barlist = ax.bar(r, data, yerr=yerror, error_kw=dict(lw=2, capsize=3, capthick=2))\n",
    "for i in range(num_methods):\n",
    "    barlist[i].set_color(colors[i])\n",
    "    \n",
    "ax.set_xlabel(ticks[metric], size=15)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False)\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "plt.savefig('../iclr_plots/grouped_lll_awa_%s.pdf'%(metric_name[metric]))\n",
    "\n",
    "# Metric 3  \n",
    "fig = plt.figure(figsize=(2.4, 4))\n",
    "ax = fig.add_axes([0.24, 0.15, 0.6, 0.75])\n",
    "sub_data1 = np.zeros(2)\n",
    "sub_data2 = np.zeros(2)\n",
    "sub_data3 = np.zeros(2)\n",
    "sub_data4 = np.zeros(2)\n",
    "sub_data5 = np.zeros(2)\n",
    "\n",
    "sub_data1 = bar_data['VAN'][3:]\n",
    "sub_data2 = bar_data['EWC'][3:]\n",
    "sub_data3 = bar_data['A-GEM'][3:]\n",
    "sub_data4  = bar_data['MEGA'][3:]\n",
    "sub_data5  = bar_data['MEGAD'][3:]\n",
    "\n",
    "barWidth = 0.20\n",
    "r1 = np.arange(len(sub_data1))\n",
    "r2 = [x + barWidth for x in r1]\n",
    "r3 = [x + barWidth for x in r2]\n",
    "r4 = [x + barWidth for x in r3]\n",
    "r5 = [x + barWidth for x in r4]\n",
    "\n",
    "plt.bar(r1, sub_data1, width=barWidth, color=colors[0])\n",
    "plt.bar(r2, sub_data2, width=barWidth, color=colors[1])\n",
    "plt.bar(r3, sub_data3, width=barWidth, color=colors[2])\n",
    "plt.bar(r4, sub_data4, width=barWidth, color=colors[3])\n",
    "plt.bar(r5, sub_data5, width=barWidth, color=colors[4])\n",
    "    \n",
    "patches = []\n",
    "\n",
    "#for i in range(num_methods):\n",
    "#        patches.append(mpatches.Patch(color=colors[i], label=labels[i]))\n",
    "#        plt.legend(handles=patches, loc='best',  \n",
    "#                  fontsize='x-small')\n",
    "        \n",
    "plt.xticks([r + barWidth for r in range(len(sub_data1))], [ticks[3], ticks[4]], size=13)\n",
    "ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "ax.yaxis.grid(linestyle='--')\n",
    "#plt.legend(loc='best')\n",
    "plt.savefig('../iclr_plots/grouped_lll_awa_time_memory.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['C0', 'm', 'C1', 'b', 'r']\n",
      "['VAN', 'EWC', 'A-GEM', 'MEGA-1', 'MEGA-2']\n"
     ]
    }
   ],
   "source": [
    "plt.clf()\n",
    "labels = ['VAN',  'EWC',  'A-GEM', 'MEGA-1', 'MEGA-2']\n",
    "colors = ['C0', 'm', 'C1',  'b', 'r']\n",
    "fig = plt.figure(figsize=(12,1))\n",
    "patches = []m\n",
    "print (colors)\n",
    "print (labels)\n",
    "for i in range(num_methods):\n",
    "        patches.append(mpatches.Patch(color=colors[i], label=labels[i]))\n",
    "        plt.legend(handles=patches, loc=2, borderaxespad=0.6, \n",
    "                   fontsize='x-large', ncol=5)\n",
    "plt.axis('off')\n",
    "#plt.show()\n",
    "plt.savefig('../iclr_plots/cub_awa_legend.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 2",
   "language": "python",
   "name": "python2"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
