{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5b963770",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os \n",
    "\n",
    "# Define a function to load and parse test result files\n",
    "def load_test_results(file_path_prefix):\n",
    "    try:\n",
    "        # Get the directory from the file path prefix\n",
    "        directory = os.path.dirname(file_path_prefix)\n",
    "        # Get the base filename from the file path prefix\n",
    "        base_filename = os.path.basename(file_path_prefix)\n",
    "\n",
    "        # Find the file that starts with the base filename\n",
    "        matching_files = [f for f in os.listdir(directory) if f.startswith(base_filename)]\n",
    "\n",
    "        if not matching_files:\n",
    "            print(f\"Error: No file found in {directory} starting with {base_filename}\")\n",
    "            return None\n",
    "\n",
    "        # Assuming only one file matches the prefix\n",
    "        file_path = os.path.join(directory, matching_files[0])\n",
    "\n",
    "        with open(file_path, 'r') as f:\n",
    "            data = json.load(f)\n",
    "        return data\n",
    "    except Exception as e:\n",
    "        print(f\"Error loading {file_path}: {e}\")\n",
    "        return None\n",
    "\n",
    "def calculate_stats(results):\n",
    "    \"\"\"\n",
    "    Calculates and prints statistics for results.\n",
    "\n",
    "    Args:\n",
    "        results (dict): Dictionary containing results.\n",
    "    \"\"\"\n",
    "    vio = results['test_eq_violation'] + results['test_ineq_violation']\n",
    "\n",
    "    vio_mean = np.mean(vio)\n",
    "    vio_mean_std = np.std(vio)\n",
    "\n",
    "    vio_max = np.max(vio)\n",
    "    vio_max_std = np.std(vio)\n",
    "\n",
    "    opt_gap = results['opt_gap']\n",
    "\n",
    "    opt_gap_mean = 100*np.mean(opt_gap)\n",
    "    opt_gap_mean_std = 100*np.std(opt_gap)\n",
    "    opt_gap_max = 100*np.max(opt_gap)\n",
    "    opt_gap_max_std = 100*np.std(opt_gap)\n",
    "\n",
    "    time = results['test_time']\n",
    "    time_mean = np.mean(time)\n",
    "    time_mean_std = np.std(time)\n",
    "    \n",
    "    print(f\"Total violation: {vio_mean:.1e} ± {vio_mean_std:.1e}\")\n",
    "    print(f\"Max violation: {vio_max:.1e} ± {vio_max_std:.1e}\")\n",
    "    print(f\"Total opt gap: {opt_gap_mean:.3f} ± {opt_gap_mean_std:.3f}\")\n",
    "    print(f\"Max opt gap: {opt_gap_max:.3f} ± {opt_gap_max_std:.3f}\")\n",
    "    print(f\"Total time: {time_mean:.3f} ± {time_mean_std:.3f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "27070502",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total violation: 2.7e+00 ± 2.3e+00\n",
      "Max violation: 8.1e+00 ± 2.3e+00\n",
      "Total opt gap: 145.272 ± 5.938\n",
      "Max opt gap: 170.018 ± 5.938\n",
      "Total time: 0.289 ± 0.000\n"
     ]
    }
   ],
   "source": [
    "method = \"adaptive_penalty\"\n",
    "prob_type = \"nonsmooth_nonconvex\"\n",
    "prob_name = \"qcqp\"\n",
    "seed = 2025\n",
    "batch = 2000\n",
    "\n",
    "if prob_type == \"convex\":\n",
    "    dir_path = f\"{prob_type}/{prob_name}/{prob_name.upper()}Problem-100-50-50-10000/MLP_{method}/test_results_seed{seed}_batch{batch}_\"\n",
    "else:\n",
    "    dir_path = f\"{prob_type}/{prob_name}/{prob_type}{prob_name.upper()}Problem-100-50-50-10000/MLP_{method}/test_results_seed{seed}_batch{batch}_\"\n",
    "\n",
    "\n",
    "results = load_test_results(dir_path)\n",
    "calculate_stats(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba2b5bef",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d33e08b0",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'nonsmooth_nonconvex\\\\\\\\socp\\\\\\\\nonsmooth_nonconvexSOCPProblem-100-50-50-10000\\\\\\\\MLP_penalty\\\\\\\\test_results_seed2025_batch2000_20250523_012212.txt'",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[31], line 4\u001b[0m\n\u001b[0;32m      2\u001b[0m result_save_path \u001b[38;5;241m=\u001b[39m \u001b[38;5;124mr\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mnonsmooth_nonconvex\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124msocp\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mnonsmooth_nonconvexSOCPProblem-100-50-50-10000\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mMLP_penalty\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mtest_results_seed2025_batch2000_20250523_012212.txt\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m      3\u001b[0m os\u001b[38;5;241m.\u001b[39mmakedirs(os\u001b[38;5;241m.\u001b[39mpath\u001b[38;5;241m.\u001b[39mdirname(result_save_path), exist_ok\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[1;32m----> 4\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mresult_save_path\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mw\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m f:\n\u001b[0;32m      5\u001b[0m     json\u001b[38;5;241m.\u001b[39mdump({\n\u001b[0;32m      6\u001b[0m     \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtest_obj\u001b[39m\u001b[38;5;124m\"\u001b[39m: \u001b[38;5;241m11\u001b[39m\n\u001b[0;32m      7\u001b[0m     }, f, indent\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m4\u001b[39m)\n",
      "File \u001b[1;32mc:\\Users\\hoang\\anaconda3\\envs\\OPT\\Lib\\site-packages\\IPython\\core\\interactiveshell.py:324\u001b[0m, in \u001b[0;36m_modified_open\u001b[1;34m(file, *args, **kwargs)\u001b[0m\n\u001b[0;32m    317\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m file \u001b[38;5;129;01min\u001b[39;00m {\u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m2\u001b[39m}:\n\u001b[0;32m    318\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[0;32m    319\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mIPython won\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mt let you open fd=\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mfile\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m by default \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    320\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mas it is likely to crash IPython. If you know what you are doing, \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    321\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124myou can use builtins\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m open.\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    322\u001b[0m     )\n\u001b[1;32m--> 324\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mio_open\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfile\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[1;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'nonsmooth_nonconvex\\\\\\\\socp\\\\\\\\nonsmooth_nonconvexSOCPProblem-100-50-50-10000\\\\\\\\MLP_penalty\\\\\\\\test_results_seed2025_batch2000_20250523_012212.txt'"
     ]
    }
   ],
   "source": [
    "import os\n",
    "result_save_path = 'nonsmooth_nonconvex\\\\socp\\\\nonsmooth_nonconvexSOCPProblem-100-50-50-10000\\\\MLP_penalty\\\\test_results_seed2025_batch2000_20250523_012212.txt'\n",
    "os.makedirs(os.path.dirname(result_save_path), exist_ok=True)\n",
    "with open(result_save_path, 'w') as f:\n",
    "    json.dump({\n",
    "    \"test_obj\": 11\n",
    "    }, f, indent=4)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fnn_opt",
   "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
