{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a2cc60b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import librosa\n",
    "import librosa.display\n",
    "import numpy as np\n",
    "import numpy.linalg as la;\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": null,
   "id": "34d82845",
   "metadata": {},
   "outputs": [],
   "source": [
    "#change 6 to 0,2, and 4 for machine ids 00,02,and 04 respectively\n",
    "trained_model = '/home/braghadeesh/Audio_data_exp_Neurips/slider_0_dB/model/6' \n",
    "\n",
    "model_trained =tf.keras.models.load_model(trained_model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0613a83e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import glob\n",
    "\n",
    "test_files_normal=[]\n",
    "test_files_abnormal=[]\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "for file_name in glob.iglob('/home/braghadeesh/Audio_Data_Neurips_2021/0_dB_slider/slider/id_00/normal/*.wav'):\n",
    "    test_files_normal.append(file_name)\n",
    "\n",
    "for file_name in glob.iglob('/home/braghadeesh/Audio_Data_Neurips_2021/0_dB_slider/slider/id_00/abnormal/*.wav'):\n",
    "    test_files_abnormal.append(file_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0df8f7f2",
   "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": null,
   "id": "29717336",
   "metadata": {},
   "outputs": [],
   "source": [
    "ren = []\n",
    "reb = []\n",
    "\n",
    "for index, eval_filename in tqdm(enumerate(test_files_normal), total=len(test_files_normal)):\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",
    "    ren.append(mse)\n",
    "\n",
    "for index, eval_filename in tqdm(enumerate(test_files_abnormal), total=len(test_files_abnormal)):\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",
    "    reb.append(mse)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "570a4e1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "bin_width = 0.25\n",
    "bins = np.arange(min(ren), max(ren) + bin_width, bin_width)\n",
    "\n",
    "fig = plt.figure(figsize=(12,4))\n",
    "plt.hist(ren, bins=bins, color=blue, alpha=0.6, label='Normal signals', edgecolor='#FFFFFF')\n",
    "plt.hist(reb, 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": "b9a442a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "##change 6 to 0,2, and 4 for machine ids 00,02,and 04 respectively, \n",
    "##after making necessary changes (mentioned) in cell 2\n",
    "\n",
    "np.save(\"normal_data_06_new.npy\",ren)\n",
    "np.save(\"abnormal_data_06_new.npy\",reb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67ab13ed",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e59af632",
   "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
}
