{
 "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": 6,
   "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": 17,
   "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": 18,
   "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",
      "0 0\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",
    "            if dv_list[i] > 0:  #NO POINTS WITHIN THE REGION IS UNSTABLE\n",
    "                Flag =False\n",
    "                V_point_list = list()  #set the list as empty\n",
    "                break\n",
    "            else:\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": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  354\n",
      "number of points beyond levelset:  46\n"
     ]
    },
    {
     "data": {
      "image/png": "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s4waNYqDDjoIM2P69Omx4d+/aBFHTJ/OiV/4AufPmEFTYyP/eOUVjj/lFABmzJjBfffdl1d72mmnwbBhjB83jjXPP79jhll2vQDvfe97mTlzJj/+8Y/Zlu/oYfDgunY293Z9EpQoyDoYr7su62iE7N/rrgtwNuZ2YBbegfT59YMGJdMPGcI7hm3POyvRr6ohQ7JjdhxZ9O+ffT9kyE6LHXXUUWzcuJENGzbg7lxwwQUsWrSIRUuWsGrRIj79kY8AMOv00/nZn/7EDbffzqc+9aluhx/Q0NA5ft8+fdhqBvvvD7vtliB4OPa443j0wQdpu+UWzj799KyuX79d4s879oABMGQIfQcMYGt0CqvTmR3pr7nmGr75zW/y3HPPMXHiRF588cWdOxk0KNX9p1p33zT00IPvryTEXbzozU3O7MpRzrhCbo8t9s6ROHIvZi9fvtyHDBniW7du9Xnz5vnkyZP9lVdecXf39vZ2//vf/+7u7m+++aa/853v9FGjRvnWrVvd3f3222/3E0880V966SVfv369v+Md7/B169btcpH685//vN9www3++uuv+/Dhw33VqlXu7v7Rj340/mJ2numHH36433fffe7ufvHFF/sXv/hFd3efMWOG33rrre7uPmLECN+wYYO7uy9YsMCPP/54d3efM2eOf/3rX+/sqyMGd/dJkyb5o48+utNYQbcxB1KP+30xlMuZnUqtJyFKTdd6OU1N27nssj5F/6rquEYB2R9VN954I3379uXEE09k+fLlHHXUUQA0NDRw0003se+++9K/f3+am5t529ve1mliO/XUU/nLX/7C0UcfTd++ffnud7/Lfvvtx4oVK/KOO3DgQK677jpOPvlk9thjD4499lheeeWVxHHfeOONnH322bz22muMHj2aG264IbH2X//1X5k2bRq/+c1v+OEPf8hVV13Fk08+ibtzwgknMG7cuMR9iRohLoP05qYjispRLUcUXUmzptK2bdt83Lhx/sQTT+wyr5ZqPXWgI4rqoaZqPQlRqyxbtowDDzyQE044gYMOOijtcIQoCUoUEUU/nLyXP9y91+tffBEeewwefjj7d+vW4vRdL9gm1B/62mus/vWv+d7XvpbK+D3Wb91anL7I7Zf27lMr+h5/f3VH3KFGb24q4VH68eOo9RIepdb3tIRHuePPLeERqi+2hEeh3UclPML0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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 = 41  # 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
}
