{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Conditional Neural Processes (CNP) for 1D regression.\n",
    "[Conditional Neural Processes](https://arxiv.org/pdf/1807.01613.pdf) (CNPs) were\n",
    "introduced as a continuation of\n",
    "[Generative Query Networks](https://deepmind.com/blog/neural-scene-representation-and-rendering/)\n",
    "(GQN) to extend its training regime to tasks beyond scene rendering, e.g. to\n",
    "regression and classification."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch #torch==2.1.2\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "import datetime\n",
    "import numpy as np #numpy==1.24.3\n",
    "import torchsnooper #torchsnooper==0.8\n",
    "import plotting_utils_cnp as plotting\n",
    "import data_generator as data\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "import pandas as pd #pandas==2.0.1\n",
    "import dask.dataframe as dd\n",
    "import sys\n",
    "sys.path.append('../utilities')\n",
    "import utilities as utils\n",
    "import import_ipynb\n",
    "import conditional_neural_process_model as cnp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "TRAINING_ITERATIONS = int(3540) # Total number of training points: training_iterations * batch_size * max_content_points\n",
    "#BATCH_SIZE = 100 # number of simulation configurations\n",
    "\n",
    "MAX_CONTEXT_POINTS = 1000 # 2000 # 4000\n",
    "MAX_TARGET_POINTS =  2000 # 4000 # 8000\n",
    "CONTEXT_IS_SUBSET = True\n",
    "BATCH_SIZE = 1\n",
    "CONFIG_WISE = False\n",
    "PLOT_AFTER = int(200)\n",
    "torch.manual_seed(0)\n",
    "\n",
    "# all available x config/ physics parameters are [\"radius\",\"thickness\",\"npanels\",\"theta\",\"length\",\"height\",\"z_offset\",\"volume\",\"nC_Ge77\",\"time_0[ms]\",\"x_0[m]\",\"y_0[m]\",\"z_0[m]\",\"px_0[m]\",\"py_0[m]\",\"pz_0[m]\",\"ekin_0[eV]\",\"edep_0[eV]\",\"time_t[ms]\",\"x_t[m]\",\"y_t[m]\",\"z_t[m]\",\"px_t[m]\",\"py_t[m]\",\"pz_t[m]\",\"ekin_t[eV]\",\"edep_t[eV]\",\"nsec\"]\n",
    "# Comment: if using data version_out v1.1 for training, \"radius\",\"thickness\",\"npanels\",\"theta\",\"length\" is probably necessary\n",
    "names_x=[\"radius\",\"thickness\",\"npanels\",\"theta\",\"length\",\"r_0[m]\",\"z_0[m]\",\"time_t[ms]\",\"r_t[m]\",\"z_t[m]\",\"L_t[m]\",\"ln(E0vsET)\",\"edep_t[eV]\",\"nsec\"]\n",
    "name_y ='total_nC_Ge77[cts]'\n",
    "x_size = len(names_x)\n",
    "if isinstance(name_y,str):\n",
    "    y_size = 1\n",
    "else:\n",
    "    y_size = len(name_y)\n",
    "\n",
    "RATIO_TESTING_VS_TRAINING = 1/40\n",
    "\n",
    "version_out=\"v1.6\"\n",
    "version_lf=\"n1.6\"\n",
    "version_hf=\"n1.6\"\n",
    "path_to_files=f\"../simulation/out/LF/{version_lf}/tier2/\"\n",
    "path_out = f'./out/'\n",
    "f_out = f'{path_out}CNPGauss_{version_out}_{TRAINING_ITERATIONS}_c{MAX_CONTEXT_POINTS}_t{MAX_TARGET_POINTS}'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set data augmentation parameters\n",
    "USE_DATA_AUGMENTATION = \"mixup\" #\"smote\" #False #\"mixup\"\n",
    "USE_BETA = [0.1,0.1] # uniform => None, beta => [a,b] U-shape [0.1,0.1] Uniform [1.,1.] falling [0.2,0.5] rising [0.2,0.5]\n",
    "SIGNAL_TO_BACKGROUND_RATIO = \"\" # \"_1to4\" # used for smote augmentation\n",
    "\n",
    "if USE_DATA_AUGMENTATION:\n",
    "    path_out = f'./out/{USE_DATA_AUGMENTATION}/'\n",
    "    f_out = f'CNPGauss_{version_out}_{TRAINING_ITERATIONS}_c{MAX_CONTEXT_POINTS}_t{MAX_TARGET_POINTS}_{USE_DATA_AUGMENTATION}{SIGNAL_TO_BACKGROUND_RATIO}'\n",
    "    if USE_DATA_AUGMENTATION == \"mixup\":\n",
    "        path_to_files = f\"../simulation/out/LF/{version_lf}/tier3/beta_{USE_BETA[0]}_{USE_BETA[1]}/\"\n",
    "        f_out = f'CNPGauss_{version_out}_{TRAINING_ITERATIONS}_c{MAX_CONTEXT_POINTS}_t{MAX_TARGET_POINTS}_beta_{USE_BETA[0]}_{USE_BETA[1]}'\n",
    "    elif USE_DATA_AUGMENTATION == \"smote\" and CONFIG_WISE == True:\n",
    "        path_to_files = f\"../simulation/out/LF/{version_lf}/tier3/smote{SIGNAL_TO_BACKGROUND_RATIO}/\"\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "d_x, d_in, representation_size, d_out = x_size , x_size+y_size, 32, y_size+1\n",
    "encoder_sizes = [d_in, 32, 64, 128, 128, 128, 64, 48, representation_size]\n",
    "decoder_sizes = [representation_size + d_x, 32, 64, 128, 128, 128, 64, 48, d_out]\n",
    "\n",
    "model = cnp.DeterministicModel(encoder_sizes,decoder_sizes)\n",
    "model.load_state_dict(torch.load(f'./out/{f_out}_model.pth'))\n",
    "model.eval()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "mode=\"LF\"\n",
    "filelist = utils.get_all_files(f\"../simulation/out/{mode}/n{version_lf[1:]}/tier2/\")\n",
    "num_total_points = 50000\n",
    "\n",
    "\n",
    "MAX_CONTEXT_POINTS_NEW = int(1/3 * num_total_points)\n",
    "MAX_TARGET_POINTS_NEW = 2 * (MAX_CONTEXT_POINTS_NEW)\n",
    "bce = nn.BCELoss()\n",
    "\n",
    "x_lf = np.empty([0,6])\n",
    "sum_target_y_lf = np.empty([0,1])\n",
    "mean_mu_cnp_lf = np.empty([0,1])\n",
    "mean_sigma_cnp_lf = np.empty([0,1])\n",
    "rGe77_lf = np.empty([0,1])\n",
    "hist_target_sig = hist_target_bkg = hist_pred_sig = hist_pred_bkg = np.zeros(100)\n",
    "fout = open(f'{path_out}{f_out}_training_new_samples.txt', \"a\")\n",
    "\n",
    "# create a PdfPages object\n",
    "pdf = PdfPages(f'{path_out}{f_out}_result_{mode}_new_samples.pdf')\n",
    "\n",
    "for i,file in enumerate(filelist):\n",
    "    print(file)\n",
    "    path_to_files = file[:-4]\n",
    "    dataset_config = data.DataGeneration(num_iterations=1, num_context_points=MAX_CONTEXT_POINTS_NEW, num_target_points=MAX_TARGET_POINTS_NEW, batch_size = 1, use_data_augmentation=\"None\", path_to_files=path_to_files,x_size=x_size,y_size=y_size, mode = \"config\", ratio_testing=0.,names_x=names_x, name_y=name_y)\n",
    "    data_config = dataset_config.get_data(0, CONTEXT_IS_SUBSET)\n",
    "    # Get the predicted mean and variance at the target points for the testing set\n",
    "    log_prob_config, mu_config, sigma_config = model(data_config.query, data_config.target_y)\n",
    "    # Define the loss\n",
    "    config_loss = -log_prob_config.mean()\n",
    "    if max(mu_config[0].detach().numpy()) <= 1 and min(mu_config[0].detach().numpy()) >= 0:\n",
    "            loss_bce_config = bce(mu_config,  data_config.target_y)\n",
    "    else:\n",
    "            loss_bce_config = -1.\n",
    "\n",
    "    mu_config = mu_config[0].detach().numpy()\n",
    "    target_y = data_config.target_y[0].detach().numpy()\n",
    "    df = pd.read_csv(file, index_col=0)\n",
    "    tmp = df[[\"fidelity\",\"radius\",\"thickness\",\"npanels\",\"theta\",\"length\"]].to_numpy()\n",
    "    x_lf         = np.append(x_lf,[df[[\"fidelity\",\"radius\",\"thickness\",\"npanels\",\"theta\",\"length\"]].to_numpy()[0]],axis=0)\n",
    "\n",
    "    sum_target_y_tmp = np.array([np.sum(target_y)])\n",
    "    sum_target_y_lf    = np.append(sum_target_y_lf, [sum_target_y_tmp], axis=0)\n",
    "    mean_mu_tmp = np.array([np.mean(mu_config)])\n",
    "    mean_mu_cnp_lf = np.append(mean_mu_cnp_lf, [mean_mu_tmp], axis=0)\n",
    "    mean_sigma_tmp = np.array([np.mean(sigma_config[0].detach().numpy())])\n",
    "    mean_sigma_cnp_lf = np.append(mean_sigma_cnp_lf, [mean_sigma_tmp], axis=0)\n",
    "    rGe77_lf = np.append(rGe77_lf,[np.array([np.sum(pd.read_csv(file)[\"prod_rate_Ge77[nuc/(kg*yr)]\"].to_numpy())])], axis=0)\n",
    "    #print(np.sum(pd.read_csv(file)[\"prod_rate_Ge77[nuc/(kg*yr)]\"].to_numpy()))\n",
    "    hist_target_sig, hist_target_bkg, hist_pred_sig, hist_pred_bkg = plotting.sum_hist(mu_config, target_y, hist_target_sig, hist_target_bkg, hist_pred_sig, hist_pred_bkg)\n",
    "    print(\"{}/{} {}, {}, radius: {} cm, test loss: {} (bce {})\".format(i,len(filelist),datetime.datetime.now().strftime(\"%Y-%m-%d %H:%M:%S\"), mode,x_lf[-1,1], config_loss, loss_bce_config))\n",
    "    fout.write(\"{}, Iteration: {}, test loss: {} (bce {})\\n\".format(datetime.datetime.now().strftime(\"%Y-%m-%d %H:%M:%S\"), i, config_loss, loss_bce_config))\n",
    "    fig = plotting.plot_result_configwise(mu_config, target_y, f'{config_loss:.2f}', x_lf[-1][1:])\n",
    "    pdf.savefig(fig)\n",
    "    #plt.show()\n",
    "    plt.clf()\n",
    "\n",
    "    \n",
    "fig1 = plotting.plot_result_summed(hist_target_sig, hist_target_bkg, hist_pred_sig, hist_pred_bkg)\n",
    "pdf.savefig(fig1)\n",
    "plt.show()\n",
    "plt.clf()\n",
    "\n",
    "fig2,_ = plt.subplots(3,2,sharey=True,figsize=(9, 9),layout=\"constrained\")\n",
    "ax2 = fig2.axes\n",
    "for i in range(len(x_lf[0,:])-1):\n",
    "\n",
    "    #ax2[i].plot(x_lf[:,0],mean_mu_cnp,'o')\n",
    "    ax2[i].errorbar(x_lf[:,i+1], mean_mu_cnp_lf[:,0], yerr=mean_sigma_cnp_lf[:,0],fmt='o', color='teal')\n",
    "    \n",
    "    ax2[i].set_xlabel(names_x[i])\n",
    "    if i % 2 == 0:\n",
    "        ax2[i].set_ylabel(r'mean probability for nC on $^{76}Ge$')\n",
    "    #ax2[i].set_ylim(0.0,0.15)\n",
    "for i in range(len(x_lf[0,:])-1,len(ax2)):\n",
    "     ax2[i].set_axis_off()\n",
    "fig2.suptitle('Conditional Neutral Process', fontsize=10)\n",
    "pdf.savefig(fig2)\n",
    "plt.show()\n",
    "\n",
    "\n",
    "fig3,_ = plt.subplots(3,2,sharey=True,figsize=(9, 9),layout=\"constrained\")\n",
    "ax3 = fig3.axes\n",
    "for i in range(len(x_lf[0,:])-1):\n",
    "    ax3[i].plot(x_lf[:,i+1],rGe77_lf,'o', color='teal')\n",
    "    ax3[i].set_title('Simulation', fontsize=10)\n",
    "    if i % 2 == 0:\n",
    "        ax3[i].set_ylabel(r'nC on $^{76}Ge$')\n",
    "    ax3[i].set_xlabel(names_x[i])\n",
    "for i in range(len(x_lf[0,:])-1,len(ax3)):\n",
    "     ax3[i].set_axis_off()\n",
    "fig3.suptitle('Simulation', fontsize=10)\n",
    "pdf.savefig(fig3)\n",
    "plt.show()\n",
    "pdf.close()\n",
    "\n",
    "fout.close()\n",
    "\n",
    "df = pd.DataFrame(x_lf, columns=[\"Mode\",\"Radius[cm]\",\"Thickness[cm]\",\"NPanels\",\"Theta[deg]\",\"Length[cm]\"])\n",
    "df['Ge-77[nevents]'] = sum_target_y_lf\n",
    "df['Ge-77_CNP'] = mean_mu_cnp_lf\n",
    "df['Ge-77_CNP_err'] = mean_sigma_cnp_lf\n",
    "df['rGe77[nuc/(kg*yr)]'] = rGe77_lf\n",
    "df=df.round(decimals=4)\n",
    "df.to_csv(f'{path_out}{f_out}_Ge77rates_new_samples.csv')\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "mode=\"HF\"\n",
    "filelist = utils.get_all_files(f\"../simulation/out/{mode}/{version_hf}/tier2/neutron-sim-HF-{version_hf}\")\n",
    "\n",
    "x_hf = np.empty([0,6])\n",
    "sum_target_y_hf = np.empty([0,1])\n",
    "mean_mu_cnp_hf = np.empty([0,1])\n",
    "mean_sigma_cnp_hf = np.empty([0,1])\n",
    "upper_lim_hf = np.empty([0,1])\n",
    "hist_target_sig = hist_target_bkg = hist_pred_sig = hist_pred_bkg = np.zeros(100)\n",
    "fout = open(f'{path_out}{f_out}_training_new_samples.txt', \"a\")\n",
    "rGe77_hf = np.empty([0,1])\n",
    "# create a PdfPages object\n",
    "pdf=PdfPages(f'{path_out}{f_out}_result_{mode}_new_samples.pdf')\n",
    "\n",
    "for i,file in enumerate(filelist):\n",
    "\n",
    "    path_to_files = file[:-4]\n",
    "    num_total_points = 0\n",
    "    with open(file, \"rbU\") as f:\n",
    "        num_total_points += int(np.floor(sum(1 for _ in f)))\n",
    "\n",
    "    MAX_CONTEXT_POINTS_NEW = int(1/3 * (num_total_points-1))\n",
    "    MAX_TARGET_POINTS_NEW = 2 * MAX_CONTEXT_POINTS_NEW\n",
    "\n",
    "    dataset_config = data.DataGeneration(num_iterations=1, num_context_points=MAX_CONTEXT_POINTS_NEW, num_target_points=MAX_TARGET_POINTS_NEW, batch_size = 1, use_data_augmentation=\"None\", path_to_files=path_to_files,x_size=x_size,y_size=y_size, mode = \"config\", ratio_testing=0.,names_x=names_x, name_y=name_y)\n",
    "    data_config = dataset_config.get_data(0, CONTEXT_IS_SUBSET)\n",
    "    \n",
    "    # Get the predicted mean and variance at the target points for the testing set\n",
    "    log_prob_config, mu_config, sigma_config = model(data_config.query, data_config.target_y)\n",
    "    # Define the loss\n",
    "    config_loss = -log_prob_config.mean()\n",
    "    if max(mu_config[0].detach().numpy()) <= 1 and min(mu_config[0].detach().numpy()) >= 0:\n",
    "            loss_bce_config = bce(mu_config,  data_config.target_y)\n",
    "    else:\n",
    "            loss_bce_config = -1.\n",
    "\n",
    "    mu_config = mu_config[0].detach().numpy()\n",
    "    \n",
    "    target_y = data_config.target_y[0].detach().numpy()\n",
    "    df = pd.read_csv(file, index_col=0)\n",
    "    x_hf         = np.append(x_hf,[df[[\"fidelity\",\"radius\",\"thickness\",\"npanels\",\"theta\",\"length\"]].to_numpy()[0]],axis=0)\n",
    "    #x         = np.append(x,[data_config.query[1][0][0][-5:].numpy()],axis=0)\n",
    "    sum_target_y_tmp = np.array([np.sum(target_y)])\n",
    "    sum_target_y_hf    = np.append(sum_target_y_hf, [sum_target_y_tmp], axis=0)\n",
    "    mean_mu_tmp = np.array([np.mean(mu_config)])\n",
    "    upper_lim_hf = np.append(upper_lim_hf,[np.array([np.percentile(mu_config,95.)])], axis=0)\n",
    "    mean_mu_cnp_hf = np.append(mean_mu_cnp_hf, [mean_mu_tmp], axis=0)\n",
    "    mean_sigma_tmp = np.array([np.mean(sigma_config[0].detach().numpy())])\n",
    "    mean_sigma_cnp_hf = np.append(mean_sigma_cnp_hf, [mean_sigma_tmp], axis=0)\n",
    "    rGe77_hf = np.append(rGe77_hf,[np.array([np.sum(pd.read_csv(file)[\"prod_rate_Ge77[nuc/(kg*yr)]\"].to_numpy())])], axis=0)\n",
    "    \n",
    "    hist_target_sig, hist_target_bkg, hist_pred_sig, hist_pred_bkg = plotting.sum_hist(mu_config, target_y, hist_target_sig, hist_target_bkg, hist_pred_sig, hist_pred_bkg)\n",
    "    print(\"{}/{} {}, {}, radius: {} cm, test loss: {} (bce {})\".format(i,len(filelist),datetime.datetime.now().strftime(\"%Y-%m-%d %H:%M:%S\"), mode,x_hf[-1,1], config_loss, loss_bce_config))\n",
    "    fout.write(\"{}, Iteration: {}, test loss: {} (bce {})\\n\".format(datetime.datetime.now().strftime(\"%Y-%m-%d %H:%M:%S\"), i, config_loss, loss_bce_config))\n",
    "    \n",
    "    fig = plotting.plot_result_configwise(mu_config, target_y, f'{config_loss:.2f}', x_hf[-1])\n",
    "    plt.close(fig)\n",
    "    pdf.savefig(fig)\n",
    "    #plt.show()\n",
    "    plt.clf()\n",
    "\n",
    "    \n",
    "fig1 = plotting.plot_result_summed(hist_target_sig, hist_target_bkg, hist_pred_sig, hist_pred_bkg)\n",
    "pdf.savefig(fig1)\n",
    "plt.show()\n",
    "plt.clf()\n",
    "\n",
    "fig2,_ = plt.subplots(3,2,sharey=True,figsize=(9, 9),layout=\"constrained\")\n",
    "ax2 = fig2.axes\n",
    "for i in range(len(x_hf[0,:])-1):\n",
    "    #ax2[i].plot(x_lf[:,0],mean_mu_cnp,'o')\n",
    "    ax2[i].errorbar(x_hf[:,i+1], mean_mu_cnp_hf[:,0], yerr=mean_sigma_cnp_hf[:,0],fmt='o', color='teal')\n",
    "    \n",
    "    ax2[i].set_xlabel(names_x[i])\n",
    "    if i % 2 == 0:\n",
    "        ax2[i].set_ylabel(r'$y_{CNP}$')\n",
    "for i in range(len(x_hf[0,:])-1,len(ax2)):\n",
    "     ax2[i].set_axis_off()\n",
    "fig2.suptitle('Conditional Neutral Process', fontsize=10)\n",
    "pdf.savefig(fig2)\n",
    "plt.show()\n",
    "\n",
    "fig3,_ = plt.subplots(3,2,sharey=True,figsize=(9, 9),layout=\"constrained\")\n",
    "ax3 = fig3.axes\n",
    "for i in range(len(x_hf[0,:])-1):\n",
    "    ax3[i].plot(x_hf[:,i+1],rGe77_hf,'o', color='teal')\n",
    "    if i % 2 == 0:\n",
    "        ax3[i].set_ylabel(r'nC on $^{76}Ge$')\n",
    "    ax3[i].set_xlabel(names_x[i])\n",
    "for i in range(len(x_hf[0,:])-1,len(ax3)):\n",
    "     ax3[i].set_axis_off()\n",
    "pdf.savefig(fig3)\n",
    "plt.show()\n",
    "\n",
    "pdf.close()\n",
    "fout.close()\n",
    "\n",
    "df= pd.read_csv(f'{path_out}{f_out}_Ge77rates_new_samples.csv', index_col=0)\n",
    "samples=np.arange(len(df))\n",
    "x = df[[\"Mode\",\"Radius[cm]\",\"Thickness[cm]\",\"NPanels\",\"Theta[deg]\",\"Length[cm]\",\"Ge-77[nevents]\",\"Ge-77_CNP\",\"Ge-77_CNP_err\",\"rGe77[nuc/(kg*yr)]\"]].to_numpy()\n",
    "x_tmp = np.append(x_hf, sum_target_y_hf, axis=1)\n",
    "x_tmp = np.append(x_tmp, mean_mu_cnp_hf, axis=1)\n",
    "x_tmp = np.append(x_tmp, mean_sigma_cnp_hf, axis=1)\n",
    "x_tmp = np.append(x_tmp, rGe77_hf, axis=1)\n",
    "x = np.append(x, x_tmp, axis=0)\n",
    "df = pd.DataFrame(x, columns=df.columns)\n",
    "samples = np.append(samples,[np.arange(len(x_hf))])\n",
    "\n",
    "df=df.round(decimals=4)\n",
    "df.to_csv(f'{path_out}{f_out}_Ge77rates_new_samples.csv')\n",
    "df.insert(0,\"Sample\",samples)\n",
    "df.to_csv(f'../multi-fidelity-gaussian-process/in/Ge77_rates_new_samples_{version_out}.csv')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig4,_ = plt.subplots(3,2,sharey=True,figsize=(9, 9),layout=\"constrained\")\n",
    "fig4.suptitle('Conditional Neutral Process', fontsize=10)\n",
    "ax4 = fig4.axes\n",
    "\n",
    "for i in range(len(x_lf[0,:])-1):\n",
    "    ax4[i].errorbar(x_lf[:,i+1], mean_mu_cnp_lf[:,0], yerr=mean_sigma_cnp_lf[:,0],fmt='o', color='teal')\n",
    "    ax4[i].set_xlabel(names_x[i])\n",
    "    if i % 2 == 0:\n",
    "        ax4[i].set_ylabel(r'mean probability for nC on $^{76}Ge$')\n",
    "\n",
    "for i in range(len(x_hf[0,:])-1):\n",
    "    #ax2[i].plot(x_lf[:,0],mean_mu_cnp,'o')\n",
    "    ax4[i].errorbar(x_hf[:,i+1], mean_mu_cnp_hf[:,0], yerr=mean_sigma_cnp_hf[:,0],fmt='o', color='orangered')\n",
    "    ax4[i].set_xlabel(names_x[i])\n",
    "\n",
    "for i in range(len(x_lf[0,:])-1,len(ax4)):\n",
    "     ax4[i].set_axis_off()\n",
    "\n",
    "\n",
    "\n",
    "for i in range(len(x_hf[0,:])-1,len(ax4)):\n",
    "     ax4[i].set_axis_off()\n",
    "\n",
    "#pdf.savefig(fig4)\n",
    "plt.show()"
   ]
  }
 ],
 "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.10.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
