{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import os\n",
    "import glob\n",
    "import pickle\n",
    "import utilities as utils\n",
    "import re\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "COMPLETE_DIR = os.path.join(os.path.dirname(os.getcwd()), 'jobs', 'completed')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "result_getter = utils.collect_result_outs\n",
    "vanilla_results = result_getter('2DTRAIN*vanilla*GLOBAL.result')\n",
    "lipreg_results = result_getter('2DTRAIN*LipReg*GLOBAL.result')\n",
    "\n",
    "#global_results = sorted(glob.glob(os.path.join(COMPLETE_DIR, 'simple2D*GLOBAL.result')))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for pairs, c in [(vanilla_results, 'r'), (lipreg_results, 'b')]:\n",
    "    epochs = utils.collect_epochs([_[0] for _ in pairs])\n",
    "    values = utils.data_from_results([_[1] for _ in pairs], 'do_unit_hypercube_eval', 'LipProblem')\n",
    "    plt.scatter(epochs, values, c=c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#seq_job_outs = utils.read_result_files(wideseq_results)\n",
    "def epoch_collector(filename):\n",
    "    return int(re.search('EPOCH\\d{4}', filename).group()[-4:])\n",
    "\n",
    "\n",
    "def make_hcube_series(result_list, lip_estimator):\n",
    "    epochs = []\n",
    "    values = []\n",
    "    for filename, res_obj in result_list:\n",
    "        epochs.append(epoch_collector(filename))\n",
    "        values.append(res_obj['do_unit_hypercube_eval'].values(lip_estimator))\n",
    "    return epochs, values\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# True output \n",
    "\n",
    "\n",
    "result_colors = [(vanilla_results, 'r'), (l2_results, 'b'), (l1_results, 'g'), (fgsm_results, 'y')]\n",
    "for result, c in result_colors:\n",
    "    epochs, values = make_hcube_series(result, 'LipProblem')\n",
    "    plt.scatter(epochs, values, c=c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "hcube_getter = lambda k: utils.job_out_series([_[1] for _ in seq_job_outs], 'do_unit_hypercube_eval', k)\n",
    "cs = 'bgrcmy'\n",
    "xs = [20 * (_+1) for _ in range(len(seq_job_outs))]\n",
    "for i, k in enumerate(['LipProblem', 'FastLip', 'LipLP', 'SeqLip', 'LipSDP']):#, 'NaiveUB']):\n",
    "    plt.scatter(xs, hcube_getter(k), c=cs[i])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "simple_job_outs = [(utils.filename_to_epoch(_[0]), _[1]) for _ in utils.read_result_files(simple_results)]\n",
    "penalty_job_outs = [(utils.filename_to_epoch(_[0]), _[1]) for _ in utils.read_result_files(l2_results)]\n",
    "simple_epochs = [_[0] for _ in simple_job_outs]\n",
    "penalty_epochs = [_[0] for _ in penalty_job_outs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "random_getter = lambda k: [utils.job_out_series([_[1] for _ in job_outs], 'do_random_evals', k)\n",
    "                           for job_outs in [simple_job_outs, penalty_job_outs]]\n",
    "\n",
    "hcube_getter = lambda k: [utils.job_out_series([_[1] for _ in job_outs], 'do_unit_hypercube_eval', k)\n",
    "                          for job_outs in [simple_job_outs, penalty_job_outs]]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter([_[0] for _ in simple_job_outs], random_getter('LipProblem')[0], c='r')\n",
    "plt.scatter([_[0] for _ in penalty_job_outs], random_getter('LipProblem')[1], c='b')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "epochs = [_[0] for _ in simple_job_outs]\n",
    "cs = ['r', 'g', 'b']\n",
    "for i, key in enumerate(['FastLip', 'LipLP', 'LipProblem']):\n",
    "    plt.scatter(epochs, random_getter(key)[1], c=cs[i])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "simple_true, l2_true = hcube_getter('LipProblem')\n",
    "plt.scatter(simple_epochs, simple_true, c='r')\n",
    "plt.scatter(penalty_epochs, l2_true, c='b')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "keyc = [('FastLip', 'b'), ('LipLP', 'r'), ('LipProblem', 'g')]\n",
    "epochs = [_[0] for _ in local_job_outs]\n",
    "for key, c in keyc:\n",
    "    plt.scatter(epochs, random_getter(key), c=c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_getter = lambda k: utils.job_out_series([_[1] for _ in local_job_outs], 'do_data_evals', k)\n",
    "keyc = [('FastLip', 'b'), ('LipLP', 'r'), ('LipProblem', 'g')]\n",
    "epochs = [_[0] for _ in local_job_outs]\n",
    "for key, c in keyc:\n",
    "    plt.scatter(epochs, data_getter(key), c=c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Local vs Global LipMIP\n",
    "local_mip = random_getter('LipProblem')\n",
    "global_mip = utils.job_out_series([_[1] for _ in local_job_outs], 'do_unit_hypercube_eval', 'LipProblem')\n",
    "for key, c in [(local_mip, 'r'), (global_mip, 'b')]:\n",
    "    plt.scatter(epochs, key, c=c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "epochs = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "local_job_outs[0][1]['do_random_evals'].average_stdevs('value')['Fast']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "result_objs = []\n",
    "for result_file in sorted(results):\n",
    "    try:\n",
    "        with open(result_file, 'rb') as f:\n",
    "            result_objs.append((result_file, pickle.load(f)))\n",
    "    except Exception as err:\n",
    "        print(\"FAILED ON %s\" % result_file, err)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "result_objs[0][1]['do_random_evals'].average_stdevs('value')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "values_arr = [result_obj[1]['do_unit_hypercube_eval'].values() for result_obj in result_objs]\n",
    "xs = [int(_[0].split('_')[1][-4:]) for _ in result_objs]\n",
    "get_hcube_series = lambda k: [_[k] for _ in values_arr]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "job_outs = [_[1] for _ in result_objs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "utils.job_out_series(job_outs, 'do_unit_hypercube_eval', 'LipProblem')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "hcube_series = lambda k: utils.job_out_series(job_outs, 'do_unit_hypercube_eval', k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "result_objs[0][1]['do_unit_hypercube_eval'].compute_times()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter(xs, hcube_series('FastLip'), c='b')\n",
    "plt.scatter(xs, hcube_series('LipLP'), c='r')\n",
    "plt.scatter(xs, hcube_series('LipProblem'), c='g')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "random_avgs = [result_obj[1]['do_random_evals'].average_stdevs('value') for result_obj in result_objs]\n",
    "get_random_series = lambda k: [_[k][0] for _ in random_avgs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter(xs, get_random_series('FastLip'), c='b')\n",
    "plt.scatter(xs, get_random_series('LipLP'), c='r')\n",
    "plt.scatter(xs, get_random_series('LipProblem'), c='g')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter(xs, get_random_series('LipProblem'), c='b')\n",
    "plt.scatter(xs, get_hcube_series('LipProblem'), c='r')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "re.search('_EPOCH\\d+_', 'test_file_EPOCH123_').group()[6:-1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
