{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a5297d9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np;\n",
    "import scipy\n",
    "import random\n",
    "#import cvxpy as cvx\n",
    "#import qcqp\n",
    "#import qcqp\n",
    "import numpy.random as ra;\n",
    "\n",
    "\n",
    "#import scipy.linalg as sla;\n",
    "import numpy.linalg as la;\n",
    "#import pdb;\n",
    "import matplotlib.pyplot as plt\n",
    "#import seaborn as sns\n",
    "import sklearn\n",
    "from sklearn import preprocessing\n",
    "\n",
    "import Matrix_Norm as mn\n",
    "\n",
    "#import glrt as glrt\n",
    "import kld as kl\n",
    "\n",
    "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\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f74ebc5b",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "d_list=[i for i in range(10,30,5)]\n",
    "\n",
    "itr=5000\n",
    "tau_max=1\n",
    "\n",
    "j=1 #j=0,1,2,3 corresponds to length of the graph = 10,15,20,25 respectively -- vary j to vary length of the graph. \n",
    "k=3 #k=0,1,2,3 corresponds to change point = 10,20,30,40 respectively -- vary k to vary change points\n",
    "tau_list=[i for i in range(10,50,10)]\n",
    "\n",
    "\n",
    "i=k+(j*4) #given j and k, we retrieve stopping time statistics of the three algorithms\n",
    "\n",
    "l_stop_uniform=np.load(\"l_stop_rand_d.npy\")\n",
    "l_stop_alg_full=np.load(\"l_stop_alg_d.npy\")\n",
    "l_stop_oracle=np.load(\"l_stop_oracle_d.npy\")\n",
    "l_stop_alg_theory=np.load(\"l_stop_alg_d_theory.npy\")\n",
    "\n",
    "\n",
    "\n",
    "l_stop_uniform=l_stop_uniform.flatten()\n",
    "l_stop_oracle=l_stop_oracle.flatten()\n",
    "l_stop_alg_full=l_stop_alg_full.flatten()\n",
    "l_stop_alg_theory=l_stop_alg_theory.flatten()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecff6c4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Stopping time statistics of URS\n",
    "l_stop_uniform1=l_stop_uniform[(i*itr*tau_max):(tau_max*itr*(i+1))]\n",
    "\n",
    "#Stopping time statistics of EG\n",
    "l_stop_alg1_full=l_stop_alg_full[(i*itr*tau_max):(tau_max*itr*(i+1))]\n",
    "\n",
    "#Stopping time statistics of Oracle\n",
    "l_stop_oracle1=l_stop_oracle[(i*itr*tau_max):(tau_max*itr*(i+1))]\n",
    "\n",
    "#Stopping time statistics of EG(theory)\n",
    "l_stop_alg1_theory=l_stop_alg_theory[(i*itr*tau_max):(tau_max*itr*(i+1))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2999fe19",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Run this to visualize histogram of stopping times \n",
    "\n",
    "plt.figure(figsize=(20,20))\n",
    "\n",
    "plt.subplot(3,1,1)\n",
    "plt.hist(l_stop_alg1_full,bins=50,label='EG(full)',color='m')\n",
    "plt.xlabel(\"Stopping Time\",fontsize=20)\n",
    "plt.ylabel(\"Frequency of Stopping\",fontsize=20)\n",
    "plt.xlim(0,2000)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xticks(range(tau_list[k],1000,100),fontsize=20)\n",
    "plt.axvline(x=tau_list[k], color='k', linestyle='--')\n",
    "\n",
    "\n",
    "plt.legend(fontsize=20)\n",
    "\n",
    "\n",
    "plt.subplot(3,1,2)\n",
    "plt.hist(l_stop_uniform1,bins=100,label='URS',color='r')\n",
    "plt.xlabel(\"Stopping Time\",fontsize=20)\n",
    "plt.ylabel(\"Frequency of Stopping\",fontsize=20)\n",
    "plt.xlim(0,2000)\n",
    "plt.xticks(range(tau_list[k],2000,500),fontsize=20)\n",
    "# plt.xlim(0,1000)\n",
    "\n",
    "#plt.xlim(100,1000)\n",
    "#plt.xticks(range(100,1000,100),fontsize=16)\n",
    "#plt.xticks(range(tau_list[k],1000,50),fontsize=20)\n",
    "\n",
    "plt.yticks(fontsize=20)\n",
    "plt.axvline(x=tau_list[k], color='k', linestyle='--')\n",
    "\n",
    "plt.legend(fontsize=20)\n",
    "\n",
    "plt.subplot(3,1,3)\n",
    "plt.hist(l_stop_oracle1,bins=50,label='Oracle',color='g')\n",
    "plt.xlabel(\"Stopping Time\",fontsize=20)\n",
    "plt.ylabel(\"Frequency of Stopping\",fontsize=20)\n",
    "#plt.xlim(0,1000)\n",
    "plt.xticks(range(tau_list[k],1000,100),fontsize=20)\n",
    "plt.xlim(0,2000)\n",
    "plt.axvline(x=tau_list[k], color='k', linestyle='--',linewidth=2)\n",
    "\n",
    "plt.legend(fontsize=20)\n",
    "\n",
    "\n",
    "\n",
    "plt.suptitle(\"Histogram of Stopping Times, Change Point ={}, Length of the Line Graph = {} \".format(tau_list[k],d_list[j]), fontsize=20)\n",
    "\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8818aa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(20,7))\n",
    "\n",
    "plt.subplot(1,1,1)\n",
    "plt.hist(l_stop_alg1_theory,bins=50,label='EG(theory)',color='m')\n",
    "plt.xlabel(\"Stopping Time\",fontsize=20)\n",
    "plt.ylabel(\"Frequency of Stopping\",fontsize=20)\n",
    "plt.xlim(0,2000)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xticks(range(tau_list[k],1000,100),fontsize=20)\n",
    "plt.axvline(x=tau_list[k], color='k', linestyle='--')\n",
    "\n",
    "\n",
    "plt.legend(fontsize=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e11abe9",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Run this to get mean and standard deviation of detection delays of the three algorithms for different change points. \n",
    "\n",
    "\n",
    "#        c_EG1, c_URS, and c_oracle store the mean of detection delays corresponding to EG, URS, and Oracle.\n",
    "\n",
    "c_EG1=[]\n",
    "c_URS=[]\n",
    "c_oracle=[]\n",
    "c_EG0=[]\n",
    "# e_EG1, e_URS, and e_oracle store standard deviations corresponding to EG, URS, and Oracle\n",
    "\n",
    "e_EG1=[]\n",
    "e_URS=[]\n",
    "e_oracle=[]\n",
    "e_EG0=[]\n",
    "\n",
    "j=3#j=0,1,2,3 for d=10,15,20,25\n",
    "\n",
    "tau_list=[i for i in range(10,50,10)]\n",
    "\n",
    "for k in range(4):\n",
    "    i=k+(j*4) \n",
    "    c_EG1.append(np.mean( (np.load(\"l_stop_alg_d.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    c_URS.append(np.mean( (np.load(\"l_stop_rand_d.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    c_oracle.append(np.mean( (np.load(\"l_stop_oracle_d.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    c_EG0.append(np.mean( (np.load(\"l_stop_alg_d_theory.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    \n",
    "    e_EG1.append(np.std( (np.load(\"l_stop_alg_d.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    e_URS.append(np.std( (np.load(\"l_stop_rand_d.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    e_oracle.append(np.std( (np.load(\"l_stop_oracle_d.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    e_EG0.append(np.std( (np.load(\"l_stop_alg_d_theory.npy\").flatten()[(i*itr*tau_max):(tau_max*itr*(i+1))]-tau_list[k]).clip(0) ))\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ecbed1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "k=0 # k=0,1,2,3 for path length d =10,15,20,25 respectively\n",
    "print(\"Oracle\")\n",
    "print(\"Mean:\",c_oracle[k])\n",
    "print(\"Std:\",e_oracle[k])\n",
    "\n",
    "print(\"EG_full\")\n",
    "print(\"Mean:\",c_EG1[k])\n",
    "print(\"Std:\",e_EG1[k])\n",
    "\n",
    "print(\"EG_Theory\")\n",
    "print(\"Mean:\",c_EG0[k])\n",
    "print(\"Std:\",e_EG0[k])\n",
    "\n",
    "print(\"URS\")\n",
    "print(\"Mean:\",c_URS[k])\n",
    "print(\"Std:\",e_URS[k])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "488508c1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94cc74dc",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
