{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# -*- coding: utf-8 -*-\n",
    "import torch \n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import timeit \n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.io import savemat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "df/dt = dx1*(4.686*x1**5 + 1.192*x1**3*x2**2 - 16.392*x1**3 - 1.302*x1**2*x2**3 + 9.72*x1**2*x2 + 0.566*x1*x2**4 + 1.42*x1*x2**2 + 16.722*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.85*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",
    "    )\n",
    "\n",
    "# Compute ∂f/∂x1 and ∂f/∂x2\n",
    "df_dx1 = diff(f, x1)\n",
    "df_dx2 = diff(f, x2)\n",
    "\n",
    "# Time derivative: df/dt = ∂f/∂x1 * dx1 + ∂f/∂x2 * dx2\n",
    "df_dt = df_dx1 * dx1 + df_dx2 * dx2\n",
    "\n",
    "# Simplify (optional)\n",
    "df_dt = simplify(df_dt)\n",
    "\n",
    "# Display result\n",
    "print(\"df/dt =\", df_dt)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Two dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "#two dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        8.361 * x1**2\n",
    "        - 11.679 * x1 * x2\n",
    "        + 4.925 * x2**2\n",
    "        - 4.098 * x1**4\n",
    "        + 3.240 * x1**3 * x2\n",
    "        + 0.710 * x1**2 * x2**2\n",
    "        - 0.063 * x1 * x2**3\n",
    "        + 0.050 * x2**4\n",
    "        + 0.781 * x1**6\n",
    "        + 0.298 * x1**4 * x2**2\n",
    "        - 0.434 * x1**3 * x2**3\n",
    "        + 0.283 * x1**2 * x2**4\n",
    "        - 0.089 * x1 * x2**5\n",
    "        + 0.012 * x2**6\n",
    "    )\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.722*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.85*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:  152\n",
      "number of \\dot V > 0 points:  248\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.017787485284843488\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": "markdown",
   "metadata": {},
   "source": [
    "# Four dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "#four dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "       4.5083e-07 * x1**4\n",
    "        - 3.9033e-09 * x1**3 * x2\n",
    "        + 1.8428e-07 * x1**2 * x2**2\n",
    "        + 1.217e-07 * x1 * x2**3\n",
    "        + 1.3021e-07 * x2**4\n",
    ")\n",
    "\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(1.80332e-6*x1**3 - 1.17099e-8*x1**2*x2 + 3.6856e-7*x1*x2**2 + 1.217e-7*x2**3) + dx2*(-3.9033e-9*x1**3 + 3.6856e-7*x1**2*x2 + 3.651e-7*x1*x2**2 + 5.2084e-7*x2**3)\n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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:  260\n",
      "number of \\dot V > 0 points:  140\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": [
      "7.949887431802988e-11\n",
      "10 4.690433584763761e-09\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": "markdown",
   "metadata": {},
   "source": [
    "# Six dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "#six dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        1.4403e-06 * x1**6\n",
    "        + 7.9555e-08 * x1**5 * x2\n",
    "        - 5.7249e-07 * x1**4 * x2**2\n",
    "        + 1.0398e-06 * x1**3 * x2**3\n",
    "        + 1.802e-06 * x1**2 * x2**4\n",
    "        + 3.2943e-07 * x1 * x2**5\n",
    "        + 3.6967e-07 * x2**6\n",
    "    )\n",
    "\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt =  dx1*(8.6418e-6*x1**5 + 3.97775e-7*x1**4*x2 - 2.28996e-6*x1**3*x2**2 + 3.1194e-6*x1**2*x2**3 + 3.604e-6*x1*x2**4 + 3.2943e-7*x2**5) + dx2*(7.9555e-8*x1**5 - 1.14498e-6*x1**4*x2 + 3.1194e-6*x1**3*x2**2 + 7.208e-6*x1**2*x2**3 + 1.64715e-6*x1*x2**4 + 2.21802e-6*x2**5)\n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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:  240\n",
      "number of \\dot V > 0 points:  160\n"
     ]
    },
    {
     "data": {
      "image/png": "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/bx5zembbb/d9ON91o7258V558Err2x97JVXouPN8Oqrr3LIIYewaNEi9t57b0477TTuuOMOjj32WHbaaSd6e3t573vfy+23376NdvHixfT399PT08MhhxzCY489tk2dfffdl3Xr1nHWWWdx0003sfPOOzdnMGED7n4XOAlYbWYr42P/C9gbwN0vAZYTvfm0FngFaN41ilJy4onN/TDU6m+9NWz77aafORPq/OYU1n6z+jx4/PFsx9Pypje9iZUrV251zFPOFW+//fa/2d5uu+3YtGnTNnV23XVXVq1axYoVK7j44ou5+uqrueyyy5qyOZij8GiCuuELvfG42V8VY5EQQmxh772j4aZ6x1vNkUceySmnnMI555yDu3PNNddwxRVXpNZPnz6dl156CYBnn32WadOmcdxxx7HffvtxyimnNG2fUngIIUQdzj8/mpOoHn7Ka+7ksMMO45RTTmHx4sUAnH766Rx66KGp9YODgxx33HHstddeXHjhhZx66qls3rwZgM997nPNG5g0y93ORW89FUer7Ep6u2Sy+mXLstnV6vaT9En9VVT7SSxbNhy0/SR9J771lBddEXDXyiJHURyKzFZktiKzy4EchRxFR9ulOIri2k/SK44iG93mKJQ9VgSn2bdLpO9ufVai38TuZTKfX45CBCfpLZK0b5dI3936LOywww4899xzXess3KP1KHbYYYdMOr31JILT7Nsl9fRZI7Nb3X676Tdu3PpYO9mfhf7+fkZHR3nmmWeaus5rr72W+cc2b9LaNL7CXSaSxqTauWiOojj01lM2vd56yqbv9O99K2nWJhrMUeiJQpQCRWYrMrtskdliC5qjEEII0RA5CiGEEA2RoxBCCNEQOYqY8cXdR0bKvzh8J9Js/9Xqx8bCtt9u+rGx9rZf5EzSLHc7l6xvPVWnEBiPUC0yhUEayviWhbtSeGTVK4VHNn0nf+9bTZ5vPQX/Uc+jZHUU1SkEqlMZFJXCIA1l/GK6K4VHVr1SeGTTd/L3vtXk6ShCL4V6mZltNLM1CeePMrMXzGxlXD6Vhx3tloKg0wjd/9K3t17kT+g5iu8CSyaoc7u7HxKXz+RhRDulIOhEQve/9O2tF/kT1FG4+21AxmnH1tOpi8O3C3n0f9YUHiHvfxn0PTW/BO1kv8gfi4amAhpgNh+43t0PqnPuKGAZMApsAM529wcS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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": [
      "2.1639403458083773e-12\n",
      "10 1.3221675512888955e-09\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": "markdown",
   "metadata": {},
   "source": [
    "# eight dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "#eight dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        1.7955e-07 * x1**8\n",
    "        - 1.0127e-08 * x1**7 * x2\n",
    "        - 3.9081e-07 * x1**6 * x2**2\n",
    "        - 1.6427e-07 * x1**5 * x2**3\n",
    "        + 8.9468e-07 * x1**4 * x2**4\n",
    "        + 1.3609e-07 * x1**3 * x2**5\n",
    "        - 2.1541e-07 * x1**2 * x2**6\n",
    "        + 5.3627e-08 * x1 * x2**7\n",
    "        + 9.1474e-08 * x2**8\n",
    "    )\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt =  dx1*(1.4364e-6*x1**7 - 7.0889e-8*x1**6*x2 - 2.34486e-6*x1**5*x2**2 - 8.2135e-7*x1**4*x2**3 + 3.57872e-6*x1**3*x2**4 + 4.0827e-7*x1**2*x2**5 - 4.3082e-7*x1*x2**6 + 5.3627e-8*x2**7) - dx2*(1.0127e-8*x1**7 + 7.8162e-7*x1**6*x2 + 4.9281e-7*x1**5*x2**2 - 3.57872e-6*x1**4*x2**3 - 6.8045e-7*x1**3*x2**4 + 1.29246e-6*x1**2*x2**5 - 3.75389e-7*x1*x2**6 - 7.31792e-7*x2**7)\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:  236\n",
      "number of \\dot V > 0 points:  164\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAAEWCAYAAAB42tAoAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO2de5xdZXnvv8/kAsIEQoAMCRMSLpbTJHwaSBrBWmR6qsb0EhGxKkVA6BRbsPVIazh4PB5bqh4xIEoFLygCH0dOUwqFQBQcyqUCZSQhgQiGmJAh0QAjl23AEPOcP9Yas7Oz195r7b3XZc/+fT+f9zPr8v7W+6x3zaxn1vuu51nm7gghhBBRdOVtgBBCiGIjRyGEEKImchRCCCFqIkchhBCiJnIUQgghaiJHIYQQoiZyFCIXzOweMzsvo7Y+bGY/N7OSmR2cRZutolY/mdksM3MzG5+hPUeE/TguqzZF/shRiNQws41m9mp4Y/m5mX3TzLoTHqOpm6GZTQCWAW939253f6Fi/2+Z2S1m9pyZjZjZSjM7tmz/p8zsdTN7JSxPmdmXzWxag/a4mR3TiLaVlJ1XycxeNLP/NLOT6unc/ZmwH38do43MHZlIBzkKkTZ/4u7dwAnA7wKfyLj9HmBf4PGI/ZOBW4Fjw7oPA7dU1Pmuu08CpgCnAocBQ406iwLx3fDaHArcD/yrmVnONokCIkchMsHdnwXuAOZW7jOzLjP7hJltMrNtZvZtMzsw3H1v+PPF8L/fvf7rNbN9zOwKM9sSlivCbb8FPFmm/0EVux5292+4+4i7vw5cDhxbbYjK3V9398eBPwOeAz5W7VzN7Bgz+w8ze8nMnjez74bbR89ldXguf2ZmB5nZbeETzS/C5d6KQx5tZg+Hx7vFzKZEtHugmX3DzLaa2bNm9o9xhojC876OwAEeXOt6VD4lhENj/2BmD4RPXN8zs0PCQ+917aL6RhQbOQqRCWY2A1gMPFpl99lh6QOOArqBL4f7Tg5/Tg6HPH5YRX8JcCIwD/gdYCHwCXd/CphTpv+DGKaeDPyscoiqnHDY5Rbg9yOq/APwPeAgoBf4UqgbPZffCc/luwR/g98EZgJHAK+y+9xH+SDwIWA6sBO4MqLd68L9xwDHA28H6s4Dmdk+BP0/7O7PU/t6VOMDwDnAVGAicFG4vdq1q9o3otjIUYi0+Tcze5FgaOM/gH+qUucMYJm7b3D3EnAx8L4EY9tnAJ92923u/hzwf4Azkxoa/id/FfA/YlTfQjAUVY3XCW780939NXe/P+og7v6Cuy939+3u/gpwKfDWimrXu/tad/8l8L+A91Y+KZhZD/BO4G/d/Zfuvo3g6eh9Nc7hveG12QzMB94Vbk96Pb7p7k+5+6vATQQOO4rYfSOKgxyFSJt3uftkd5/p7n8V3kwqmQ5sKlvfBIwnmDOIQzX99CRGmtmhBP/p/rO7fyeG5HBgJGLf3wMGPGxmj5vZh2q0u5+ZXRMO87xMMFwzucIRbC5b3gRMAA5hT2aG27eGk9MvAtcQ/JcfxU3htZnq7n/g7kPh9qTX42dly9sJnkCiiN03ojjobQRRBLYQ3OhGOYJgCOXnBDfkuPrRCesjwm2xMLODCJzEre5+aYz6XcCfAHdV2+/uPwP+Iqz7FuAuM7vX3ddXqf4xgon0N7n7z8xsHsHwXPmk8oyy5SMI/it/vmL7ZuBXwCHuvrPeOdSh1vWonD+pxV6pqRP2jSgIeqIQReA7wEfN7EgLXp/9J4I3cnYSTBrvIhgrr6X/hJkdGk6kfhK4IU7DZnYAsBJ4wN2X1qk7wcx+O2zvMILXbqvVO71sQvoXBDfM0ddJf15xLpMI5iVeDCep/3eVQ/65mc02s/2ATwP/Uvl6qrtvJXB2XzCzA8IJ6aPNrHIYKw61rkcS9rp2dfpGFBQ5ClEErgWuJxh2+SnwGnAhgLtvJxi3fyAcUjmxiv4fgUeAx4A1wI/CbXE4leC13XPCN3NGyxFldf7MzErAiwSv0r4AzHf3qKeW3wUeCjW3An/j7j8N930KuC48l/cCVwBvIHhCeBC4s8rxrge+RTDEsy/wkYh2P0gwmfwEwU34X4BGXuGNvB5JiLh2tfpGFBTTh4uEEELUQk8UQgghaiJHIYQQoiZyFEIIIWoiRyGEEKImYzKO4pBDDvFZs2Y1pP3lL3/J/vvv31qDWoDsSobsSobsSkYR7WrWpqGhoefd/dCqO919zJX58+d7owwODjasTRPZlQzZlQzZlYwi2tWsTcAjHnFP1dCTEEKImshRCCGEqIkchRBCiJqMyclsIYSoxuuvv87w8DCvvfZaU8c58MADWbduXYusag1xbdp3333p7e1lwoQJsY8tRyGE6BiGh4eZNGkSs2bNwpr46usrr7zCpEmTWmhZ88Sxyd154YUXGB4e5sgjj4x9bA09CSE6htdee42DDz64KSfRzpgZBx98cOInqtwchZnNMLNBM1sXfsDkb6rUMTO70szWm9ljZnZCHraK4nPjjTBrFnR1BT9Hoj4pFFN/442dpR8ZaW/7k9CpTmKUhs4/6r3ZtAtB+uMTwuVJwFPA7Io6i4E7CD7iciLwUJxjK44iO4pg1w03uO+3nzvsLsuWDfoNNzSu328/T0Vfrb+ybD9Kv2zZYK7tR+lb/fv1xBNPtOQ4L7/8ckuO00qS2FStHyhiHIW7b3X3H4XLrwDr2PtrZkuAb4fn8SDBJyIbya8vxjCXXALbt++5bdeuYHuj+u3bO0u/a1e+7TejbzfGjRvHvHnzmDt3LqeffjrbK0++gje/+c11j3nFFVfUPU4zFOJ7FGY2i+AjKXPd/eWy7bcBn/XwA+xmdjfwcXd/pMox+oF+gJ6envkDAwMN2VIqlejurvXJ33yQXdEMDe29rbe3xPBwN/PnN6YfpdX6av2VZftR+tH+yqv9KI49trW/XwceeCDHHHNM08f59a9/zbhx4+pXrMK0adPYunUrAOeeey7HH388F1xwQVP2zJ07lx/84AdMnVrrE+m7Wb9+PS+99NIe2/r6+obcfUFVQdSjRlaF4EPsQ8C7q+y7HXhL2frdBF8W09BTQSiCXTNn7jlsAe6XXTboM2c2rgdPRV+tv7JsP0p/2WWDubYfpc976OmGGwI7zIKfo8NpzQw97b///r9Z/spXvuIf/vCH3d39C1/4gs+ZM8fnzJnjl19++V71BwcH/a1vfaufdtppfuyxx/oHPvAB37Vrl3/xi1/0CRMm+OzZs/2UU07xnTt3+llnneVz5szxuXPn+rJly/ayoW2GniD4BjGwHLjR3f+1SpVh9vyAfC/Bh9+F+A2XXgr77bfntq6uYHuj+v326yx9V8WdoJ3sT4sbb4T+fti0KXBdmzYF662aaN+5cyd33HEHxx13HENDQ3zzm9/koYce4sEHH+RrX/sajz766F6aRx99lCuuuIInnniCDRs28MADD/CRj3yE6dOnc/vttzM4OMiqVat49tlnWbt2LWvWrOGcc85p2tY833oy4BvAOnev+pF6gm/qfjB8++lE4CUPPiIvxG844wz46ldh5kwwC37OnBlsb1T/1a92ln60z9rR/rRIa+7k1VdfZd68eSxYsIAjjjiCc889l/vvv59TTz2V/fffn+7ubt797ndz33337aVduHAhvb29dHV1MW/ePDZu3LhXnaOOOooNGzZw4YUXcuedd3LAAQc0ZzD5Btz9HnAmsMbMVoXb/idwBIC7Xw2sIHjzaT2wHWjeNYoxyRln7Hljueee5vTNtt9u+ilToMo9J7P2m9WnwTPPJNselze84Q2sWrVqj20ec654n332+c3yuHHj2Llz5151DjroIFavXs3KlSu56qqruOmmm7j22mubsjk3R+HBBHXNF3rDcbO/zsYiIYTYzRFHBMNN1ba3mpNPPpmzzz6bpUuX4u7cfPPNXH/99bH1kyZN4pVXXgHg+eefZ+LEiZx22mkcffTRnH322U3bpxQeQghRhUsvDeYkyoef0po7OeGEEzj77LNZuHAhAOeddx7HH398bH1/fz+nnXYahx9+OFdccQXnnHMOu8J3nj/zmc80b2DULHc7F731lJyotzvqUZT+qrR/+fLBpvRxzz+pPqq/smo/iuXLB3NtP0o/Ft96Sos0A+5yv6mnUeQoktFMZG0R+kuR2YrMjosiswPkKOQoEtPMe/BF6C/FUTSvVxxFMjrNUSh7rEjt7Y6saNZ+6dtbn5Tgnti5NHL+chQi8i2ONN7uSINm7Ze+vfVJ2HfffXnhhRc61lm4B9+j2HfffRPp9NaTyPTtjjSoZn/SyOxmzn8s6Ldt23NbO9mfhN7eXoaHh3nuueeaOs5rr72W+GabNnFtGv3CXSKixqTauWiOIjl660lvPXXCW0+tooh2NWsTNeYo9EQhgGJGxiZBkdmKzBbpoTkKIYQQNZGjEEIIURM5CiGEEDWRoxBA8x+3L5p+ZCTf9ttNPzLS3vaLlIma5W7noreektFsCo8ipKBQCo/m9J2SwqNVFNGuNN96yv2mnkaRo0hGsyk8ipCCQik8mtN3SgqPVlFEu9J0FHl/CvVaM9tmZmsj9p9iZi+Z2aqwfDJrGzuBvFMwSC99M3qRPnnPUXwLWFSnzn3uPi8sn87Apo4j7xQM0kvfjF6kT66Owt3vBRJOO4pW0+zH7YuoT5rCo2j2Z63vqrgTtJP9In0sGJrK0QCzWcBt7j63yr5TgOXAMLAFuMjdH484Tj/QD9DT0zN/YGCgIXtKpRLd3d0NadMkbbtGRuDZZ2HHDpg4EQ4/PIjWjWtXo/pm24/Sz5hRYvLk+P2Vlf1R1zHv/nvxxRKbN3cX5vqN6jv177ERmrWpr69vyN0XVN0ZNXmRVQFmAWsj9h0AdIfLi4GfxDmmJrOzQ3YlQ3YlQ3bFZ8xOZtfD3V9291K4vAKYYGaH5GyWEEJ0FIV2FGZ2mJlZuLyQwN4X8rVKCCE6i7xfj/0O8EPgWDMbNrNzzex8Mzs/rPIeYK2ZrQauBN4XPiKJFpN3ZK0isxWZrcjsAhM1JtXORXMUyVBktiKzFZmdjCLapchsOQpFZifUKzJbkdlpUkS7OnYyW2RD3pG10kvfjF6kjxyFyD2yVnrpm9GL9JGjELlH1ioyO3+9IrNFTaLGpNq5aI4iOVEft6/HqF2N6pttP0q/fPlgru1H6aOuY979t3z5YKGu36i+U/8eG0GT2XIUsishsisZsisZRbRLk9lCCCFyQ45CCCFETeQoBJB/ZK0isxWZrcjuAhM1JtXORXMUyVBktiKz2zkyu9n2G6GI9wlNZstRKDI7oV6R2Z0Tmd1s+41QxPuEJrNFquQdWSu99HnqRX3kKETukbXSS5+nXtRHjkLkHlmryOz89e0cma3I7gyIGpNq56I5iuQoMluR2UW6fkkjs5ttPylFvE9oMluOQnYlRHYlQ3Ylo4h2jdnJbDO71sy2mdnaiP1mZlea2Xoze8zMTsjaRiGE6HTynqP4FrCoxv53Am8MSz/wlQxsEkIIUUaujsLd7wVqxdAuAb4dPhk9CEw2s2nZWCeEEALAgqGpHA0wmwXc5u5zq+y7Dfisu98frt8NfNzdH6lSt5/gqYOenp75AwMDiewYGYFnn4WpU0ts29bN4YfDlCnJ9Tt2wMSJtFxfKpXo7u7Orf0oRu3Kq/0o/YwZJSZPju6vtNuP0kddx7z778UXS2ze3F2Y6zeqr/d7nxdFtKtZm/r6+obcfUHVnVGTF1kVYBawNmLf7cBbytbvBubXO2bSyezyFACjEapFSWEwSq2JqjxTQCiFh1J45J3CIw+KaNeYfuupjqO4Bnh/2fqTwLR6x0zqKMpTAJSnMihCCoNRav0S5JkCQik8lMIj7xQeeVBEu8bsW08xuBX4YPj204nAS+6+tdWN5J1CQHrppW9cL9In79djvwP8EDjWzIbN7FwzO9/Mzg+rrAA2AOuBrwF/lYYdeacQkF566RvXi/TJ+62n97v7NHef4O697v4Nd7/a3a8O97u7/7W7H+3ux3mVSexWkHcKAemVwiNvfTun8BAZEDUm1c6lkcjs0RQAo2PbRUlhMEq98ce8UkAohUcyvVJ4JNMXcS7AvZh2jenJ7DSKUnhkh+xKhuxKhuyKTydPZgshhMgZOQohhBA1kaMIGf04+9BQe34cXvo99SO1EsNk0H676UdG2tt+kTJRY1LtXBSZrchsRWYrMjtNimiXJrNTdhSKzG5cr8hsRWYrMrsYaDI7ZfKOLJVeeukb14v0kaMg/8hS6aWXvnG9SB85CvKPLJVekdl56xWZLWoSNSbVzkWR2YrMVmR2Mr0is5NRRLs0mZ2BoxiliL8A7rIrKbIrGbIrGUW0S5PZQgghckOOQgghRE3kKEIUmT229IrMTqbPOzJbFJyoMaksCrCI4POm64GlVfafArwErArLJ+McV5HZisxWZHb7RGbXoohzAe7FtGtMTmYD44CngaOAicBqYHZFnVOA25IeW5HZ2dmvyGxFZjfbfi2KeEN2L6ZdY3UyeyGw3t03uPsOYABYkocheUeWSi99J+tF8cnTURwObC5bHw63VXKSma02szvMbE4ahuQdWSq99J2sF8XHgieOHBo2Ox14h7ufF66fCSx09wvL6hwA7HL3kpktBr7o7m+MOF4/0A/Q09Mzf2BgILYtIyOwaRPs2gW9vSWGh7vp6oKZM2HKlGT6UVqtL5VKdHd359Z+FKVSiR07unNrP0o/Y0aJ8eO7C3P9Rql2HfO8fqP6nTtLbN68264s269Frd/7PCmiXc3a1NfXN+TuC6rujBqTSrsAJwEry9YvBi6uo9kIHFLv2IrMVmS2IrOT6fOOzI6iiHMB7sW0a6xOZo8HNgBHsnsye05FncPY/dSzEHhmdL1WUWR2dsiuZMiuZMiu+KTpKMY3/JzSJO6+08wuAFYSvAF1rbs/bmbnh/uvBt4DfNjMdgKvAu8LT0gIIURG5OYoANx9BbCiYtvVZctfBr6ctV1CCCF2o8hsIYQQNZGjCFEKj7GlVwqPZHohahI1edHORSk8lMJDKTySvXlUxMlZd9mVhDH51lOaRSk8srNfKTzaP4VHlF1FQHbFZ6ym8CgMeacwkF76PPVC1EOOgvxTGEgvfZ56IeqRyFGY2YFmNjstY/Ii74/DS996fVdXe9ufpV6IukSNSY0W4G7gAOAggsjoVcDn6+nyLErhoRQeSuGRTF/EMXd32ZWEXCezgUfDn+cC/xAuP1ZPl2dRCo/skF3JkF3JkF3xyXsye7yZHQqcDvx7ix9ohBBCFJw4juJS4D+AZ9z9YTM7CvhpumYJIYQoCnUdhbsPuPtsd+8P1ze4ey5foksTRWaPLX2nRWYLkSpRY1LAx8KflwPLKkuUrghFkdmKzO6kyOxWUMQxd3fZlYRcJrOBd4U/z61WonRFKIrMzs5+RWbnH5ndCop443OXXUnI5XsU7v5v4eIN7v6r8n1m1uQHDotF3pGx0kvfjF6ItIkzmf2wmf3u6IqZLQF+mJ5J2ZN3ZKz00jejFyJt4jiKs4BrzOwzZnYdcCHwtlY0bmaLzOxJM1tvZkur7DczuzLc/5iZndCKdivJOzJWekVmK7JaFJqoManyAvwpUAK2AkfF0cQ45jjgaeAodn8ze3ZFncXAHYABJwIPxTm2IrMVmd1pkdnNUsQxd3fZlYS8I7OvAe4Djglv3D8G/rKeLsZxTwJWlq1fDFxcpe33l60/CUyrd2xFZmeH7EqG7EqG7IpPmo7Cgv3RmNnfAZeFB8LMJgNfdPezmnmSMbP3AIvc/bxw/UzgTe5+QVmd24DPuvv94frdwMfd/ZEqx+sH+gF6enrmDwwMNGRXqVSiu7u7IW2ayK5kyK5kyK5kFNGuZm3q6+sbcvcFVXdGeZC0C0FKkK+XrZ8JfKmizu3AW8rW7wbm1zu2niiyQ3YlQ3YlQ3bFJ9dcT2Z2tJkNhJPJT42Wht3WboaBGWXrvcCWBuoIkTt5R2Y3qx8ZaW/7O1nfbFaJWER5EN/9X/x9wDuANcDRwD8Cn66ni3Hc8cAG4Eh2T2bPqajzR+w5mf1wnGPriSI7ZFf+kdmt0C9bNlioyPpRfZzrmEf/lduV5/VrNqtEOTQ5mT0U/lxTtu2+ero4hWBy/CmCt58uCbedD5wfLhtwVbh/DbAgznHlKLJDduUfmd0KfXlGgiJE1o/q41zHPPqv3K48r1+zWSXKqeUoIiOzy/iVmRnwtJmdDzwLTG3k6aUSd18BrKjYdnXZsgN/3Yq2hEiLvCOzpe9cfVZR/XEC7j4KdAMfAX4POA/4UGvNEKJ9yTsyW/rO1WcV1R8nzfhD7v6Kuz8DfNTdl7j7A601Q4j2Je/I7FbouyruBO1mf6fqM4vqjxqTqlaAHyWpn1fRHEV2yK6AvCOzm9UvXz5YqMj6UX3c65h1/1Xalef1azarxCg0M5m9R+Xw+9lFL3IU2SG7kiG7kiG74pNLHIWZrTCzWRWbr23xA40QQoiCU2uO4lvA98zsEjObAODuX8rEKiGEEIWh1oeLbjKz24FPAo+Y2fXArrL9yzKwTwghRM7Ue+vpdeCXwD7ApIoixJihnVM4tEKvFB7tq881hQewCHgC+CywX1S9IhZNZmfHWLAryxQMSuGRTK8UHvG1uaTwIMjxNCdqf5GLHEV2jAW7skzBoBQeyfRK4RFfm0sKD3f//RQeYIQoHO2cwkH6ztYXKYWHEGOadk7hIH1n6wuTwkOIsU47p3BolV4pPNpTX8gUHu1SNEeRHWPFrqxSMCiFRzK9UnjE1xYmhUe7FDmK7JBdyZBdyZBd8UkzhUec71G0HDObAnwXmAVsBN7r7r+oUm8j8Arwa2CnR334WwghRGrkNUexFLjb3d8I3B2uR9Hn7vPkJIQQIh/ychRLgOvC5euAd+VkhygIrY5sHRnJt/120ysyu331uUZmp1mAFyvWfxFR76fAj4AhoD/u8TVHkR2tsCuNyNZlywYLEVlciSKzk+kVmR1fm2ZktgX7W4+Z3QUcVmXXJcB17j65rO4v3P2gKseY7u5bzGwq8H3gQne/N6K9fqAfoKenZ/7AwEBDdpdKJbq7uxvSpslYtmvNGtixY+/tEyfCccc1pu/tLbFtW3fD+mbbj9JX668s24/ST51aYnh4T7uybD9Kf+SR9X+/8ui/8uuY5/Ur1/b27r6Gcdsup6+vb8ijhvijPEiaBXgSmBYuTwOejKH5FHBRnOPriSI7WmGX2Z7/TY0Ws8b1l1022JS+2faj9NX6K8v2o/TVUngUof/i/H7l0X/lduV5/cq15dcwbtvl0MiHi1LmVuCscPks4JbKCma2v5lNGl0G3g6szcxCkRntHBkrvfSKzE6PzwJvM7OfAG8L1zGz6Wa2IqzTA9xvZquBh4Hb3f3OXKwVqZJGZGtXV3tE1hZFr8js9tQrMruJoqGn7GiVXa2ObF2+PJldisxWZLYisxWZHZuxfkNuNbIrGbIrGbIrPmlGZispoBBCiJrIUQghhKiJHIVoCUWLbFVkdjK9IrPbVz9mI7PTLpqjyI7BwcFCRBYrMrs5vSKzk+k7LTI795t6GkWOIjsGBwcL8c3nagF3RfjmcyX6ZnYyvb6ZHV+b5jezNfQkmqadvzksvfTtrNc3s0Xb0M6RrdJL3876sR6ZLcYQRYxsVWS2IrM7Qa/I7CaK5iiyY9SuvCOLFZmtyGxFZisyW45CdiVCdiVDdiWjiHYpMlsIIURuyFEIIYSoiRyFEEKImshRiJZQtBQISuGRTK8UHu2rVwoPTWb/hiLbVYQUFErh0ZxeKTyS6ZXCI4MCnA48DuwCFtSot4jg+9rrgaVxjy9HkR1K4aEUHkrhkd/1G+spPNYC7wbujapgZuOAq4B3ArOB95vZ7GzME0lo5xQI0kvfzvoxncLD3de5+5N1qi0E1rv7BnffAQwAS9K3TiSlnVMgSC99O+uzSuFhwRNHPpjZPcBF7v5IlX3vARa5+3nh+pnAm9z9gohj9QP9AD09PfMHBgYasqlUKtHd3d2QNk2KbNeOHd1s2gS7du3e3tUFM2fClCn1jzEyQsv1M2aUGD++O7f2o/TVrmOW7Ufpd+4ssXnzbrvyvn6j+okT6//e59F/5dcxz+tXru3tLTE83J2o7XL6+vqG3H1B1Z1RY1LNFuAugiGmyrKkrM49RMxREMxjfL1s/UzgS3Ha1hxFdiiFRzK9Ungk0yuFR3ztmE3hUcdRnASsLFu/GLg4znHlKLJDdiVDdiVDdsWnU1N4/BfwRjM70swmAu8Dbs3ZJiGE6DhycRRmdqqZDRM8NdxuZivD7dPNbAWAu+8ELgBWAuuAm9z98TzsFUKITiavt55udvded9/H3Xvc/R3h9i3uvris3gp3/y13P9rdW51hXZTRzpGp1fSKzE6m7/TIbFGHqDGpdi6ao0hGM5GhisxWZHa7R2Y3QhHvE2nOUeR+U0+jyFEko5nIUEVmKzK73SOzG6GI94lOncwWGdHOkanSS59VdHInI0ch2joyVXrps4pO7mTkKERbf1w+St/V1d72Z63vqrgTtJv9zehFDKLGpNq5aI4iOY1GhioyO5lekdnJ9FlFZieliPcJTWbLUciuhMiuZMiuZBTRLk1mCyGEyA05CiGEEDWRoxAtIe/IWkVmKzJbkdkpEjUm1c5FcxTZochsRWYrMrsYaDJbjqLQdhUhsliR2c3pFZmdjCL+PWoyWxSavCNrpZe+Gb2ojxyFaJq8I2ull74ZvaiPHIVomrwjaxWZrchsRWanTNSYVDsXzVFkhyKzk+kVmZ1Mr8js+Iy5yWzgdOBxYBcR38wO620E1gCrap1EZZGjyA7ZlQzZlQzZFZ80HcX4XB5jYC3wbuCaGHX73P35lO0RQggRQS6Owt3XAZhZHs0LIYRIgAVPHDk1bnYPcJG7PxKx/6fALwAHrnH3r9Y4Vj/QD9DT0zN/YGCgIZtKpRLd3d0NadNEdiVDdiVDdiWjiHY1a1NfX9+Quy+oujNqTKrZAtxFMMRUWZaU1bmH2nMU08OfU4HVwMlx2tYcRXZoMjuZXpPZyfSazI7PmJvM/k3jdRxFRd1PETx9yFEUCKXwUAoPpfAoBh3pKID9gcoiFmkAAAmSSURBVElly/8JLIpzXDmK7FAKD6XwUAqPYjDmUniY2almNgycBNxuZivD7dPNbEVYrQe438xWAw8Dt7v7nXnYK2qTdwoG6aVvRi/qk4ujcPeb3b3X3fdx9x53f0e4fYu7Lw6XN7j774RljrsrzrKg5J2CQXrpm9GL+iiFh2iavFMwKIWHUngohUfKRI1JtXPRHEV26K2nZHq99ZRMr7ee4jNmJ7PTKnIU2SG7kiG7kiG74jPmJrOFEEK0D3IUQgghaiJHIVpCsx+3b7V+ZCTf9ttNPzLSnD5vmj1/UYeoMal2LpqjyA5FZisyO00UmR0fTWbLURTariJEFisyuzl9M5HZaaLI7PhoMlsUmrwja6XPV5837W5/OyBHIZom78ha6fPV5027298OyFGIpsk7slaR2flGZueNIrMzIGpMqp2L5iiyQ5HZyfRjNTI7LRSZHZ+x+M1sMcY444ygFEV/zz35tt9u+ilTYOPGxvV50+z5i9po6EkIIURN5CiEEELUJK8PF33ezH5sZo+Z2c1mNjmi3iIze9LM1pvZ0qztFPHJO7JYkdmdHZktUiZq8iLNArwdGB8ufw74XJU644CngaOAicBqYHac42syOzsUma3I7DQp8u990RhzAXfu/j133xmuPgj0Vqm2EFjvwZfudgADwJKsbBTxueQS2L59z23btwfb89Lv2pVv++2m37Wrcb0Y+1jgSHI0wOzfge+6+w0V298DLHL388L1M4E3ufsFEcfpB/oBenp65g8MDDRkT6lUoru7uyFtmhTZriefjLZr/vz6xxgait7XqL63t8TwcHdu7Ufpq13HLNuP0o/2VyP6NCny733R7GrWpr6+viF3X1B1Z9SjRrMFuAtYW6UsKatzCXAzocOq0J8OfL1s/UzgS3Ha1tBTdijXk3I9pUmRf++LRlsOPbn7H7r73CrlFgAzOwv4Y+CM0MhKhoEZZeu9wJa07BWNU4TIYkVmN6dv58hskQFRHiTNAiwCngAOrVFnPLABOJLdk9lz4hxfTxTZocjsZHpFZiej6L/3RWIsRmZ/GdgH+L6ZATzo7ueb2XSC4abF7r7TzC4AVhK8AXWtuz+ek72iDnlHFisyu7Mjs0W65OIo3P2YiO1bgMVl6yuAFVnZJYQQYm8UmS2EEKImchRCCCFqIkchhBCiJnIUQgghaiJHIYQQoia5p/BIAzN7DtjUoPwQ4PkWmtMqZFcyZFcyZFcyimhXszbNdPdDq+0Yk46iGczsEY/Kd5IjsisZsisZsisZRbQrTZs09CSEEKImchRCCCFqIkexN1/N24AIZFcyZFcyZFcyimhXajZpjkIIIURN9EQhhBCiJnIUQgghatLxjsLMPm9mPzazx8zsZjObHFFvkZk9aWbrzWxpBnadbmaPm9kuM4t85c3MNprZGjNbZWaPFMiurPtripl938x+Ev48KKJeJv1V7/wt4Mpw/2NmdkJatiSw6RQzeynsm1Vm9sm0bQrbvdbMtpnZ2oj9mfdVTLsy7y8zm2Fmg2a2Lvw7/JsqdVrfX1EfquiUArwdGB8ufw74XJU644CngaPY/RGl2Snb9dvAscA9wIIa9TYCh2TYX3Xtyqm//i+wNFxeWu06ZtVfcc6fIJ3+HYABJwIPFcCmU4DbsvpdKmv3ZOAEYG3E/kz7KoFdmfcXMA04IVyeBDyVxe9Wxz9RuPv33H1nuPogwSdXK1kIrHf3De6+AxgAlqRs1zp3fzLNNhohpl2Z91d4/OvC5euAd6XcXi3inP8S4Nse8CAw2cym5WxTLrj7vcBIjSpZ91VcuzLH3be6+4/C5VeAdcDhFdVa3l8d7ygq+BCBJ67kcGBz2fowe1+cvHDge2Y2ZGb9eRsTkkd/9bj7Vgj+mICpEfWy6K845591H8Vt7yQzW21md5jZnBTtSUKR//5y6y8zmwUcDzxUsavl/ZXXp1AzxczuAg6rsusSd78lrHMJsBO4sdohqmxr+r3iOHbF4PfcfYuZTSX4tOyPw/+E8rQr8/5KcJiW91cV4px/Kn1Ugzjt/Ygg30/JzBYD/wa8MUWb4pJ1X8Ult/4ys25gOfC37v5y5e4qkqb6qyMchbv/Ya39ZnYW8MfAf/dwkK+CYWBG2XovsCVtu2IeY0v4c5uZ3UwwxNDUja8FdmXeX2b2czOb5u5bw8fsbRHHaHl/VSHO+afSR83YVH7DcfcVZvbPZnaIu+ed/C7rvopFXv1lZhMInMSN7v6vVaq0vL86fujJzBYBHwf+1N23R1T7L+CNZnakmU0E3gfcmpWNUZjZ/mY2aXSZYGK+6hsaGZNHf90KnBUunwXs9eSTYX/FOf9bgQ+Gb6icCLw0OnSWEnVtMrPDzMzC5YUE94cXUrQpLln3VSzy6K+wvW8A69x9WUS11vdXljP2RSzAeoLxvFVhuTrcPh1YUVZvMcEbBk8TDMGkbdepBP8Z/Ar4ObCy0i6CN1hWh+XxotiVU38dDNwN/CT8OSXP/qp2/sD5wPnhsgFXhfvXUOPNtgxtuiDsl9UEL3a8OW2bwna/A2wFXg9/t87Nu69i2pV5fwFvIRhGeqzsnrU47f5SCg8hhBA16fihJyGEELWRoxBCCFETOQohhBA1kaMQQghREzkKIYQQNZGjECIhYQbPn5rZlHD9oHB9ZpPHPd/MPtgaK4VoHXo9VogGMLO/B45x934zuwbY6O6fydsuIdJATxRCNMblwIlm9rcEQVBfqKxgZn9iZg+Z2aNmdpeZ9YTbrxz9doGZvcPM7jWzLjP7lJldFG7/iJk9EX5PYCDD8xJiLzoi15MQrcbdXzezvwPuBN7uQeruSu4HTnR3N7PzgL8HPkbwvYz/MrP7gCuBxe6+K8wGMcpS4Eh3/5VFfExLiKzQE4UQjfNOghQPcyP29wIrzWwN8HfAHAAPcor9BfB94Mvu/nQV7WPAjWb25wRZjYXIDTkKIRrAzOYBbyP4gthHzWyamV1q4Wcxw2pfInAExwF/CexbdojjCBLITY9o4o8I8vXMB4bMTE//IjfkKIRISJjB8ysE3wJ4Bvg8cJm7X+Lu89x9Xlj1QODZcPmsMv1MgiGo44F3mtmbKo7fBcxw90GC4arJQHea5yRELeQohEjOXwDPuPv3w/V/Bv6bmb21ot6ngP8XzkU8D3ukib7Ig29jnAt83czKnzbGATeEQ1aPApe7+4upnY0QddDrsUIIIWqiJwohhBA1kaMQQghREzkKIYQQNZGjEEIIURM5CiGEEDWRoxBCCFETOQohhBA1+f+632+9uXbxNwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8.20240038345907e-15\n",
      "8 9.920803263793411e-12\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": "markdown",
   "metadata": {},
   "source": [
    "# Ten dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "#ten dimension\n",
    "def f(x1,x2):\n",
    "    f =  (\n",
    "        3.8004e-07 * x1**10\n",
    "        + 8.6002e-12 * x1**9 * x2\n",
    "        - 2.0778e-06 * x1**8 * x2**2\n",
    "        - 1.526e-06 * x1**7 * x2**3\n",
    "        + 3.9535e-06 * x1**6 * x2**4\n",
    "        + 1.3389e-06 * x1**5 * x2**5\n",
    "        - 2.5368e-06 * x1**4 * x2**6\n",
    "        - 2.9038e-07 * x1**3 * x2**7\n",
    "        + 5.8496e-07 * x1**2 * x2**8\n",
    "        + 1.3671e-07 * x1 * x2**9\n",
    "        + 5.7793e-08 * x2**10\n",
    "    )\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt =   dx1*(3.8004e-6*x1**9 + 7.74018e-11*x1**8*x2 - 1.66224e-5*x1**7*x2**2 - 1.0682e-5*x1**6*x2**3 + 2.3721e-5*x1**5*x2**4 + 6.6945e-6*x1**4*x2**5 - 1.01472e-5*x1**3*x2**6 - 8.7114e-7*x1**2*x2**7 + 1.16992e-6*x1*x2**8 + 1.3671e-7*x2**9) + dx2*(8.6002e-12*x1**9 - 4.1556e-6*x1**8*x2 - 4.578e-6*x1**7*x2**2 + 1.5814e-5*x1**6*x2**3 + 6.6945e-6*x1**5*x2**4 - 1.52208e-5*x1**4*x2**5 - 2.03266e-6*x1**3*x2**6 + 4.67968e-6*x1**2*x2**7 + 1.23039e-6*x1*x2**8 + 5.7793e-7*x2**9)\n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# mathematical simulation to show\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of V > 0 points:  348\n",
      "number of V < 0 points:  52\n",
      "number of \\dot V < 0 points:  292\n",
      "number of \\dot V > 0 points:  108\n"
     ]
    },
    {
     "data": {
      "image/png": "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u4q+fk2S2qus+pNYtWoiaP1J+rTfr7T1Z3EU3Z5UBjFGceCBB/qKFSv8mWee8bPPPts/8pGPPL/Phz/8YT/nnHPc/YWOotUBnHLKKX7RRRfFtm5xFNPT077vvvv6ihUr/KqrrvLnnntuKxuyOoqQAXe/CxwP3GpmN8fr/iewN4C7nwesJnrzaT3wa+DdRRnzzndG5dpr4Z57+tfnrX9YGXT7XXtt2Prrpt911/6+94OqP7S+E/fdl219Wl70ohdx8803v2BddJ/uzXbbbff852222YZNmzZttc8uu+zCunXrWLNmDZ///Of5xje+wQUXXJDL5mCOwqMB6q4v9MZe7i/LsUgIIbaw995w772d1w+aV7/61Zx44omceuqpuDuXXnopF110UWr93LlzefLJJwF4+OGHmTNnDscccwz77bcfJ554Ym77lMJDCCE6cMYZsHw5/PrXW9a9+MXR+kFz8MEHc+KJJ3LooYcCcPLJJ3PQQQel1i9fvpxjjjmGPffck7PPPpt3v/vdbN68GYBPfOIT+Q1M6pOqcxnGMYq89fdLVcZONEahMYpBj1F0O26VAu4efth93Tr3hx56wteti5Z7UZvB7CLLsL31lLf+PFTBUeitJ731NKyR2Q8/7D456X7jjZGjuPHGaLmXs5Cj6MNR1D2OIm/9eaiCo1AcRX694iiyURVHsW5d5CRaHcWNN0bru5HVUSh7LPnfbqi7vu6Ebj/p66WP7okzg40bs62H/s5fjoLktxjSvt1Qd33dCd1+0tdHv/322/PII4/MGGcxZ0629e7RfBTbb799pnr01hP5326ou77udDr/WbPq0/5V0G/Y8MJ1dbM/rX7BggVMTU3xq1/9Kt3BE3j66acz32yLYONGeOSRqLPtueee5tFHt8cMdtsNkia7a85wl4mkPqk6F731pLee9NZTNv2wvPU0KKryvXfPf+9qggaz01OlL0ArsisbsisbsisbVbQrr03dHIXGKIQQQnRFjkIIIURX5CiEEEJ0RY5iQNRpcvki9KFpt396Op++bu2fVz89XW/7h1nf1E5OFvjbTRq8qHMpezC77ik88uirMKinFB5K4VF2+7XaFfL65U0/1Ap66yk9/dz46p7CI4++Co5CKTzy64clhceg9K12hbx+edMPtdLNUQTtejKzC8xsg5ndlrD9CDN73MxujstHy7YxDXVL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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.000285859691572802\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Input \u001b[0;32mIn [13]\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     74\u001b[0m \u001b[38;5;66;03m#get region with stable if and only if\u001b[39;00m\n\u001b[1;32m     75\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m (\u001b[38;5;28mlen\u001b[39m(v_list)):  \n\u001b[0;32m---> 76\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[43mv_list\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m<\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mpho\u001b[49m:\n\u001b[1;32m     77\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m dv_list[i] \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m:  \u001b[38;5;66;03m#NO POINTS WITHIN THE REGION IS UNSTABLE\u001b[39;00m\n\u001b[1;32m     78\u001b[0m             Flag \u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "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": 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
}
