{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%autoreload\n",
    "import warnings\n",
    "import os\n",
    "import time\n",
    "\n",
    "import math as m\n",
    "import numpy as np\n",
    "np.random.seed(1)\n",
    "\n",
    "from save_results import ResultSaver\n",
    "\n",
    "from model_definitions import load_task\n",
    "from measures import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def results(task,metric):\n",
    "    result_saver = ResultSaver('results_'+task+'.p')\n",
    "    result_metrics_saver = ResultSaver('results_metrics_'+task+'_'+metric+'.p')\n",
    "    return result_saver, result_metrics_saver"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_metric(task,param,metric):    \n",
    "    get_model, x_train, y_train, suby_train, x_test, y_test, suby_test = load_task(task)\n",
    "    if metric == 'sharpness_worstcase_0':\n",
    "        model = get_model(param['depth_factor'],param['width_factor'],dropout=0.,weight_decay = 0.,\n",
    "                          batchnorm_train_mode = 0)\n",
    "    else:\n",
    "        model = get_model(param['depth_factor'],param['width_factor'],dropout=0.,weight_decay = 0.)\n",
    "        \n",
    "    model.load_weights('saved_weights/'+task+'/'+str([str(key)+':'+str(param[key]) for key in sorted(param)])+'.h5')\n",
    "    \n",
    "    if metric == 'neural_subclass_selectivity':\n",
    "        m = neural_subclass_selectivity(model,x_train,y_train,suby_train, data_subset = 1.,subclass_agg='median',preact=True)\n",
    "    elif metric == 'layer_subclass_clustering':    \n",
    "        m=layer_subclass_clustering(model,x_train,y_train,suby_train, batch_size = 128,training_phase = 0, \n",
    "                                    data_subset = 1.,layerwise = False,subclass_agg='median',preact=False)\n",
    "    elif metric == 'neural_intraclass_selectivity':    \n",
    "        k_neuron = {'C100coarse-WRN':30,'C10-VGG':30, 'C100-WRN':30}\n",
    "        m=neural_intraclass_selectivity(model,x_train,y_train, data_subset = 1.,k_neuron=k_neuron[task],\n",
    "                                        subclass_agg='mean', preact = True)\n",
    "    elif metric == 'layer_intraclass_clustering':    \n",
    "        k_layer = {'C100coarse-WRN':5,'C10-VGG':1, 'C100-WRN':5}\n",
    "        m=layer_intraclass_clustering(model,x_train,y_train, data_subset = .5,k_layer=k_layer[task],\n",
    "                                        subclass_agg='mean', preact=True)\n",
    "        \n",
    "    elif metric == 'sharpness_random_0':\n",
    "        m = sharpness_random(model,x_train,y_train, data_subset = .1, epsilon_weight_scale = 1e-3, nb_samplings = 10, \n",
    "                     kernel_only = False, training_phase = 0, batch_size = 300)\n",
    "    elif metric == 'sharpness_random_1':\n",
    "        m = sharpness_random(model,x_train,y_train, data_subset = .1, epsilon_weight_scale = 1e-3, nb_samplings = 10, \n",
    "                     kernel_only = True, training_phase = 1, batch_size = 300)\n",
    "        \n",
    "    elif metric == 'sharpness_worstcase_1':\n",
    "        m = sharpness_worstcase(model,x_train,y_train, data_subset = .1, epsilon_weight_scale = 1e-3, \n",
    "                                kernel_only = True, training_phase = 1,\n",
    "                                batch_size = 300, epochs = 6,lr = 10.,noise = False)\n",
    "    elif metric == 'sharpness_worstcase_0':\n",
    "        m = sharpness_worstcase(model,x_train,y_train, data_subset = .2, epsilon_weight_scale = 1e-3, \n",
    "                                kernel_only = False, training_phase = 0,\n",
    "                                batch_size = 300, epochs = 6,lr = 1.,noise = False)\n",
    "    \n",
    "    return m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "task = 'C100coarse-WRN'\n",
    "metric = 'neural_intraclass_selectivity'\n",
    "\n",
    "result_saver, result_metrics_saver = results(task,metric)\n",
    "\n",
    "results_models = result_saver.load_results()\n",
    "params = [dict(param) for param in results_models.keys()]\n",
    "# params = np.random.choice(params,40,replace = False)\n",
    "print(len(params))\n",
    "\n",
    "results_metrics = result_metrics_saver.load_results()\n",
    "\n",
    "res = {}\n",
    "for i,param in enumerate(params):\n",
    "    if frozenset(param.items()) not in results_metrics.keys():\n",
    "        start =time.time()\n",
    "        m = compute_metric(task,param,metric)\n",
    "        t = time.time()-start\n",
    "        print(i,t)\n",
    "        \n",
    "        res.update({frozenset(param.items()):{'metric':m,'time':t}})\n",
    "        \n",
    "        if i%40==0 or i==5:\n",
    "            result_metrics_saver.update_results([],res)\n",
    "        K.clear_session()\n",
    "        \n",
    "result_metrics_saver.update_results([],res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Evaluate matrics using Kendall coefficient"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from kendall_coefficient import kendall_coeff, granulated_kendall_coeff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "task = 'C100coarse-WRN'\n",
    "metrics = ['neural_subclass_selectivity','layer_subclass_clustering',\n",
    "           'neural_intraclass_selectivity','layer_intraclass_clustering',\n",
    "           'sharpness_random_0','sharpness_random_1',\n",
    "           'sharpness_worstcase_0','sharpness_worstcase_1']\n",
    "hyperparams = ['lr','batch_size','weight_decay','optimizer','dropout','data_augmentation','width_factor','depth_factor']\n",
    "\n",
    "results_models = load_results_models(task).load_results()\n",
    "\n",
    "params = [dict(param) for param in results_models.keys()]\n",
    "if task == 'C10-VGG':\n",
    "    params = [param for param in params if param['dropout']!=0.4]\n",
    "\n",
    "for i,metric in enumerate(metrics):\n",
    "    results_metrics = load_results_metrics(task,metric).load_results()\n",
    "    \n",
    "    test_performances = []\n",
    "    metric_values = []\n",
    "    for param in params:\n",
    "        test_performances.append(results_models[frozenset(param.items())]['test_performance'][-1])\n",
    "        if 'sharpness' in metric:\n",
    "            m = results_metrics[frozenset(param.items())]['metric']\n",
    "            metric_values.append(m[0])\n",
    "        else:\n",
    "            metric_values.append(results_metrics[frozenset(param.items())]['metric'])\n",
    "\n",
    "    coeffs = granulated_kendall_coeff(metric_values,test_performances,params)\n",
    "    \n",
    "    # display results in a string that can be copied for filling a Latex table\n",
    "    string_results = ''\n",
    "    mean = 0\n",
    "    for key in hyperparams:\n",
    "        string_results+= str(round(coeffs[key],2)) + ' & '\n",
    "        mean+=coeffs[key]\n",
    "    print(string_results + str(round(mean/len(hyperparams),2)))\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
