{
 "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 = 28.01*dx1*x1**3*x2**2 + 42.015*dx1*x1**2*x2 + 49.704*dx1*x1*x2**2 + 122.0598*dx1*x1 - 14.005*dx1*x2 + 14.005*dx2*x1**4*x2 + 14.005*dx2*x1**3 + 49.704*dx2*x1**2*x2 - 14.005*dx2*x1 + 58.3508*dx2*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",
    "term1 = (6.93 * x1 - 2.45 * x2)**2\n",
    "term2 = (2.45 * (x1 + x1**2 * x2) + 4.48 * x2)**2\n",
    "term3 = (2.45 * x1 - x2)**2  # Corrected term\n",
    "term4 = (x1 + x1**2 * x2 + 1.45 * x2)**2\n",
    "# Define f(x1, x2)\n",
    "f =  term1 + term2 + term3 + term4\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",
    "    term1 = (6.93 * x1 - 2.45 * x2)**2\n",
    "    term2 = (2.45 * (x1 + x1**2 * x2) + 4.48 * x2)**2\n",
    "    term3 = (2.45 * x1 - x2)**2  # Corrected term\n",
    "    term4 = (x1 + x1**2 * x2 + 1.45 * x2)**2\n",
    "    # Define f(x1, x2)\n",
    "    f =  term1 + term2 + term3 + term4\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = 28.01*dx1*x1**3*x2**2 + 42.015*dx1*x1**2*x2 + 49.704*dx1*x1*x2**2 + 122.0598*dx1*x1 - 14.005*dx1*x2 + 14.005*dx2*x1**4*x2 + 14.005*dx2*x1**3 + 49.704*dx2*x1**2*x2 - 14.005*dx2*x1 + 58.3508*dx2*x2\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:  180\n",
      "number of \\dot V > 0 points:  220\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.8491047999972604\n",
      "36 20.378515199933968\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)/100\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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  34\n",
      "number of points beyond levelset:  366\n"
     ]
    },
    {
     "data": {
      "image/png": "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ySWn8/3v/4y5c+cydOhQfvSjH+XV9uvXjz/96WkmTDiDW26Zwm67DeTEE8/k5JO/zx13zOawww7j0ksvZcaMGcyZM4e77757i2WEbaek9x/po+mjIGc2yTsjpc+vz/rnvSC77w5vvJF/XpT/qnbffUtncrdu6elbb701s2fPZtGiRdx3332cfvrpuDszZ85k5syZHHDAAZx22gheemkRr776PLvtNpDtt+/Lc889w3PPpef37duXRx55hJNPPpnu3bvT2NjImDFjePLJJwEYOXI0u+7aRLdu3dhrr+G89tpLvPLKIgYNGsSee+6JmXHqqaeGxj979sOceuoBfPe7RzFhwnk0Njaxdu07HHfcGAAmTJjAQw89lFd7wgknsPvuMGxYetwMZunvD3DIIYcwceJErr/+ejbmOXzYccfq3H+kj6aPghIFaQfjddelHY2Qfr3uunjOyIzeTPpS6fv0iabv23fzj1ouUf6r6ts3PWbmyKJnz/Tnvn0/3u+ggw5i5cqVrFixAnfn/PPPZ/bs2cybN5vZs5fwla+cAcCJJ07iH//4PdOm3cg3vvGNDsdvaOj10fjdunXHbAO77gpbbdVx7ACHH34Yjz76DLfd1saJJ57JVltBjx5bxp+PXr160bcv9OrVHfcNwGZndkZ/zTXX8OMf/5hXX32VkSNH8tZbb31sGX36VOf+U496iK+PRNjFi67c5MyuHOWMK87tscXeORJG9sXshQsXet++fX3Dhg0+Y8YMHz16tK9du9bd3dvb2/2NN95wd/cPPvjA99prLx80aJBv2LDB3d2nTZvmRx11lL/99tv+5ptv+ic/+Ulfvnz5Fhepv/Od7/iNN97o7733nvfv39+XLFni7u5f/epXQy9m55u+//77+0MPPeTu7hdffLF/73vfc3f3CRMm+O233+7u7gMGDPAVK1a4u/usWbN8zJgx7u4+ZcoUv+iiiz5aViYGd/dRo0b5M88887Gx4mynuNTjfl8M5XJmJ1LrSYhSk1svp6lpE5df3q3o/6oy1ygg/U/VTTfdRPfu3TnqqKNYuHAhBx10EAANDQ3ccsst7LzzzvTs2ZPm5mZ22GGHj0xsxx9/PI899hgHH3ww3bt35+c//zm77LILixYtyjtu7969ue666zjmmGPYZpttOOyww1i7dm3kuG+66SbOPPNM1q1bx+DBg7nxxhsj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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 = 20.37  # 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": "markdown",
   "metadata": {},
   "source": [
    "# since the dynamics of the model is different, we need reverse it  as x = -x "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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",
    "\n",
    "# Convert tensors to NumPy array\n",
    "array_data1 = np.array([[-val for val in t] for t in uV_point_list]) #stable V\n",
    "array_data2 = np.array([[-val for val in t] for t in iV_point_list]) #unstable\n",
    "\n",
    "\n",
    "# Save as .mat\n",
    "savemat('stable_VDP_SOS_TAC.mat', {'data': array_data1})\n",
    "savemat('unstable_VDP_SOS_TAC.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
}
