{
 "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": "markdown",
   "metadata": {},
   "source": [
    "# mathematical simulation to show\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "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",
    "c = 2\n",
    "v = 6\n",
    "\n",
    "for x1 in x1_list:   \n",
    "    for x2 in x2_list:\n",
    "        dx1 = v * np.sin(x2)\n",
    "        dx2 = -x2 - c*v*np.sin(x2)*x1/x2\n",
    "        v = x1*x1 + x2*x2/c\n",
    "        dv1 = 2*x1*dx1+2*x2*dx2/c\n",
    "        \n",
    "        state_list.append([x1,x2])\n",
    "        v_list.append(v)\n",
    "        dv_list.append(dv1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "144 2.2247362880886437\n"
     ]
    }
   ],
   "source": [
    "#Search for the biggest pho\n",
    "Num_points = 0\n",
    "Index_pho = 0\n",
    "Flag = True\n",
    "pho = min(v_list)\n",
    "while(Flag):\n",
    "    pho = pho+0.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": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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+59SWvZjwG5mtjPRYDoBOCmlZQkhhMgZZQ+ScPcPpDiccPcNwBnA3cAi4OY0lweozbyInpCyyCNPM3rUZp7AF3XVZp6aR23myXvUZq4285DyVPKozbzeAaU281Q9ajNP3qM28+Q9ajNPx6M283oJrcFXnvQ9ajPPzqM2c3lq9VShGAMqtAZfedL3qM08O4+rzVyeGj1VKMaAUpt58TxqM8/OozbzYnvUZp7AQRLuajNPyaM28+Q9ajNXm3lIeSp5mrbNPHPUZl48T0hZ5JGnGT2NaDMXQgghGokGlBBCiCDRgBJCCBEkGlBCCCGCRANKCCFEkGhACSGECJJiDSi1mRfPE1IWeeRpRo/azBP4oq7azFPzqM08eY/azNVmHlKeSh61mdc7oNRmnqpHbebJe9RmnrxHbebpeNRmXi+hNfjKk75HbebZedRmLk+tnioUY0CF1uArT/oetZln53G1mctTo6cKxRhQajMvnkdt5tl51GZebI/azBM4SMJdbeYpedRmnrxHbeZqMw8pTyWP2syTQm3mxfOElEUeeZrRozZzIYQQRUMDSgghRJBoQAkhhAgSDSghhBBBogElhBAiSDSghBBCBEmxBpTazIvnCSmLPPI0o0dt5gl8UVdt5ql51GaevEdt5mozDylPJY/azOsdUGozT9WjNvPkPWozT96jNvN0PGozr5fQGnzlSd+jNvPsPGozl6dWTxWKMaBCa/CVJ32P2syz87jazOWp0VOFYgwotZkXz6M28+w8ajMvtkdt5gkcJOGuNvOUPGozT96jNnO1mYeUp5Kn6drMzewTwAXAHsAkd388kwWrzbx4npCyyCNPM3qasM38KeBjwAMNWr4QQojAacgnKHdfBGCdj/4RQgghYsw7H4GT5cLN5gJfrbSJz8xmADMAWltbJ8yaNauuZba1tdHS0lKXIyvykjUvOSE/WfOSE/KTNS85oXhZp0yZMt/dJ252Q1c7ppI4AfcRbcrrfDq25D5zgYndddZ9kITXsZO8AeQla15yuucna15yuucna15yuhcvK1kfJOHuH07LLYQQovkpxveghBBC5I6GDCgz+6iZLQX2B+40s7szWbDazIvnCSmLPPI0o0dt5gnsg1KbeWoetZkn71GbudrMQ8pTyaM283oHlNrMU/WozTx5j9rMk/eozTwdj9rM6yW0Bl950veozTw7j9rM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\n",
      "text/plain": [
       "<Figure size 432x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of points within levelset:  144\n",
      "number of points beyond levelset:  256\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"
    }
   ],
   "source": [
    "#Original Stability region chosen as benchmark\n",
    "WV_point_list = list()\n",
    "uWV_point_list = list()\n",
    "n = 2.23\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/c > 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": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Convert to numpy array\n",
    "# np.savetxt('V.txt', V_candidate.detach().numpy(), fmt='%.6f')  # Adjust format as needed\n",
    "# # Save to text file\n",
    "# np.savetxt('LV.txt', L_V.detach().numpy(), fmt='%.6f')  # Adjust format as needed\n",
    "\n",
    "\n",
    "# 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_PF_P.mat', {'data': array_data1})\n",
    "savemat('stable_PF_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
}
