{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2d456214",
   "metadata": {},
   "outputs": [],
   "source": [
    "# make ipython reload modules whenever they have changed on disk\n",
    "%load_ext autoreload\n",
    "%autoreload 2 \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "dfd5887d",
   "metadata": {},
   "outputs": [],
   "source": [
    "#conda create -n tf-gpu tensorflow-gpu\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "acda027c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import librosa\n",
    "import librosa.display\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "plt.style.use('Solarize_Light2')\n",
    "prop_cycle = plt.rcParams['axes.prop_cycle']\n",
    "colors = prop_cycle.by_key()['color']\n",
    "blue = colors[1]\n",
    "red = colors[5]\n",
    "import tensorflow as tf\n",
    "import os, sys\n",
    "import sound_tools\n",
    "import utils\n",
    "from sklearn.model_selection import train_test_split\n",
    "import pickle\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a7e74102",
   "metadata": {},
   "outputs": [],
   "source": [
    "DATA           = '/home/braghadeesh/Audio_Data_Neurips_2021/0_dB_slider/slider'\n",
    "#PROCESSED_DATA = os.path.join(DATA, 'processed_new_04')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6ab8df67",
   "metadata": {},
   "source": [
    "# feature params\n",
    "\n",
    "n_mels = 64\n",
    "frames = 5\n",
    "n_fft = 1024\n",
    "hop_length = 512\n",
    "power = 2.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b0975cba",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_mels = 64\n",
    "frames = 5\n",
    "n_fft = 1024\n",
    "hop_length = 512\n",
    "power = 2.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f459a5ab",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# Build the list of normal and abnormal files:\n",
    "normal_files, abnormal_files = utils.build_files_list(root_dir=DATA)\n",
    "\n",
    "# filter and retain only files for machine id 00\n",
    "normal_files = [f for f in normal_files if 'id_06' in f]\n",
    "abnormal_files = [f for f in abnormal_files if 'id_06' in f]\n",
    "\n",
    "\n",
    "# Concatenate them to obtain a features and label datasets that we can split:\n",
    "X = np.concatenate((normal_files, abnormal_files), axis=0)\n",
    "y = np.concatenate((np.zeros(len(normal_files)), np.ones(len(abnormal_files))), axis=0)\n",
    "\n",
    "\n",
    "train_files, test_files, train_labels, test_labels = train_test_split(X, y,\n",
    "                                                                      train_size=0.8,\n",
    "                                                                      random_state=42,\n",
    "                                                                      shuffle=True,\n",
    "                                                                      stratify=y\n",
    "                                                                     )\n",
    "# We will want to reuse this same train/test split for our next experiment in the next notebook:\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# We now keep only the normal signals from the train files to train the autoencoder:\n",
    "train_files_normal = [f for f in train_files if f not in abnormal_files]\n",
    "train_labels_normal = np.zeros(len(train_files_normal))\n",
    "\n",
    "train_files_abnormal=[f for f in train_files if f in abnormal_files]\n",
    "train_labels_abnormal = np.ones(len(train_files_abnormal))\n",
    "\n",
    "test_files=np.concatenate((test_files,train_files_abnormal),axis=0)\n",
    "test_labels=np.concatenate((test_labels,train_labels_abnormal),axis=0)\n",
    "\n",
    "# dataset = dict({\n",
    "#     'train_files': train_files_normal,\n",
    "#     'test_files': test_files,\n",
    "#     'train_labels': train_labels_normal,\n",
    "#     'test_labels': test_labels\n",
    "# })\n",
    "\n",
    "# for key, values in dataset.items():\n",
    "#     fname = os.path.join(PROCESSED_DATA, key + '.txt')\n",
    "#     with open(fname, 'w') as f:\n",
    "#         for item in values:\n",
    "#             f.write(str(item))\n",
    "#             f.write('\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b0c7c4c5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 196/196 [00:21<00:00,  9.33it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtAAAAEbCAYAAADzkLN2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABO+UlEQVR4nO3dd1hT1/8H8HcmECBhKojKEEFxISpO3KtV3LNaR7XWUbW2/qpVq7WO2t3a+bVarR1WrVvrrAv3Vpy4wYnsTcj4/UFNRUKSi0CCvl/P4/PIzck5n/u5gXxyc+65Im1WnB5ERERERGQRsbUDICIiIiIqT1hAExEREREJwAKaiIiIiEgAFtBERERERAKwgCYiIiIiEoAFNBERERGRACygqVxb9usqSBRVDP/sVQGoXqs5ps9cgJycHGuHVyLOnL2A2XO/QFJSss2NL1FUwey5X1ghqvJv7/7DkCiqYO/+w4ZtbTv1RdtOfS3uIyUlFbPnfoFTp6MFjf30cZs99wtIFFWg0WgE9VOcuITuY3lhbp9btutVquOv37gNXy5cVGr937odh9lzv8CNm7cLPRZQoymGj5pUamOXtmW/rsLPv/xp7TConJFaOwCikrDy9x9R2ccb6ekZWL9xGxZ89h3SMzKx8Is51g7tmZ05dwEfzv8Sgwb2hJubq02Nf3DvBlSu5F3mMT2vvv1qnqD2Kalp+HD+l/Dx8UZY/ToWP6+0j5upuITuY3lR3GNRUjZs3o5/dh/ApAmjSqX/W7fv4MP5X6J5s0YI8Pct8NiaP3+CUulUKuOWheW/rYZGo8VrQwdYOxQqR1hA03MhtG4IAqv5AwA6tGuJq9dv4edf/sRXn82GWPzifNGi1Wqh1+shlZbNr3aT8LAyGaek5Obmws7OrtD2Z82bXq9HXl4e5HL5M8UXUjPomZ5vzuP9t+ZxK+19pLJXP7S2tUMgKnMvTmVBL5Sw0NrIzs5BQkKSYVtWVjamzpiPajWbwV4VgGo1m2H+xwuh0+kKPPfRo0SMmzgNvtXD4eBSDb7VwzFkxETk5uYa2mzbsQfNW3eHo1sgXL1C0LPfCFyJuV6gn8df2+7aHYWGTV+Ck3t11G3YDus3bivQLubqDfTqPxJevqFQuAbCL6gx+g0aDY1Gg2W/rsKIN94BAATXaWmYqnLrdhyA/K/iZ8z6GB9/9p1hv6LPXzZMbXnc7rHHX9U/SaPR4JPPv0ftsLZQuAaiYtV6eKnbYFy+cs2i8Z+ewlGSuSnKzVuxGDx8PCpWrQcHl2oIa9wJ6zZsNbqv5y9cRudug6D0DEb/wWNM5g0AfluxFvUbd4TCNRAVqtTFkBETcf/+wwJ9B9Roildfm4Cff/kTIaGtYa8KwJat/xQZ76NHiRg07E24VKwJN+9aGDryLaSkpBZq9/T0hoyMTEx4+334BTWGg0s1ePvVR8cuA3H5yjXcuh2HajWbAQDeGPeu4dgs+3VVgRxv2rITDZp0hoNLNfywaLlh/41Nvbl0+Srade4HJ/fq8PFvgFkfflbg98OS15UlcT09heNKzHX06j8Sbt614OgWiGatumHbjj1Gx7h67Sa69hwKpWcw/IObYM78rwr9Dhtz//5DDB35FipUqQsHl2oIDe+A31asLdDm8f4dOXYKg4ePh0vFmqgc0AAT35lpckqYuX1+zJLX+9lzF9G9z3C4V6oNR7dARLTtiaiDR03u2/BRk7D8t79w994Dw9gBNZoaHk9ISMLYCe+hSrWGcHCphpDQ1li05PcCfTx4EI9hr09C5YAGcHCpBh//BojsNQzx8QnYu/8w2nXuBwDo1PUVwxiPpx89PYVDSB5v3LyNLj2GwMm9Orx8QzF56odYtOR3o6+zp23fuRct2vSAq1cIlJ7BqFmvFebM/0pQPtt26ot9UUdw8PBxw349j1OMqOTxDDQ9l27djoNKpYS7e/6UA41Gg5e6DcLFy1cxY+pE1K5VA0ePncLcBQuRlJyCzxbMBAAkJ6egRdseSEpOwfQpE1Cndk3EP0rAxs07oFbnwc7ODtt27EFkr2Fo07o5Viz/HhmZmfhgzudo2b4XTh3eBh+f/74av37jNib93weYMnkcPNxd8cXCn9Bv0GhcPLPHcMa8W+9hcFEp8d3X8+Hh7oq79x5g6/Y90Ol06NK5HaZPmYB5Hy80TFMBAG+vCoYxfvltNQL8q+KTj2bAUeGASt4VcTb6osW5GjhkHDZs2o6Jb45AuzYtkJOTi6iDR3H/QbxF4z+ppHNjTNyde2jaqhsqeLrj849nwdPDDav+2oS+r7yBtSsXo1vXjgXa9+w3Aq8NHYB33x5b4NsIY3lbtOR3jBk/Ff36RGLe7Km4d/8hZnzwMY4dP40Th7bCycnR8Py9+w7h7LkLeH/aW6jg6QE/38pFxtxn4Os4G30J8z6YgsBAP6z6axMmvjPT9IEB8Pa7s7Hp752Y+8EUVA/0Q2JiMg4dOYGU1DTU96uFv1YsQp+BozB18jhE/rvf1Z74ej3m2g28NXkWpk+dgAB/X7i5upgcr1f/kRg+pD+mTB6HHbv2Ye6CryEWizFrxttmY33M26uC2biedO/eA7Rs3wvOTk5Y+MUcqJTO+P5/vyCy1zBsXLMML3VqU6B97wEjMezVfnhr/Ehs/nsXPpj7OSpX9sbwIf2LjCkzMwttOvVFckoq5n4wBVUqV8Lvf67F0BETkZWVjVEjBhVoP3TERAzo2x1/rViEI0dPYva8L+HqosIH779T7H225PV+6nQ0WnXojfr1auN/330MhYMD/rf4V3Ts8goO7F6HBmF1jY4/Y+pEPHqUhBOnzmL96p8BAHb/fhuSlpaOiHY9kZ2dg5nT34a/XxXs2LUP4yZOg1qtxptjhgMAhox8C7Gxd/Dx/BmoUtkbD+MTsHvPQWRlZyMstDa+/XIu3pw0A19//iEaNqgHAAipUb3InFuSR7VajU5dX0FOTi6+/WoeKnh6YMmyFViz7m+T/QL5hXePviPQu+fLmPHeRMjlcly9dhM3b8Ua2liSz2+/mochr02EVqfFD98sAAAoncvvdBQqOyyg6bmg1eqg0WiQnp6BdRu3Ye36rfjykw8gkUgAACtWbcCBQ8exZ8dqtGzRBADQrk0LAMCH87/Cu2+PRYUKHvjqm8W4cTMWxw5sKfC15MB+PQz/nzn7UwT4V8Xf65cbvvJv2rgBatRthS8WLsLnH88ytE1ITMLenX+hemD+G2RYaB34BDTA6jWb8d6745GQkISr125i3aolBQq/V/r3BAB4erojICD/TfjJaSpP0uv12Lbpdzg4OAjO2+69B7F2/d/46rPZGD/2NcP2Ht06G/5vbvwnlWRuijJ77hfQ6/XYs/0vwwekTh1aI+7ufXww5/NCBfT4sa9hwrgRhfp5Om9arRaz5nyG1i2bYsXy7w3tagRXQ6v2vbF0+coCOUpOScXxg3/Dq4gPE4/t/Gc/Dhw6jt9/+RYD+nY3xPty91dx5+59k889cuwkXunfAyOG/Tc3s2f3lwz/f/wa9ff3NTotIyEhCdsO/Y7QerVMjvPYyOGvYMrkcQCAju1bIS0tA18sXISJb46Ai4vKoj7s7OzMxvWkL7/5CcnJqTi4Z73h9fVy57aoHdYW73/wSaECetKEUYZiuX3bCOzZdxB/rt5gsoBetnwVrl67iX+2rULrlvlnZl/q1Abx8QmY+eGnGDFsgOFvBZD/+/64yGvfNgJHj5/Bn6s3FFlAW7LPlrzep0yfh6pVfLBr65+G6UCdOrRC3YbtMXfB11i3aonR8asF+MHT0w1ymazQ2Au/W4LbsXdx9vhOw9jt20YgJSV/zvbo11+FVCrFkaMnMW/2FAwa0NPw3L69uhr+X/PfqTc1ggMtngJkLo/Lfl2NGzdjcXjfRoQ3qg8g/7iENemE2Li7Jvs+deY81Go1vv96PpRKZwBA29bNC7SxJJ8hNYOgVDpBo9GWuylpZF2cwkHPhZDQ1rBT+sPDpw5eH/N/GDViEMaNGWZ4fPvOvfCtWhnNmjSERqMx/OvQriXy8vJw5NgpAPnFTqMG9Yqc05eZmYVTZ86jX+/IAvNl/f2qonnThtgfVfCr1uqB/oY3LQCoUMEDFTw9EBt3DwDg7u6KAP+qmDZzAX76+Q9cvXZT8L536tC6WMUzkL+/IpEII4cPLNbzn1TSuSnK9p178VKntlCpnAscy07tW+Js9EWkpaUXaP/kh4EnPZ23KzHXER+fgIH9exZo16JZOHyrVsa+qCMFtjcJDzNbPAPAkaOnIJFI0LvHywW29+/bzexzG4bVwy+/rcZHn3yDEyfPQqvVmn3Ok/x8q1hcPANA395dC/zcv283ZGRk4vzFK4LGFSLqwFE0CQ8r8OFMIpFgQN/uOHPuQqHj2aVzuwI/1woJRpyZ18z+g0fhU8nLUDw/9sqAnnj0KBEXL8UU2P5y57YFfq5Tu4bZ16U55l7v2dnZ2Bd1BH16doFYLDa8rvV6Pdq1aWF2GkdRtu/ch8aNQuHvV6XA70vHDq2QmJiMi5euAgAaNaiHz778EQu/W4Lo85eg1+ufaX8B83k8euwUqlbxMRTPACASidCre8HfFWNC64ZAJpNh4JBx+GvdFsTHJxR4vLTySfQYC2h6Lqz58yccjdqMzeuWo13bCPywaDmW//6X4fH4R4m4HXsHdkr/Av+atIwEACT+u0RbYlJygWkGT0tOToVerzc6haFiRU8kJacU2GbsK3M7OzlycvPnAYpEImzf/AcahNXF9FkLUKNuSwSGNDfMVbVEUdMpLJGYmAw3N5diF+BPKuncFCX+USJ+/f2vQsfy3Wn5qzskPrXcXlH5eXr74/iMtfeq6Inkp+K3pHgGgPsPHsLVVQWZTFZge8UKHmafu/CLORg1YjCWLl+JxhFd4eUbirff/QBZWdkWjS30tVGxgqfRGO/eeyCoHyGSklOM5rJiRU/o9XokPzVX3M3NpcDPdnZy5OTkwpTk5JQij+vjGEyOIZcXuAaiOMy93pOSUqDVajF3wdeFXtvf/bgMycmpFs31flr8owTsP3C0UJ/9B40G8N/vy4rl3yOySwd8+sUPCA3viCrVGlo8v7zIfTaTx/sP4lHB073Q8ypY8LsRWM0fWzf+Bp1Oh6EjJqKSfxiatozEvqj8edmllU+ixziFg54LtWsFG85gtW3dDKHhHTFl+jz07vEyHB0VcHdzgb9fVfz56/dGn+/nm38BlIe7G+6ZKBZcXVUQiUR48PBRoccePnwE96feMCwR4O+LXxZ/Bb1ej7PnLuK7H5fhzbemw8+3SqGvr40RiUSFttnb5680oVbnFdj+dHHp4eGGpKQUZGdnP3MRXRq5McbdzRUtmofj3bfHGH28knfFAj8by4+x7Y8LHGPxP3j4qND806L6fZq3V0UkJ6ciLy+vQBH98KkzZsY4OTli/odTMf/Dqbgdewdr1m3Be+8vgFwux4K508w+39IY/4vpUYElyh7H6FPJC4Dlrysh3Fxd8PBhfOFYHj6CSCQyO2/bEq6uLoUuZAX+O9buVlge8mkuLiqIxWKMfWMoXn2lt9E2xVlRyN3NFRU8PfDlpx8YfTw4qBqA/KL126/m4duv5uFKzHUs/201Ppj7OTw83DBm1BDB41rC26sCLl2+Wmj702eTi9KmVTO0adUMubm5OHj4BD6Y8zkiew3DjUuHSy2fRI/x1UPPHTs7O3w8bzri4xMMZ3I7dWiNuDv34OTkiIYN6hX65+HhBiB/CbxjJ87g7DnjF+E5OirQoH4d/LVuS4Gv02/H3sGhIyfRMqJJseMWiUQIrVcLn3+cf3HZhX+/Nrezy5+7l51t+Y1hfKvmX9B2/sJ/X71rNBrs/Gd/gXYd2rWEXq/HkmVF30TA0vFLMzdP6tSxFaLPX0KtkCCjx9LYMnWWCA6qhooVPLHyr40Fth86cgK3Y++gVTHjb9I4DFqtFmvWF7wwauXqjUU8wzjfqpXx9sQ3UKdWDcNxfXyhWEndNGj1ms2FYnRyckTtkGBDDID515WQuFpGNMGRY6cLrLig1Wqxas0m1K9XG84lcEFXqxaNcefufRw8fLzA9hWr1qNCBQ/UNHMxnCWe9Vg4OioQ0Twc56IvIqx+HaOvbdPj2yHbyNidOrTG5ZhrqFrFx2ifxvIbHFQN8z6cCldX1TP9HTKncXgYYuPu4tjx04Zter0eazeYv4jwSXZ2dmjbujkmTxqNzMws3LwVKyifcjt5ie4XvRh4BpqeS926dkSjBvXw+df/w7jRQzFoQE/88usqdHh5AN6eOAp164RArc7DjRu3sfHvHVi3cgkUCge8NX4kVqxaj45dB2L6lAmoXasGEhKTsHHzDvyw8CM4Ozth9szJiOw1DJG9hmHMqCHIyMzE7LlfQKVyxtsCb2JwLvoSJv3fLPTtHYnAan7QarX45bfVkEqlaNMqf1mskBr5F+98/7/lGDK4D2RSKerWqWlyzeFGDeqhWoAvpkyfC51eBzu5HD8sWo7cXHWBdm1aNUOvHi/jnSkfIu7OPbRp1Qx5eRpEHTyKlzu3Q+uWTQWNX5K5Kcrs9yejSUQkWnfog7Gjh8HPtzKSk1Nx4eIV3LgZiyX/+7xY/UokEnzw/jsYM34qXn1tAgYN6Im79x7i/Q8+QfVAfwx7tV+x+u3QriVaNGuEMePfQ2JCsmEVjgsWzCtu3ro7Irt0QO1aNeDk5Ij9UUdwNvoihgzuAyB/moO7uytWrt6IOrVrwFGhgL9fVcPFlUItXvoHdDodGjaohx279mHJshWYNf1twwWElr6uhMT11psj8ctvq9Gp6yuYNeNtKJ2d8cOi5Yi5egOb1i4r1n48beir/bDw+5/RZ+AozJn1Lir7eOGPleux658o/PDNggIXEBZXSRyLzxbMROuOfdC522C8NrQ/vL0qICExGadPR0Or0+GjOe8V+dyQmtXx088p+GHRcjQMqwt7ezvUqV0Tb40fiVVrNqFVh96Y+OZIBAdVQ2ZmFq7EXEPUwWNYv/pnpKamoWOXgXhlQE8EB1WDTCbDxs07kJycig7tWgIAggIDIJVKsXT5Sri5ucBOLkdwULVn+oAz7NW++PSL7/OPywfvwtPDHUuWrUBycv60HVNniH/86VdEHTyKlzq1RZXK3khITMbHn36LSt4VUbtWsKB8htSojh8W/YqVf21ENX9fODs7Gc7MExWFZ6DpufXhrP9DfHwC/rf4N8hkMmzd+BtGDn8FP/38B7r2HIpXXxuP5b+vRrPGDSGX53+17uKiQtQ/69AjsjM+/ux7vNz9Vfzf1DmQSqWGNp07tsGmtcuQmpqGAa+OwdgJ01AjOBD7d61FpX+/6raUV0VPVKnig6+++Qk9+r6GQcPexP37D7FxzVLDlIF6dUMwa/rb2Pz3TrRs1wuNI7ri3lPrEj9NKpVi3aolqFK5El4b9TbGT5qBDu0iMHRw4fVNVyz/DrOmT8KGTdvRo+8IjBwzGRcuxhjmjAoZvyRzU5SqVXxw7MAW1K0TghmzPkanroMwbuJ07DtwFG2eugpfqFEjBuGXJV/j/IXL6NlvJKbOmIf27SKwZ/vqAkvYCfXXip/wUqc2mDZrAQYOGQeNVmvRXTIjWjTG6jWb8eprExDZayjWrN+CLz6ZZVhVRCwWY9F3nyA5JRUdu7yCxhFdsenvncWOc92qJdi1Owo9+r6G31esw/QpEzDjvYmGxy19XQmJq1IlL+zftRYhNYMwbuJ09Bs0GsnJKdi0dhk6dzQ/hckSjo4K7Nm+Gh3atcS0mR+hZ7+ROBd9Eb8s+brQEnbFVRLHIqx+HRyN2gx3Nxe8NXkWOkcOxqTJsxB94TIimjc2+dwRwwaif99umPHBJ2jSMhLd++SvGKNSKXFg9zq81KkNPv3iB7zUbTBGjpmMjZt3GD6k29vboX5oHSxeugL9Bo1G7wGv48jRk/h16UJ0j+wEIP+C54VfzMG56Eto07EvGkd0xUmBt5B/mlwux7ZNv6NO7ZoYO+E9DB81CVUqV8LYN4bmx/7v6hrG1KsbgszMLEyfuQCdIwdjwqT34edXFbu2rjRMR7M0n+++PRZtWzfHqLHvonFEV4wZP/WZ9oteDCJtVtyzX2pLREREVAIiew3D5StXcfXCQWuHQlQkTuEgIiIiq/hy4SI4OjqieqA/0tMz8Ne6Lfh72z/47uv51g6NyCQW0ERERGQVdnI5vv52MWLj7kKr1SE4KACLvv+0wM2DiGwRp3AQEREREQnAiwiJiIiIiAQod1M4UtPSrB2CWSKRqERug/oiYc6EY86Kh3kTjjkTjjkrHuZNOOZMOCE5EwFQKpWFtvMMdClQOhe99A4Zx5wJx5wVD/MmHHMmHHNWPMybcMyZcEJyVtR65CygiYiIiIgEYAFNRERERCQAC2giIiIiIgHK3UWERERERGVFq9UjMTUPeXk62OKlevceqaHT6awdRrnydM5EAGQyMdxVMkgkIov6YAFNREREVITE1Dw42Inh6SqDSGRZcVWWJGIxtCygBXk6Z3q9HulZWiSm5qGCm9yiPjiFg4iIiKgIeXk6OCkkNlk8U8kQiURwVkiQl2f5B5EyKaCXbzqA//vyT3y4aH2hx3YcOY/R85YhIyunLEIhIiIispgeYPH8AhCJRIKm6JRJAd20XiDGD+hQaHtSWiYu37wHN6VjWYRBRERERPTMyqSArl7VCwqHwnNKVu88hl5tG+bP3iYiIiKycWq5K9KkJfdPLXc1O6abVy3MmPWJ4edvvl+KBZ9+V5q7WUhkz2E4fea8RW2X/rISf67aYNUYSpvVLiI8GxMLF2cFKld0M9s26tQVRJ2OAQAM69oUlSp6lHZ4haTq7JGlMX9yXyEVAciByshtH8k05kw45qx4mDfhmDPhmLPisbW83XukhuSJu9Hl6IH/nTteYv2/Ua8RHIq4291jdnZybN66C5PfegPu7q4Qi0QQi0SGuCRmnq/RaCCVPlvJJxLl35XP3FgAMHL4wGcaqyRiMMdYH2KxuNDrLyMjw+jzrVJAq/M02HrwHCYO7GhR+4iwYESEBQMAUtPSkJqWVprhGZUmleDHs8fMthtdLxwqBawSY3mmUiqZM4GYs+Jh3oRjzoRjzorHFvOm0+kKrnIhzl+1ocToYXYVDalEgqGD++LbH5dhxnsTodProdProdXpcPfufYybOB0JicnwcHfFt1/NReXKlTBuwjS4uKoQHX0JdeuEIDk5Bfb29rh67Qbi7tzHt1/NxYpVG3D85Fk0rF8H3y2cDwB4590PcfrMeWTn5KBb1454790388PUG8kFgNlzv8DW7XsglUrRplUzzPng/7Dg0+/g6KjA+LHDcep0NCa8PRMKhQOahIdh1+4oHNq3AX/8uQ7bduxFVnY2bt2KQ5eX2mH2zMkWxaDOy8OESe/j9NkLEIlEGDSwJ8a+MdTilBe1colOpyv0+iuqWLdKAf0oOR2JKRmYszj/9H5KWhbmLdmEqcO7QOWksEZIRERERDZrxPCBiGjTExPGvVZg+/+9Nxf9+3bDwP498NsfazF1xkf4bdk3AIDr129j3eolkEgkGDdhGlJS07BhzVJs3b4HA4eMw7ZNv6FGcCDade6P6POXUKd2Tcx4bwJcXV2g1WrRo88IXLh4BbVCgo3GlJycgi1b/8HRA5shEomQmlr4w8+bb83Al599gMaN6mP23C8KPBZ9/jL27foLcrkc4c274PURg1DZx9tsDNHnL+Peg3gc2pdfRxobt7RZZRk7nwqu+HTSAMx/sy/mv9kXLkoFpo+IZPFMREREZITS2Qn9+3bD/xb/VmD7sRNn0KdXFwBA/76ROHLslOGx7pEdIZFIDD937tgaIpEIITWro4KnO0JqBkEsFqNGUCBi4+4BANZv3I7WHfqgVfs+uHzlGi7HXC8yJmdnJ9jZyTHh7ZnYtGUnHBzsCzyempqGjIxMNG5UHwAMcT7WMqIxlEpn2NvbITioGu7csSwGP9/KuH37DqZMm4ddu6Pg7OxkUQ5LUpkU0IvX7cMny/7Gg8RUTF24CgfPxJTFsERERETPjTGjXsVvf6xFVlZ2kW1ET6zMoFA4FHhMLpcBAMQiMeTy/xZ3EItF0Gg0uH37Dr79YSnWr16CA3vWoWP7lsjNyS1yLKlUil1bV6Jblw74e+tu9B34RoHHzU11sXsiBolEAo1Ga1EMLi4q7N+9Bs2bNcKSpSsw4e2ZJscpDWUyhWNkz1YmH5//Zt+yCIOIiIio3HJ1dUGPbp3w24o1GDSgFwCgcaP6WLt+K/r37YbVazajSeOwYvefnpEBhcIBSqUz4h8lYNfuA2jerFGR7TMyM5GdlYMO7VuiYYO6aND0pQKPu7io4OTkiOMnz6JRg3pYu35ricSQmJgMmVyGbl07wt+vCsZNnF68HX4GvJU3ERERkYXsxfkLBpRkf0KMGzMMi5euMPz88bzpGDdxGr75fqnhIsLiql2rBurWrommrbrDr2plNA6vb7J9RkYWBg99Ezm5auj1esybPaVQm4VfzsFb78yCQuGAFs0aQak0Pd3CkhjuP3iIN9+aAd2/FwK+P22SgL0sGSJtVlwJXkpa+qx1dW6a1NXiVTiqKLQ2dxWxrbPFK69tHXNWPMybcMyZcMxZ8dhi3u48zEHlivbmG1pJUStK2IqMzEw4OebfMO+rb37Cg4cJWDD3PavGVFTOjB1riVgMJ6fCRT/PQBMRERFRqdixcz+++uYnaDRaVKlcCd99Pc/aIZUIFtBEREREVCp69XgJvXq8ZL5hOWOVZeyIiIiIiMorFtBERERERAKwgCYiIiIiEoAFNBERERGRACygiYiIiCxkp1PALltacv90CovG3fz3Lrh51ULM1RuGbQcOHkO/QaNLa1efSWTPYTh95rxFbZf+shJ/rtpg1RiE4iocRERERJbKVSNp8Y8l1p3byNGAg/l2a9b9jSaNw7B2/VZM/b9xJTa+MRqNBlJp2ZWIw4f2L7OxSgoLaCIiIiIblpGZiWPHT2PDmqUYNPTNAgV0enoGXh0+AVev3USzpg3x2YL3IRaLUSWgId54/VVs37kX9vb2+P2Xb1DB0wNxcfcwftIMJCQmG+5cWLlyJYybMA0uripER19C3TohSE5Ogb29Pa5eu4G4O/fx7VdzsWLVBhw/eRYN69fBdwvnAwDeefdDnD5zHtk5OejWtSPee/dNk/sye+4X2Lp9D6RSKdq0aoY5H/wfFnz6HRwdFRg/djhOnY7GhLdnQqFwQJPwMOzaHYVD+zbgjz/XYduOvcjKzsatW3Ho8lI7zJ452aIYtFotJkx6H6fPXoBIJMKrr/TC6FFDnumYcAoHERERkQ37e+tutG3TAoHV/ODiosLZcxcNj508HY05H/wfDu5dj5u34rBpy04AQGZWNho2qIuo3evQrEkDLP/tLwDAu9Pmon/fbjiwZx369OqKqTM+MvR1/fptrFu9BHNnvwsASElNw4Y1SzHvwykYOGQcxr4xBIf3bcDFy1cRff4SAGDGexOwe8cqHNizDocOn8CFi1eK3I/k5BRs2foPDu/fiAN71mHypDcKtXnzrRn4/JOZ2LHlD0gkBcvU6POX8fP/PseBPeuxbsM23Ll736IYos9fxr0H8Ti0bwMO7l2PQQN7WZz7orCAJiIiIrJha9b9bbgZSa8eL2HNur8NjzWoXwd+vlUgkUjQu8fLOHLsFABALpehU4fWAIB6dWshNu4eAOD4ybPo06sLAKB/30hDewDoHtkREonE8HPnjq0hEokQUrM6Kni6I6RmEMRiMWoEBRr6W79xO1p36INW7fvg8pVruBxzvcj9cHZ2gp2dHBPenolNW3bCwaHgbbNTU9OQkZGJxo3qA4AhzsdaRjSGUukMe3s7BAdVw507lsXg51sZt2/fwZRp87BrdxSUzoVvzS0Up3AQERER2aikpBREHTyKS5evQiQSQavTQSQCZs98BwAgEokKtH/8s0wqNfxfIhFDq9EY7V+E/56vUBScjC2XywAAYpEYcrncsF0sFkGj0eD27Tv49oel+GfbSri4qDBuwjTk5uQWuS9SqRS7tq7E/qgjWLt+Kxb//Ac2rFlqeFyv15vMhd0TMUgkEmg0WoticHFRYf/uNdi95yCWLF2BjZt2YOGXc0yOZQ7PQBMRERHZqI2bd6B/3244d3IXzp7YifOn/oFvlco4cjT/zPHJ09G4ffsOdDod1m3ciibhYSb7C28YirXrtwIAVq/ZjCaNTbc3JT0jAwqFA5RKZ8Q/SsCu3QdMts/IzERaWjo6tG+J+XOmIPrC5QKPu7io4OTkiOMnzwKAIc5njSExMRk6nR7dunbEtCnjC0yBKS6egSYiIiKylJ08f+WMEuwPMH52GMifvjFx/IgC2yK7dsBfa7egZ/fOaNQwFLPnfYmLl2LQrGlDdH25vcnhFsydhvGTZuCb75caLiIsrtq1aqBu7Zpo2qo7/KpWRuPw+ibbZ2RkYfDQN5GTq4Zer8e82VMKtVn45Ry89c4sKBQOaNGsEZRK09MtLInh/oOHePOtGdDpdACAD2a8LWAvjRNps+JMny+3MalpaVYZN03qih/PHjPbbnS9cFRRaK0WZ3mlUiqZM4GYs+Jh3oRjzoRjzorHFvN252EOKle0N9/QSiRiMbT/FobPg4zMTDg5OgIAvvrmJzx4mIAFc98r0TGKypmxYy0Ri+HkVLiI5xloIiIiIrIJO3bux1ff/ASNRosqlSvhu6/nWTsko1hAExEREZFN6NXjJcOKI7aMFxESERERFUEE86tDUPmn1+shMt/MoEzOQC/fdADR1+7A2dEeM0f1AACs+ec4zl2Ng1QigYeLM4ZGNofC3q4swiEiIiKyiEwmRnqWFs4KSaEl4+j5oNfrkZ6lhUxm+XnlMimgm9YLROuGNbFsU5RhW03/SujRpgEkYjHW7j6BbYei0attw7IIh4iIiMgi7ioZElPzkJ6hgS2ehxaLxYbVJcgyT+dMhPwPSu4qmcV9lEkBXb2qFxJS0gtsCwnwMfzfv5InTl2+XRahEBEREVlMIhGhgpvcfEMrscWVS2xdSeTMJi4iPHT2KhqG+Bf5eNSpK4g6HQMAGNa1KSpV9Cir0Ayy1NICd+EpilQqBaCFSqks/aCeM8yZcMxZ8TBvwjFnwjFnxcO8CcecCWdpzjIyMoxut3oB/feBsxCLxQivHVBkm4iwYESEBQPIXwfaGp+0NFJXqNVq8+00GkBuvfWqyyt+ghaOOSse5k045kw45qx4mDfhmDPhhORMIjY+L9qqq3AcPncN0dfuYESPlpyYT0RERETlgtUK6AvX72D74WiM7dsOcpnVT4QTEREREVmkTCrXxev2Ieb2A2Rk52DqwlWIbBmKbYeiodFo8fUf2wEA/j6eGPRys7IIh4iIiIio2MqkgB7Zs1Whbc1Dg8piaCIiIiKiEsU7ERIRERERCcACmoiIiIhIABbQREREREQCsIAmIiIiIhKABTQRERERkQAsoImIiIiIBGABTUREREQkAAtoIiIiIiIBWEATEREREQlQJnciJNtgp1MAuWozjeTIFWeVTUBERERE5RAL6BdJrhpJi3802cRt5GjAoYziISIiIiqHOIWDiIiIiEgAFtBERERERAKwgCYiIiIiEoAFNBERERGRACygiYiIiIgEYAFNRERERCQAC2giIiIiIgFYQBMRERERCcACmoiIiIhIABbQREREREQClMmtvJdvOoDoa3fg7GiPmaN6AAAys3Px07q9SEzJgLuLE17v2RqODnZlEQ4RERERUbGVyRnopvUCMX5AhwLbth2KRg0/b8wZ2xs1/Lyx/XB0WYRCRERERPRMyqSArl7VCwoHeYFt52Ji0bROIACgaZ1AnL0SWxahEBERERE9kzKZwmFMWmY2VM4KAIDKWYH0rJwi20aduoKo0zEAgGFdm6JSRY8yifFJWWop5HK52XZSqRSAFiqlsvSDEkibp4ZcZnofZFIp7JWKMoqooJLKWarOHlkavck2CqkIKnHRr7nywhZfZ+UB8yYccyYcc1Y8zJtwzJlwluYsIyPD6HarFdBCRIQFIyIsGACQmpaG1LS0Mo9BI3WFWq02306jAeSwSozm2GmkUOeZ3oc8jQYZaWVfWKqUyhLLWZpUgh/PHjPZZnS9cEBje8dIiJLM2YuEeROOOROOOSse5k045kw4ITmTiI1P1rDaKhxKRwekpmcBAFLTs+CssLdWKEREREREFrNaAV03qAoOR18DAByOvoa6QVWtFQoRERERkcXKZArH4nX7EHP7ATKyczB14SpEtgxFp6Z18NO6fTh45ircVE4Y1at1WYRCRERERPRMyqSAHtmzldHtkwZ1KovhiYiIiIhKDO9ESEREREQkAAtoIiIiIiIBWEATEREREQlg0RzoK7fuw93FCR4uzkhNz8K6PSch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\n",
      "text/plain": [
       "<Figure size 864x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# evaluate trained autoencoder model on test set\n",
    "\n",
    "trained_model = '/home/braghadeesh/Audio_data_exp_Neurips/slider_0_dB/model/61' # trained only on machine id_00\n",
    "\n",
    "model_trained = tf.keras.models.load_model(trained_model)\n",
    "\n",
    "y_true = test_labels\n",
    "reconstruction_errors = []\n",
    "\n",
    "for index, eval_filename in tqdm(enumerate(test_files), total=len(test_files)):\n",
    "    # Load signal\n",
    "    signal, sr = sound_tools.load_sound_file(eval_filename)\n",
    "\n",
    "    # Extract features from this signal:\n",
    "    eval_features = sound_tools.extract_signal_features(\n",
    "        signal, \n",
    "        sr, \n",
    "        n_mels=n_mels, \n",
    "        frames=frames, \n",
    "        n_fft=n_fft, \n",
    "        hop_length=hop_length\n",
    "    )\n",
    "    \n",
    "    # Get predictions from our autoencoder:\n",
    "    prediction = model_trained.predict(eval_features)\n",
    "    \n",
    "    # Estimate the reconstruction error:\n",
    "    mse = np.mean(np.mean(np.square(eval_features - prediction), axis=1))\n",
    "    reconstruction_errors.append(mse)\n",
    "    \n",
    "# test set reconstruction error analysis\n",
    "\n",
    "data = np.column_stack((range(len(reconstruction_errors)), reconstruction_errors))\n",
    "bin_width = 0.25\n",
    "bins = np.arange(min(reconstruction_errors), max(reconstruction_errors) + bin_width, bin_width)\n",
    "\n",
    "fig = plt.figure(figsize=(12,4))\n",
    "plt.hist(data[y_true==0][:,1], bins=bins, color=blue, alpha=0.6, label='Normal signals', edgecolor='#FFFFFF')\n",
    "plt.hist(data[y_true==1][:,1], bins=bins, color=red, alpha=0.6, label='Abnormal signals', edgecolor='#FFFFFF')\n",
    "plt.xlabel(\"Testing reconstruction error\")\n",
    "plt.ylabel(\"# Samples\")\n",
    "plt.title('Reconstruction error distribution on the testing set', fontsize=16)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "60a58411",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save(\"reconstruction_errors_06.npy\",reconstruction_errors)\n",
    "np.save(\"normal_data_06.npy\",data[y_true==0][:,1])\n",
    "np.save(\"abnormal_data_06.npy\",data[y_true==1][:,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a2d397e",
   "metadata": {},
   "outputs": [],
   "source": [
    "range(len(reconstruction_errors))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14a3911c",
   "metadata": {},
   "outputs": [],
   "source": [
    "reconstruction_errors\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10e603d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.mean(data[y_true==1][:,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8422ebf1",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.mean(data[y_true==0][:,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd2eafb7",
   "metadata": {},
   "outputs": [],
   "source": [
    "len(abnormal_files)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "217c8826",
   "metadata": {},
   "outputs": [],
   "source": [
    "y.shape\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76b5e32d",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "data = np.column_stack((range(len(reconstruction_errors)), reconstruction_errors))\n",
    "bin_width = 0.25\n",
    "bins = np.arange(min(reconstruction_errors), max(reconstruction_errors) + bin_width, bin_width)\n",
    "\n",
    "fig = plt.figure(figsize=(12,4))\n",
    "plt.hist(data[y_true==0][:,1], bins=bins, color=blue, alpha=0.6, label='Normal signals', edgecolor='#FFFFFF')\n",
    "plt.hist(data[y_true==1][:,1], bins=bins, color=red, alpha=0.6, label='Abnormal signals', edgecolor='#FFFFFF')\n",
    "plt.xlabel(\"Testing reconstruction error\")\n",
    "plt.ylabel(\"# Samples\")\n",
    "plt.title('Reconstruction error distribution on the testing set', fontsize=16)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26d2c25f",
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_features.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17443ef2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.9.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
