{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "============--------------------------------- case500----------------------------=================\n",
      "\n",
      "\n",
      "BNN Type        Flag   Config Info     Percentage Cost Error     Eq Gap Mean  Eq Gap Max   Ineq Gap Max Ineq Gap Mean\n",
      "---------------------------------------------------------------------------------------------------------------------\n",
      "Sandwich        Mean   10-Min          2.002923                  0.056016     0.781374     0.19160591   0.0004936412\n",
      "Supervised      Mean   10-Min          1.1914005                 0.072989     2.401997     0.14071675   0.00039994423\n",
      "Sandwich        SvP    10-Min          2.0092602                 0.066257     0.770566     0.190464     0.00049     \n",
      "Supervised      SvP    10-Min          1.1910311                 0.088526     2.204773     0.141483     0.000402    \n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import glob\n",
    "import re\n",
    "import pandas as pd\n",
    "def read_and_store_results(file):\n",
    "    \"\"\"\n",
    "    Reads a .pkl file and extracts all relevant results, storing them in a dictionary.\n",
    "\n",
    "    Parameters:\n",
    "    - file (str): The path to the .pkl file.\n",
    "\n",
    "    Returns:\n",
    "    - results (dict): A dictionary containing all relevant extracted values.\n",
    "    \"\"\"\n",
    "    # Initialize the results dictionary\n",
    "    results_mean = {}\n",
    "    results_svp ={}\n",
    "    results ={}\n",
    "    # Load the .pkl file\n",
    "    try:\n",
    "        with open(file, 'rb') as f:\n",
    "            R = pickle.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Error loading file {file}: {e}\")\n",
    "        return None\n",
    "\n",
    "    # Try to extract all fields, handling missing fields using KeyError\n",
    "    try:\n",
    "        # Extract Percentage Cost Errors\n",
    "        results_mean['Percentage Cost Error (Mean)'] = R.get('Percentage Cost Error (Mean)', None)\n",
    "        results_mean['Eq Gap Max (Mean)'] = R.get('Eq Gap Max (Mean)', None)\n",
    "        results_mean['Eq Gap Mean (Mean)'] = R.get('Eq Gap Mean (Mean)', None)\n",
    "        results_mean['Ineq Gap Max (Mean)'] = R.get('Ineq Gap Max (Mean)', None)\n",
    "        results_mean['Ineq Gap Mean (Mean)'] = R.get('Ineq Gap Mean (Mean)', None)\n",
    "\n",
    "        # Best Cost, Lagrangian, and Eq/Ineq Gaps\n",
    "        results['Percentage Cost Error (Best Cost)'] = R.get('Percentage Cost Error (Best Cost)', None)\n",
    "        results['Percentage Cost Error (Best Lagrangian)'] = R.get('Percentage Cost Error (Best Lagrangian)', None)\n",
    "        results_svp['Percentage Cost Error (Best Eq Gap)'] = R.get('Percentage Cost Error (Best Eq Gap)', None)\n",
    "        results['Percentage Cost Error (Best Ineq Gap)'] = R.get('Percentage Cost Error (Best Ineq Gap)', None)\n",
    "\n",
    "        # Best Indices\n",
    "        results['Best Cost Index'] = R.get('Best Cost Index', None)\n",
    "        results['Best Lagrangian Index'] = R.get('Best Lagrangian Index', None)\n",
    "        results['Best Eq Gap Norm Index'] = R.get('Best Eq Gap Norm Index', None)\n",
    "        results['Best Ineq Gap Norm Index'] = R.get('Best Ineq Gap Norm Index', None)\n",
    "\n",
    "        # Costs\n",
    "        results['Cost (Best Cost)'] = R.get('Cost (Best Cost)', None)\n",
    "        results['Cost (Best Lagrangian)'] = R.get('Cost (Best Lagrangian)', None)\n",
    "        results_svp['Cost (Best Eq Gap)'] = R.get('Cost (Best Eq Gap)', None)\n",
    "\n",
    "        # Eq Gaps\n",
    "        results['Eq Gap (Best Cost)'] = R.get('Eq Gap (Best Cost)', None)\n",
    "        results['Eq Gap (Best Lagrangian)'] = R.get('Eq Gap (Best Lagrangian)', None)\n",
    "        results_svp['Eq Gap (Best Eq Gap)'] = R.get('Eq Gap (Best Eq Gap)', None)\n",
    "\n",
    "        # Ineq Gaps\n",
    "        results['Ineq Gap Mean (Best Lagrangian)'] = R.get('Ineq Gap Mean (Best Lagrangian)', None)\n",
    "        results['Ineq Gap Max (Best Lagrangian)'] = R.get('Ineq Gap Max (Best Lagrangian)', None)\n",
    "        results['Eq Gap Max (Best Lagrangian)'] = R.get('Eq Gap Max (Best Lagrangian)', None)\n",
    "        results_svp['Eq Gap Mean (Best Eq Gap)'] = R.get('Eq Gap Mean (Best Eq Gap)', None)\n",
    "        results_svp['Eq Gap Max (Best Eq Gap)'] = R.get('Eq Gap Max (Best Eq Gap)', None)\n",
    "        results_svp['Ineq Gap Max (Best Eq Gap)'] = R.get('Ineq Gap Max (Best Eq Gap)', None)\n",
    "        results_svp['Ineq Gap Mean (Best Eq Gap)'] = R.get('Ineq Gap Mean (Best Eq Gap)', None)\n",
    "        results['All_error'] = R.get('A',None) - R.get('Y_test',None)\n",
    "        results['Mean_error'] = R.get('y_predict_mean',None) - R.get('Y_test',None)\n",
    "    except KeyError as e:\n",
    "        print(f\"KeyError: {e} is missing in the file {file}\")\n",
    "    \n",
    "    return results,results_svp,results_mean\n",
    "\n",
    "\n",
    "# Function to process and store all results\n",
    "def process_all_results(files, pattern):\n",
    "    \"\"\"\n",
    "    Process only the .pkl files that match the specified pattern and store pattern-based metadata.\n",
    "\n",
    "    Parameters:\n",
    "    - files (list): List of .pkl files to process.\n",
    "    - pattern (str): Regular expression pattern to match filenames.\n",
    "\n",
    "    Returns:\n",
    "    - all_results (list): A list of dictionaries containing the results and metadata for each matched file.\n",
    "    \"\"\"\n",
    "    all_results = []\n",
    "    all_results_mean = []\n",
    "    all_results_svp = []\n",
    "    # Compile the regex pattern\n",
    "    regex = re.compile(pattern)\n",
    "\n",
    "    for file in files:\n",
    "        # Check if the file matches the pattern\n",
    "        match = regex.search(file)\n",
    "        if match:\n",
    "            # Process and read the results from the file\n",
    "            result,results_svp,results_mean = read_and_store_results(file)\n",
    "            if result:\n",
    "                # Extract metadata from the filename\n",
    "                extracted_info = extract_info_from_filename(file)\n",
    "                \n",
    "                # Add metadata to the result dictionary\n",
    "                results_mean['File Name'] = file\n",
    "                results_mean['Flag'] = 'Mean'\n",
    "                results_svp['File Name'] = file\n",
    "                results_svp['Flag'] = 'SvP'\n",
    "                result['File Name'] = file\n",
    "                results_svp.update(extracted_info)  # Add pattern-based info to the result\n",
    "                results_mean.update(extracted_info)  # Add pattern-based info to the result\n",
    "                result.update(extracted_info)  # Add pattern-based info to the result\n",
    "\n",
    "                # Append the result with identification metadata\n",
    "                all_results.append(result)\n",
    "                all_results_mean.append(results_mean)\n",
    "                all_results_svp.append(results_svp)\n",
    "        # else:\n",
    "            # print(f\"File {file} does not match the pattern. Skipping.\")\n",
    "\n",
    "    return all_results,all_results_svp,all_results_mean\n",
    "\n",
    "def extract_info_from_filename(filename):\n",
    "    \"\"\"\n",
    "    Extract pattern-based information from the filename for identification.\n",
    "\n",
    "    Parameters:\n",
    "    - filename (str): The full filename.\n",
    "\n",
    "    Returns:\n",
    "    - extracted_info (dict): Dictionary containing extracted metadata (like config, supervised/semisupervised).\n",
    "    \"\"\"\n",
    "    base_filename = filename.split('/')[-1]  # Get the base filename\n",
    "\n",
    "    # Extract relevant parts from the filename\n",
    "    if 'semisupervisedBNN' in base_filename:\n",
    "        bnn_type = 'Sandwich'\n",
    "    elif 'supervisedBNN' in base_filename:\n",
    "        bnn_type = 'Supervised'\n",
    "    else:\n",
    "        bnn_type = 'Unknown BNN type'\n",
    "\n",
    "    # Extract config info\n",
    "    config_info = 'Unknown config'\n",
    "    if 'config_1' in base_filename:\n",
    "        config_info = '20-Min'\n",
    "    elif 'config_2' in base_filename:\n",
    "        config_info = '10-Min'\n",
    "    elif 'config' in base_filename:\n",
    "        config_info = 'config'\n",
    "\n",
    "    return {\n",
    "        'BNN Type': bnn_type,\n",
    "        'Config Info': config_info\n",
    "    }\n",
    "\n",
    "\n",
    "def convert_results_to_dataframes(all_results):\n",
    "    \"\"\"\n",
    "    Converts a list of result dictionaries to a list of pandas DataFrames.\n",
    "\n",
    "    Parameters:\n",
    "    - all_results (list): List of dictionaries where each dictionary contains extracted results.\n",
    "\n",
    "    Returns:\n",
    "    - dataframes (list): List of DataFrames where each DataFrame corresponds to a dictionary.\n",
    "    \"\"\"\n",
    "    dataframes = []\n",
    "    for result in all_results:\n",
    "        df = pd.DataFrame([result])  # Convert dictionary to a single-row DataFrame\n",
    "        dataframes.append(df)\n",
    "    \n",
    "    return dataframes\n",
    "\n",
    "\n",
    "# Example Usage\n",
    "# Define the pattern you want to match in filenames\n",
    "pattern = r\"pglib_opf_case500_goc_.*(supervisedBNN|semisupervisedBNN)_config.*\\.pkl\"\n",
    "\n",
    "# Find all .pkl files in the directory\n",
    "files = glob.glob('/Users/pareek/Documents/Codes/BNN-OPF/results/*.pkl')\n",
    "\n",
    "\n",
    "# Process only the files that match the pattern\n",
    "all_results,all_results_svp,all_results_mean = process_all_results(files, pattern)\n",
    "\n",
    "# Convert results to a list of DataFrames\n",
    "dataframes = convert_results_to_dataframes(all_results)\n",
    "df_svp = convert_results_to_dataframes(all_results_svp)\n",
    "df_mean = convert_results_to_dataframes(all_results_mean)\n",
    "\n",
    "match = re.search(r'case(\\d+)', all_results_mean[0]['File Name'])\n",
    "\n",
    "# Check if a match is found\n",
    "if match:\n",
    "    case_number = match.group(0)\n",
    "    print(f'============--------------------------------- {case_number}----------------------------=================')  # Output: case118\n",
    "print('\\n')\n",
    "# Define column headers\n",
    "header = f\"{'BNN Type':<15} {'Flag':<6} {'Config Info':<15} {'Percentage Cost Error':<25} {'Eq Gap Mean':<12} {'Eq Gap Max':<12} {'Ineq Gap Max':<12} {'Ineq Gap Mean':<12}\"\n",
    "\n",
    "# Print the header\n",
    "print(header)\n",
    "print('-' * len(header))  # Print a separator line\n",
    "\n",
    "# Loop through the dataframes and print Mean results\n",
    "for k in range(len(df_mean)):\n",
    "    # Format the mean results with 'Mean' as the flag\n",
    "    row = df_mean[k][['BNN Type', 'Flag',\n",
    "                      'Config Info', \n",
    "                      'Percentage Cost Error (Mean)', \n",
    "                      'Eq Gap Mean (Mean)', \n",
    "                      'Eq Gap Max (Mean)', \n",
    "                      'Ineq Gap Max (Mean)', \n",
    "                      'Ineq Gap Mean (Mean)']].to_string(header=False, index=False).split()\n",
    "    \n",
    "    # Print row with formatted columns\n",
    "    print(f\"{row[0]:<15} {row[1]:<6} {row[2]:<15} {row[3]:<25} {row[4]:<12} {row[5]:<12} {row[6]:<12} {row[7]:<12}\")\n",
    "\n",
    "# Print a blank line to separate Mean and SvP outputs\n",
    "# print('\\n')\n",
    "\n",
    "# Loop through the dataframes and print SvP results\n",
    "for k in range(len(df_svp)):\n",
    "    # Format the SvP results with 'SvP' as the flag\n",
    "    row = df_svp[k][['BNN Type', 'Flag',\n",
    "                     'Config Info', \n",
    "                     'Percentage Cost Error (Best Eq Gap)', \n",
    "                     'Eq Gap Mean (Best Eq Gap)', \n",
    "                     'Eq Gap Max (Best Eq Gap)', \n",
    "                     'Ineq Gap Max (Best Eq Gap)', \n",
    "                     'Ineq Gap Mean (Best Eq Gap)']].to_string(header=False, index=False).split()\n",
    "    \n",
    "    # Print row with formatted columns\n",
    "    print(f\"{row[0]:<15} {row[1]:<6} {row[2]:<15} {row[3]:<25} {row[4]:<12} {row[5]:<12} {row[6]:<12} {row[7]:<12}\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/anaconda3/envs/bnn/lib/python3.11/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "\u001b[38;20m2024-09-26 16:21:26,782 - bnn-opf - INFO - Parsed case file (dataloader.py:26)\u001b[0m\n",
      "\u001b[38;20m2024-09-26 16:21:26,887 - bnn-opf - INFO - Admittance matrices created (dataloader.py:33)\u001b[0m\n",
      "\u001b[38;20m2024-09-26 16:21:26,888 - bnn-opf - INFO - Generator info parsed (dataloader.py:41)\u001b[0m\n",
      "\u001b[38;20m2024-09-26 16:21:26,972 - bnn-opf - INFO - Bus info parsed (dataloader.py:55)\u001b[0m\n",
      "\u001b[38;20m2024-09-26 16:21:26,973 - bnn-opf - INFO - Reading dataset (dataloader.py:57)\u001b[0m\n",
      "100%|██████████| 1/1 [00:42<00:00, 42.37s/it]\n",
      "\u001b[38;20m2024-09-26 16:22:10,006 - bnn-opf - INFO - Dataset parsed and organized (dataloader.py:66)\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "import logging\n",
    "\n",
    "import os\n",
    "\n",
    "from logger import CustomFormatter\n",
    "from dataloader import load_data\n",
    "from acopf import *\n",
    "from bnncommon import *\n",
    "from supervisedmodel import *\n",
    "from stopping import *\n",
    "from sandwiched import run_sandwich\n",
    "from classes import SampleCounts\n",
    "from jax import random\n",
    "from modelio import *\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import glob\n",
    "import re\n",
    "def read_from_results(file):\n",
    "    with open(file, 'rb') as g:\n",
    "        res = pickle.load(g)\n",
    "    return res\n",
    "\n",
    "\n",
    "\n",
    "file = '/Users/pareek/Documents/Codes/BNN-OPF/output/pglib_opf_case500_goc_1_1024_semisupervisedBNN_config.pkl'\n",
    "\n",
    "def get_logger(debug, warn, error): \n",
    "    log = logging.getLogger('bnn-opf')\n",
    "    log.setLevel(logging.DEBUG)\n",
    "    \n",
    "    if (debug == True):\n",
    "        log.setLevel(logging.DEBUG)\n",
    "    if (error == True): \n",
    "        log.setLevel(logging.ERROR)\n",
    "    if (warn == True):\n",
    "        log.setLevel(logging.WARNING)\n",
    "    \n",
    "    # create console handler\n",
    "    ch = logging.StreamHandler()\n",
    "    ch.setFormatter(CustomFormatter()) \n",
    "    log.addHandler(ch)\n",
    "    \n",
    "    # create file handler\n",
    "    # fh = logging.FileHandler(f'./logs/analysis.log', mode='w')\n",
    "    # fh.setFormatter(CustomFormatter())\n",
    "    # log.addHandler(fh) \n",
    "    return log\n",
    "\n",
    "rng_key, sample_counts, params = read_from_file(file)\n",
    "\n",
    "log = get_logger(True, False, False)\n",
    "opf_data = load_data('/Users/pareek/Documents/Codes/BNN-OPF/data/', 'pglib_opf_case500_goc', log, sample_counts)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "E_norm = np.linalg.norm(all_results[0]['All_error'],axis=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.68152994, 0.9466809 , 0.6239391 , 0.71585774, 0.4687095 ,\n",
       "       0.92886376, 0.5006015 , 0.5807669 , 0.73174155, 0.50279427,\n",
       "       1.2243184 , 0.9279571 , 1.0976088 , 1.2980353 , 1.0104959 ,\n",
       "       0.6637332 , 0.616565  , 0.9063492 , 0.69530904, 0.97199994,\n",
       "       0.84476113, 0.60623336, 0.67281127, 0.6525396 , 1.1864309 ,\n",
       "       0.73963356, 1.0090528 , 0.5876221 , 0.81320375, 0.83108205,\n",
       "       0.4458406 , 0.8246821 , 1.1870759 , 0.5347191 , 0.6843453 ,\n",
       "       0.91931856, 0.4870554 , 0.6705409 , 0.9533953 , 0.67894316,\n",
       "       0.94537437, 0.53330886, 0.8767778 , 0.5291939 , 0.65947986,\n",
       "       0.62153727, 1.1334599 , 1.032633  , 0.64422804, 0.95256084,\n",
       "       0.7516932 , 0.9923625 , 0.48592964, 0.55838203, 1.106807  ,\n",
       "       1.142876  , 0.92592824, 1.2089088 , 0.6903852 , 1.653856  ,\n",
       "       0.43680605, 0.84849703, 0.7763341 , 0.8486128 , 0.6701925 ,\n",
       "       0.6192906 , 0.92312884, 0.8277662 , 0.8661783 , 0.67816794,\n",
       "       0.70439565, 0.5148694 , 1.298872  , 0.78032976, 0.9190026 ,\n",
       "       0.9758212 , 0.49252844, 0.7964809 , 0.61291933, 0.7995459 ,\n",
       "       0.67047894, 1.4879065 , 0.74234897, 0.6917778 , 0.6303431 ,\n",
       "       0.46901724, 0.92749757, 1.1491542 , 0.7085097 , 0.70986605,\n",
       "       0.7821797 , 0.50343245, 0.7854928 , 0.6024371 , 1.0563699 ,\n",
       "       0.70930827, 0.9154059 , 0.77703816, 0.82678145, 0.8758742 ,\n",
       "       1.0507853 , 1.4909859 , 0.80051243, 0.9072    , 0.715695  ,\n",
       "       0.8702064 , 1.0191762 , 0.645762  , 0.9269912 , 0.8640422 ,\n",
       "       0.7514521 , 0.83828497, 0.5866816 , 0.7573824 , 0.6452039 ,\n",
       "       1.1492865 , 0.72481567, 0.7831789 , 0.90617216, 0.87415415,\n",
       "       0.67785865, 1.0253007 , 0.73915184, 1.4604361 , 0.8417446 ,\n",
       "       0.62956524, 0.91741014, 0.9125278 , 1.1010317 , 0.6180615 ,\n",
       "       0.97152346, 0.73265386, 0.58006054, 0.91265434, 0.5307039 ,\n",
       "       1.6728361 , 0.79778826, 0.82629395, 1.1203376 , 0.62536436,\n",
       "       1.7742758 , 0.60410523, 0.45933712, 0.67604184, 0.6461513 ,\n",
       "       0.5585506 , 0.5108056 , 0.63578254, 0.8290012 , 1.3033948 ,\n",
       "       0.95069516, 0.8201629 , 0.71530974, 0.6586247 , 0.437451  ,\n",
       "       0.56848735, 0.67282957, 0.75247556, 0.5740841 , 0.7329847 ,\n",
       "       1.5113302 , 0.6072302 , 1.1530845 , 0.7324746 , 0.9166946 ,\n",
       "       0.62097   , 0.7440767 , 0.6591897 , 1.0144341 , 0.685755  ,\n",
       "       0.74903464, 0.85533816, 1.4243554 , 0.6954807 , 1.1179599 ,\n",
       "       1.1090779 , 0.7147808 , 1.0242677 , 0.98848915, 0.9614254 ,\n",
       "       0.41883934, 0.80011433, 0.5999506 , 0.9880029 , 1.026133  ,\n",
       "       0.709607  , 0.50506943, 0.9420823 , 0.6566463 , 0.6206883 ,\n",
       "       0.4439637 , 0.9698273 , 0.52872795, 0.71135986, 0.85432214,\n",
       "       0.7396303 , 0.61972934, 0.7820554 , 1.1254203 , 0.8359269 ,\n",
       "       0.6629009 , 0.59430116, 0.80166423, 0.8654459 , 0.9435484 ,\n",
       "       0.94905514, 0.5371915 , 0.8502024 , 1.2001665 , 0.81946164,\n",
       "       0.6477071 , 1.1205449 , 0.9566173 , 0.9024504 , 0.62192863,\n",
       "       1.3074396 , 0.81529707, 0.75064695, 0.61670554, 0.88853735,\n",
       "       0.73291445, 1.0431054 , 1.0430675 , 1.151584  , 0.83570504,\n",
       "       0.6346453 , 0.6543651 , 0.88717866, 0.7165136 , 0.4777367 ,\n",
       "       0.926464  , 1.1791805 , 0.67968494, 0.80388886, 1.1786294 ,\n",
       "       0.83426416, 0.4460905 , 0.5069953 , 1.2131641 , 1.2820505 ,\n",
       "       0.515349  , 0.5403677 , 0.96524346, 1.0827904 , 0.66713196,\n",
       "       0.8611868 , 0.8199709 , 0.6136423 , 0.5827471 , 1.0662625 ,\n",
       "       0.69296396, 0.56398404, 1.3974048 , 0.5876447 , 0.8073672 ,\n",
       "       0.61447   , 0.548609  , 0.8735666 , 0.54138553, 1.1229483 ,\n",
       "       0.82996213, 1.3382237 , 0.69825745, 0.7241934 , 0.75713855,\n",
       "       0.9484219 , 0.7590566 , 0.7421623 , 0.8484877 , 1.0331743 ,\n",
       "       0.68814975, 1.108445  , 0.46442592, 0.9409633 , 0.6479443 ,\n",
       "       0.94416296, 1.1383202 , 0.7405496 , 0.6871696 , 0.79222006,\n",
       "       0.94520366, 0.8503684 , 0.5850824 , 0.5464107 , 0.5193221 ,\n",
       "       0.5733609 , 0.64817685, 1.0312463 , 0.6765097 , 0.67066586,\n",
       "       0.75646603, 0.81574994, 1.5209336 , 0.580615  , 0.47866508,\n",
       "       1.1215957 , 0.5442151 , 0.8541263 , 0.5775596 , 0.65972257,\n",
       "       0.8264942 , 1.3609663 , 0.7591122 , 1.0126562 , 0.73971546,\n",
       "       0.92416036, 0.71553946, 0.71492535, 0.9251932 , 0.35345122,\n",
       "       0.91948026, 0.6864602 , 1.0924599 , 0.7430415 , 1.369866  ,\n",
       "       0.89124435, 0.60062844, 0.80017596, 0.75834906, 0.6021172 ,\n",
       "       1.3346202 , 0.65092885, 0.6360308 , 0.76892674, 0.9529329 ,\n",
       "       0.9610392 , 0.44098672, 0.5843726 , 1.0708647 , 0.5513117 ,\n",
       "       0.60701895, 0.7728333 , 1.1028752 , 0.6676337 , 1.0369135 ,\n",
       "       0.5843795 , 0.773143  , 0.83440816, 0.72892416, 0.78931123,\n",
       "       0.8010369 , 0.58837134, 0.5249589 , 0.9296613 , 1.0921627 ,\n",
       "       0.68602306, 0.7309778 , 1.3962094 , 0.6505869 , 0.5822495 ,\n",
       "       0.69160956, 1.1934724 , 0.9437979 , 0.93312055, 1.1666429 ,\n",
       "       0.55332243, 1.2284584 , 1.0243584 , 0.76285803, 0.48401865,\n",
       "       0.70264095, 0.98223627, 0.7783818 , 0.8262015 , 0.76424944,\n",
       "       0.9197477 , 1.0292357 , 0.6671109 , 1.150638  , 1.409735  ,\n",
       "       1.0471236 , 0.70273834, 0.96779144, 0.62667894, 1.0165282 ,\n",
       "       0.60496235, 0.5110735 , 0.84275234, 0.5375628 , 0.9338279 ,\n",
       "       0.6624601 , 1.1430491 , 0.6740277 , 0.7781782 , 0.7557506 ,\n",
       "       0.61451536, 1.0595047 , 0.7197042 , 0.46332115, 0.6813261 ,\n",
       "       0.6330688 , 1.1526486 , 0.46981877, 0.4706093 , 0.77609026,\n",
       "       0.43651924, 1.2111148 , 0.59146744, 0.9665176 , 0.8698394 ,\n",
       "       0.8227044 , 0.72790426, 1.0676756 , 0.55236155, 0.7488609 ,\n",
       "       0.68412477, 0.78472507, 0.5959179 , 0.712293  , 1.30517   ,\n",
       "       0.9243923 , 0.8648309 , 0.7913757 , 1.0185541 , 0.75682014,\n",
       "       0.5882158 , 0.6065904 , 0.5491681 , 0.8570686 , 0.5607834 ,\n",
       "       0.6008894 , 0.3532155 , 0.63578784, 0.8438411 , 0.56576115,\n",
       "       0.55136126, 1.0216683 , 0.7105378 , 0.73712826, 0.8746901 ,\n",
       "       0.44998863, 0.61552554, 0.8066681 , 0.7410383 , 1.017002  ,\n",
       "       0.700388  , 0.5742682 , 0.8949179 , 0.87382555, 0.70627433,\n",
       "       0.575923  , 0.9298238 , 0.8599312 , 0.78063774, 0.7051233 ,\n",
       "       1.2589256 , 0.6155114 , 0.35522693, 0.7665293 , 0.77778906,\n",
       "       0.84313846, 0.9423578 , 0.7596097 , 0.92578864, 0.8980139 ,\n",
       "       0.7129345 , 0.86153036, 0.76086324, 0.8513017 , 0.80208856,\n",
       "       0.5622253 , 1.4951508 , 1.0526563 , 0.7543714 , 0.90107054,\n",
       "       0.7221014 , 0.5503032 , 1.3528159 , 0.90833807, 0.5215792 ,\n",
       "       0.63287276, 1.0679139 , 0.7170813 , 0.46673056, 0.80067205,\n",
       "       1.3443764 , 0.52228224, 0.70326036, 1.069577  , 0.79653347,\n",
       "       0.8488491 , 1.0575495 , 0.9197248 , 0.9826271 , 1.1111284 ,\n",
       "       0.9408672 , 1.1736795 , 0.93441874, 0.55523854, 0.7732868 ,\n",
       "       0.5431653 , 0.85731626, 0.8702908 , 0.7562706 , 0.9423417 ,\n",
       "       0.80456245, 0.7190025 , 0.7012712 , 0.7690295 , 1.6416513 ,\n",
       "       1.7237697 , 0.7228904 , 1.2662402 , 0.5924046 , 0.6567258 ,\n",
       "       0.6169617 , 0.91683424, 0.69716984, 0.72296923, 0.8732114 ,\n",
       "       0.96857035, 0.7817092 , 0.7006424 , 1.1299309 , 0.84927607,\n",
       "       0.63662404, 0.6001205 , 0.87255824, 0.7091585 , 1.0824945 ,\n",
       "       0.88954395, 0.6211361 , 0.9321464 , 1.1237882 , 0.8902453 ,\n",
       "       0.74438375, 0.7185692 , 0.41791797, 0.9400299 , 0.7091879 ,\n",
       "       0.34921128, 0.7883998 , 0.9896059 , 0.9635802 , 1.1868545 ,\n",
       "       0.8932232 , 0.8541515 , 0.6921228 , 0.91099656, 0.7184554 ,\n",
       "       0.5361655 , 0.6443542 , 0.7071028 , 0.63841015, 0.80276036,\n",
       "       0.8347658 , 0.83778435, 1.001933  , 0.5468318 , 0.77350384,\n",
       "       0.6651921 , 0.80640715, 0.57870144, 1.1686627 , 0.7605785 ,\n",
       "       0.68704116, 0.8347847 , 0.7807928 , 0.5247698 , 0.6811403 ,\n",
       "       0.66643035, 0.67536956, 1.5421435 , 0.99428207, 0.9479732 ,\n",
       "       1.2630862 , 1.0198594 , 0.6950801 , 0.9008746 , 0.96859384,\n",
       "       1.1594843 , 0.6644968 , 1.2006038 , 0.7837105 , 0.9193213 ,\n",
       "       0.6586386 , 0.7464824 , 0.7164545 , 0.8833507 , 0.74572027,\n",
       "       0.77396154, 0.7692111 , 1.0533581 , 1.3687851 , 0.8762857 ,\n",
       "       1.0588722 , 1.6053429 , 1.357914  , 0.9962949 , 0.5912554 ,\n",
       "       0.82137036, 0.7566897 , 0.7066279 , 1.0013783 , 1.10632   ,\n",
       "       0.45679164, 0.57673883, 0.75696695, 1.126613  , 0.73054814,\n",
       "       0.43150744, 1.4806482 , 1.2597235 , 1.5890759 , 0.6332011 ,\n",
       "       0.5558512 , 0.5955378 , 0.7241323 , 1.0902354 , 0.9036565 ,\n",
       "       0.985562  , 0.7287071 , 0.7059878 , 1.2612444 , 1.0302551 ,\n",
       "       0.73513955, 1.3845773 , 1.412252  , 0.86785513, 1.4405452 ,\n",
       "       0.96766925, 0.44822106, 0.9093491 , 0.670189  , 1.397665  ,\n",
       "       0.7377771 , 0.8442843 , 0.88294613, 0.65712607, 0.85149115,\n",
       "       0.49718505, 0.8244807 , 1.1194148 , 0.8660551 , 1.1515298 ,\n",
       "       0.6467167 , 0.95193094, 0.5291103 , 1.0533472 , 0.6271743 ,\n",
       "       0.5993423 , 1.3429317 , 0.58029336, 0.5497044 , 0.87237614,\n",
       "       0.86066175, 0.793507  , 0.6822013 , 1.0447655 , 0.49606755,\n",
       "       1.177996  , 0.79620713, 0.8541076 , 0.53064835, 0.51207405,\n",
       "       0.73657954, 1.1017364 , 0.7537304 , 0.69772166, 0.7678094 ,\n",
       "       1.1337637 , 1.2697219 , 0.71986085, 0.8108555 , 0.45084742,\n",
       "       0.61198515, 0.5279029 , 0.7923192 , 0.48544866, 0.6389109 ,\n",
       "       0.9367585 , 0.85846746, 0.772334  , 0.77901286, 0.54707795,\n",
       "       1.3099151 , 0.58254963, 0.8134291 , 0.45530012, 0.5674317 ,\n",
       "       0.97592944, 0.83914524, 0.7120549 , 1.1632959 , 0.8668946 ,\n",
       "       0.3589769 , 0.5885209 , 1.1056365 , 0.7085257 , 0.88132876,\n",
       "       0.6631496 , 0.80902094, 1.0164944 , 1.0501108 , 0.5774417 ,\n",
       "       0.49133164, 1.0548885 , 0.7018755 , 1.0533963 , 1.0493114 ,\n",
       "       0.8279549 , 0.34615573, 1.3335266 , 0.444583  , 0.8149717 ,\n",
       "       0.47556877, 0.78469265, 0.93769807, 0.7033985 , 1.051381  ,\n",
       "       1.0949771 , 0.63129437, 0.8710954 , 1.4834242 , 1.1439999 ,\n",
       "       1.4760909 , 1.5025854 , 0.8410622 , 0.75438404, 0.53454965,\n",
       "       0.50931084, 0.8024534 , 0.81268007, 0.43836403, 0.7206468 ,\n",
       "       0.92258143, 0.8940458 , 0.47702456, 0.59065294, 2.8085136 ,\n",
       "       0.70264333, 0.89365625, 0.54842776, 0.7521832 , 0.896884  ,\n",
       "       0.63300663, 1.6755297 , 0.55402267, 0.97542036, 0.9110996 ,\n",
       "       1.088524  , 0.5255702 , 0.4767405 , 0.7785217 , 0.5358902 ,\n",
       "       0.5079839 , 0.7895963 , 0.78999555, 0.8014704 , 1.0529137 ,\n",
       "       1.1734871 , 0.62372375, 0.65587926, 0.8900281 , 0.8124507 ,\n",
       "       0.610993  , 0.7435212 , 0.82271284, 0.78015906, 0.97481346,\n",
       "       0.58624846, 0.6307517 , 0.78990936, 0.73334473, 0.58697987,\n",
       "       0.7136644 , 0.9204605 , 0.79578143, 0.94922817, 0.75958526,\n",
       "       0.7649136 , 1.1503218 , 0.5748143 , 0.5833676 , 0.83725625,\n",
       "       1.0175474 , 1.3502603 , 1.0318347 , 0.44268414, 0.5209115 ,\n",
       "       0.90573764, 1.002534  , 1.43155   , 0.8052173 , 0.9418634 ,\n",
       "       0.7151755 , 1.2360175 , 1.0567529 , 0.810442  , 0.9393729 ,\n",
       "       0.46568766, 1.163474  , 0.9998637 , 0.35378444, 1.1798576 ,\n",
       "       0.6079437 , 0.9698381 , 0.59829026, 0.4306462 , 0.79692733,\n",
       "       1.3657522 , 1.1238369 , 0.7228987 , 0.52266836, 0.5325092 ,\n",
       "       1.0362216 , 1.239545  , 1.0947344 , 1.2005987 , 0.98717237,\n",
       "       0.64620674, 1.2339567 , 0.8412025 , 1.2127901 , 1.1542994 ,\n",
       "       0.9568416 , 0.9564266 , 1.0727316 , 0.6743306 , 1.1078061 ,\n",
       "       1.5470783 , 1.0296249 , 0.56058156, 1.0775727 , 0.69200796,\n",
       "       0.81455517, 1.4382042 , 0.731297  , 0.7435376 , 0.79140955,\n",
       "       0.8571919 , 0.8254898 , 0.5692432 , 0.8150288 , 0.9156767 ,\n",
       "       0.7813892 , 1.2102091 , 1.2222924 , 0.4886609 , 0.9332209 ,\n",
       "       0.7379762 , 0.5735621 , 1.08363   , 1.3035183 , 0.9590274 ,\n",
       "       0.6517102 , 0.5854108 , 0.7236782 , 1.4909858 , 0.47846022,\n",
       "       0.8667418 , 0.6530611 , 0.8261197 , 1.2837456 , 0.88192344,\n",
       "       0.75418746, 0.48836854, 0.63702106, 0.7441827 , 0.57885736,\n",
       "       0.50365007, 0.5297322 , 0.55568594, 0.90456516, 0.47805882,\n",
       "       0.83353734, 0.9289438 , 0.99281156, 0.9342496 , 0.49028963,\n",
       "       1.0329072 , 1.0662472 , 0.8521405 , 0.97384965, 0.5983235 ,\n",
       "       0.8026648 , 0.73720306, 0.7451788 , 0.87559956, 0.7851896 ,\n",
       "       1.0462793 , 0.79249203, 0.86119795, 0.60123056, 0.39245954,\n",
       "       0.34195703, 0.66272527, 0.8176473 , 0.5501229 , 0.49394113,\n",
       "       0.7497378 , 0.4391936 , 1.022799  , 1.1427345 , 1.0235685 ,\n",
       "       0.7958374 , 0.736442  , 0.8148048 , 0.8039466 , 0.9664388 ,\n",
       "       0.9324198 , 0.8105378 , 1.0131499 , 0.5210129 , 0.6796394 ,\n",
       "       0.7859314 , 0.7263294 , 0.769285  , 0.6360712 , 0.8108811 ,\n",
       "       0.89434636, 0.76967466, 0.4949106 , 0.6921794 , 1.3440127 ,\n",
       "       0.6533743 , 0.92028695, 0.8205034 , 0.91878116, 0.8394109 ,\n",
       "       0.85952705, 0.8733977 , 0.44481447, 0.9789209 , 0.91752136,\n",
       "       1.4257361 , 0.8720656 , 0.47508353, 0.7073613 , 0.6411646 ,\n",
       "       1.4366529 , 0.4931854 , 0.49076122, 0.6512227 , 0.52428675,\n",
       "       0.6819166 , 0.60318303, 1.0620282 , 0.5332551 , 0.55538183,\n",
       "       1.0858724 , 1.0534661 , 0.880096  , 0.52396816, 0.60688543,\n",
       "       0.9932069 , 0.7316269 , 0.60331607, 0.87302786, 1.1561565 ,\n",
       "       0.6393089 , 0.74897414, 0.6506848 , 0.8467937 , 0.9571522 ,\n",
       "       1.0424035 , 1.0655833 , 0.78093547, 0.83231324, 0.5429057 ,\n",
       "       0.31987995, 0.9008928 , 0.8721478 , 0.5696651 , 0.75903195,\n",
       "       0.7242799 , 0.81816185, 1.3994823 , 1.1434402 , 0.5582048 ,\n",
       "       0.628955  , 0.8948741 , 0.6294803 , 0.60287815, 0.84709257,\n",
       "       0.81393   , 0.6113165 , 0.8716175 , 0.97360957, 0.9337272 ,\n",
       "       0.603608  , 0.81507474, 0.988739  , 0.71822804, 0.8833802 ,\n",
       "       0.73964137, 0.4223846 , 0.7057069 , 0.96148926, 0.7850458 ,\n",
       "       1.1122715 , 0.5322632 , 0.8212305 , 0.7213731 , 1.0535203 ,\n",
       "       0.84713966, 1.0481576 , 0.8329888 , 0.7937309 , 1.1632644 ],\n",
       "      dtype=float32)"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "E_norm.min(axis=0)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "bnn",
   "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.11.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
