{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import curve_fit\n",
    "import random\n",
    "import dask.dataframe as dd\n",
    "import sys\n",
    "sys.path.append('../utilities')\n",
    "import utilities as utils\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# read in LF simulations\n",
    "version = 'n1.4'\n",
    "if not os.path.exists(f'out/{version}'):\n",
    "   os.makedirs(f'out/{version}')\n",
    "\n",
    "filelist = utils.get_all_files(f\"../simulation/out/LF/{version}/tier2/\",\".csv\")\n",
    "x = np.empty([0,12])\n",
    "for file in filelist:\n",
    "   print(file)\n",
    "   #df = pd.read_csv(file)\n",
    "   #del df['nprimaries']\n",
    "   #df.insert(len(df.columns),'nprimaries',np.ones(len(df)))\n",
    "   #print(df)\n",
    "   #df.to_csv(file)\n",
    "   df = dd.read_csv(file)\n",
    "   x = np.append(x,[np.array([0., \n",
    "                              df[\"radius\"].compute()[0], \n",
    "                              df[\"thickness\"].compute()[0], \n",
    "                              df[\"npanels\"].compute()[0], \n",
    "                              df[\"theta\"].compute()[0], df[\"length\"].compute()[0], \n",
    "                              np.sum(df[\"total_nC_Ge77[cts]\"].compute()), \n",
    "                              np.sum(df[\"prod_rate_Ge77[nuc/(kg*yr)]\"].compute()),\n",
    "                              df[\"nC_Ge77_scaling\"].compute()[0], np.sum(df[\"nprimaries\"].compute()),\n",
    "                              np.sum(df[\"nprimaries\"].compute())+np.sum(df[\"nsec\"].compute()), \n",
    "                              np.sum(df[\"nsec\"].compute())])],\n",
    "                              axis=0)\n",
    "\n",
    "nLF=len(filelist)\n",
    "# read in HF simulations\n",
    "version = 'v1.1'\n",
    "if not os.path.exists(f'out/{version}'):\n",
    "   os.makedirs(f'out/{version}')\n",
    "nfiles = [202, 185, 193, 197]\n",
    "filelist = utils.get_all_files(f\"../simulation/out/HF/{version}/tier2/neutron-sim-HF-n1.1\",\".csv\")\n",
    "print(filelist)\n",
    "for i, file in enumerate(filelist):\n",
    "   df = dd.read_csv(file)\n",
    "   x = np.append(x,[np.array([1., df[\"radius\"].compute()[0], df[\"thickness\"].compute()[0], df[\"npanels\"].compute()[0], df[\"theta\"].compute()[0], df[\"length\"].compute()[0], np.sum(df[\"total_nC_Ge77[cts]\"].compute()), np.sum(df[\"prod_rate_Ge77[nuc/(kg*yr)]\"].compute()),df[\"nC_Ge77_scaling\"].compute()[0],np.sum(df[\"nprimaries\"].compute()),len(df.compute())+np.sum(df[\"nsec\"].compute()),np.sum(df[\"nsec\"].compute())])],axis=0)\n",
    "\n",
    "df_new = dd.from_array(x, columns = [\"mode\",\"radius\",\"thickness\",\"npanels\",\"theta\",\"length\", \"nC_Ge77[cts]\", \"production\", \"scaling\", \"nprimaries\",\"neutrons\",\"nsec\"])\n",
    "nHF = len(filelist)\n",
    "version = 'n1.4'\n",
    "print(df_new.compute())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "r_water = 11./2.\n",
    "frac_enter_exp = 0.27\n",
    "rate_muon = 3.6 * 1.e-4 * (np.pi*r_water**2) * (60.*60.*24.*365)\n",
    "frac_neutrons_LAr = np.zeros(nHF+nLF)\n",
    "frac_neutrons_LAr[:nLF] = 1./0.13\n",
    "frac_neutrons_LAr[nLF:] = 1.\n",
    "\n",
    "factor = (df_new[\"nprimaries\"].to_dask_array().compute()+df_new[\"nsec\"].to_dask_array().compute()) * frac_enter_exp * frac_neutrons_LAr / rate_muon\n",
    "print(df_new[\"nprimaries\"].to_dask_array().compute()[0]+df_new[\"nsec\"].to_dask_array().compute()[0],df_new[\"nC_Ge77[cts]\"].to_dask_array().compute()[0],rate_muon)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "rate_Ge77 = df_new[\"nC_Ge77[cts]\"].to_dask_array().compute()/factor/1000.\n",
    "df_new[\"rate_Ge77[nuc/kg/yr]\"]=dd.from_array(np.round(rate_Ge77,5))\n",
    "print(rate_Ge77)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, _ = plt.subplots(3,2,sharey=True,figsize=(12, 12) ,layout=\"constrained\")\n",
    "ax = fig.axes\n",
    "ax[0].plot(df_new[\"radius\"].to_dask_array().compute()[:-6],rate_Ge77[:-6], \"o\",color=\"teal\", label=\"low fidelity\")\n",
    "ax[0].plot(df_new[\"radius\"].to_dask_array().compute()[-6:],rate_Ge77[-6:], \"o\",color=\"orangered\", label=\"high fidelity\")\n",
    "ax[0].set_xlabel(\"radius [cm]\", fontsize=10)\n",
    "ax[0].set_ylabel(r\"$^{77}Ge$ production rate [nuc/(kg$\\cdot$yr)]\", fontsize=10)\n",
    "ax[0].legend(loc=\"lower left\")\n",
    "\n",
    "ax[1].plot(df_new[\"thickness\"].to_dask_array().compute()[:-6],rate_Ge77[:-6], \"o\",color=\"teal\", label=\"low fidelity\")\n",
    "ax[1].plot(df_new[\"thickness\"].to_dask_array().compute()[-6:],rate_Ge77[-6:], \"o\",color=\"orangered\", label=\"high fidelity\")\n",
    "ax[1].set_xlabel(\"thickness [cm]\", fontsize=10)\n",
    "\n",
    "fig = plt.figure(figsize=(8,6))\n",
    "ax[2].plot(df_new[\"npanels\"].to_dask_array().compute()[:-6],rate_Ge77[:-6], \"o\",color=\"teal\", label=\"low fidelity\")\n",
    "ax[2].plot(df_new[\"npanels\"].to_dask_array().compute()[-6:],rate_Ge77[-6:], \"o\",color=\"orangered\", label=\"high fidelity\")\n",
    "ax[2].set_xlabel(\"number of panels\", fontsize=10)\n",
    "ax[2].set_ylabel(r\"$^{77}Ge$ production rate [nuc/(kg$\\cdot$yr)]\", fontsize=10)\n",
    "\n",
    "ax[3].plot(df_new[\"theta\"].to_dask_array().compute()[:-6],rate_Ge77[:-6], \"o\",color=\"teal\", label=\"low fidelity\")\n",
    "ax[3].plot(df_new[\"theta\"].to_dask_array().compute()[-6:],rate_Ge77[-6:], \"o\",color=\"orangered\", label=\"high fidelity\")\n",
    "ax[3].set_xlabel(\"angle of panels [deg]\", fontsize=10)\n",
    "\n",
    "\n",
    "ax[4].plot(df_new[\"length\"].to_dask_array().compute()[:-6],rate_Ge77[:-6], \"o\",color=\"teal\", label=\"low fidelity\")\n",
    "ax[4].plot(df_new[\"length\"].to_dask_array().compute()[-6:],rate_Ge77[-6:], \"o\",color=\"orangered\", label=\"high fidelity\")\n",
    "ax[4].set_xlabel(\"length [cm]\", fontsize=10)\n",
    "ax[4].set_ylabel(r\"$^{77}Ge$ production rate [nuc/(kg$\\cdot$yr)]\", fontsize=10)\n",
    "ax[5].set_axis_off()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def monte_carlo_simulations(rate_mean, rate_std, n_iter=10000):\n",
    "    outputs = []\n",
    "    for i in range(n_iter):\n",
    "        result = random.normalvariate(rate_mean, rate_std)\n",
    "        outputs.append(result)\n",
    "    return outputs\n",
    "\n",
    "def gauss(x, A, mean, sigma):\n",
    "    return A * np.exp(-(x - mean) ** 2 / (2 * sigma ** 2))\n",
    "\n",
    "def Ge77MonteCarlosSim(nevt,factor):\n",
    "    sigma = []\n",
    "    for i,evt in enumerate(nevt):\n",
    "        nevt_std=np.sqrt(evt)\n",
    "        events = monte_carlo_simulations(evt,nevt_std)\n",
    "        events = np.array(events) * factor[i]\n",
    "        values, bins = np.histogram(events, bins=100)    \n",
    "        x = (bins[:-1] + bins[1:]) / 2\n",
    "        plt.scatter(x,values)\n",
    "        parameters, covariance = curve_fit(gauss, x, values, p0=[250, evt*factor[i], nevt_std*factor[i]])\n",
    "        plt.plot(x,gauss(x,parameters[0],parameters[1],parameters[2]))\n",
    "        sigma.append(parameters[2])\n",
    "    return sigma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sigma = Ge77MonteCarlosSim(df_new[\"nC_Ge77[cts]\"].to_dask_array().compute()[:nLF],1./(factor[:nLF]*1000.))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,4))\n",
    "mean = np.mean(sigma)\n",
    "std = np.std(sigma)\n",
    "plt.axhline(y = mean, color = 'orangered')\n",
    "x=[i for i in range(0,265)]\n",
    "plt.fill_between(x,mean-std,mean+std,color='coral', alpha=0.3)\n",
    "plt.plot(df_new[\"radius\"].to_dask_array().compute()[:nLF],sigma,\"o\",color=\"teal\")\n",
    "plt.xlabel('Radius [cm]')\n",
    "plt.ylabel(r'$\\sigma\\,\\rm [nuclei/(kg \\cdot yr)]$')\n",
    "plt.text(210,0.012,f\"mean = {np.round(mean,4)} +- {np.round(std,4)}\",fontsize=8)\n",
    "\n",
    "plt.savefig(f\"out/{version}/noise_LF_{version}.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "f=open(f'out/{version}/Ge77_rates_{version}.csv',\"w\")\n",
    "f.write(f\"# LF noise: mean = {mean:.5f} +- {std:.5f}\"+\"\\n\")\n",
    "f.close()\n",
    "df_new.to_csv(f'out/{version}/Ge77_rates_{version}.csv',mode='a')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "legend",
   "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": 4
}
