{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "downloading ame2020.csv\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from kbgen.config import rootdir\n",
    "import urllib.request\n",
    "import os\n",
    "\n",
    "def delta(Z, N):\n",
    "    A = Z + N\n",
    "    aP = 11.18\n",
    "    delta = aP * A ** (-1 / 2)\n",
    "    delta[(Z % 2 == 1) & (N % 2 == 1)] *= -1\n",
    "    delta[(Z % 2 == 0) & (N % 2 == 1)] = 0\n",
    "    delta[(Z % 2 == 1) & (N % 2 == 0)] = 0\n",
    "    return delta\n",
    "\n",
    "\n",
    "def semi_empirical_mass_formula(Z, N):\n",
    "    A = N + Z\n",
    "    aV = 15.75\n",
    "    aS = 17.8\n",
    "    aC = 0.711\n",
    "    aA = 23.7\n",
    "    Eb = (\n",
    "        aV * A\n",
    "        - aS * A ** (2 / 3)\n",
    "        - aC * Z * (Z - 1) / (A ** (1 / 3))\n",
    "        - aA * (N - Z) ** 2 / A\n",
    "        + delta(Z, N)\n",
    "    )\n",
    "    Eb[Eb < 0] = 0\n",
    "    return Eb / A * 1000  # keV\n",
    "\n",
    "\n",
    "def apply_to_df_col(column):\n",
    "    def wrapper(fn):\n",
    "        return lambda df: df[column].astype(str).apply(fn)\n",
    "\n",
    "    return wrapper\n",
    "\n",
    "\n",
    "@apply_to_df_col(column=\"jp\")\n",
    "def get_spin_from(string):\n",
    "    string = (\n",
    "        string.replace(\"(\", \"\")\n",
    "        .replace(\")\", \"\")\n",
    "        .replace(\"+\", \"\")\n",
    "        .replace(\"-\", \"\")\n",
    "        .replace(\"]\", \"\")\n",
    "        .replace(\"[\", \"\")\n",
    "        .replace(\"GE\", \"\")\n",
    "        .replace(\"HIGH J\", \"\")\n",
    "        .replace(\">\", \"\")\n",
    "        .replace(\"<\", \"\")\n",
    "        .strip()\n",
    "        .split(\" \")[0]\n",
    "    )\n",
    "    if string == \"\":\n",
    "        return float(\"nan\")\n",
    "    else:\n",
    "        return float(eval(string))  # eval for 1/2 and such\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"jp\")\n",
    "def get_parity_from(string):\n",
    "    # find the first + or -\n",
    "    found_plus = string.find(\"+\")\n",
    "    found_minus = string.find(\"-\")\n",
    "\n",
    "    if found_plus == -1 and found_minus == -1:\n",
    "        return float(\"nan\")\n",
    "    elif found_plus == -1:\n",
    "        return 0  # -\n",
    "    elif found_minus == -1:\n",
    "        return 1  # +\n",
    "    elif found_plus < found_minus:\n",
    "        return 1  # +\n",
    "    elif found_plus > found_minus:\n",
    "        return 0  # -\n",
    "    else:\n",
    "        raise ValueError(\"something went wrong\")\n",
    "\n",
    "\n",
    "def get_half_life_from(df):\n",
    "    # selection excludes unknown lifetimes and ones where lifetimes are given as bounds\n",
    "    series = df.half_life_sec.copy()\n",
    "    series[(df.half_life_sec == \" \") | (df.operator_hl != \" \")] = float(\"nan\")\n",
    "    series = series.astype(float)\n",
    "    series = series.apply(np.log10)\n",
    "    return series\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"qa\")\n",
    "def get_qa_from(string):\n",
    "    # ~df.qa.isna() & (df.qa != \" \")\n",
    "    if string == \" \":\n",
    "        return float(\"nan\")\n",
    "    else:\n",
    "        return float(string)\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"qbm\")\n",
    "def get_qbm_from(string):\n",
    "    return float(string.replace(\" \", \"nan\"))\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"qbm_n\")\n",
    "def get_qbm_n_from(string):\n",
    "    return float(string.replace(\" \", \"nan\"))\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"qec\")\n",
    "def get_qec_from(string):\n",
    "    return float(string.replace(\" \", \"nan\"))\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"sn\")\n",
    "def get_sn_from(string):\n",
    "    return float(string.replace(\" \", \"nan\"))\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"sp\")\n",
    "def get_sp_from(string):\n",
    "    return float(string.replace(\" \", \"nan\"))\n",
    "\n",
    "\n",
    "def get_abundance_from(df):\n",
    "    # abundance:\n",
    "    # assumes that \" \" means 0\n",
    "    return df.abundance.replace(\" \", \"0\").astype(float)\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"half_life\")\n",
    "def get_stability_from(string):\n",
    "    if string == \"STABLE\":\n",
    "        return 1.0\n",
    "    elif string == \" \":\n",
    "        return float(\"nan\")\n",
    "    else:\n",
    "        return 0.0\n",
    "\n",
    "\n",
    "@apply_to_df_col(\"isospin\")\n",
    "def get_isospin_from(string):\n",
    "    return float(eval(string.replace(\" \", \"float('nan')\")))\n",
    "\n",
    "@apply_to_df_col(\"electric_quadrupole\")\n",
    "def get_electric_quadrupole_from(string):\n",
    "    return float(eval(string.replace(\" \", \"float('nan')\")))\n",
    "\n",
    "\n",
    "def get_binding_energy_from(df):\n",
    "    binding = df.binding.replace(\" \", \"nan\").astype(float)\n",
    "    return binding\n",
    "\n",
    "\n",
    "def get_radius_from(df):\n",
    "    return df.radius.replace(\" \", \"nan\").astype(float)\n",
    "\n",
    "\n",
    "def get_targets(df):\n",
    "    # place all targets into targets an empty copy of df\n",
    "    targets = df[[\"z\", \"n\"]].copy()\n",
    "    # binding energy per nucleon\n",
    "    targets[\"binding\"] = get_binding_energy_from(df)\n",
    "    # binding energy per nucleon minus semi empirical mass formula\n",
    "    targets[\"binding_semf\"] = targets.binding - semi_empirical_mass_formula(df.z, df.n)\n",
    "    # radius in fm\n",
    "    targets[\"radius\"] = get_radius_from(df)\n",
    "    # half life in log10(sec)\n",
    "    targets[\"half_life_sec\"] = get_half_life_from(df)\n",
    "    # stability in {0, 1, nan}\n",
    "    targets[\"stability\"] = get_stability_from(df)\n",
    "    # spin as float\n",
    "    targets[\"spin\"] = get_spin_from(df)\n",
    "    # parity as {0 (-),1 (+), nan}\n",
    "    targets[\"parity\"] = get_parity_from(df)\n",
    "    # isotope abundance in %\n",
    "    targets[\"abundance\"] = get_abundance_from(df)\n",
    "    # qa = alpha decay energy in keV\n",
    "    targets[\"qa\"] = get_qa_from(df)\n",
    "    # qbm = beta minus decay energy in keV\n",
    "    targets[\"qbm\"] = get_qbm_from(df)\n",
    "    # qbm_n = beta minus + neutron emission energy in keV\n",
    "    targets[\"qbm_n\"] = get_qbm_n_from(df)\n",
    "    # qec = electron capture energy in keV\n",
    "    targets[\"qec\"] = get_qec_from(df)\n",
    "    # sn = neutron separation energy in keV\n",
    "    targets[\"sn\"] = get_sn_from(df)\n",
    "    # sp = proton separation energy in keV\n",
    "    targets[\"sp\"] = get_sp_from(df)\n",
    "    # isospin as float\n",
    "    targets[\"isospin\"] = get_isospin_from(df)\n",
    "    # electric quadrupole moment in barns\n",
    "    targets[\"electric_quadrupole\"] = get_electric_quadrupole_from(df)\n",
    "    # These are semi-empirical mass formula terms\n",
    "    targets[\"volume\"] = targets.z + targets.n  # volume\n",
    "    targets[\"surface\"] = targets.volume ** (2 / 3)  # surface\n",
    "    targets[\"symmetry\"] = ((targets.z - targets.n) ** 2) / targets.volume  # symmetry\n",
    "    targets[\"delta\"] = delta(targets.z, targets.n)  # delta\n",
    "    targets[\"coulomb\"] = (targets.z**2 - targets.z) / targets.volume ** (\n",
    "        1 / 3\n",
    "    )  # coulomb\n",
    "\n",
    "    return targets\n",
    "\n",
    "\n",
    "def get_nuclear_data(recreate=False):\n",
    "    def lc_read_csv(url):\n",
    "        req = urllib.request.Request(\"https://nds.iaea.org/relnsd/v0/data?\" + url)\n",
    "        req.add_header(\n",
    "            \"User-Agent\",\n",
    "            \"Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:77.0) Gecko/20100101 Firefox/77.0\",\n",
    "        )\n",
    "        return pd.read_csv(urllib.request.urlopen(req))\n",
    "\n",
    "    datadir = os.path.join(rootdir, \"data/nuclr\")\n",
    "    if recreate or not os.path.exists(os.path.join(datadir, \"ground_states.csv\")):\n",
    "        os.makedirs(datadir, exist_ok=True)\n",
    "        df = lc_read_csv(\"fields=ground_states&nuclides=all\")\n",
    "        df.to_csv(os.path.join(datadir, \"ground_states.csv\"), index=False)\n",
    "    else:\n",
    "        ame_path = os.path.join(datadir, \"ame2020.csv\")\n",
    "        if not os.path.exists(ame_path):\n",
    "            os.makedirs(os.path.dirname(ame_path), exist_ok=True)\n",
    "            print(\"downloading ame2020.csv\")\n",
    "            urllib.request.urlretrieve(\n",
    "                \"https://zenodo.org/record/8345025/files/ame2020.csv?download=1\",\n",
    "                ame_path,\n",
    "            )\n",
    "        df2 = pd.read_csv(ame_path).set_index([\"z\", \"n\"])\n",
    "        df2 = df2[~df2.index.duplicated(keep=\"first\")]\n",
    "        df = pd.read_csv(os.path.join(datadir, \"ground_states.csv\")).set_index([\"z\", \"n\"])\n",
    "        df[\"binding_unc\"] = df2.binding_unc\n",
    "        df[\"binding_sys\"] = df2.binding_sys\n",
    "        df.reset_index(inplace=True)\n",
    "\n",
    "    df = get_targets(df)\n",
    "    df = df[\n",
    "        (df.z > 8) & (df.n > 8)\n",
    "    ]\n",
    "    df.to_csv(os.path.join(datadir, \"nuclr.csv\"), index=False)\n",
    "    return df\n",
    "\n",
    "get_nuclear_data()\n",
    "\n",
    "df = pd.read_csv(os.path.join(rootdir, 'data/nuclr', 'nuclr.csv'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>z</th>\n",
       "      <th>n</th>\n",
       "      <th>binding</th>\n",
       "      <th>binding_semf</th>\n",
       "      <th>radius</th>\n",
       "      <th>half_life_sec</th>\n",
       "      <th>stability</th>\n",
       "      <th>spin</th>\n",
       "      <th>parity</th>\n",
       "      <th>abundance</th>\n",
       "      <th>...</th>\n",
       "      <th>qec</th>\n",
       "      <th>sn</th>\n",
       "      <th>sp</th>\n",
       "      <th>isospin</th>\n",
       "      <th>electric_quadrupole</th>\n",
       "      <th>volume</th>\n",
       "      <th>surface</th>\n",
       "      <th>symmetry</th>\n",
       "      <th>delta</th>\n",
       "      <th>coulomb</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3338.000000</td>\n",
       "      <td>3338.000000</td>\n",
       "      <td>909.000000</td>\n",
       "      <td>2770.000000</td>\n",
       "      <td>3197.000000</td>\n",
       "      <td>2806.000000</td>\n",
       "      <td>2774.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>3035.000000</td>\n",
       "      <td>3270.000000</td>\n",
       "      <td>3212.000000</td>\n",
       "      <td>108.000000</td>\n",
       "      <td>526.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>57.280665</td>\n",
       "      <td>81.540838</td>\n",
       "      <td>7985.997867</td>\n",
       "      <td>-8.995421</td>\n",
       "      <td>4.715438</td>\n",
       "      <td>1.659136</td>\n",
       "      <td>0.076322</td>\n",
       "      <td>1.726835</td>\n",
       "      <td>0.678443</td>\n",
       "      <td>2.491827</td>\n",
       "      <td>...</td>\n",
       "      <td>-301.728265</td>\n",
       "      <td>7762.206856</td>\n",
       "      <td>7184.147363</td>\n",
       "      <td>1.134259</td>\n",
       "      <td>0.645015</td>\n",
       "      <td>138.821503</td>\n",
       "      <td>25.935824</td>\n",
       "      <td>4.934945</td>\n",
       "      <td>0.009312</td>\n",
       "      <td>703.846494</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>27.142675</td>\n",
       "      <td>42.178138</td>\n",
       "      <td>689.592600</td>\n",
       "      <td>199.368930</td>\n",
       "      <td>0.817895</td>\n",
       "      <td>4.292596</td>\n",
       "      <td>0.265553</td>\n",
       "      <td>1.771720</td>\n",
       "      <td>0.467158</td>\n",
       "      <td>12.789689</td>\n",
       "      <td>...</td>\n",
       "      <td>7958.977147</td>\n",
       "      <td>3674.157313</td>\n",
       "      <td>5474.348085</td>\n",
       "      <td>0.884990</td>\n",
       "      <td>1.400942</td>\n",
       "      <td>68.791533</td>\n",
       "      <td>9.357898</td>\n",
       "      <td>4.063336</td>\n",
       "      <td>0.896839</td>\n",
       "      <td>485.354687</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-224.958399</td>\n",
       "      <td>-0.114900</td>\n",
       "      <td>-22.065085</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>-31898.002000</td>\n",
       "      <td>-2146.000000</td>\n",
       "      <td>-3443.833600</td>\n",
       "      <td>-1.500000</td>\n",
       "      <td>-3.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-7.905454</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>36.000000</td>\n",
       "      <td>48.000000</td>\n",
       "      <td>7763.765475</td>\n",
       "      <td>-56.907912</td>\n",
       "      <td>4.305200</td>\n",
       "      <td>-0.514602</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>-5305.916000</td>\n",
       "      <td>5345.046200</td>\n",
       "      <td>3010.115100</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>-0.041700</td>\n",
       "      <td>85.000000</td>\n",
       "      <td>19.332111</td>\n",
       "      <td>1.227885</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>291.057015</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>58.000000</td>\n",
       "      <td>81.000000</td>\n",
       "      <td>8084.314300</td>\n",
       "      <td>-46.013140</td>\n",
       "      <td>4.880700</td>\n",
       "      <td>1.285445</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>416.772000</td>\n",
       "      <td>7268.835150</td>\n",
       "      <td>6120.530800</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.210500</td>\n",
       "      <td>139.000000</td>\n",
       "      <td>26.833451</td>\n",
       "      <td>4.114286</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>632.986299</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>79.000000</td>\n",
       "      <td>112.000000</td>\n",
       "      <td>8376.275175</td>\n",
       "      <td>-22.110414</td>\n",
       "      <td>5.381200</td>\n",
       "      <td>3.204209</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>2.500000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>5132.797500</td>\n",
       "      <td>9670.498925</td>\n",
       "      <td>10411.350750</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>0.840000</td>\n",
       "      <td>191.000000</td>\n",
       "      <td>33.165680</td>\n",
       "      <td>8.133110</td>\n",
       "      <td>0.684208</td>\n",
       "      <td>1071.851967</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>118.000000</td>\n",
       "      <td>178.000000</td>\n",
       "      <td>8794.555500</td>\n",
       "      <td>3349.038000</td>\n",
       "      <td>5.904800</td>\n",
       "      <td>32.385585</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>23956.622000</td>\n",
       "      <td>27715.000000</td>\n",
       "      <td>32060.654900</td>\n",
       "      <td>4.500000</td>\n",
       "      <td>10.600000</td>\n",
       "      <td>294.000000</td>\n",
       "      <td>44.214517</td>\n",
       "      <td>19.768627</td>\n",
       "      <td>5.590000</td>\n",
       "      <td>2076.277633</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8 rows × 23 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                 z            n      binding  binding_semf      radius  \\\n",
       "count  3367.000000  3367.000000  3338.000000   3338.000000  909.000000   \n",
       "mean     57.280665    81.540838  7985.997867     -8.995421    4.715438   \n",
       "std      27.142675    42.178138   689.592600    199.368930    0.817895   \n",
       "min       0.000000     0.000000     0.000000   -224.958399   -0.114900   \n",
       "25%      36.000000    48.000000  7763.765475    -56.907912    4.305200   \n",
       "50%      58.000000    81.000000  8084.314300    -46.013140    4.880700   \n",
       "75%      79.000000   112.000000  8376.275175    -22.110414    5.381200   \n",
       "max     118.000000   178.000000  8794.555500   3349.038000    5.904800   \n",
       "\n",
       "       half_life_sec    stability         spin       parity    abundance  ...  \\\n",
       "count    2770.000000  3197.000000  2806.000000  2774.000000  3367.000000  ...   \n",
       "mean        1.659136     0.076322     1.726835     0.678443     2.491827  ...   \n",
       "std         4.292596     0.265553     1.771720     0.467158    12.789689  ...   \n",
       "min       -22.065085     0.000000     0.000000     0.000000     0.000000  ...   \n",
       "25%        -0.514602     0.000000     0.000000     0.000000     0.000000  ...   \n",
       "50%         1.285445     0.000000     1.500000     1.000000     0.000000  ...   \n",
       "75%         3.204209     0.000000     2.500000     1.000000     0.000000  ...   \n",
       "max        32.385585     1.000000    10.000000     1.000000   100.000000  ...   \n",
       "\n",
       "                qec            sn            sp     isospin  \\\n",
       "count   3035.000000   3270.000000   3212.000000  108.000000   \n",
       "mean    -301.728265   7762.206856   7184.147363    1.134259   \n",
       "std     7958.977147   3674.157313   5474.348085    0.884990   \n",
       "min   -31898.002000  -2146.000000  -3443.833600   -1.500000   \n",
       "25%    -5305.916000   5345.046200   3010.115100    0.500000   \n",
       "50%      416.772000   7268.835150   6120.530800    1.000000   \n",
       "75%     5132.797500   9670.498925  10411.350750    1.500000   \n",
       "max    23956.622000  27715.000000  32060.654900    4.500000   \n",
       "\n",
       "       electric_quadrupole       volume      surface     symmetry  \\\n",
       "count           526.000000  3367.000000  3367.000000  3367.000000   \n",
       "mean              0.645015   138.821503    25.935824     4.934945   \n",
       "std               1.400942    68.791533     9.357898     4.063336   \n",
       "min              -3.000000     1.000000     1.000000     0.000000   \n",
       "25%              -0.041700    85.000000    19.332111     1.227885   \n",
       "50%               0.210500   139.000000    26.833451     4.114286   \n",
       "75%               0.840000   191.000000    33.165680     8.133110   \n",
       "max              10.600000   294.000000    44.214517    19.768627   \n",
       "\n",
       "             delta      coulomb  \n",
       "count  3367.000000  3367.000000  \n",
       "mean      0.009312   703.846494  \n",
       "std       0.896839   485.354687  \n",
       "min      -7.905454     0.000000  \n",
       "25%       0.000000   291.057015  \n",
       "50%       0.000000   632.986299  \n",
       "75%       0.684208  1071.851967  \n",
       "max       5.590000  2076.277633  \n",
       "\n",
       "[8 rows x 23 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "df.replace(\" \", float(\"NaN\"), inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>z</th>\n",
       "      <th>n</th>\n",
       "      <th>binding</th>\n",
       "      <th>binding_semf</th>\n",
       "      <th>radius</th>\n",
       "      <th>half_life_sec</th>\n",
       "      <th>stability</th>\n",
       "      <th>spin</th>\n",
       "      <th>parity</th>\n",
       "      <th>abundance</th>\n",
       "      <th>...</th>\n",
       "      <th>qec</th>\n",
       "      <th>sn</th>\n",
       "      <th>sp</th>\n",
       "      <th>isospin</th>\n",
       "      <th>electric_quadrupole</th>\n",
       "      <th>volume</th>\n",
       "      <th>surface</th>\n",
       "      <th>symmetry</th>\n",
       "      <th>delta</th>\n",
       "      <th>coulomb</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3338.000000</td>\n",
       "      <td>3338.000000</td>\n",
       "      <td>909.000000</td>\n",
       "      <td>2770.000000</td>\n",
       "      <td>3197.000000</td>\n",
       "      <td>2806.000000</td>\n",
       "      <td>2774.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>3035.000000</td>\n",
       "      <td>3270.000000</td>\n",
       "      <td>3212.000000</td>\n",
       "      <td>108.000000</td>\n",
       "      <td>526.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "      <td>3367.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>57.280665</td>\n",
       "      <td>81.540838</td>\n",
       "      <td>7985.997867</td>\n",
       "      <td>-8.995421</td>\n",
       "      <td>4.715438</td>\n",
       "      <td>1.659136</td>\n",
       "      <td>0.076322</td>\n",
       "      <td>1.726835</td>\n",
       "      <td>0.678443</td>\n",
       "      <td>2.491827</td>\n",
       "      <td>...</td>\n",
       "      <td>-301.728265</td>\n",
       "      <td>7762.206856</td>\n",
       "      <td>7184.147363</td>\n",
       "      <td>1.134259</td>\n",
       "      <td>0.645015</td>\n",
       "      <td>138.821503</td>\n",
       "      <td>25.935824</td>\n",
       "      <td>4.934945</td>\n",
       "      <td>0.009312</td>\n",
       "      <td>703.846494</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>27.142675</td>\n",
       "      <td>42.178138</td>\n",
       "      <td>689.592600</td>\n",
       "      <td>199.368930</td>\n",
       "      <td>0.817895</td>\n",
       "      <td>4.292596</td>\n",
       "      <td>0.265553</td>\n",
       "      <td>1.771720</td>\n",
       "      <td>0.467158</td>\n",
       "      <td>12.789689</td>\n",
       "      <td>...</td>\n",
       "      <td>7958.977147</td>\n",
       "      <td>3674.157313</td>\n",
       "      <td>5474.348085</td>\n",
       "      <td>0.884990</td>\n",
       "      <td>1.400942</td>\n",
       "      <td>68.791533</td>\n",
       "      <td>9.357898</td>\n",
       "      <td>4.063336</td>\n",
       "      <td>0.896839</td>\n",
       "      <td>485.354687</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-224.958399</td>\n",
       "      <td>-0.114900</td>\n",
       "      <td>-22.065085</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>-31898.002000</td>\n",
       "      <td>-2146.000000</td>\n",
       "      <td>-3443.833600</td>\n",
       "      <td>-1.500000</td>\n",
       "      <td>-3.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>-7.905454</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>36.000000</td>\n",
       "      <td>48.000000</td>\n",
       "      <td>7763.765475</td>\n",
       "      <td>-56.907912</td>\n",
       "      <td>4.305200</td>\n",
       "      <td>-0.514602</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>-5305.916000</td>\n",
       "      <td>5345.046200</td>\n",
       "      <td>3010.115100</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>-0.041700</td>\n",
       "      <td>85.000000</td>\n",
       "      <td>19.332111</td>\n",
       "      <td>1.227885</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>291.057015</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>58.000000</td>\n",
       "      <td>81.000000</td>\n",
       "      <td>8084.314300</td>\n",
       "      <td>-46.013140</td>\n",
       "      <td>4.880700</td>\n",
       "      <td>1.285445</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>416.772000</td>\n",
       "      <td>7268.835150</td>\n",
       "      <td>6120.530800</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.210500</td>\n",
       "      <td>139.000000</td>\n",
       "      <td>26.833451</td>\n",
       "      <td>4.114286</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>632.986299</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>79.000000</td>\n",
       "      <td>112.000000</td>\n",
       "      <td>8376.275175</td>\n",
       "      <td>-22.110414</td>\n",
       "      <td>5.381200</td>\n",
       "      <td>3.204209</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>2.500000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>5132.797500</td>\n",
       "      <td>9670.498925</td>\n",
       "      <td>10411.350750</td>\n",
       "      <td>1.500000</td>\n",
       "      <td>0.840000</td>\n",
       "      <td>191.000000</td>\n",
       "      <td>33.165680</td>\n",
       "      <td>8.133110</td>\n",
       "      <td>0.684208</td>\n",
       "      <td>1071.851967</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>118.000000</td>\n",
       "      <td>178.000000</td>\n",
       "      <td>8794.555500</td>\n",
       "      <td>3349.038000</td>\n",
       "      <td>5.904800</td>\n",
       "      <td>32.385585</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>23956.622000</td>\n",
       "      <td>27715.000000</td>\n",
       "      <td>32060.654900</td>\n",
       "      <td>4.500000</td>\n",
       "      <td>10.600000</td>\n",
       "      <td>294.000000</td>\n",
       "      <td>44.214517</td>\n",
       "      <td>19.768627</td>\n",
       "      <td>5.590000</td>\n",
       "      <td>2076.277633</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8 rows × 23 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                 z            n      binding  binding_semf      radius  \\\n",
       "count  3367.000000  3367.000000  3338.000000   3338.000000  909.000000   \n",
       "mean     57.280665    81.540838  7985.997867     -8.995421    4.715438   \n",
       "std      27.142675    42.178138   689.592600    199.368930    0.817895   \n",
       "min       0.000000     0.000000     0.000000   -224.958399   -0.114900   \n",
       "25%      36.000000    48.000000  7763.765475    -56.907912    4.305200   \n",
       "50%      58.000000    81.000000  8084.314300    -46.013140    4.880700   \n",
       "75%      79.000000   112.000000  8376.275175    -22.110414    5.381200   \n",
       "max     118.000000   178.000000  8794.555500   3349.038000    5.904800   \n",
       "\n",
       "       half_life_sec    stability         spin       parity    abundance  ...  \\\n",
       "count    2770.000000  3197.000000  2806.000000  2774.000000  3367.000000  ...   \n",
       "mean        1.659136     0.076322     1.726835     0.678443     2.491827  ...   \n",
       "std         4.292596     0.265553     1.771720     0.467158    12.789689  ...   \n",
       "min       -22.065085     0.000000     0.000000     0.000000     0.000000  ...   \n",
       "25%        -0.514602     0.000000     0.000000     0.000000     0.000000  ...   \n",
       "50%         1.285445     0.000000     1.500000     1.000000     0.000000  ...   \n",
       "75%         3.204209     0.000000     2.500000     1.000000     0.000000  ...   \n",
       "max        32.385585     1.000000    10.000000     1.000000   100.000000  ...   \n",
       "\n",
       "                qec            sn            sp     isospin  \\\n",
       "count   3035.000000   3270.000000   3212.000000  108.000000   \n",
       "mean    -301.728265   7762.206856   7184.147363    1.134259   \n",
       "std     7958.977147   3674.157313   5474.348085    0.884990   \n",
       "min   -31898.002000  -2146.000000  -3443.833600   -1.500000   \n",
       "25%    -5305.916000   5345.046200   3010.115100    0.500000   \n",
       "50%      416.772000   7268.835150   6120.530800    1.000000   \n",
       "75%     5132.797500   9670.498925  10411.350750    1.500000   \n",
       "max    23956.622000  27715.000000  32060.654900    4.500000   \n",
       "\n",
       "       electric_quadrupole       volume      surface     symmetry  \\\n",
       "count           526.000000  3367.000000  3367.000000  3367.000000   \n",
       "mean              0.645015   138.821503    25.935824     4.934945   \n",
       "std               1.400942    68.791533     9.357898     4.063336   \n",
       "min              -3.000000     1.000000     1.000000     0.000000   \n",
       "25%              -0.041700    85.000000    19.332111     1.227885   \n",
       "50%               0.210500   139.000000    26.833451     4.114286   \n",
       "75%               0.840000   191.000000    33.165680     8.133110   \n",
       "max              10.600000   294.000000    44.214517    19.768627   \n",
       "\n",
       "             delta      coulomb  \n",
       "count  3367.000000  3367.000000  \n",
       "mean      0.009312   703.846494  \n",
       "std       0.896839   485.354687  \n",
       "min      -7.905454     0.000000  \n",
       "25%       0.000000   291.057015  \n",
       "50%       0.000000   632.986299  \n",
       "75%       0.684208  1071.851967  \n",
       "max       5.590000  2076.277633  \n",
       "\n",
       "[8 rows x 23 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "z                        int64\n",
       "n                        int64\n",
       "binding                float64\n",
       "binding_semf           float64\n",
       "radius                 float64\n",
       "half_life_sec          float64\n",
       "stability              float64\n",
       "spin                   float64\n",
       "parity                 float64\n",
       "abundance              float64\n",
       "qa                     float64\n",
       "qbm                    float64\n",
       "qbm_n                  float64\n",
       "qec                    float64\n",
       "sn                     float64\n",
       "sp                     float64\n",
       "isospin                float64\n",
       "electric_quadrupole    float64\n",
       "volume                   int64\n",
       "surface                float64\n",
       "symmetry               float64\n",
       "delta                  float64\n",
       "coulomb                float64\n",
       "dtype: object"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# dtype per column\n",
    "df.dtypes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       " 1.0    30\n",
       " 0.5    20\n",
       " 1.5    20\n",
       " 2.0    13\n",
       " 0.0    12\n",
       " 2.5     6\n",
       " 3.0     2\n",
       "-0.5     2\n",
       " 4.5     1\n",
       " 3.5     1\n",
       "-1.5     1\n",
       "Name: isospin, dtype: int64"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[\"isospin\"].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 0 is numerical and 1 is categorical\n",
    "# columns:\n",
    "# 'z', 'n', 'binding', 'binding_semf', 'radius', 'half_life_sec',\n",
    "#        'stability', 'spin', 'parity', 'abundance', 'qa', 'qbm', 'qbm_n', 'qec',\n",
    "#        'sn', 'sp', 'isospin', 'electric_quadrupole', 'volume', 'surface',\n",
    "#        'symmetry', 'delta', 'coulomb'\n",
    "schema = {\n",
    "    'z': 0,\n",
    "    'n': 0,\n",
    "    'binding' : 0,\n",
    "    'binding_semf' : 0,\n",
    "    'radius' : 0,\n",
    "    'half_life_sec' : 0,\n",
    "    'stability' : 1,\n",
    "    'spin' : 0,\n",
    "    'parity' : 1,\n",
    "    'abundance' : 0,\n",
    "    'qa' : 0,\n",
    "    'qbm' : 0,\n",
    "    'qbm_n' : 0,\n",
    "    'qec' : 0,\n",
    "    'sn' : 0,\n",
    "    'sp' : 0,\n",
    "    'isospin' : 1,\n",
    "    'electric_quadrupole' : 0,\n",
    "    'volume' : 0,\n",
    "    'surface' : 0,\n",
    "    'symmetry' : 0,\n",
    "    'delta' : 0,\n",
    "    'coulomb' : 0\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'z': 0,\n",
       " 'n': 0,\n",
       " 'binding': 0,\n",
       " 'binding_semf': 0,\n",
       " 'radius': 0,\n",
       " 'half_life_sec': 0,\n",
       " 'stability': 1,\n",
       " 'spin': 0,\n",
       " 'parity': 1,\n",
       " 'abundance': 0,\n",
       " 'qa': 0,\n",
       " 'qbm': 0,\n",
       " 'qbm_n': 0,\n",
       " 'qec': 0,\n",
       " 'sn': 0,\n",
       " 'sp': 0,\n",
       " 'isospin': 1,\n",
       " 'electric_quadrupole': 0,\n",
       " 'volume': 0,\n",
       " 'surface': 0,\n",
       " 'symmetry': 0,\n",
       " 'delta': 0,\n",
       " 'coulomb': 0}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# save schema\n",
    "import json\n",
    "json.dump(schema, open(os.path.join(rootdir, 'data/nuclr', 'nuclr_schema.json'), 'w'))\n",
    "schema = json.load(open(os.path.join(rootdir, 'data/nuclr', 'nuclr_schema.json'), 'r'))\n",
    "schema"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[<Axes: title={'center': 'z'}>, <Axes: title={'center': 'n'}>,\n",
       "        <Axes: title={'center': 'binding'}>,\n",
       "        <Axes: title={'center': 'binding_semf'}>,\n",
       "        <Axes: title={'center': 'radius'}>],\n",
       "       [<Axes: title={'center': 'half_life_sec'}>,\n",
       "        <Axes: title={'center': 'stability'}>,\n",
       "        <Axes: title={'center': 'spin'}>,\n",
       "        <Axes: title={'center': 'parity'}>,\n",
       "        <Axes: title={'center': 'abundance'}>],\n",
       "       [<Axes: title={'center': 'qa'}>, <Axes: title={'center': 'qbm'}>,\n",
       "        <Axes: title={'center': 'qbm_n'}>,\n",
       "        <Axes: title={'center': 'qec'}>, <Axes: title={'center': 'sn'}>],\n",
       "       [<Axes: title={'center': 'sp'}>,\n",
       "        <Axes: title={'center': 'isospin'}>,\n",
       "        <Axes: title={'center': 'electric_quadrupole'}>,\n",
       "        <Axes: title={'center': 'volume'}>,\n",
       "        <Axes: title={'center': 'surface'}>],\n",
       "       [<Axes: title={'center': 'symmetry'}>,\n",
       "        <Axes: title={'center': 'delta'}>,\n",
       "        <Axes: title={'center': 'coulomb'}>, <Axes: >, <Axes: >]],\n",
       "      dtype=object)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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PUJQUJDSX+9ubm5o166dxvlTF9v824mNjRXynd/7778PExPd3hjnsvtPq1athHV9//33ePjwoUqaw4cPw8vLC82aNUN2drYwBQQEqH0006VLF1haWgqfGzZsCADo2bOnUrko5qt7XKQP7733ntLnV69e4fPPP8dbb70FExMTmJiYoFq1anj9+jVu3rwppDt16hS6desGBwcHYZ6xsTEGDhyotbzZ2NjAw8MDixcvxrJly/D7778jNzdXa+vXBa706NH8+fOxZs0arF27Fj169NB3dtj/s7W1VfqseFMjIyNDH9mpUBwdHZU+m5iYwNbWFqmpqUUuV1yZK5YvuP7C5pV1O/kvFMB/+6FLXHb/6dSpE/bv34/s7Gx89NFHqFWrFry8vLBz504hTXJyMq5cuQKxWKw0WVlZgYhUugAo2HTA1NS0yPlv3rwpUZ51xcnJSelzUFAQVq5ciZEjR+Lo0aP47bffcOHCBdSsWVPpHJWamlrmmBdHJBLhxIkTCAgIQGRkJN5++23UrFkTkyZNwsuXL7W2HW3iNj16snnzZsycORPh4eEqjfMYq6iSkpLg4uIifM7OzkZqamqZKwyK5ZOSktRuU1sU20lOTla7H7rEZaesb9++6Nu3LzIzM3Hu3DlEREQgKCgIderUQdu2bWFnZwdzc/NC29op2rZUdPnvQslkMhw+fBizZ8/G1KlThfmZmZl49uyZ0nK2traljrmZmZmw3vzU9SXl5uaGjRs3AgD++usvfP/99wgPD0dWVhbWrFlT7LbKG9/p0YPo6GiMGjUKw4cPx+zZs/WdHca0Zvv27Uqfv//+e2RnZ5e547P69evDyckJO3fuBBEJ8+/du4e4uLgyrTu/Tp06AQB2796tNP/HH39Edna21rajDpedehKJBL6+vli0aBEA4PfffwcABAYG4p9//oGtrS1atmypMhXsdLEyEIlEICKVfoI2bNiAnJwcpXldunTBiRMnkJycLMzLyclRiY86irK7cuWK0vyDBw8WuZynpydmzJgBb29vXLp0qdjt6APf6Slnd+7cwQcffIC6deti2LBhKq+WNm/evNJ1fMWqjr1798LExAR+fn7CG0hNmzZVaedRUkZGRpg3bx5GjhyJd999F6NGjcKLFy8QHh6u1dv1jRs3xuDBg7F06VIYGxuja9euuH79OpYuXQqpVKrxm06lwWX3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",
      "text/plain": [
       "<Figure size 640x480 with 25 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df.hist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "processed data not found, tokenizing...\n",
      "done\n"
     ]
    }
   ],
   "source": [
    "from kbgen.data.datasets import NuCLR\n",
    "from kbgen.config import defaults_customLM as config\n",
    "\n",
    "config[\"tokenizer\"] = \"custom\"\n",
    "dataset = NuCLR.from_config(config)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sandbox",
   "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"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
