{
 "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*(106066.689*x1**9 + 0.012402*x1**8*x2 + 70711.1232*x1**7*x2**2 - 36.6891*x1**6*x2**3 + 17680.4202*x1**5*x2**4 - 6.775*x1**4*x2**5 + 1964.6336*x1**3*x2**6 - 0.64521*x1**2*x2**7 + 81.8424*x1*x2**8 - 0.01314*x2**9) + dx2*(0.001378*x1**9 + 17677.7808*x1**8*x2 - 15.7239*x1**7*x2**2 + 11786.9468*x1**6*x2**3 - 6.775*x1**5*x2**4 + 2946.9504*x1**4*x2**5 - 1.50549*x1**3*x2**6 + 327.3696*x1**2*x2**7 - 0.11826*x1*x2**8 + 13.642*x2**9)\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",
    "        10606.6689 * x1**10\n",
    "        + 0.001378 * x1**9 * x2\n",
    "        + 8838.8904 * x1**8 * x2**2\n",
    "        - 5.2413 * x1**7 * x2**3\n",
    "        + 2946.7367 * x1**6 * x2**4\n",
    "        - 1.355 * x1**5 * x2**5\n",
    "        + 491.1584 * x1**4 * x2**6\n",
    "        - 0.21507 * x1**3 * x2**7\n",
    "        + 40.9212 * x1**2 * x2**8\n",
    "        - 0.01314 * x1 * x2**9\n",
    "        + 1.3642 * x2**10\n",
    "    )\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 = 2.4205*x1**2 + 6.2131e-06*x1*x2 + 0.40342*x2**2\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(4.841*x1 + 6.2131e-6*x2) + dx2*(6.2131e-6*x1 + 0.80684*x2)\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:  400\n",
      "number of \\dot V > 0 points:  0\n"
     ]
    },
    {
     "data": {
      "image/png": "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9KeffpZ/+ctfdnf3nXfeedu2eOMb37jtfRYuXOiXX365u7vvs89sX7Zsva9bt8mXL3/c58zZ30899VS/9tpr/bnnnsu9LciYA4h6T2AzmwwMAgcAF7n73zZZpx/oB+jt7V0wMDBQuL+hoaFth11VQr7yU0VPIF+htNrXLrvswgEHHJBz3R7cR18uaeY8/vhGJk+eXMjDnnvuybp167Z77aKLLuKJJ57grLPOAuCcc85h5syZfOhDH9q2/vLly7ngggu48sorATj99NOZP38+J554InPnzuXGG29k+vTpTJ48maGhIX7yk5+wZMkSZs6cycUXXzzKx3333cfGjRu3e62vr2/Q3Q8ftXKzUaHdDZgOLAXmjrWeykG3lyr6qqInd/kKpdW+so4AmhFyBBDC8H/0jQwODvohhxzimzdv9qGhIT/44IP99ttv3279pUuX+lve8pZtmg9/+MN+6aWXurv73Llz/f777/dNmzb5+vXrfePGje7uvmLFCp83b15THyFHAJUoBeHuT5rZMuBoYE1kO0KILmbRouSc/9MNF9eEzC2EMH/+fN73vvdxxBFHAHDKKadw2GGH5db39/dzzDHHsMcee3DhhRdy8skn8/zzzwPwhS98YeIGm40K7WjA7sD09PGLgeXAX46l0RyA5gA0BxCm1xxA83P4We87kTmAkP5D9evWbcqt74ggGPCnwApgNcl//Z8ZT6MkcDn9Z6EksJLASgIrCVyZpiRwOf1noSRwfr2SwGH6bkwCt6L/LL2SwAWJnUaUvri+k71L3359sp97gXYngaugH7kNxqPrB4DYaUTpi+s72bv07dVPmTKFDRs2bLcDnEiStxP17sn9AKZMmZKvA2pwQ5iJzvhLH0/fTBuaBO7Uz94q/aOPbv9ap/nPq581axZr165l/fr121774x+T8smN/xSbwYwZkHVzrS1btmzbgRbRN9JK/XPPbeGJJ6aMqx++I1hump0XqmrTVUC6CkhXAYXp63IVUKv0I33F/v4muu8ahrpOAjdSl1BMq6iiryp6cpevUOQrjIn6yhoAun4OQAghRHM0AAghRE2pxQCgewJ3rl73BNY9gaUvvu8al2bnharalAQup/8slARWErhTksCt0jf6qsL3N5F9VyPUdRJYSeDieiWB8+uVBA7TtzoJ3Cp9o68qfH8T2Xc1kjUAdP0poE5LM0pf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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.037838007794271405\n",
      "180 3.8594767950156954\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(-3.14, 3.14, 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 = 2*np.sin(x2)\n",
    "        dx2 = -x2 - 2*6*np.sin(x2)/x2*x1\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])>=3.14:\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:  180\n",
      "number of points beyond levelset:  220\n"
     ]
    },
    {
     "data": {
      "image/png": "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uooTTjhhw/2333479hi97f/666/n0Ucf5Te/+Q1NTU20t7czbNiwyGMIEZd8XAMQmaXUqdAttvCanwqthKFDh7LtttuyYMECAG655RYmT54cWT9kyBDeeeedDfefffZZDj74YK644gq23357Xn755Zp7FqIr+SkASgKHo3/33cjS00+Hq6+G4cMLFySHD4cf/OADTj89+vC1SAJ3dBSORLprb775ZmbNmsWkSZNob2/n0ksv7aH/6CNoby/s5623PnnsuOOO484779xwEXjWrFmMGzeOxsZGjjjiCMaPH59aEngD776r933aeiWBq7wGoCRwRfpaJIFL6Z+5777IVyOVBE4vCewdHYXXKoH3npLA0fVKAldL2qk8JSI33ubRo7xKAlen9yqSwFVHgfW+T08fkXwUgLRTeUpE9iRiHDXNNGyoSdx66auOAut9n54+IvkoAGmn8pSI7EnEOGqaadhQk7j10lcdBdb7Pj19RPJRANJO5SkRufG2GFHgUmnYOEniatK0tUjipq2vJglcdRRY7/v09FEpdWEg6Qb8E/AE0A7MA3aOolMSOJtJ4O76ZxYujCXvnoZdvTpeuKmaNG1UbbnAVbVJ3rSTwM8sXJjIe09J4Oj6fpcEBrbucvtC4PooOiWB60sISeBSVJtuTYIQPbkrCRyHED25J5sETuUUkLuv6XJ3K8DL9RUiCQYOHEhTUxPjx49nv/3263VVziSZP38+n/vc50puHzp0KBMmTGCvvfbi8ssv73U/ixYt4sILL+y1z1tvvcWPfvSjqvyK/oV596951Wtgs+8AZwFvA83u/kaZfjOAGQANDQ37t7S0VDVuZ2cngwf3vRZ8vQnRV1Kehg4dyu677x65/ya3387ml1+OrViBjxjB+9/8JutOOaUqD8OHD+e1114D4MEHH+T73/8+9957b8X7W7t2LQMHDoytW7BgAddddx1z5swpu/3dd9/l0EMP5ac//SkTJkyo2NeLL77ISSedxKOPPhpZv3z58lhLXkQlT+/3aqmFr+bm5jZ3P6DHA6UOC2rRgAeBp0q0ad36fR24PMo+dQ0gh9cAbr3VfYstvGugZt0WW8TzUOJE+vrF4NwLq3tOmzZtw/0rr7zSDzjgAB83bpxfOnOm++LF/o9f/KL/4Gtf23AS/Rvf+IZfe+21vm7dOp85c6bvtdde3tjY6C0tLe5e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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Original Stability region chosen as benchmark\n",
    "WV_point_list = list()\n",
    "uWV_point_list = list()\n",
    "n = 3.859\n",
    "for i in range (len(state_list)):\n",
    "    a = state_list[i][0]\n",
    "    b = state_list[i][1]\n",
    "    if v_list[i] > n:\n",
    "        WV_point_list.append([a,b])\n",
    "    else:\n",
    "        uWV_point_list.append([a,b]) \n",
    "print(\"number of points within levelset: \", len(uWV_point_list))\n",
    "print(\"number of points beyond levelset: \", len(WV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_W = [point[0] for point in WV_point_list]\n",
    "y_values_W = [point[1] for point in WV_point_list]\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_uW = [point[0] for point in uWV_point_list]\n",
    "y_values_uW = [point[1] for point in uWV_point_list]\n",
    "\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values_uW, y_values_uW, color='Blue', label='In Points')\n",
    "plt.scatter(x_values_W, y_values_W, color='Red', label='Beyond Points')\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": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 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": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Four dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "#four dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        1151.0021 * x1**4\n",
    "        + 0.00061868 * x1**3 * x2\n",
    "        + 383.6674 * x1**2 * x2**2\n",
    "        - 0.0037202 * x1 * x2**3\n",
    "        + 31.9722 * x2**4\n",
    "    )\n",
    "\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(4604.0084*x1**3 + 0.00185604*x1**2*x2 + 767.3348*x1*x2**2 - 0.0037202*x2**3) + dx2*(0.00061868*x1**3 + 767.3348*x1**2*x2 - 0.0111606*x1*x2**2 + 127.8888*x2**3)\n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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:  400\n",
      "number of \\dot V > 0 points:  0\n"
     ]
    },
    {
     "data": {
      "image/png": "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9KeffpZ/+ctfdnf3nXfeedu2eOMb37jtfRYuXOiXX365u7vvs89sX7Zsva9bt8mXL3/c58zZ30899VS/9tpr/bnnnsu9LciYA4h6T2AzmwwMAgcAF7n73zZZpx/oB+jt7V0wMDBQuL+hoaFth11VQr7yU0VPIF+htNrXLrvswgEHHJBz3R7cR18uaeY8/vhGJk+eXMjDnnvuybp167Z77aKLLuKJJ57grLPOAuCcc85h5syZfOhDH9q2/vLly7ngggu48sorATj99NOZP38+J554InPnzuXGG29k+vTpTJ48maGhIX7yk5+wZMkSZs6cycUXXzzKx3333cfGjRu3e62vr2/Q3Q8ftXKzUaHdDZgOLAXmjrWeykG3lyr6qqInd/kKpdW+so4AmhFyBBDC8H/0jQwODvohhxzimzdv9qGhIT/44IP99ttv3279pUuX+lve8pZtmg9/+MN+6aWXurv73Llz/f777/dNmzb5+vXrfePGje7uvmLFCp83b15THyFHAJUoBeHuT5rZMuBoYE1kO0KILmbRouSc/9MNF9eEzC2EMH/+fN73vvdxxBFHAHDKKadw2GGH5db39/dzzDHHsMcee3DhhRdy8skn8/zzzwPwhS98YeIGm40K7WjA7sD09PGLgeXAX46l0RyA5gA0BxCm1xxA83P4We87kTmAkP5D9evWbcqt74ggGPCnwApgNcl//Z8ZT6MkcDn9Z6EksJLASgIrCVyZpiRwOf1noSRwfr2SwGH6bkwCt6L/LL2SwAWJnUaUvri+k71L3359sp97gXYngaugH7kNxqPrB4DYaUTpi+s72bv07dVPmTKFDRs2bLcDnEiStxP17sn9AKZMmZKvA2pwQ5iJzvhLH0/fTBuaBO7Uz94q/aOPbv9ap/nPq581axZr165l/fr121774x+T8smN/xSbwYwZkHVzrS1btmzbgRbRN9JK/XPPbeGJJ6aMqx++I1hump0XqmrTVUC6CkhXAYXp63IVUKv0I33F/v4muu8ahrpOAjdSl1BMq6iiryp6cpevUOQrjIn6yhoAun4OQAghRHM0AAghRE2pxQCgewJ3rl73BNY9gaUvvu8al2bnharalAQup/8slARWErhTksCt0jf6qsL3N5F9VyPUdRJYSeDieiWB8+uVBA7TtzoJ3Cp9o68qfH8T2Xc1kjUAdP0poE5LM0pf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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.2812679421160712\n",
      "180 2919.2799712211972\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(-3.14, 3.14, 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 = 2*np.sin(x2)\n",
    "        dx2 = -x2 - 2*6*np.sin(x2)/x2*x1\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])>=3.14:\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": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  180\n",
      "number of points beyond levelset:  220\n"
     ]
    },
    {
     "data": {
      "image/png": "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/jps3Fhd/caN0fSVaH3Rq1ZXH+etk+X3vXN9RLIxALhO5WU4EVlss3/8I1rzxbarVD9uXM/T6+ZqL7/8LKZMGcFppzVx0kkH8sQTT5TUXnbZZSxY8EjJeufPn8/jjz8eqf0oy2ultyRwCvQRycYA4DqVl+FEZLHNttwyWvNbbgkPPgjHHQeHHBL8/cMf+sXSl0u+9oILruZ3v2vnoot+ynnnnVdSe+WVV3LEEZNK1tvTAFDMe6X7XqneksAp0EckGwOA61RehhORheQisNtu0Zp/4gn48Y9h9ergcsTq1TBjRh09fADfxG67dU/D9unz6bL58+fzuc99jhNOOIF99tmH008/HQ2vexTTHnfcBFasWAFAe3s748aNY/z48Rx//PG8/fbbAJx11lm0td1Fnz7w5S83cOONP+CMMw7klFNG8cEHy3j55Ze54YYbuPbaa2lqamLBggXMnj2bxsZGRo8ezYQJE4q2H7Xvdtst6Otq6i0JnBJ9VArdGPC1WBK4dySBFy5cEllb8YyUGtzMXLw4uAm6eHHwfJtttlHVYB+33XZbfe2113TDhg06btw4XbBgQTft5MnTdNas2drRoXrnnXfqIYccoqqqo0aN0vnz5+u6dev0+9//vl544YWqqjpt2jSdPTvYftddh+uMGdfr4sWqV131Kz3nnHNUVfUHP/iBXn311Zvaamxs1JUrV6qq6ttvv13UexzWrl1XkX7hwiWWBLYksB/FksC1JSlPS5ZEHwBECg8AIpV5yB0AJk2atGn5+eefr7feemu37adNm6YNDQ06evRonTRpkj777LP6zjvv6LBhw1Q1+BbQihUrdMyYMZu2nz17tqqqDh8+fNOB/S9/+Yt+4QtfUNXuA8B5552nkyZN0t/85jfaEfdIXYRC306KQ5zXKg5Zer9XiiWBjcyy++7wyiuFl1eLrbbaatPjvn37sr5I0ODqq6/mhBNO2PT83Xffjd1GqfpvuOEGnnzySe6//36amppob29n8ODBkdswjLhk4x6AkVoKXQrt31+rfim0HAYNGsT222/PggULALj11luZOHFiZP3AgQN57733Nj1/4YUXOPTQQ7nyyivZcccdee2116ru2TByyc4AYElgf/Tvvx9ZevrpcM01MGRIcENyyBD4xS8+4vTTozdfjSRwR0dwJpKvveWWW5g5cybjx4+nvb2dyy67rJv+k0+gvT2o5513Pl133HHHcffdd2+6CTxz5kxGjRpFY2MjEyZMYPTo0c6SwJt4/31737vWWxK4wnsAlgQuS1+NJHAh/ZK5cyPfjbQksLsksHZ0BK9VAu89SwJH11sSuFJcp/IsEbn5Mo0e5bUkcGV6rSAJXHEU2N737vQRycYA4DqVZ4nI7kSMo7pMw/qaxK2VvuIosL3v3ekjko0BwHUqzxKR3YkYR3WZhvU1iVsrfcVRYHvfu9NHJBsDgOtUniUiN18WIwpcKA0bJ0lcSZq2Gklc1/pKksAVR4Htfe9OH5VCNwaSLsC/AM8A7RYBAzwAAA4KSURBVMA8YNcoOksCpzMJnK9fsnBhLHl+Gnbt2njhpkrStFG1xQJXlSZ5XSeBlyxcmMh7z5LA0fW9LgkMbJvz+ALghig6SwLXFh+SwIWoNN2aBD56UrUkcBx89KSabBLYySUgVV2X83QbQIttaxhJ0LdvX5qamhg9ejQHHnhgyVk5k2T+/Pl86UtfKrh80KBBjBkzhn333ZcrrriiZD2LFi3iggsuKLnNO++8w69//euK/Bq9C9H8r3nVqmGRHwFTgXeBZlV9q8h204HpAPX19WNbWloqarezs5MBA3qeC77W+OgrKU+DBg1ir732irx9vzvvZKsrrkBWrkSHDuXD73+fjaecUpGHIUOG8MYbbwDwyCOP8POf/5wHH3yw7Po2bNhA3759Y+sWLFjA9ddfz+zZs4suf//99znssMP47W9/y5gxY8r29corr3DSSSfx5JNPRtavWLEi1pQXUcnS+71SquGrubm5TVUP6rai0GlBNQrwCPBcgTIlb7tLgCui1Gn3ADJ4D+C221T799fcQM3G/v3jeShwIb1rMjjVYHbPKVOmbHp+1VVX6UEHHaSjRo3Sy2bMUF28WP/57LP1F9/97qaL6N/73vf0uuuu040bN+qMGTN033331cbGRm1paVHVoO8mTpyoXz3uOB3Z0KCnHX20bmxvV+3o0AcffFBHjhyphx12mH7zm9/UyZMnd7Pc2toaLA+9n3zkkfr7q67SD1eu1LPOOksbGxu1qalJ//znP2++vQaTzH3ta1/TiRMnasPw4Xrdd7+runChnnz00VpXV6ejR4/WGTNm6KpVq/SII47Q0aNH6/7776+PPvpoNx92D6B27RfT97p7AJsZgOHAc1G2tSRwMm0Xw4cksA4dunnbXWXo0Gj6InHaPn366OjRo3XkyJG67bbb6qJFi1RV9aGHHtJzzz1XN27cqBvefFMnH364/veNN+pL99yjY0aOVG1r0w1vvql77LGHdnR06F133aWTJk3St99+W1evXq3Dhg3TVatWBdNMDxyorz3wgG548kkdN2qULvj3f9cPH39ch+66qy5fvlw3btyoJ554YvEB4MgjVdvatOPhh3X4kCH6XEuLzrroIj3r1FNVVXXp0qU6bNgw/fDDD7sNAOPHj9ePXn9dX3r+ed1h0CD9xxNP6Ev33KP777nnpr6fNWuW/vCHP1RV1fXr13e/X2BJYCf/d/n6XpcEFpG9c55+GViWaIOuU3mWiNx8mcaM8sZZXmi7AnHa/lttRXt7O8uWLWPu3LlMnToVVWXevHnMmzePMWPGcOARR7Ds5Zf522uv0bDrrgweNIinly5l3l13MWbMGAYPHsxjjz3GqaeeSt++famvr2fixIksXLgQgEP235+hO+1Enz59aPrMZ3h51SqWvfgiI3bZhb333hsR4YwzzihqfcETTzDm1FM56pvf5OJp09h/zz15rL2dM5ubAdhnn30YPnw4y5cv76adPHkyW3V0MHiHHdh5++35e9ckQDl9f/DBB/Pb3/6Wyy+/nGeffZaBAwd27zu1JHAq9RFxNR30T0VkJLAReAU4P9HWXKfyLBHZnahx1Pr64GfACi2PQoR2xo8fT0dHB2+99RaqyiWXXBL85OOiRZtt9/UpU7j5vvtYvWYNZ3/rWwBdZ7EF2arfp/9effv0Yf2GDQBICU0uRzQ18cdrr91smaoGM7z1wFZbbbVp33PbBjYtnzBhAo8++ij3338/Z555JjNnzmTq1KndtuuGve/910fE1beAvqqqjap6gKoep6pRZycpD9epPEtEdidqHPWCC6CubrNF2r9/sDwKEdpZtmwZGzZsYPDgwRx99NHcdNNNdHZ2wpZb8vqbb/Lm2rUAHN/czNwnnmDh0qUcffTRQHAQ/f3vf8+GDRt46623ePTRRznkkEOCivNDVMA+DQ289MYbvPDCCwDccccdxY0V0E8YM4bb580DYPny5bz66quMHDky0r4P3Hpr3vvgg03LX3nlFXbeeWfOPfdczjnnHJ566qmS+k3Y+95/fUQsCey7Ps3ei+njRHmnT4d//mfYZZdAt8sufDRrVrA8CkXitB9+/DFNTU00NTVx8sknc8stt9C3b1+OOuooTjvtNMaPH8+oU07hhIsvDg6awJZbbEHzwQdz0le/uumbNccffzwHHHAAn/3sZ/n85z/PVVddxS677BK0U1fXre26/v35zXXXMXnyZA4//HCGDx9e3HsB/f896SQ21NUxatQoTj75ZG6++ebNftCm277nDCKDt9uOw0aPpvHkk5k5cybz58+nqamJMWPGMGfOHC688MKSesDe92nRR6XQjQFfi30LKIPfAlLt9i2edWvXVqQvNwq84emndXRjoy5fvrzbZkUDV46jwOvWrq1Ib98Cql37xfS9+ltAcYolgWuLJYE/5fnnn9cRI0bot7/97YLrLQkcjyy93yvFfhPYMByz33778eKLL7q2YRhVJRv3AAzv0IjfhDHcYa9R78cGAKPm1NXVsWbNGjvAeIyqsmbNGuryvoFl9C7sEpBRc4YOHcrKlSt5662C0z/1yEcffeTdgclHT1CZr7q6OoYOHVplR4ZP2ABg1JwtttiCESNGlK2fP39+7EnRksZHT+CvL8MP7BKQYRhGRrEBwDAMI6PYAGAYhpFRnP0gTDmIyFsEk8dVwo5ARxXsVBsfffnoCfz05aMnMF9x8NETVMfXcFXdKX9hqgaAaiAii7TQL+M4xkdfPnoCP3356AnMVxx89ATJ+rJLQIZhGBnFBgDDMIyMksUB4DeuDRTBR18+egI/ffnoCcxXHHz0BAn6ytw9AMMwDCMgi2cAhmEYBjYAGIZhZJZePwCIyNUiskxEnhGRu0VkuyLbHSMi/ysiK0Tk4oQ9nSgiz4vIRhEp+vUuEXlZRJ4VkXYRWVRsOwe+atZXYXs7iMjDIvK38O/2RbZLvL962ncJuD5c/4yIHJiEjzJ8fU5E3g37pl1ELquBp5tE5E0Rea7I+pr3VQRPNe+nsN1hItIqIkvD/8ELC2xT/f4q9CsxvakARwH9wsc/A35WYJu+wAvAHsCWwGJgvwQ97QuMBOYDB5XY7mVgxxr2VY++at1XYZtXAReHjy8u9BrWor+i7DtwLPAgIMA44MkavG5RfH0O+GOt3kthmxOAA4Hniqx30Vc9eap5P4XtDgEODB8PBJbX4r3V688AVHWeqq4Pn/4FKDS/7SHAClV9UVX/AbQAUxL0tFRV/zep+ssloq+a9lXIFOCW8PEtwFcSbq8YUfZ9CvCfGvAXYDsRGeKBr5qjqo8Ca0tsUvO+iuDJCar6hqo+FT5+D1gK7Ja3WdX7q9cPAHmcTTCC5rMb8FrO85V073wXKDBPRNpEZLprMyEu+qpeVd+A4B8F2LnIdkn3V5R9d9E/UdscLyKLReRBEdk/YU9R8PX/zmk/iUgDMAZ4Mm9V1furV/wegIg8AuxSYNWlqnpPuM2lwHrg9kJVFFhW0fdjo3iKwGGqukpEdgYeFpFl4ScYl76q3ldQ2leMaqreX3lE2fdE+qcHorT5FMF8MJ0icizwX8DeCfvqCRd91RNO+0lEBgBzgItUdV3+6gKSivqrVwwAqjqp1HoRmQZ8CfiChhfT8lgJDMt5PhRYlaSniHWsCv++KSJ3E5zqV3RAq4KvqvcVlPYlIn8XkSGq+kZ4yvtmkTqq3l95RNn3RPqnUl+5BxNVfUBEfi0iO6qqy8nPXPRVSVz2k4hsQXDwv11V/1Bgk6r3V6+/BCQixwD/BHxZVT8ostlCYG8RGSEiWwKnAPfWymMhRGQbERnY9ZjgZnbBby7UGBd9dS8wLXw8Deh2plKj/oqy7/cCU8NvbIwD3u26fJUgPfoSkV1ERMLHhxD8769J2FdPuOirkrjqp7DN/wcsVdVrimxW/f6q9d3uWhdgBcF1s/aw3BAu3xV4IGe7YwnuvL9AcDkkSU/HE4zmHwN/Bx7K90TwjY7FYXk+aU9RfdW6r8L2BgN/Av4W/t3BVX8V2nfgfOD88LEAvwrXP0uJb3nV2Nc3wn5ZTPBliM/WwNMdwBvAJ+H76hzXfRXBU837KWz3cILLOc/kHKuOTbq/bCoIwzCMjNLrLwEZhmEYhbEBwDAMI6PYAGAYhpFRbAAwDMPIKDYAGIZhZBQbAAwjJJyR8SUR2SF8vn34fHiF9Z4vIlOr49Iwqod9DdQwchCR7wJ7qep0EbkReFlVf+Lal2EkgZ0BGMbmXAuME5GLCMI5P8/fQESOE5EnReRpEXlEROrD5dd3zR8vIkeLyKMi0kdELheRGeHyC0RkSTife0sN98swutEr5gIyjGqhqp+IyExgLnCUBtMr5/MYME5VVUS+DnwX+A7BbxUsFJEFwPXAsaq6MZxZoIuLgRGq+rEU+XEiw6gVdgZgGN35IsF0AY1F1g8FHhKRZ4GZwP4AGsw1dS7wMPCvqvpCAe0zwO0icgbB7LSG4QwbAAwjBxFpAo4k+MWlb4nIEBH5kYQ/ERhu9kuCA/wo4DygLqeKUQSTh+1apInJBPO5jAXaRMTOwg1n2ABgGCHhjIz/RjAX+6vA1cAsVb1UVZtUtSncdBDwevh4Wo5+OMGloDHAF0Xk0Lz6+wDDVLWV4LLRdsCAJPfJMEphA4BhfMq5wKuq+nD4/NfAPiIyMW+7y4HZ4bX+DthsOt8ZGvwuwTnAf4hI7tlBX+C28NLR08C1qvpOYntjGD1gXwM1DMPIKHYGYBiGkVFsADAMw8goNgAYhmFkFBsADMMwMooNAIZhGBnFBgDDMIyMYgOAYRhGRvn/IimDiCiaC3oAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Original Stability region chosen as benchmark\n",
    "WV_point_list = list()\n",
    "uWV_point_list = list()\n",
    "n = Index_pho\n",
    "for i in range (len(state_list)):\n",
    "    a = state_list[i][0]\n",
    "    b = state_list[i][1]\n",
    "    if v_list[i] > n:\n",
    "        WV_point_list.append([a,b])\n",
    "    else:\n",
    "        uWV_point_list.append([a,b]) \n",
    "print(\"number of points within levelset: \", len(uWV_point_list))\n",
    "print(\"number of points beyond levelset: \", len(WV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_W = [point[0] for point in WV_point_list]\n",
    "y_values_W = [point[1] for point in WV_point_list]\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_uW = [point[0] for point in uWV_point_list]\n",
    "y_values_uW = [point[1] for point in uWV_point_list]\n",
    "\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values_uW, y_values_uW, color='Blue', label='In Points')\n",
    "plt.scatter(x_values_W, y_values_W, color='Red', label='Beyond Points')\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": [
    "# Six dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "#six dimension\n",
    "def f(x1,x2):\n",
    "    f =(\n",
    "        7573.2596 * x1**6\n",
    "        + 0.0019264 * x1**5 * x2\n",
    "        + 3786.6299 * x1**4 * x2**2\n",
    "        - 0.12788 * x1**3 * x2**3\n",
    "        + 631.1066 * x1**2 * x2**4\n",
    "        - 0.014925 * x1 * x2**5\n",
    "        + 35.0614 * x2**6\n",
    "    )\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(45439.5576*x1**5 + 0.009632*x1**4*x2 + 15146.5196*x1**3*x2**2 - 0.38364*x1**2*x2**3 + 1262.2132*x1*x2**4 - 0.014925*x2**5) + dx2*(0.0019264*x1**5 + 7573.2598*x1**4*x2 - 0.38364*x1**3*x2**2 + 2524.4264*x1**2*x2**3 - 0.074625*x1*x2**4 + 210.3684*x2**5)\n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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:  400\n",
      "number of \\dot V > 0 points:  0\n"
     ]
    },
    {
     "data": {
      "image/png": "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9KeffpZ/+ctfdnf3nXfeedu2eOMb37jtfRYuXOiXX365u7vvs89sX7Zsva9bt8mXL3/c58zZ30899VS/9tpr/bnnnsu9LciYA4h6T2AzmwwMAgcAF7n73zZZpx/oB+jt7V0wMDBQuL+hoaFth11VQr7yU0VPIF+htNrXLrvswgEHHJBz3R7cR18uaeY8/vhGJk+eXMjDnnvuybp167Z77aKLLuKJJ57grLPOAuCcc85h5syZfOhDH9q2/vLly7ngggu48sorATj99NOZP38+J554InPnzuXGG29k+vTpTJ48maGhIX7yk5+wZMkSZs6cycUXXzzKx3333cfGjRu3e62vr2/Q3Q8ftXKzUaHdDZgOLAXmjrWeykG3lyr6qqInd/kKpdW+so4AmhFyBBDC8H/0jQwODvohhxzimzdv9qGhIT/44IP99ttv3279pUuX+lve8pZtmg9/+MN+6aWXurv73Llz/f777/dNmzb5+vXrfePGje7uvmLFCp83b15THyFHAJUoBeHuT5rZMuBoYE1kO0KILmbRouSc/9MNF9eEzC2EMH/+fN73vvdxxBFHAHDKKadw2GGH5db39/dzzDHHsMcee3DhhRdy8skn8/zzzwPwhS98YeIGm40K7WjA7sD09PGLgeXAX46l0RyA5gA0BxCm1xxA83P4We87kTmAkP5D9evWbcqt74ggGPCnwApgNcl//Z8ZT6MkcDn9Z6EksJLASgIrCVyZpiRwOf1noSRwfr2SwGH6bkwCt6L/LL2SwAWJnUaUvri+k71L3359sp97gXYngaugH7kNxqPrB4DYaUTpi+s72bv07dVPmTKFDRs2bLcDnEiStxP17sn9AKZMmZKvA2pwQ5iJzvhLH0/fTBuaBO7Uz94q/aOPbv9ap/nPq581axZr165l/fr121774x+T8smN/xSbwYwZkHVzrS1btmzbgRbRN9JK/XPPbeGJJ6aMqx++I1hump0XqmrTVUC6CkhXAYXp63IVUKv0I33F/v4muu8ahrpOAjdSl1BMq6iiryp6cpevUOQrjIn6yhoAun4OQAghRHM0AAghRE2pxQCgewJ3rl73BNY9gaUvvu8al2bnharalAQup/8slARWErhTksCt0jf6qsL3N5F9VyPUdRJYSeDieiWB8+uVBA7TtzoJ3Cp9o68qfH8T2Xc1kjUAdP0poE5LM0pf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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.028929452633659553\n",
      "180 30590.028929452634\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(-3.14, 3.14, 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 = 2*np.sin(x2)\n",
    "        dx2 = -x2 - 2*6*np.sin(x2)/x2*x1\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+ 1\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])>=3.14:\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": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  180\n",
      "number of points beyond levelset:  220\n"
     ]
    },
    {
     "data": {
      "image/png": "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M84oysPQoUN55513AHj66af5+c9/zuOPP15wfdu2baNnz5556xYvXsytt97KvHnzsi7funUrhx9+OHfddRe1tbUF+3r99dc57bTTeP755wPr169fn9eUF0FJ0ue9WErhq66urlFVx3ZakemwoBQFeBp4KUOZmrbdD4AbgtRp1wASeA3gvvtU+/XT1EDN9n798vOQ4UR622Rwqt7snlOnTm1/PmvWLB07dqyOGTNGr5sxQ3X5cv2nCy7QX1x1VftJ9B/+8Id6yy236Pbt23XGjBm6//77a1VVldbX16uq13eTJk3Sk088UUePHKlnHXusbm9qUm1p0ccff1xHjx6thx9+uF522WU6ZcqUTpYbGhq85b73048+Wh+cNUs/aW7W888/X6uqqrSmpkb/+Mc/dtxevUnm/u7v/k4nTZqkI0eM0Fuuukp16VI9/dhjtW/fvlpdXa0zZszQt99+W4888kitrq7WAw88UBctWtTJh10DKF/72fTd7hpABwMwAngpyLaWBA6n7Wy4kATWYcM6tt1Whg0Lps8Sp+3Ro4dWV1fr6NGjddCgQbps2TJVVX3yySf14osv1u3bt+u2997TKUccoX+6/XZ99dFHtXb0aNXGRt323nu61157aUtLiz788MM6efJk/eCDD3TDhg06fPhwffvtt71ppgcO1Dcfe0y3Pf+8jh8zRhf/53/qJ88+q8P22EPXrVun27dv11NPPTX7AHD00aqNjdry1FM6YuhQfam+XmdfeaWef+aZqqq6Zs0aHT58uH7yySedBoAJEybop2+9pa+uWqU7Dx6sny9Zoq8++qgeuPfe7X0/e/Zs/fGPf6yqql9++WXn6wWWBI7k/y5d3+2SwCKyb8rT7wBrQ20w6lSeJSI7LtM8o7z5LM+0XYY4bb8+fWhqamLt2rU88cQTnHfeeagqCxYsYMGCBdTW1nLwkUey9rXX+OubbzJyjz0YMngwL65Zw4KHH6a2tpYhQ4bwzDPPcOaZZ9KzZ08qKyuZNGkSS5cuBWDcgQcybNdd6dGjBzVf/zqvvf02a195hVG7786+++6LiHDOOedktb54yRJqzzyTYy67jKunTePAvffmmaYmzq2rA2C//fZjxIgRrFu3rpN2ypQp9GlpYcjOO7PbTjvxbtskQCl9f+ihh3LXXXdx/fXXs3LlSgYOHNi579SSwLHUBySq6aB/KiKjge3A68ClobYWdSrPEpGdCRpHraz0fgYs0/IgBGhnwoQJtLS08P7776Oq/OAHP/B+8nHZsg7bXTR1Knf/7nds2LiRC773PYC2o9iM9On11b9Xzx49+HLbNgAkhyaVI2tq+N+bb+6wTFW9Gd66oE+fPu2vPbVtoH35xIkTWbRoEb///e8599xzmTlzJuedd16n7Tphn3v39QGJ6i6gk1W1SlUPUtUTVTXo7CSFEXUqzxKRnQkaR738cujbt8Mi7dfPWx6EAO2sXbuWbdu2MWTIEI499ljuvPNOWltbYYcdeOu993hv0yYATqqr44klS1i6Zg3HHnss4O1EH3zwQbZt28b777/PokWLGDdunFdxeogK2G/kSF595x1efvllAB544IHsxjLoJ9bWcv+CBQCsW7eON954g9GjRwd67QP792fLxx+3L3/99dfZbbfduPjii7nwwgt54YUXcurbsc+9+/qAWBLYdX2cvWfT5xPlnT4d/umfYPfdPd3uu/Pp7Nne8iBkidN+8tln1NTUUFNTw+mnn84999xDz549OeaYYzjrrLOYMGECY844g1OuvtrbaQI79O5N3aGHctrJJ7ffWXPSSSdx0EEH8Y1vfINvfetbzJo1i913391rp2/fTm337dePO265hSlTpnDEEUcwYsSI7N4z6P/+tNPY1rcvY8aM4fTTT+fuu+/u8IM2nV57yiAyZMcdOby6mqrTT2fmzJksXLiQmpoaamtrmT9/PldccUVOPWCf+7jog5LpwoCrxe4CSuBdQKqd7uLZvGlTUfpCo8DbXnxRq6uqdN26dZ02yxq4ijgKvHnTpqL0dhdQ+drPpu/WdwHlUywJXF4sCfwVq1at0lGjRun3v//9jOstCZwfSfq8F4v9JrBhRMwBBxzAK6+8ErUNwygpybgGYDiHBrwTxogOe4+6PzYAGGWnb9++bNy40XYwDqOqbNy4kb5pd2AZ3Qs7BWSUnWHDhtHc3Mz772ec/qlLPv30U+d2TC56guJ89e3bl2HDhpXYkeESNgAYZad3796MGjWqYP3ChQvznhQtbFz0BO76MtzATgEZhmEkFBsADMMwEooNAIZhGAklsh+EKQQReR9v8rhi2AVoKYGdUuOiLxc9gZu+XPQE5isfXPQEpfE1QlV3TV8YqwGgFIjIMs30yzgR46IvFz2Bm75c9ATmKx9c9ATh+rJTQIZhGAnFBgDDMIyEksQB4I6oDWTBRV8uegI3fbnoCcxXPrjoCUL0lbhrAIZhGIZHEo8ADMMwDGwAMAzDSCzdfgAQkZtEZK2IrBCRR0RkxyzbHScifxGR9SJydcieThWRVSKyXUSy3t4lIq+JyEoRaRKRZdm2i8BX2frKb29nEXlKRP7q/90py3ah91dXr108bvXXrxCRg8PwUYCvb4rIR37fNInIdWXwdKeIvCciL2VZX/a+CuCp7P3ktztcRBpEZI3/P3hFhm1K31+ZfiWmOxXgGKCX//hnwM8ybNMTeBnYC9gBWA4cEKKn/YHRwEJgbI7tXgN2KWNfdemr3H3ltzkLuNp/fHWm97Ac/RXktQPHA48DAowHni/D+xbE1zeB/y3XZ8lvcyJwMPBSlvVR9FVXnsreT367Q4GD/ccDgXXl+Gx1+yMAVV2gql/6T58DMs1vOw5Yr6qvqOrnQD0wNURPa1T1L2HVXygBfZW1r3ymAvf4j+8B/ibk9rIR5LVPBf5bPZ4DdhSRoQ74KjuqugjYlGOTsvdVAE+RoKrvqOoL/uMtwBpgz7TNSt5f3X4ASOMCvBE0nT2BN1OeN9O586NAgQUi0igi06M24xNFX1Wq6jvg/aMAu2XZLuz+CvLao+ifoG1OEJHlIvK4iBwYsqcguPp/F2k/ichIoBZ4Pm1VyfurW/wegIg8DeyeYdU1qvqov801wJfA/ZmqyLCsqPtjg3gKwOGq+raI7AY8JSJr/W8wUfoqeV9Bbl95VFPy/kojyGsPpX+6IEibL+DNB9MqIscD/wPsG7Kvroiir7oi0n4SkQpgPnClqm5OX51BUlR/dYsBQFUn51ovItOAE4Cj1D+ZlkYzMDzl+TDg7TA9Bazjbf/veyLyCN6hflE7tBL4KnlfQW5fIvKuiAxV1Xf8Q973stRR8v5KI8hrD6V/ivWVujNR1cdE5DYR2UVVo5z8LIq+ykmU/SQivfF2/ver6m8ybFLy/ur2p4BE5DjgH4HvqOrHWTZbCuwrIqNEZAfgDOC35fKYCREZICID2x7jXczOeOdCmYmir34LTPMfTwM6HamUqb+CvPbfAuf5d2yMBz5qO30VIl36EpHdRUT8x+Pw/vc3huyrK6Loq5xE1U9+m78C1qjqnCyblb6/yn21u9wFWI933qzJL3P95XsAj6VsdzzelfeX8U6HhOnpJLzR/DPgXeDJdE94d3Qs98uqsD0F9VXuvvLbGwL8Afir/3fnqPor02sHLgUu9R8L8O/++pXkuMurzL6+6/fLcrybIb5RBk8PAO8AX/ifqwuj7qsAnsreT367R+CdzlmRsq86Puz+sqkgDMMwEkq3PwVkGIZhZMYGAMMwjIRiA4BhGEZCsQHAMAwjodgAYBiGkVBsADAMH39GxldFZGf/+U7+8xFF1nupiJxXGpeGUTrsNlDDSEFErgL2UdXpInI78Jqq/mvUvgwjDOwIwDA6cjMwXkSuxAvn/Dx9AxE5UUSeF5EXReRpEan0l9/aNn+8iBwrIotEpIeIXC8iM/zll4vIan8+9/oyvi7D6ES3mAvIMEqFqn4hIjOBJ4Bj1JteOZ1ngPGqqiJyEXAV8A94v1WwVEQWA7cCx6vqdn9mgTauBkap6meS5ceJDKNc2BGAYXTm23jTBVRlWT8MeFJEVgIzgQMB1Jtr6mLgKeDfVPXlDNoVwP0icg7e7LSGERk2ABhGCiJSAxyN94tL3xORoSLyE/F/ItDf7Jd4O/gxwCVA35QqxuBNHrZHliam4M3ncgjQKCJ2FG5Ehg0AhuHjz8j4H3hzsb8B3ATMVtVrVLVGVWv8TQcDb/mPp6XoR+CdCqoFvi0ih6XV3wMYrqoNeKeNdgQqwnxNhpELGwAM4ysuBt5Q1af857cB+4nIpLTtrgfm+ef6W6DDdL4z1PtdgguB/xKR1KODnsB9/qmjF4GbVfXD0F6NYXSB3QZqGIaRUOwIwDAMI6HYAGAYhpFQbAAwDMNIKDYAGIZhJBQbAAzDMBKKDQCGYRgJxQYAwzCMhPL/zwswrd53JK8AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Original Stability region chosen as benchmark\n",
    "WV_point_list = list()\n",
    "uWV_point_list = list()\n",
    "n = Index_pho\n",
    "for i in range (len(state_list)):\n",
    "    a = state_list[i][0]\n",
    "    b = state_list[i][1]\n",
    "    if v_list[i] > n:\n",
    "        WV_point_list.append([a,b])\n",
    "    else:\n",
    "        uWV_point_list.append([a,b]) \n",
    "print(\"number of points within levelset: \", len(uWV_point_list))\n",
    "print(\"number of points beyond levelset: \", len(WV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_W = [point[0] for point in WV_point_list]\n",
    "y_values_W = [point[1] for point in WV_point_list]\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_uW = [point[0] for point in uWV_point_list]\n",
    "y_values_uW = [point[1] for point in uWV_point_list]\n",
    "\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values_uW, y_values_uW, color='Blue', label='In Points')\n",
    "plt.scatter(x_values_W, y_values_W, color='Red', label='Beyond Points')\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": [
    "# eight dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "#eight dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        3726.5663 * x1**8\n",
    "        + 0.0011034 * x1**7 * x2\n",
    "        + 2484.3775 * x1**6 * x2**2\n",
    "        - 0.55463 * x1**5 * x2**3\n",
    "        + 621.1069 * x1**4 * x2**4\n",
    "        - 0.10348 * x1**3 * x2**5\n",
    "        + 69.013 * x1**2 * x2**6\n",
    "        - 0.0099348 * x1 * x2**7\n",
    "        + 2.8755 * x2**8\n",
    "    )\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt =   dx1*(29812.5304*x1**7 + 0.0077238*x1**6*x2 + 14906.265*x1**5*x2**2 - 2.77315*x1**4*x2**3 + 2484.4276*x1**3*x2**4 - 0.31044*x1**2*x2**5 + 138.026*x1*x2**6 - 0.0099348*x2**7) + dx2*(0.0011034*x1**7 + 4968.755*x1**6*x2 - 1.66389*x1**5*x2**2 + 2484.4276*x1**4*x2**3 - 0.5174*x1**3*x2**4 + 414.078*x1**2*x2**5 - 0.0695436*x1*x2**6 + 23.004*x2**7)\n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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:  400\n",
      "number of \\dot V > 0 points:  0\n"
     ]
    },
    {
     "data": {
      "image/png": "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9KeffpZ/+ctfdnf3nXfeedu2eOMb37jtfRYuXOiXX365u7vvs89sX7Zsva9bt8mXL3/c58zZ30899VS/9tpr/bnnnsu9LciYA4h6T2AzmwwMAgcAF7n73zZZpx/oB+jt7V0wMDBQuL+hoaFth11VQr7yU0VPIF+htNrXLrvswgEHHJBz3R7cR18uaeY8/vhGJk+eXMjDnnvuybp167Z77aKLLuKJJ57grLPOAuCcc85h5syZfOhDH9q2/vLly7ngggu48sorATj99NOZP38+J554InPnzuXGG29k+vTpTJ48maGhIX7yk5+wZMkSZs6cycUXXzzKx3333cfGjRu3e62vr2/Q3Q8ftXKzUaHdDZgOLAXmjrWeykG3lyr6qqInd/kKpdW+so4AmhFyBBDC8H/0jQwODvohhxzimzdv9qGhIT/44IP99ttv3279pUuX+lve8pZtmg9/+MN+6aWXurv73Llz/f777/dNmzb5+vXrfePGje7uvmLFCp83b15THyFHAJUoBeHuT5rZMuBoYE1kO0KILmbRouSc/9MNF9eEzC2EMH/+fN73vvdxxBFHAHDKKadw2GGH5db39/dzzDHHsMcee3DhhRdy8skn8/zzzwPwhS98YeIGm40K7WjA7sD09PGLgeXAX46l0RyA5gA0BxCm1xxA83P4We87kTmAkP5D9evWbcqt74ggGPCnwApgNcl//Z8ZT6MkcDn9Z6EksJLASgIrCVyZpiRwOf1noSRwfr2SwGH6bkwCt6L/LL2SwAWJnUaUvri+k71L3359sp97gXYngaugH7kNxqPrB4DYaUTpi+s72bv07dVPmTKFDRs2bLcDnEiStxP17sn9AKZMmZKvA2pwQ5iJzvhLH0/fTBuaBO7Uz94q/aOPbv9ap/nPq581axZr165l/fr121774x+T8smN/xSbwYwZkHVzrS1btmzbgRbRN9JK/XPPbeGJJ6aMqx++I1hump0XqmrTVUC6CkhXAYXp63IVUKv0I33F/v4muu8ahrpOAjdSl1BMq6iiryp6cpevUOQrjIn6yhoAun4OQAghRHM0AAghRE2pxQCgewJ3rl73BNY9gaUvvu8al2bnharalAQup/8slARWErhTksCt0jf6qsL3N5F9VyPUdRJYSeDieiWB8+uVBA7TtzoJ3Cp9o68qfH8T2Xc1kjUAdP0poE5LM0pf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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.00022248807574416142\n",
      "180 23981.000222488074\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(-3.14, 3.14, 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 = 2*np.sin(x2)\n",
    "        dx2 = -x2 - 2*6*np.sin(x2)/x2*x1\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+ 1\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])>=3.14:\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": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  180\n",
      "number of points beyond levelset:  220\n"
     ]
    },
    {
     "data": {
      "image/png": "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8IFs3AQGSwJ7lARubd1I//79Ix/8166FRYtg/vzg76efxrOfr1+7tjZaH/SfflqeXkTo378/ra0bLQnsWt/VksDlFksCJ9N2MZJKAj/22Eva2hrNfmur6oIFqvPmfVZWr15fkX7BAo2kj6Ndv359Vduuln716vUV6R977KWy33qWBPY/CZyNM4DLL4cPPth62QcfBMt916fZexG5Krz5ZrTm33wTNm+urn7z5mj6SrS+6FWrq4/z1sny+965PiLZGABcp/IynIgsttrHH0drvth6lepHjep8et1c7Q9/eA6TJg3l9NMbOfnkA5k7d25J7ZVXXsmcOU+W3O7s2bN55plnIrUfZXmt9JYEToE+ItkYAFyn8jKciCy22rbbRmt+223h0Udh4kQ49NDg729/u00sfbnkay++eAa/+U0L3/rWT7jgggtKaq+++mqOPHJ8ye12NgAU817pvleqtyRwCvQRycYA4DqVl+FEZCG5COyxR7Tm586Ff/93WL06uByxejVMndqLTj6Ab2GPPTqmYbt1+2zZ7NmzOeqoozjxxBPZZ599OOOMM9Dwukcx7cSJY1i+fDkALS0tjBo1itGjR3PCCSfwzjvvAHDOOeewYMH9dOsGX/vaEG655QeceeaBnHrqCD74YCmvvfYaN998M9dffz2NjY3MmTOHWbNmMXz4cBoaGhgzZkzR9qP23R57BH1dTb0lgVOij0qhGwO+FksCd40k8Lx5L0XWVjwjpQY3MxcuDG6CLlwYPN9+++1VNdjHvn376ooVK3TTpk06atQonTNnTgfthAmTdebMWdraqnrffffpoYceqqqqI0aM0NmzZ+v69ev1iiuu0EsuuURVVSdPnqyzZgXr7777YJ069UZduFB1+vRf6Hnnnaeqqj/4wQ90xowZW9oaPny4rly5UlVV33nnnaLe47Bu3fqK9PPmvWRJYEsC+1EsCVxbkvL00kvRBwCRwgOASGUecgeA8ePHb1l+4YUX6p133tlh/cmTJ+uQIUO0oaFBx48fry+88IK+++67OmjQIFUNvgW0fPlyHTly5Jb1Z82apaqqgwcP3nJg/8tf/qJf/vKXVbXjAHDBBRfo+PHj9Ze//KW2xj1SF6HQt5PiEOe1ikOW3u+VYklgI7N87nPw+uuFl1eLnj17bnncvXt3Pi0SNJgxYwYnnnjilufvvfde7DZKbf/mm2/m2Wef5eGHH6axsZGWlhb69+8fuQ3DiEs27gEYqaXQpdDevbXql0LLoV+/fuy4447MmTMHgDvvvJOxY8dG1vfp04f3339/y/OXX36Zww47jKuvvpqdd96ZFStWVN2zYeSSnQHAksD+6DdsiCw94wy47joYMCC4ITlgAPzsZxs544zozVcjCdzaGpyJ5GvvuOMOpk2bxujRo2lpaeHKK6/soP/kE2hpCbbz7ruf1U2cOJEHH3xwy03gadOmMWLECIYPH86YMWNoaGhwlgTewoYN9r53rbckcIX3ACwJXJa+GkngQvqXHnss8t1IS9d+iXMAAA6qSURBVAK7SwJra2vwWiXw3rMkcHS9JYErxXUqzxKRWy/T6FFeSwJXptcKksAVR4Htfe9OH5FsDACuU3mWiOxIxDiqyzSsr0ncWukrjgLb+96dPiLZGABcp/IsEdmRiHFUl2lYX5O4tdJXHAW29707fUSyMQC4TuVZInLrZTGiwIXSsHGSxJWkaauRxHWtryQJXHEU2N737vRRKXRjIOkC/BuwCGgBngB2j6KzJHA6k8D5+pfmzYslz0/DrlsXL9xUSZo2qrZY4KrSJK/rJPBL8+Yl8t6zJHB0fZdLAgN9cx5fDNwcRWdJ4NriQxK4EJWmW5PAR0+qlgSOg4+eVJNNAju5BKSq63Oebg9osXUNIwm6d+9OY2MjDQ0NHHjggSVn5UyS2bNn89WvfrXg8n79+jFy5Ej23XdfrrrqqpLbmT9/PhdffHHJdd59911uuummivwaXQvR/K951aphkR8BZwPvAeNU9e0i600BpgDU19cf1NTUVFG7bW1t1NV1Phd8rfHRV1Ke+vXrx1577RV5/W3uu4+eV12FrFyJDhzIh1dcweZTT63Iw4ABA1i1ahUATz75JD/96U959NFHy97epk2b6N69e2zdnDlzuPHGG5k1a1bR5Rs2bODwww/ntttuY+TIkWX7ev311zn55JN59tlnI+uXL18ea8qLqGTp/V4p1fA1bty4Bap6cIeKQqcF1SjAk8CLBcqkvPUuA66Ksk27B5DBewB33aXau7fmBmo29+4dz0OBC+ntk8GpBrN7Tpo0acvz6dOn68EHH6wjRozQK6dOVV24UL9/7rn6s+9+d8tF9O9973t6ww036ObNm3Xq1Km677776vDhw7WpqUlVg74bO3asfmPiRB02ZIiefuyxurmlRbW1VR999FEdNmyYHn744XrRRRfphAkTOlhubm4OlofeTzn6aL13+nT9cOVKPeecc3T48OHa2Niof/7zn7deX4NJ5v7xH/9Rx44dq0MGD9Ybvvtd1Xnz9JRjj9VevXppQ0ODTp06Vd966y098sgjtaGhQffff3996qmnOviwewC1a7+YvsvdA9jKAAwGXoyyriWBk2m7GD4kgXXgwK3bbi8DB0bTF4nTduvWTRsaGnTYsGHat29fnT9/vqqqPv7443r++efr5s2bddOaNTrhiCP0f265RV996CEdOWyY6oIFumnNGt1zzz21tbVV77//fh0/fry+8847unr1ah00aJC+9dZbwTTTffroikce0U3PPqujRozQOb/6lX74zDM6cPfdddmyZbp582Y96aSTig8ARx+tumCBtv7pTzp4wAB9salJZ37rW3rOaaepquqSJUt00KBB+uGHH3YYAEaPHq0b33xTX128WHfq108/njtXX33oId3/85/f0vczZ87Ua665RlVVP/300473CywJ7OT/Ll/f5ZLAIrJ3ztOvAUsTbdB1Ks8SkVsv05hR3jjLC61XIE7bu2dPWlpaWLp0KY899hhnn302qsoTTzzBE088wciRIznwyCNZ+tpr/G3FCobsvjv9+/Xj+SVLeOL++xk5ciT9+/fn6aef5rTTTqN79+7U19czduxY5s2bB8Ch++/PwF12oVu3bjR+4Qu89tZbLH3lFYbutht77703IsKZZ55Z1PqcuXMZedppHHPRRVw6eTL7f/7zPN3SwlnjxgGwzz77MHjwYJYtW9ZBO2HCBHq2ttJ/p53Ydccd+Xv7JEA5fX/IIYdw22238cMf/pAXXniBPn36dOw7tSRwKvURcTUd9E9EZBiwGXgduDDR1lyn8iwR2ZGocdT6+uBnwAotj0KEdkaPHk1raytvv/02qspll10W/OTj/PlbrffNSZO4/Q9/YPXatZz77W8DtJ/FFqTnNp/9e3Xv1o1PN20CQEpocjmysZE/Xn/9VstUNZjhrRN69uy5Zd9z2wa2LB8zZgxPPfUUDz/8MGeddRbTpk3j7LPP7rBeB+x9778+Iq6+BfQNVR2uqgeo6kRVjTo7SXm4TuVZIrIjUeOoF18MvXpttUh79w6WRyFCO0uXLmXTpk3079+fY489lltvvZW2tjbYdlveXLOGNevWAXDCuHE8Nncu85Ys4dhjjwWCg+i9997Lpk2bePvtt3nqqac49NBDgw3nh6iAfYYM4dVVq3j55ZcBuOeee4obK6AfM3Ikdz/xBADLli3jjTfeYNiwYZH2vc922/H+Bx9sWf7666+z6667cv7553Peeefx3HPPldRvwd73/usjYklg3/Vp9l5MHyfKO2UKfP/7sNtugW633dg4c2awPApF4rQffvQRjY2NNDY2csopp3DHHXfQvXt3jjnmGE4//XRGjx7NiFNP5cRLLw0OmsC2PXow7pBDOPkb39jyzZoTTjiBAw44gC9+8Yt86UtfYvr06ey2225BO716dWi7V+/e/PKGG5gwYQJHHHEEgwcPLu69gP6fTj6ZTb16MWLECE455RRuv/32rX7QpsO+5wwi/XfYgcMbGhh+yilMmzaN2bNn09jYyMiRI3nggQe45JJLSuoBe9+nRR+VQjcGfC32LaAMfgtItcO3eNavW1eRvtwo8Kbnn9eG4cN12bJlHVYrGrhyHAVev25dRXr7FlDt2i+m79LfAopTLAlcWywJ/BmLFy/WoUOH6ne+852C9ZYEjkeW3u+VYr8JbBiO2W+//XjllVdc2zCMqpKNewCGd2jEb8IY7rDXqOtjA4BRc3r16sXatWvtAOMxqsratWvplfcNLKNrYZeAjJozcOBAVq5cydtvF5z+qVM2btzo3YHJR09Qma9evXoxcODAKjsyfMIGAKPm9OjRg6FDh5atnz17duxJ0ZLGR0/gry/DD+wSkGEYRkaxAcAwDCOj2ABgGIaRUZz9IEw5iMjbBJPHVcLOQGsV7FQbH3356An89OWjJzBfcfDRE1TH12BV3SV/YaoGgGogIvO10C/jOMZHXz56Aj99+egJzFccfPQEyfqyS0CGYRgZxQYAwzCMjJLFAeCXrg0UwUdfPnoCP3356AnMVxx89AQJ+srcPQDDMAwjIItnAIZhGAY2ABiGYWSWLj8AiMgMEVkqIotE5EER2aHIeseJyF9FZLmIXJqwp5NEZLGIbBaRol/vEpHXROQFEWkRkfnF1nPgq2Z9Fba3k4j8SUT+Fv7dsch6ifdXZ/suATeG9YtE5MAkfJTh6ygReS/smxYRubIGnm4VkTUi8mKR+pr3VQRPNe+nsN1BItIsIkvC/8FLCqxT/f4q9CsxXakAxwDbhI+vBa4tsE534GVgT2BbYCGwX4Ke9gWGAbOBg0us9xqwcw37qlNfte6rsM3pwKXh40sLvYa16K8o+w4cDzwKCDAKeLYGr1sUX0cBf6zVeylscwxwIPBikXoXfdWZp5r3U9juAODA8HEfYFkt3ltd/gxAVZ9Q1U/Dp38BCs1veyiwXFVfUdWPgSZgUoKelqjqX5PafrlE9FXTvgqZBNwRPr4D+HrC7RUjyr5PAn6tAX8BdhCRAR74qjmq+hSwrsQqNe+rCJ6coKqrVPW58PH7wBJgj7zVqt5fXX4AyONcghE0nz2AFTnPV9Kx812gwBMiskBEprg2E+Kir+pVdRUE/yjArkXWS7q/ouy7i/6J2uZoEVkoIo+KyP4Je4qCr/93TvtJRIYAI4Fn86qq3l9d4vcARORJYLcCVZer6kPhOpcDnwJ3F9pEgWUVfT82iqcIHK6qb4nIrsCfRGRp+AnGpa+q9xWU9hVjM1Xvrzyi7Hsi/dMJUdp8jmA+mDYROR74HbB3wr46w0VfdYbTfhKROuAB4Fuquj6/uoCkov7qEgOAqo4vVS8ik4GvAl/W8GJaHiuBQTnPBwJvJekp4jbeCv+uEZEHCU71KzqgVcFX1fsKSvsSkb+LyABVXRWe8q4pso2q91ceUfY9kf6p1FfuwURVHxGRm0RkZ1V1OfmZi74qict+EpEeBAf/u1X1twVWqXp/dflLQCJyHPCvwNdU9YMiq80D9haRoSKyLXAq8PtaeSyEiGwvIn3aHxPczC74zYUa46Kvfg9MDh9PBjqcqdSov6Ls+++Bs8NvbIwC3mu/fJUgnfoSkd1ERMLHhxL8769N2FdnuOirkrjqp7DN/wcsUdXriqxW/f6q9d3uWhdgOcF1s5aw3Bwu3x14JGe94wnuvL9McDkkSU8nEIzmHwF/Bx7P90TwjY6FYVmctKeovmrdV2F7/YH/Bv4W/t3JVX8V2nfgQuDC8LEAvwjrX6DEt7xq7Oufw35ZSPBliC/WwNM9wCrgk/B9dZ7rvorgqeb9FLZ7BMHlnEU5x6rjk+4vmwrCMAwjo3T5S0CGYRhGYWwAMAzDyCg2ABiGYWQUGwAMwzAyig0AhmEYGcUGAMMICWdkfFVEdgqf7xg+H1zhdi8UkbOr49Iwqod9DdQwchCR7wJ7qeoUEbkFeE1Vf+zal2EkgZ0BGMbWXA+MEpFvEYRzfpq/gohMFJFnReR5EXlSROrD5Te2zx8vIseKyFMi0k1EfigiU8PlF4vIS+F87k013C/D6ECXmAvIMKqFqn4iItOAx4BjNJheOZ+ngVGqqiLyTeC7wL8Q/FbBPBGZA9wIHK+qm8OZBdq5FBiqqh9JkR8nMoxaYWcAhtGRrxBMFzC8SP1A4HEReQGYBuwPoMFcU+cDfwL+Q1VfLqBdBNwtImcSzE5rGM6wAcAwchCRRuBogl9c+raIDBCRH0n4E4Hhaj8nOMCPAC4AeuVsYgTB5GG7F2liAsF8LgcBC0TEzsINZ9gAYBgh4YyM/0kwF/sbwAxgpqperqqNqtoYrtoPeDN8PDlHP5jgUtBI4Csiclje9rsBg1S1meCy0Q5AXZL7ZBilsAHAMD7jfOANVf1T+PwmYB8RGZu33g+BWeG1/lbYajrfqRr8LsF5wH+JSO7ZQXfgrvDS0fPA9ar6bmJ7YxidYF8DNQzDyCh2BmAYhpFRbAAwDMPIKDYAGIZhZBQbAAzDMDKKDQCGYRgZxQYAwzCMjGIDgGEYRkb5/5ssH97SqG2CAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Original Stability region chosen as benchmark\n",
    "WV_point_list = list()\n",
    "uWV_point_list = list()\n",
    "n = Index_pho\n",
    "for i in range (len(state_list)):\n",
    "    a = state_list[i][0]\n",
    "    b = state_list[i][1]\n",
    "    if v_list[i] > n:\n",
    "        WV_point_list.append([a,b])\n",
    "    else:\n",
    "        uWV_point_list.append([a,b]) \n",
    "print(\"number of points within levelset: \", len(uWV_point_list))\n",
    "print(\"number of points beyond levelset: \", len(WV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_W = [point[0] for point in WV_point_list]\n",
    "y_values_W = [point[1] for point in WV_point_list]\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_uW = [point[0] for point in uWV_point_list]\n",
    "y_values_uW = [point[1] for point in uWV_point_list]\n",
    "\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values_uW, y_values_uW, color='Blue', label='In Points')\n",
    "plt.scatter(x_values_W, y_values_W, color='Red', label='Beyond Points')\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": [
    "# Ten dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "#ten dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        10606.6689 * x1**10\n",
    "        + 0.001378 * x1**9 * x2\n",
    "        + 8838.8904 * x1**8 * x2**2\n",
    "        - 5.2413 * x1**7 * x2**3\n",
    "        + 2946.7367 * x1**6 * x2**4\n",
    "        - 1.355 * x1**5 * x2**5\n",
    "        + 491.1584 * x1**4 * x2**6\n",
    "        - 0.21507 * x1**3 * x2**7\n",
    "        + 40.9212 * x1**2 * x2**8\n",
    "        - 0.01314 * x1 * x2**9\n",
    "        + 1.3642 * x2**10\n",
    "    )\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(106066.689*x1**9 + 0.012402*x1**8*x2 + 70711.1232*x1**7*x2**2 - 36.6891*x1**6*x2**3 + 17680.4202*x1**5*x2**4 - 6.775*x1**4*x2**5 + 1964.6336*x1**3*x2**6 - 0.64521*x1**2*x2**7 + 81.8424*x1*x2**8 - 0.01314*x2**9) + dx2*(0.001378*x1**9 + 17677.7808*x1**8*x2 - 15.7239*x1**7*x2**2 + 11786.9468*x1**6*x2**3 - 6.775*x1**5*x2**4 + 2946.9504*x1**4*x2**5 - 1.50549*x1**3*x2**6 + 327.3696*x1**2*x2**7 - 0.11826*x1*x2**8 + 13.642*x2**9)  \n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# mathematical simulation to show\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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:  218\n",
      "number of \\dot V > 0 points:  182\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": [
      "3.827877514481346e-06\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+ 1\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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Example data\n",
    "x_list = [point[0] for point in state_list]\n",
    "y_list = [point[1] for point in state_list]\n",
    "val_list = dv_list  # Some positive, some negative\n",
    "\n",
    "# Convert to numpy arrays\n",
    "x = np.array(x_list)\n",
    "y = np.array(y_list)\n",
    "v = np.array(val_list)\n",
    "\n",
    "# Create mask for negative values\n",
    "mask_neg = v < 0\n",
    "\n",
    "# Plot negative regions\n",
    "plt.figure(figsize=(6, 5))\n",
    "plt.scatter(x[mask_neg], y[mask_neg], c='red', label='Negative Region', s=20)\n",
    "plt.xlabel('X')\n",
    "plt.ylabel('Y')\n",
    "plt.title('Regions with Negative Indicator Values')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Original Stability region chosen as benchmark\n",
    "WV_point_list = list()\n",
    "uWV_point_list = list()\n",
    "n = 1.22\n",
    "for i in range (len(state_list)):\n",
    "    a = state_list[i][0]\n",
    "    b = state_list[i][1]\n",
    "    if a*a+b*b > n:\n",
    "        WV_point_list.append([a,b])\n",
    "    else:\n",
    "        uWV_point_list.append([a,b]) \n",
    "print(\"number of points within levelset: \", len(uWV_point_list))\n",
    "print(\"number of points beyond levelset: \", len(WV_point_list))\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_W = [point[0] for point in WV_point_list]\n",
    "y_values_W = [point[1] for point in WV_point_list]\n",
    "\n",
    "# Extracting the x and y coordinates from the list Unstable points\n",
    "x_values_uW = [point[0] for point in uWV_point_list]\n",
    "y_values_uW = [point[1] for point in uWV_point_list]\n",
    "\n",
    "\n",
    "# Plotting the points\n",
    "plt.scatter(x_values_uW, y_values_uW, color='Blue', label='Beyond Points')\n",
    "plt.scatter(x_values_W, y_values_W, color='Red', label='In Points')\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
}
