{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# -*- coding: utf-8 -*-\n",
    "import torch \n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import timeit \n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.io import savemat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "df/dt = dx1*(4.686*x1**5 + 1.192*x1**3*x2**2 - 16.392*x1**3 - 1.302*x1**2*x2**3 + 9.72*x1**2*x2 + 0.566*x1*x2**4 + 1.42*x1*x2**2 + 16.7218*x1 - 0.089*x2**5 - 0.063*x2**3 - 11.679*x2) + dx2*(0.596*x1**4*x2 - 1.302*x1**3*x2**2 + 3.24*x1**3 + 1.132*x1**2*x2**3 + 1.42*x1**2*x2 - 0.445*x1*x2**4 - 0.189*x1*x2**2 - 11.679*x1 + 0.072*x2**5 + 0.2*x2**3 + 9.8498*x2)\n"
     ]
    }
   ],
   "source": [
    "from sympy import symbols, diff, simplify\n",
    "\n",
    "# Define symbols\n",
    "x1, x2, dx1, dx2 = symbols('x1 x2 dx1 dx2')\n",
    "\n",
    "# Define f(x1, x2)\n",
    "f =(\n",
    "        8.361 * x1**2\n",
    "        - 11.679 * x1 * x2\n",
    "        + 4.925 * x2**2\n",
    "        - 4.098 * x1**4\n",
    "        + 3.240 * x1**3 * x2\n",
    "        + 0.710 * x1**2 * x2**2\n",
    "        - 0.063 * x1 * x2**3\n",
    "        + 0.050 * x2**4\n",
    "        + 0.781 * x1**6\n",
    "        + 0.298 * x1**4 * x2**2\n",
    "        - 0.434 * x1**3 * x2**3\n",
    "        + 0.283 * x1**2 * x2**4\n",
    "        - 0.089 * x1 * x2**5\n",
    "        + 0.012 * x2**6\n",
    "    ) - 0.0001*(x1*x1+x2*x2)\n",
    "\n",
    "# Compute ∂f/∂x1 and ∂f/∂x2\n",
    "df_dx1 = diff(f, x1)\n",
    "df_dx2 = diff(f, x2)\n",
    "\n",
    "# Time derivative: df/dt = ∂f/∂x1 * dx1 + ∂f/∂x2 * dx2\n",
    "df_dt = df_dx1 * dx1 + df_dx2 * dx2\n",
    "\n",
    "# Simplify (optional)\n",
    "df_dt = simplify(df_dt)\n",
    "\n",
    "# Display result\n",
    "print(\"df/dt =\", df_dt)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Two dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "#two dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        8.361 * x1**2\n",
    "        - 11.679 * x1 * x2\n",
    "        + 4.925 * x2**2\n",
    "        - 4.098 * x1**4\n",
    "        + 3.240 * x1**3 * x2\n",
    "        + 0.710 * x1**2 * x2**2\n",
    "        - 0.063 * x1 * x2**3\n",
    "        + 0.050 * x2**4\n",
    "        + 0.781 * x1**6\n",
    "        + 0.298 * x1**4 * x2**2\n",
    "        - 0.434 * x1**3 * x2**3\n",
    "        + 0.283 * x1**2 * x2**4\n",
    "        - 0.089 * x1 * x2**5\n",
    "        + 0.012 * x2**6\n",
    "    )- 0.0001*(x1*x1+x2*x2)\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(4.686*x1**5 + 1.192*x1**3*x2**2 - 16.392*x1**3 - 1.302*x1**2*x2**3 + 9.72*x1**2*x2 + 0.566*x1*x2**4 + 1.42*x1*x2**2 + 16.7218*x1 - 0.089*x2**5 - 0.063*x2**3 - 11.679*x2) + dx2*(0.596*x1**4*x2 - 1.302*x1**3*x2**2 + 3.24*x1**3 + 1.132*x1**2*x2**3 + 1.42*x1**2*x2 - 0.445*x1*x2**4 - 0.189*x1*x2**2 - 11.679*x1 + 0.072*x2**5 + 0.2*x2**3 + 9.8498*x2)\n",
    "    \n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of V > 0 points:  400\n",
      "number of V < 0 points:  0\n",
      "number of \\dot V < 0 points:  222\n",
      "number of \\dot V > 0 points:  178\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.017785269218361495\n",
      "182 10.368811954304663\n"
     ]
    }
   ],
   "source": [
    "Num = 20\n",
    "#real value for state, same as the deviation form\n",
    "x1_list = np.linspace(-2, 2, Num, endpoint=True)\n",
    "x2_list = np.linspace(-2, 2, Num, endpoint=True) \n",
    "\n",
    "state_list = list()\n",
    "v_list = list()\n",
    "dv_list = list()\n",
    "\n",
    "for x1 in x1_list:   \n",
    "    for x2 in x2_list:\n",
    "        dx1 = x2\n",
    "        dx2 = -x1-(x1*x1-1)*x2\n",
    "        #second order\n",
    "#         v =  1.1807e-06*x1**2 + 1.6225e-08*x1*x2 + 4.682e-07*x2**2 \n",
    "#         dv1 = 2*1.1807e-06*x1*dx1 + 1.6225e-08*(x1*dx2 + dx1*x2) + 2*4.682e-07*x2*dx2\n",
    "\n",
    "        #four order\n",
    "        v = f(x1,x2)\n",
    "        dv = df_dt(x1,x2,dx1,dx2)\n",
    "\n",
    "        state_list.append([x1,x2])\n",
    "        v_list.append(v)\n",
    "        dv_list.append(dv)\n",
    "        \n",
    "#plot the region for the stable states\n",
    "V_point_list = list()\n",
    "PV_point_list = list()\n",
    "for i in range (len(state_list)):\n",
    "    if v_list[i] >0:\n",
    "        V_point_list.append(state_list[i])\n",
    "    else:\n",
    "        PV_point_list.append(state_list[i]) \n",
    "print(\"number of V > 0 points: \", len(V_point_list))\n",
    "print(\"number of V < 0 points: \", len(PV_point_list))\n",
    "\n",
    "#plot the region for the stable states\n",
    "dV_point_list = list()\n",
    "PdV_point_list = list()\n",
    "for i in range (len(state_list)):\n",
    "    if dv_list[i] <0:\n",
    "        dV_point_list.append(state_list[i])\n",
    "    else:\n",
    "        PdV_point_list.append(state_list[i]) \n",
    "print(\"number of \\dot V < 0 points: \", len(dV_point_list))\n",
    "print(\"number of \\dot V > 0 points: \", len(PdV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list\n",
    "x_values = [point[0] for point in dV_point_list]\n",
    "y_values = [point[1] for point in dV_point_list]\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values, y_values, color='blue', label='Points')\n",
    "\n",
    "# Adding labels and title\n",
    "plt.xlabel('X-axis')\n",
    "plt.ylabel('Y-axis')\n",
    "plt.title('Plot of 2D stable Points')\n",
    "\n",
    "# Displaying the plot\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.show()\n",
    "\n",
    "#Search for the biggest pho\n",
    "Num_points = 0\n",
    "Index_pho = 0\n",
    "Flag = True\n",
    "pho = min(v_list)\n",
    "print(pho)\n",
    "while(Flag):\n",
    "    pho = pho+ min(v_list)/2\n",
    "    V_point_list = list()\n",
    "    #get region with stable if and only if\n",
    "    for i in range (len(v_list)):  \n",
    "        if v_list[i] < pho:\n",
    "            V_point_list.append(state_list[i])\n",
    "    #Check the boundary, via the magnitude of CA and T, the lines\n",
    "    for k in V_point_list: \n",
    "        if abs(k[0])>=2 or abs(k[1])>=2:\n",
    "            #print(k)\n",
    "            Flag =False\n",
    "            V_point_list = list()  #set the list as empty\n",
    "            break \n",
    "    K = len(V_point_list)  #if number of samples increase, update the value of pho\n",
    "    if K > Num_points:\n",
    "        Num_points = K\n",
    "        Index_pho = pho\n",
    "print(Num_points,Index_pho)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  176\n",
      "number of points beyond levelset:  224\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#identify the stability region\n",
    "iV_point_list = list()\n",
    "uV_point_list = list()\n",
    "n = 10  # pho obtained\n",
    "for i in range (len(v_list)):\n",
    "    if v_list[i] > n:\n",
    "        iV_point_list.append(state_list[i])\n",
    "    else:\n",
    "        uV_point_list.append(state_list[i]) \n",
    "print(\"number of points within levelset: \", len(uV_point_list))\n",
    "print(\"number of points beyond levelset: \", len(iV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list Beyond levelset\n",
    "x_values = [point[0] for point in iV_point_list]\n",
    "y_values = [point[1] for point in iV_point_list]\n",
    "\n",
    "\n",
    "# Extracting the x and y coordinates from the list Within levelset\n",
    "x_values_b = [point[0] for point in uV_point_list]\n",
    "y_values_b = [point[1] for point in uV_point_list]\n",
    "\n",
    "\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values, y_values, color='Blue', label='Beyond Points')\n",
    "plt.scatter(x_values_b, y_values_b, color='Red', label='In Points')\n",
    "\n",
    "\n",
    "# Adding labels and title\n",
    "plt.xlabel('X-axis')\n",
    "plt.ylabel('Y-axis')\n",
    "plt.title('V <' + str(n))\n",
    "\n",
    "# Displaying the plot\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Convert to numpy array\n",
    "# np.savetxt('V.txt', V_candidate.detach().numpy(), fmt='%.6f')  # Adjust format as needed\n",
    "# # Save to text file\n",
    "# np.savetxt('LV.txt', L_V.detach().numpy(), fmt='%.6f')  # Adjust format as needed\n",
    "\n",
    "\n",
    "# Convert tensors to NumPy array\n",
    "array_data1 = np.array([t for t in WV_point_list]) #unstable V\n",
    "array_data2 = np.array([t for t in uWV_point_list]) #stable\n",
    "\n",
    "\n",
    "# Save as .mat\n",
    "savemat('unstable_VDP_P.mat', {'data': array_data1})\n",
    "savemat('stable_VDP_P.mat', {'data': array_data2})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
