{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# -*- coding: utf-8 -*-\n",
    "import torch \n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import timeit \n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.io import savemat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "df/dt = dx1*(4.686*x1**5 + 1.192*x1**3*x2**2 - 16.392*x1**3 - 1.302*x1**2*x2**3 + 9.72*x1**2*x2 + 0.566*x1*x2**4 + 1.42*x1*x2**2 + 16.7218*x1 - 0.089*x2**5 - 0.063*x2**3 - 11.679*x2) + dx2*(0.596*x1**4*x2 - 1.302*x1**3*x2**2 + 3.24*x1**3 + 1.132*x1**2*x2**3 + 1.42*x1**2*x2 - 0.445*x1*x2**4 - 0.189*x1*x2**2 - 11.679*x1 + 0.072*x2**5 + 0.2*x2**3 + 9.8498*x2)\n"
     ]
    }
   ],
   "source": [
    "from sympy import symbols, diff, simplify\n",
    "\n",
    "# Define symbols\n",
    "x1, x2, dx1, dx2 = symbols('x1 x2 dx1 dx2')\n",
    "\n",
    "# Define f(x1, x2)\n",
    "f =(\n",
    "        8.361 * x1**2\n",
    "        - 11.679 * x1 * x2\n",
    "        + 4.925 * x2**2\n",
    "        - 4.098 * x1**4\n",
    "        + 3.240 * x1**3 * x2\n",
    "        + 0.710 * x1**2 * x2**2\n",
    "        - 0.063 * x1 * x2**3\n",
    "        + 0.050 * x2**4\n",
    "        + 0.781 * x1**6\n",
    "        + 0.298 * x1**4 * x2**2\n",
    "        - 0.434 * x1**3 * x2**3\n",
    "        + 0.283 * x1**2 * x2**4\n",
    "        - 0.089 * x1 * x2**5\n",
    "        + 0.012 * x2**6\n",
    "    ) - 0.0001*(x1*x1+x2*x2)\n",
    "\n",
    "# Compute ∂f/∂x1 and ∂f/∂x2\n",
    "df_dx1 = diff(f, x1)\n",
    "df_dx2 = diff(f, x2)\n",
    "\n",
    "# Time derivative: df/dt = ∂f/∂x1 * dx1 + ∂f/∂x2 * dx2\n",
    "df_dt = df_dx1 * dx1 + df_dx2 * dx2\n",
    "\n",
    "# Simplify (optional)\n",
    "df_dt = simplify(df_dt)\n",
    "\n",
    "# Display result\n",
    "print(\"df/dt =\", df_dt)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Two dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "#two dimension\n",
    "def f(x1,x2):\n",
    "    f = (\n",
    "        8.361 * x1**2\n",
    "        - 11.679 * x1 * x2\n",
    "        + 4.925 * x2**2\n",
    "        - 4.098 * x1**4\n",
    "        + 3.240 * x1**3 * x2\n",
    "        + 0.710 * x1**2 * x2**2\n",
    "        - 0.063 * x1 * x2**3\n",
    "        + 0.050 * x2**4\n",
    "        + 0.781 * x1**6\n",
    "        + 0.298 * x1**4 * x2**2\n",
    "        - 0.434 * x1**3 * x2**3\n",
    "        + 0.283 * x1**2 * x2**4\n",
    "        - 0.089 * x1 * x2**5\n",
    "        + 0.012 * x2**6\n",
    "    )- 0.0001*(x1*x1+x2*x2)\n",
    "    return f\n",
    "\n",
    "def df_dt(x1,x2,dx1,dx2):\n",
    "    df_dt = dx1*(4.686*x1**5 + 1.192*x1**3*x2**2 - 16.392*x1**3 - 1.302*x1**2*x2**3 + 9.72*x1**2*x2 + 0.566*x1*x2**4 + 1.42*x1*x2**2 + 16.7218*x1 - 0.089*x2**5 - 0.063*x2**3 - 11.679*x2) + dx2*(0.596*x1**4*x2 - 1.302*x1**3*x2**2 + 3.24*x1**3 + 1.132*x1**2*x2**3 + 1.42*x1**2*x2 - 0.445*x1*x2**4 - 0.189*x1*x2**2 - 11.679*x1 + 0.072*x2**5 + 0.2*x2**3 + 9.8498*x2)\n",
    "    \n",
    "    \n",
    "    return df_dt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of V > 0 points:  144\n",
      "number of V < 0 points:  0\n",
      "number of \\dot V < 0 points:  144\n",
      "number of \\dot V > 0 points:  0\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAAEWCAYAAAB42tAoAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAAsTAAALEwEAmpwYAAApm0lEQVR4nO3de7xcZX3v8c83kBDCDgSIbsANOyCWihACOyJYsQRvkVaiPYBaKkaxkVqK19OieBQ9XrDloLVqRakFCRoqVE0hiredqvWCiQ2QgEhALjtELolCNhAg5Xf+WGvIMJmZPbNn1qxZM9/367Vee2bWetb6zayZ59nr8nseRQRmZma1TMk7ADMz625uKMzMrC43FGZmVpcbCjMzq8sNhZmZ1eWGwszM6nJDYbmQtFLSWzq0rb+SdK+kcUl7d2Kb7VLvc5I0R1JI2rmD8bxP0sWd2p51BzcUlhlJd0h6NK2g75V0iaSBJtfRUmUoaSpwIfDyiBiIiE0V8/9A0jcl3S9ps6RrJR1SNv88SU9I2pJOv5b0GUn7TjKekHTwZMq2U9n7Gpf0e0k/kXTsROUi4mMR0VADn25jaevRWt7cUFjWXhURA8BRwHzg/R3e/iAwHVhXY/4sYDlwSLrsdcA3K5a5IiJmAnsBrwH2AVZPtrHoIlek++YZwI+Bf5eknGOyLuSGwjoiIjYA3wIOq5wnaYqk90u6U9J9kr4saY909g/Tv79P//vd4b9eSbtI+pSke9LpU+lrfwDcUlb+B1Xiui4i/iUiNkfEE8AngUOqnaKKiCciYh3wWuB+4N3V3qukgyX9p6QHJT0g6Yr09dJ7uT59L6+VtKekq9Mjmt+lj4cqVvlsSddJeig9+tmrxnb3kPQvkjZK2iDpI5J2qrZs5fsCLiVpAPeWtJ+k5ekR1npJf1m2jaeOEsqO9t4o6a70vZ6bzlsIvA94bfper09fXyzp9vTo7DeSTpsoPsufGwrrCEn7AycC/11l9uJ0WgAcBAwAn0nnvTj9Oys9dfTTKuXPBY4B5gFHAEcD74+IXwPPKyt/QgOhvhj4beUpqnIR8T8kRx3H1Vjk/wLfAfYEhoB/SsuV3ssR6Xu5guQ3+K/AMHAA8Cjb33vJ6cCbgX2BbcCna2z3knT+wcCRwMuBCU8TSdqF5PO/OyIeAJYBY8B+wMnAxyTV++xeRHJE9hLgA5KeGxHfBj5GetQSEUdI2i2N/ZXpEdoLgTUTxWf5c0NhWfuGpN+TnNr4T5LKo9JpwIURcXtEjAPvBV7XxHWJ04APR8R9EXE/8CHgDc0Gmv4n/1ngXQ0sfg/JqahqniCp+PeLiK0R8eNaK4mITRFxVUQ8EhFbgI8Cf1yx2GURsTYiHgb+D3Bq5ZGCpEGShvgdEfFwRNxHcnT0ujrv4dR039wNjACvSRv0PwL+Lo19DXAxSWNVy4ci4tGIuB64nqSxruVJ4DBJu0bExvQIzbqcGwrL2qsjYlZEDEfE2yLi0SrL7AfcWfb8TmBnkmsGjahWfr9mgpT0DJKjgM9FxFcbKPIsYHONeX8LCLhO0jpJb66z3RmSLkpPuz1EcqptVkVDcHfZ4zuBqcDsilUNp69vTC9O/x64CHhmnffwb+m+eWZEnBARq0k+t81po1W+zWfVWc9vyx4/QnJEuIO0oXstcGYa5zWS/rDOeq1LuKGwbnAPSUVXcgDJKZR7gUa6N65W/p5GNy5pT5JGYnlEfLSB5acArwJ+VG1+RPw2Iv4yIvYD3gp8rs6dTu8mOW3zgojYne2n2sovKu9f9vgAkiOWByrWczfwGDA7rfxnRcTuEfE8mnMPsJekmRXb3NDkeqDKvouIayPiZSSn0X4FfHES67UOc0Nh3eCrwDslHajk9tnSue1tJBeNnyS5dlGv/PslPUPSbOADQEO3ZUraHbgW+K+IOGeCZXeW9Nx0e/uQ3HZbbblTyi5I/46kwnwyfX5vxXuZSXJd4vfpReoPVlnlX0g6VNIM4MPAlel1kqdExEaSxu7/Sdo9vUHg2ZIqT2PVFRF3Az8BPi5puqS5wBk0+HlWuBeYkzasSBqUtCi9VvEYMM72z8W6mBsK6wZfAi4jOe3yG2Ar8DcAEfEIyXn7/0pPqRxTpfxHgFXADcCNwC/T1xrxGuD5wJvSu3NK0wFly7xW0jjwIMmttJuAkYioddTyfODnaZnlwNsj4vZ03nnApel7ORX4FLAryRHCz4BvV1nfZSQXqn9Lcqvv2TW2ezowDbiJpIG6kuQ/92a9HphDcnTxdeCDEfG9Sazna+nfTZJ+SVLfvCtd72aSazF/NYn1WofJAxeZmVk9PqIwM7O63FCYmVldbijMzKwuNxRmZlZXx7on7qTZs2fHnDlzJlX24YcfZrfddmtvQG3guJrjuJrjuJrTi3GtXr36gYh4RtWZEdFz08jISEzW6OjopMtmyXE1x3E1x3E1pxfjAlZFjTrVp57MzKwuNxRmZlaXGwozM6vLDYWZmdXlhsLMzOrKraGQtL+kUUk3pX32v73KMpL06XQ4xhskHZVVPJdfDnPmwOrVyd/LL59c+SlTXL4bym+uNVJEh7ZftPKbNxc7fpdvrf6aUK3bobKeSHq1PCp9PBP4NXBoxTInkoyzLJKhLn/eyLqbvT126dKIGTMiIOKCC0YDkudLlzZfvjS1u3y92946sf1aRkdHc91+rfIXXjjaVfuvpNp+7IbP78ILR7tq/5XKN3K7Zx6fX3lc3bD/Wqm/Sqhze2xuDcUOgSRjEL+s4rWLgNeXPb8F2HeidTXbUAwPb99BpQ8aktebLV8+tbN8vR9MJ7Zfy+joaK7br1X+ggtGu2r/lVTbj93w+ZV/77th/5XKN9JQ5PH5lcfVDfuvlfqrpF5D0RXdjEuaQzIWwWER8VDZ61cD50c65rCk75OM5buqyjqWAEsABgcHR5YtW9bw9lev3v54aGicsbHtIzmOjDRXvlK7yo+PjzMwUHWEyY5sv5bx8XFuuaV6XJ3Yfq3ypf3YLfuvpNp+zHP/lcpXfu87vf1aDjmk9ve+E9uvVb58P3bD/iuZTP1VsmDBgtURMb/qzFotSKcmkvF1VwN/VmXe1cCLyp5/H5g/0Tp9RNG5+H1E4SMKH1Hkv/+yPqLI9a4nSVOBq4DLI+LfqyyygaePFzzE5MbureujH4UZM57+2owZyesuX8zyU6YUO/5Ol59SURMULX6Xn3z5htRqQbKeSC5Qfxn4VJ1l/oSnX8y+rpF1T6avp6VLt/9nNTzc/IWgUnkpMik/0X9WWW+/llJceW2/VvmrrhrNdfu1ytfaj3l/flddNdpV+69UvtG+izr9+VXGlff+a7X+iqh/RJFnQ/EiIEjGOV6TTicCZwJnxvbG5LPAbSRjIU942ikm2VCU9GJnX1lyXM1xXM1xXM3JqlPA3LoZj+QCtSZYJoC/7kxEZmZWjTOzzcysLjcUZmZWlxuKlLvwKHZ5y1fe+9/le7QLjywnd+HRX1141IqrG/ViXO7Cw114FHJywl3n4u+GhLtacXWjXozLCXf5fv97PuGuW9x1V3Ovu3x3lbd85b3/Xb618o1wQwEccEBzr7t8d5W3fOW9/12+tfKNcENB/in0Lt+BLggsM3nvf5fv4S48spzchUf/deFRK65u06txuQsPd+FRuMldeHSO42qO42qO42pOVl14+NSTmZnV5YbCzMzqckORcma2M6OtuPL+/ndLeWdmZ3iNwpnZrWVmdyPH1Zwix+XMbGdmd6ShcGb25MsXuYLJg+NqjjOzmyvvzOwM5Z0ZWfTyZnnK+/tf9PKNyHvM7C9Juk/S2hrzj5f0oKQ16fSBLOLIOzOy6OXN8pT397/o5RuR9xHFJcDCCZb5UUTMS6cPZxFE3pmRRS9vlqe8v/9FL9+QWuekOjUBc4C1NeYdD1zd7Dqdmd35zOxu47iaU/S4nJmdbWa2kvn5kTQnbQwOqzLveOAqYAy4B3hPRKyrsZ4lwBKAwcHBkWXLlk0qnvHxcQYGBiZVNkuOqzmOqzmOqzm9GNeCBQtWR8T8qjNrtSCdmqh/RLE7MJA+PhG4tZF1uguPznFczXFczXFczenLLjwi4qGIGE8frwCmSpqdc1hmZn2lqxsKSftIUvr4aJJ4N2WxrX7PzDbrZ3n//pyZXf+001eBjcATJNchzgDOBM5M558FrAOuB34GvLCR9Tozu/UxpxvVi4fgWXJczelEXM7MTuDM7Pr6PTO7Ff1cwUyG42pOJ+JyZnaiXkPR1aeeOiXvzMi8y5v1s7x/f3mXb4QbCvLPjMy7vFk/y/v3l3f5RrihIP/MyLzLm/WzvH9/eZdvhBsK4LTT4AtfgOHh5PnwcPL8tNOaLy8Vr7xZP8v799fO8pDN73/n9q2q2E47LZlWroQ77ph8+Va3n1d5s36W9++vXeUnW39NxEcUZmZWlxsKMzOryw2FmZnV5YYiVfQuPMwsP3n//rPuwsMXs0k+1CVL4JFHkud33pk8h8YuMOVd3szyk/fvvxP1h48ogHPP3f4hlzzySPJ6EcqbWX7y/v13ov5wQ0H+KfTugsOsuPL+/bsLjw7JO4XeXXCYFVfev3934dEheafQuwsOs+LK+/fvLjw6pOhdeJhZfvL+/bsLjw4qehceZpafvH//Pd2Fh6QvSbpP0toa8yXp05LWS7pB0lGdjtHMrN/lferpEmBhnfmvBJ6TTkuAf+5ATGZmVibXhiIifghsrrPIIuDL6Uh9PwNmSdo3i1jyzsw2s/7V7ZnZSoZKzY+kOcDVEXFYlXlXA+dHxI/T598H/i4iVlVZdgnJUQeDg4Mjy5YtaziGzZuTbMYnn4ShoXHGxgaYMiW5KLTXXs2VL2mmfCPGx8cZGBhoz8rayHE1x3E1px/iarX+aLX+KlmwYMHqiJhfdWatwbQ7NQFzgLU15l0NvKjs+feB+ROtc2RkpKlBxVsdnLzVwdEb0YlB5ifDcTXHcTWnH+Jqtf5otf4qAVZFjTo172sUE9kA7F/2fCh9ra2KkBlpZr2pCPVPtzcUy4HT07ufjgEejIiN7d5IETIjzaw3FaH+yfv22K8CPwUOkTQm6QxJZ0o6M11kBXA7sB74IvC2LOIoQmakmfWmItQ/uSbcRcTrJ5gfwF9nHUcp0aXU2+LwcPIhN5MZWSp/111JS95MeTPrX63WH63WX41wZnYq78xsM+tfzsw2M7NCc0NhZmZ1uaEwM7O63FCk3IWHmeWl27vw8MVsijG4uZn1piLUPz6ioBiDm5tZbypC/eOGgmKk0JtZbypC/eOGgmKk0JtZbypC/eOGgmKk0JtZbypC/eOGgtYHJ291cHQz61+t1h+t1l+N8F1PKXfhYWZ5cRceZmZWaG4ozMysLjcUqawzG83MspJ1/ZX3wEULJd0iab2kc6rMXyzpfklr0uktWcRRymy8887keSmz0Y2FmXW7TtRfuTUUknYCPgu8EjgUeL2kQ6ssekVEzEuni7OIxZnVZlZUvZ6ZfTSwPiJuj4jHgWXAojwCcWa1mRVVJ+ovJaONdp6kk4GFEfGW9PkbgBdExFllyywGPg7cD/waeGdE3F1jfUuAJQCDg4Mjy5YtaziWG2+Exx9PHg8NjTM2NgDAtGlw+OHNvrNsjI+PMzAwkHcYO3BczXFczXFcE2tX/bVgwYLVETG/6syIyGUCTgYuLnv+BuAzFcvsDeySPn4r8ING1j0yMhLNWLo0YsaMCIi44ILRgOT50qVNrSZTo6OjeYdQleNqjuNqjuOaWLvqL2BV1KhT8zz1tAHYv+z5UPraUyJiU0Q8lj69GBjJIpBOZDaamWWh1zOzfwE8R9KBJA3E64A/L19A0r4RsTF9ehJwc1bBZJ3ZaGaWlazrr9waiojYJuks4FpgJ+BLEbFO0odJDoGWA2dLOgnYBmwGFucVr5lZv8q1r6eIWAGsqHjtA2WP3wu8t9NxmZnZds7MTjkz28yKymNmd4DHvDazovKY2R3izGwzK6pez8zuGs7MNrOi8pjZHeIxr82sqDxmdod4zGszK6quGzNb0hRJu7dv893BmdlmVlSdqL8mbCgkfUXS7pJ2A9YCN0n63+0LoTucdlqS0Tgykvx1I2FmRZF1/dXIEcWhEfEQ8GrgW8CBJB34mZlZH2ikoZgqaSpJQ7E8Ip4A8umb3MzMOq6RhLuLgDuA64EfShoGHsoyKLMsPPHEE4yNjbF169bcYthjjz24+ebM+rac0PTp0xkaGmLq1Km5xWDFM2FDERGfBj5d9tKdkhZkF1I+Lr88SVD5m7+BxYuTOwZ8naK3jI2NMXPmTObMmYOkXGLYsmULM2fOzGXbEcGmTZsYGxvjwAMPzCUGy0bW9VfNhkLSX0TEUknvqrHIhe0LI1/uwqM/bN26NddGIm+S2Hvvvbn//vvzDsXaKO8uPHZL/86sMfUMd+HRP/q1kSjp9/ffizpRf9U8ooiIi9K/H6qcJ2la+0LIn7vwMLOi6oouPCStlDSn7PnzSUan6xnuwsM6ZdasWcybN4/DDjuMU045hUcq/xUss3z5cs4///y667vjjjv4yle+0u4wrUC6pQuPjwPflvQ2SR8luQvqTe3YuKSFkm6RtF7SOVXm7yLpinT+z8sbrHZyFx5WTamP/ylT2tfH/6677sqaNWtYu3Yt06ZN4/Of/3zNZU866STOOWeHn8XTuKGwrujCIyKuBc4E/hF4M3BiRPyy1Q1L2gn4LPBK4FDg9ZIOrVjsDOB3EXEw8EngE61utxp34WGVShcI77wTIrZfIGzngDDHHXcc69evZ/Pmzbz61a9m7ty5HHPMMdxwww0AXHLJJZx11lkALF68mLPPPpsXvvCFHHTQQVx55ZUAnHPOOfzoRz9i3rx5fPKTn2TdunUcffTRzJs3j7lz53Lrrbe2L2DrSt3Shcf/Af4JeDFwHrBS0p+0YdtHA+sj4vaIeBxYBiyqWGYRcGn6+ErgJcroapy78LByWV8g3LZtG9/61rc4/PDD+eAHP8iRRx7JDTfcwMc+9jFOP/30qmU2btzIj3/8Y66++uqnjjTOP/98jjvuONasWcM73/lOPv/5z/P2t7+dNWvWsGrVKoaGhtoTsHW1rOuvRhLu9gaOjohHgZ9K+jZwMXBNi9t+FnB32fMx4AW1lomIbZIeTON5oHJlkpYASwAGBwdZuXLlpIIaHx+fdNksOa7mVItrjz32YMuWLQ2Vv+uuAWDH/0nuuivYsmV80nE9+uijzJ07F4Bjjz2WU089lRNOOIHLLruMLVu28PznP58HHniADRs2sHXrVh5//HG2bNnCE088wSte8Qoefvhh9t9/f+699162bNnCI488wrZt2556X/PmzeMjH/kIt912G6961as4+OCDd3jPW7du3eGzKdJ+7Ab9FlcjCXfvqHh+J/CytkfSooj4AvAFgPnz58fxxx8/qfWsXLmSyZbNkuNqTrW4br755oaT3Q44IDndtOPrailhbtddd33q1FLJlClTGBgYeGq9UrKN6dOnM23aNGbOnMnUqVOZNWvWU8tEBDNnzmTGjBnsvPPOT71+xhlncPzxx3PNNddw6qmnctFFF3HCCSc8bXvTp0/nyCOPfNprRdqP3aDf4mrk1NMzJF0gaYWkH5SmNmx7A7B/2fOh9LWqy0jaGdgD2NSGbe8g68HJrVg6eYPDcccdx+XpF27lypXMnj2b3XdvrDf/mTNnPu2I4fbbb+eggw7i7LPPZtGiRTs0Stabsq6/Gjn1dDlwBfAnJBe13wi0I7XzF8BzJB1I0iC8DvjzimWWp9v7KXAy8IOIaHuHhM7Mtkql/X7uucn96AcckF23Lueddx5vfvObmTt3LjNmzODSSy+duFBq7ty57LTTThxxxBEsXryYxx57jMsuu4ypU6eyzz778L73va/9AVtX6Uj9FRF1J2B1+veGstd+MVG5RibgRODXwG3AuelrHwZOSh9PB74GrAeuAw5qZL0jIyPRjOHhiOTelogLLhh96vHwcFOrydTo6GjeIVRVpLhuuummzgdS4aGHHso7hKqfQ5H2YzfoprjaVX8Bq6JGndrIEcUT6d+N6d1O9wB7tamRWgGsqHjtA2WPtwKntGNb9Tgz28yKqisys4GPSNoDeDfwHpI7nt7ZvhDy58xsMyuqrsjMjoirI+LBiFgbEQsiYiQilrcvhPw5M7t/RPsvcRVKv7//XtQVmdnlJLWckd2NnJndH6ZPn86mTZv6trKMdDyK6dOn5x2KtVEn6q9641GsAN4WEXeUv9y+TXeX005LppUrk8xG6z1DQ0OMjY3lOh7D1q1bc62oSyPcWW/Juv6qdzH7X4HvSLoU+PtIxspuNRvbLDdTp07NfWS3lStX7pDsZtbtap56ioivAUcBuwOrJL0H2CzpXXVGvTMzsx4z0e2xjwMPA7uQjGr3ZOYRmZlZV6l5RCFpIbAGmAEcFREfjIgPlaZOBdgp7sLDzIoqzy48zgVOiYh17d1k93EXHmZWVJ2ov+pdoziuHxoJ6Mzg5GZmWehE/dVUHkWvchceZlZU3dKFR89zFx5mVlRd0YVHP3AXHmZWVF3XhUevchceZlZUuXbh0W/chYeZFVXW9ZePKMzMrK5cGgpJe0n6rqRb07971ljufyStSaee6trczKwo8jqiOAf4fkQ8B/h++ryaRyNiXjqdlGVAzsw2s6LKMzM7S4uA49PHlwIrgb/LKRZnZptZYXWi/lIeg7hI+n1EzEofC/hd6XnFcttI+pvaBpwfEd+os84lwBKAwcHBkWXLljUcz403wuOPJ4+HhsYZGxsAYNo0OPzwhleTqfHxcQYGBvIOYweOqzmOqzmOa2Ltqr8WLFiwOiLmV50ZEZlMwPeAtVWmRcDvK5b9XY11PCv9exBwB/DsRrY9MjISzZAiIJkuuGD0qcdSU6vJ1OjoaN4hVOW4muO4muO4Jtau+gtYFTXq1MxOPUXES2vNk3SvpH0jYqOkfYH7aqxjQ/r3dkkrgSOB29od6wEHJIdr1V43M+tmnai/8rqYvRx4Y/r4jcA3KxeQtKekXdLHs4E/Am7KIhhnZptZUfVyZvb5wMsk3Qq8NH2OpPmSLk6XeS7JyHrXA6Mk1ygyaSicmW1mRdWzmdkRsQl4SZXXVwFvSR//BOjYpWRnZptZUTkz28zMcuWGwszM6nJDkWo1s7FUfsoUZ3abWXNarT96NTO7q7Sa2ejMbjObrCLUPz6ioPUxZz3mtplNVhHqHzcUtD7mrMfcNrPJKkL944aC1sec9ZjbZjZZRah/3FDQemajM7vNbLKKUP+4oaD1zMby8pIzu82sca3WHz2bmd2NWs1sLJU3M2tWq/WHM7PNzCxXbijMzKwuNxRmZlaXG4qUu/Aws7y4C48CKEIKvZn1piLUP7kcUUg6RdI6SU9Kqj6Yd7LcQkm3SFov6Zys4ilCCr2Z9aYi1D95nXpaC/wZ8MNaC0jaCfgs8ErgUOD1kg7NIpgipNCbWW8qQv2TS0MRETdHxC0TLHY0sD4ibo+Ix4FlwKIs4ilCCr2Z9aYi1D+KiPatrdmNSyuB96RDoFbOOxlYGBFvSZ+/AXhBRJxVY11LgCUAg4ODI8uWLWs4js2bk/N6Tz4JQ0PjjI0NMGVKkuG4117NlS9ppnwjxsfHGRgYaM/K2shxNcdxNacf4mq1/mi1/ipZsGDB6oiofikgIjKZgO+RnGKqnBaVLbMSmF+j/MnAxWXP3wB8ppFtj4yMRLOWLo0YHo644ILRGB5Onk+mvBSTKj+R0dHR9q6wTRxXcxxXc/olrlbrj1brr4gIYFXUqFMzu+spIl7a4io2APuXPR9KX8uEu/Aws7y4C4/J+wXwHEkHSpoGvA5YnnNMZmZ9J6/bY18jaQw4FrhG0rXp6/tJWgEQEduAs4BrgZuBf4uIdXnEa2bWz/K66+nrETEUEbtExGBEvCJ9/Z6IOLFsuRUR8QcR8eyIyHR0h7wzs53ZbVZcef/+nZndAXlnRjqz26y48v7992xmdrfJOzPSmd1mxZX377+XM7O7St6Zkc7sNiuuvH//PZuZ3W3yzox0ZrdZceX9++9E/eGGgvwHN+/E4Ohmlo28f/+dqD/cUND64OTtHBx9MuXNLD95//5brb8a4bueUnlnZjuz26y48v7993NmtpmZdQE3FGZmVpcbCjMzq8sNRaroXXi4CxCzycv799ftXXhkNh5FnlOz41EsXRoxY0YEJP25Q/K80T7dy8uXpnaXr9f/favbb0W/jBfQLo6rOZ2IazK/n/K4OvH7b7T8ZOqvEuqMR+EjCvJPoc+7vFk/y/v3l3f5RrihIP8U+rzLm/WzvH9/eZdvhBsK8k+hz7u8WT/L+/eXd/lGuKEg/xT6vMub9bO8f395l29EXiPcnSJpnaQnJc2vs9wdkm6UtEbSqqziKXoXHu4CxGzy8v79uQuP2tYCfwZc1MCyCyLigYzjKXwXHu4CxGzy8v79dXsXHrk0FBFxM4CkPDZvZmZNUHL7bE4bl1YC74mIqqeVJP0G+B0QwEUR8YU661oCLAEYHBwcWbZs2aRiGh8fZ2BgYFJls+S4muO4muO4mtOLcS1YsGB1RFS/FFArwaLVCfgeySmmymlR2TIrgfl11vGs9O8zgeuBFzey7WYT7iKS5JTh4SRhZXi4+WSVUnkpMik/UeJR1tuvpZ8TtSbDcTWn0bg6/f2vjCuv319l+cnWXxH1E+5yzaCeqKGoWPY8kqMPZ2bnsP1ail7BdJrjak4jceXx/e+3zOyubSiA3YCZZY9/AixsZL3NNhTDw9t3UOmDhuT1ZsuXT+0sX+8H04nt11LkCiYPjqs5jcSVx/e/PK48f3+V5SdTf5XUayjyuj32NZLGgGOBayRdm76+n6QV6WKDwI8lXQ9cB1wTEd/OIp68MyOLXt4sT3l//4tevhG5NBQR8fWIGIqIXSJiMCJekb5+T0ScmD6+PSKOSKfnRURm6WN5Z0YWvbxZnvL+/he9fCOcmU3+mZFFL2+Wp7y//0Uv35Ba56SKPPmuJ9/15LiaU/S4fNdTD9/1lNU0mYaipOg/mE5zXM1xXM1xXM1pJa56DYVPPZmZWV1uKMzMrC43FGZmVpcbilSrg5N3y+Dq/Vre8pX3/nf51uqvCdW6eFHkyV14dLYLj7y7MKgVVzfqxbiy3P/uwqO58j3ZhUdWk7vw6Fz8o6OjuXdhUCuubtSLcWW5/92FR3Ple6oLj26Tdwq9y7dW3vKV9/53+dbKN8INBfmn0Lt8a+UtX3nvf5dvrXwj3FCQfwq9y7sLkSLLe/+7vLvw6Mg1igh34dFqFx55d2FQK65u06txZbX/3YVHc+XdhUfGDUVJr/6Qs+K4muO4muO4muMuPMzMLBduKMzMrK68Rrj7B0m/knSDpK9LmlVjuYWSbpG0XtI5WcbkzOzeKr95c77bL1r5zZuLHb/L92BmNvByYOf08SeAT1RZZifgNuAgYBpwPXBoI+t3ZnZ/ZWZXK3/hhaNdtf9Kqu3Hbvj8LrxwtKv2nzOznZld2SC8Bri8yuvHAteWPX8v8N5G1unM7M7F3w2Z2dXKl+7+yGv7tcpX24/d8PmVf++7Yf+Vyjszu7nyWWVmK5mfH0n/AVwREUsrXj8ZWBgRb0mfvwF4QUScVWM9S4AlAIODgyPLli1rOIbVq7c/HhoaZ2xs4KnnIyPNla/UrvLj4+MMDAxUXaYT269lfHycW26pHlcntl+rfGk/dsv+K6m2H/Pcf6Xyld/7Tm+/lkMOqf2978T2a5Uv34/dsP9KJlN/lSxYsGB1RMyvOrNWC9LqBHwPWFtlWlS2zLnA1yFpsCrKnwxcXPb8DcBnGtm2jyg6F7+PKHxE4SOK/Pdf1kcUmV3MjoiXRsRhVaZvAkhaDPwpcFoaZKUNwP5lz4fS19ou78xIl29/+SlTih1/p8tPqagJiha/y0++fENqtSBZTsBC4CbgGXWW2Rm4HTiQ7Rezn9fI+p2Z3X+Z2ZXlr7pqNNft1ypfaz/m/fldddVoV+0/Z2ZPrnxPZWYD64G7gTXp9Pn09f2AFWXLnQj8muTup3MbXb8zszvHcTXHcTXHcTUnq8zsndt4cNKwiDi4xuv3kDQOpecrgBWdisvMzHbkzGwzM6vLDYWZmdXlhsLMzOpyQ2FmZnXlnpmdBUn3A3dOsvhs4IE2htMujqs5jqs5jqs5vRjXcEQ8o9qMnmwoWiFpVdRKY8+R42qO42qO42pOv8XlU09mZlaXGwozM6vLDcWOvpB3ADU4ruY4ruY4rub0VVy+RmFmZnX5iMLMzOpyQ2FmZnX1fUMh6R8k/UrSDZK+LmlWjeUWSrpF0npJ53QgrlMkrZP0pKSat7tJukPSjZLWSFrVRXF1+vPaS9J3Jd2a/t2zxnL/k35WayQtzzCeuu9f0i6Srkjn/1zSnKxiaTKuxZLuL/uM3tKBmL4k6T5Ja2vMl6RPpzHfIOmorGNqMK7jJT1Y9ll9oENx7S9pVNJN6W/x7VWWae9nVqtb2X6ZgJcDO6ePPwF8osoyO5F0dX4Q28fGODTjuJ4LHAKsBObXWe4OYHYHP68J48rp8/p74Jz08TnV9mM6b7wDn9GE7x94G9u7138dyXDA3RDXYhocSbKNcb0YOApYW2P+icC3AAHHAD/vkriOB67u5GeVbndf4Kj08UySoRgq92NbP7O+P6KIiO9ExLb06c9IRtKrdDSwPiJuj4jHgWXAoozjujkibslyG5PRYFwd/7zS9V+aPr4UeHXG26unkfdfHu+VwEskqQvi6riI+CGwuc4ii4AvR+JnwCxJ+3ZBXLmIiI0R8cv08RbgZuBZFYu19TPr+4aiwptJWuFKzyIZaKlkjB13TF4C+I6k1ZKW5B1MKo/PazAiNqaPfwsM1lhuuqRVkn4m6dUZxdLI+39qmfQflQeBvTOKp5m4AP5XerriSkn7V5nfad38+ztW0vWSviXpeZ3eeHrK8kjg5xWz2vqZ5TJwUadJ+h6wT5VZ58b2MbzPBbYBl3dTXA14UURskPRM4LuSfpX+J5R3XG1XL67yJxERkmrd9z2cfl4HAT+QdGNE3NbuWAvsP4CvRsRjkt5KctRzQs4xdatfknyfxiWdCHwDeE6nNi5pALgKeEdEPJTltvqioYiIl9abL2kx8KfASyI9wVdhA1D+n9VQ+lqmcTW4jg3p3/skfZ3k9EJLDUUb4ur45yXpXkn7RsTG9BD7vhrrKH1et0taSfLfWLsbikbef2mZMUk7A3sAm9ocR9NxRUR5DBeTXPvJWybfp1aVV84RsULS5yTNjojMOwuUNJWkkbg8Iv69yiJt/cz6/tSTpIXA3wInRcQjNRb7BfAcSQdKmkZy8TGzO2YaJWk3STNLj0kuzFe9Q6PD8vi8lgNvTB+/EdjhyEfSnpJ2SR/PBv4IuCmDWBp5/+Xxngz8oMY/KR2Nq+I89kkk57/zthw4Pb2T5xjgwbLTjLmRtE/pupKko0nq06wbe9Jt/gtwc0RcWGOx9n5mnb5i320TsJ7kXN6adCrdibIfsKJsuRNJ7i64jeQUTNZxvYbkvOJjwL3AtZVxkdy9cn06reuWuHL6vPYGvg/cCnwP2Ct9fT5wcfr4hcCN6ed1I3BGhvHs8P6BD5P8QwIwHfha+v27Djgo68+owbg+nn6XrgdGgT/sQExfBTYCT6TfrTOAM4Ez0/kCPpvGfCN17gLscFxnlX1WPwNe2KG4XkRybfKGsnrrxCw/M3fhYWZmdfX9qSczM6vPDYWZmdXlhsLMzOpyQ2FmZnW5oTAzs7rcUJg1Ke298zeS9kqf75k+n9Pien/SlgDN2sy3x5pNgqS/BQ6OiCWSLgLuiIiP5x2XWRZ8RGE2OZ8EjpH0DpIEqAsqF5D0jbSzxnWlDhslDSsZM2O2pCmSfiTp5em88fTvvpJ+mI5xsFbScZ17W2Y78hGF2SRJegXwbeDlEfHdKvP3iojNknYl6T7jjyNik5LBgF5BkpF9cES8NV1+PCIGJL0bmB4RH5W0EzAjku6kzXLhIwqzyXslSRcPh9WYf7akUvcO+5P2LBoRFwO7k3S58J4q5X4BvEnSecDhbiQsb24ozCZB0jzgZSSjh70zvcBdGhLzTEnHAy8Fjo2II4D/JunfCUkz2D5A1kDluiPpJv7FJL19XiLp9IzfjlldfdHNuFk7pb13/jPJOAB3SfoH4PyImFe2zCLgdxHxiKQ/JGlQSj5BMu7JncAXSbq4L1//MDAWEV9Me7s9Cvhylu/JrB4fUZg17y+Bu8quS3wOeK6kPy5b5tvAzpJuBs4nOf1EuszzScb0vhx4XNKbKtZ/PHC9pP8GXgv8Y2bvxKwBvphtZmZ1+YjCzMzqckNhZmZ1uaEwM7O63FCYmVldbijMzKwuNxRmZlaXGwozM6vr/wMmJ7cfulSOQgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7.206298136782682\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",
    "        if x1*x1+x2*x2 > 3.7:\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": [
    "# # 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
}
