{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d090002b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3326f4ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "def results(runs:list):\n",
    "    \"\"\"\n",
    "    Function to process and print results from multiple runs of a model.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    runs : list\n",
    "        List of file paths to the run data files.\n",
    "    \"\"\"\n",
    "\n",
    "    opt_values = []\n",
    "    residual_max = []\n",
    "    residual_avg = []\n",
    "    inference_times = []\n",
    "    training_times = []\n",
    "\n",
    "    for run in runs:\n",
    "        with open(run, 'rb') as file:\n",
    "            data = pickle.load(file)\n",
    "        opt_values.append(data['test_loss'][-1].mean())\n",
    "        residual_max.append(data['test_eq_max'][-1].mean())\n",
    "        residual_avg.append(data['test_eq_mean'][-1].mean())\n",
    "        inference_times.append(data['test_time'][-1])\n",
    "        training_times.append(data['train_time'].sum())\n",
    "\n",
    "    print(f'objective value: {np.array(opt_values).mean():.2f} ({np.array(opt_values).std():.2f})')\n",
    "    print(f'max residual: {np.array(residual_max).mean():.2f} ({np.array(residual_max).std():.2f})')\n",
    "    print(f'avg residual: {np.array(residual_avg).mean():.2f} ({np.array(residual_avg).std():.2f})')\n",
    "    print(f'inference time: {np.array(inference_times).mean():.3f} ({np.array(inference_times).std():.3f})')\n",
    "    print(f'training time: {np.array(training_times).mean():.2f} ({np.array(training_times).std():.2f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0115cdef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "EXPERIMENT N_C = 50, N_O = 100\n",
      "objective value: -10.31 (0.07)\n",
      "max residual: 0.00 (0.00)\n",
      "avg residual: 0.00 (0.00)\n",
      "inference time: 0.003 (0.000)\n",
      "training time: 1377.75 (223.78)\n"
     ]
    }
   ],
   "source": [
    "print(\"EXPERIMENT N_C = 50, N_O = 100\")\n",
    "runs = [\n",
    "    r'results\\NonconvexProblem-100-0-50-10000\\method\\a72798119498701b77841427dbaa9483f8df6c6e\\1746992416-325208\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-50-10000\\method\\a72798119498701b77841427dbaa9483f8df6c6e\\1746992440-012178\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-50-10000\\method\\a72798119498701b77841427dbaa9483f8df6c6e\\1746992452-0663805\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-50-10000\\method\\b9fd569e04242547bddd09d51250300a8671bb10\\1747000429-6101992\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-50-10000\\method\\a72798119498701b77841427dbaa9483f8df6c6e\\1747036943-811023\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-50-10000\\method\\a72798119498701b77841427dbaa9483f8df6c6e\\1747036958-948415\\stats.dict'\n",
    "]\n",
    "results(runs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fd18cbc6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "EXPERIMENT N_C = 70, N_O = 100\n",
      "objective value: -2.76 (0.06)\n",
      "max residual: 0.00 (0.00)\n",
      "avg residual: 0.00 (0.00)\n",
      "inference time: 0.002 (0.000)\n",
      "training time: 1234.43 (498.22)\n"
     ]
    }
   ],
   "source": [
    "print(\"EXPERIMENT N_C = 70, N_O = 100\")\n",
    "runs = [\n",
    "    r'results\\NonconvexProblem-100-0-70-10000\\method\\85f65e740239770e07812bcf4bc1de212eff8794\\1747076494-8687587\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-70-10000\\method\\85f65e740239770e07812bcf4bc1de212eff8794\\1747080147-6740105\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-70-10000\\method\\85f65e740239770e07812bcf4bc1de212eff8794\\1747080154-6743784\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-70-10000\\method\\85f65e740239770e07812bcf4bc1de212eff8794\\1747086240-9441245\\stats.dict',\n",
    "    r'results\\NonconvexProblem-100-0-70-10000\\method\\85f65e740239770e07812bcf4bc1de212eff8794\\1747086248-502801\\stats.dict',\n",
    "]\n",
    "results(runs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c8d43c86",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "EXPERIMENT N_C = 150, N_O = 200\n",
      "objective value: -6.27 (0.07)\n",
      "max residual: 0.00 (0.00)\n",
      "avg residual: 0.00 (0.00)\n",
      "inference time: 0.004 (0.000)\n",
      "training time: 1511.03 (517.57)\n"
     ]
    }
   ],
   "source": [
    "print(\"EXPERIMENT N_C = 150, N_O = 200\")\n",
    "runs = [\n",
    "    r'results\\NonconvexProblem-200-0-150-10000\\method\\9f427d925e0db17fdd073ffa001763a2981dbae2\\1747060624-2833443\\stats.dict',\n",
    "    r'results\\NonconvexProblem-200-0-150-10000\\method\\9f427d925e0db17fdd073ffa001763a2981dbae2\\1747065023-638537\\stats.dict',\n",
    "    r'results\\NonconvexProblem-200-0-150-10000\\method\\9f427d925e0db17fdd073ffa001763a2981dbae2\\1747069960-8965888\\stats.dict',\n",
    "    r'results\\NonconvexProblem-200-0-150-10000\\method\\9f427d925e0db17fdd073ffa001763a2981dbae2\\1747086352-0643601\\stats.dict',\n",
    "    r'results\\NonconvexProblem-200-0-150-10000\\method\\9f427d925e0db17fdd073ffa001763a2981dbae2\\1747086418-307028\\stats.dict',\n",
    "]\n",
    "results(runs)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv_dc3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
