{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "\n",
    "# Get the current working directory (assumed to be 'notebooks')\n",
    "current_dir = os.getcwd()\n",
    "\n",
    "# Get the root directory of the repository\n",
    "root_dir = os.path.abspath(os.path.join(current_dir, '..'))\n",
    "\n",
    "# Add the 'src' directory to the system path\n",
    "src_dir = os.path.join(root_dir, 'src')\n",
    "if src_dir not in sys.path:\n",
    "    sys.path.append(src_dir)\n",
    "\n",
    "import numpy as np\n",
    "from ripser import ripser\n",
    "import matplotlib.pyplot as plt\n",
    "from src.utils.tda import get_tda, get_sw\n",
    "from src.utils.plotting import plot_diagram\n",
    "from mpl_toolkits.mplot3d import Axes3D\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "t_values = np.linspace(0, 6*np.pi, 600)\n",
    "time_series_1 = np.sin(t_values)\n",
    "time_series_2 = np.sin(t_values) + np.sin(2*t_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(t_values, time_series_1, label='time series 1')\n",
    "plt.savefig('../outputs/tda/examples/time-domain-1.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(t_values, time_series_2, label='time series 2')\n",
    "plt.savefig('../outputs/tda/examples/time-domain-2.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "D1, B1, PS1 = get_tda(time_series_1, 2, 4)\n",
    "sw_point_cloud_1 = get_sw(time_series_1, 2, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_diagram(D1, demo_mode=False, filename='../outputs/tda/examples/persistance-diagram-1.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(f'{PS1 = }') # Print periodicity scores\n",
    "print(f'{B1 = }')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter(sw_point_cloud_1[:,0], sw_point_cloud_1[:,1], marker = '*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "D2, B2, PS2 = get_tda(time_series_2, 3, 4)\n",
    "sw_point_cloud_2 = get_sw(time_series_2, 3, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_diagram(D2, demo_mode=False, filename='../outputs/tda/examples/persistance-diagram-2.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(f'{PS2 = }') # Print periodicity scores\n",
    "print(f'{B2 = }')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(111, projection='3d')\n",
    "ax.scatter(sw_point_cloud_2[:,0], sw_point_cloud_2[:,1], sw_point_cloud_2[:,2], marker = '*')\n",
    "ax.set_xticklabels([])\n",
    "ax.set_yticklabels([])\n",
    "ax.set_zticklabels([])\n",
    "#ax.view_init(elev=30, azim=60)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "implicit-thinking",
   "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": 2
}
