{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f3ec92bc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f92080d84f0>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#CONTINUOUS SOLUTION,degenerate A\n",
    "\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "\n",
    "A = np.array([[1.2,-3],[-1,1]])\n",
    "\n",
    "C = - np.dot(A,A.T)\n",
    "a = np.array([[0, 0, C[0][0],C[0][1]], [0, 0,C[1][0],C[1][1]],[1,0,0,0],[0,1,0,0]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,19,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "T = 2550 \n",
    "\n",
    "s = np.zeros(T)\n",
    "d = np.zeros(T)\n",
    "y = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_1[t] = c[0][0] ** 0.5\n",
    "    g_2[t] = c[2][2] ** 0.5\n",
    "    g_3[t] = c[1][1]\n",
    "    g_4[t] = c[3][3]\n",
    "    g_5[t] = g_1[t] * g_2[t] \n",
    "    \n",
    "\n",
    "    \n",
    "plt.plot(g_1,label = \"Standard Deviation of y_1,1\") \n",
    "plt.plot(g_2,label = \"Standard Deviation of X_1,1\")\n",
    "plt.show()\n",
    "\n",
    "plt.title(\" \")\n",
    "plt.legend() \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "e6cf34bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "#CONTINUOUS SOLUTION,degenerate A\n",
    "\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "A = np.array([[1.1,-1],[-1,1]]) \n",
    "C = - np.dot(A,A.T)\n",
    "a = np.array([[0, 0, C[0][0],C[0][1]], [0, 0,C[1][0],C[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "\n",
    "A_2 = np.array([[1.2,-1.2],[-1,1]])\n",
    "C_2 = - np.dot(A_2,A_2.T)\n",
    "a_2 = np.array([[0, 0, C_2[0][0],C_2[0][1]], [0, 0,C_2[1][0],C_2[1][1]],[1,0,0,0],[0,1,0,0]])\n",
    "\n",
    "A_3 = np.array([[1.5,-1.5],[-1,1]]) \n",
    "C_3 = - np.dot(A_3,A_3.T)\n",
    "a_3 = np.array([[0, 0, C_3[0][0],C_3[0][1]], [0, 0,C_3[1][0],C_3[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "T = 2000 \n",
    "\n",
    "s = np.zeros(T)\n",
    "d = np.zeros(T)\n",
    "y = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "\n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_1[t] = c[0][0]\n",
    "    g_2[t] = c[2][2]\n",
    "    g_3[t] = c[1][1]\n",
    "    g_4[t] = c[3][3]\n",
    "\n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a_2)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_5[t] = c[0][0]\n",
    "    g_6[t] = c[2][2]\n",
    "    g_7[t] = c[1][1]\n",
    "    g_8[t] = c[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a_3)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_9[t] = c[0][0]\n",
    "    g_10[t] = c[2][2]\n",
    "    g_11[t] = c[1][1]\n",
    "    g_12[t] = c[3][3]\n",
    "\n",
    "\n",
    "    \n",
    "plt.plot(g_1) #累积策略的方差，无界\n",
    "plt.plot(g_2)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "57b72be5",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "#CONTINUOUS SOLUTION,non-degenerate A\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "A = np.array([[1,-2],[-1,1]]) \n",
    "C = - np.dot(A,A.T)\n",
    "a = np.array([[0, 0, C[0][0],C[0][1]], [0, 0,C[1][0],C[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "\n",
    "A_2 = np.array([[2,-3],[-1,5]])\n",
    "C_2 = - np.dot(A_2,A_2.T)\n",
    "a_2 = np.array([[0, 0, C_2[0][0],C_2[0][1]], [0, 0,C_2[1][0],C_2[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "A_3 = np.array([[2,-1.5],[-2,3]]) \n",
    "C_3 = - np.dot(A_3,A_3.T)\n",
    "a_3 = np.array([[0, 0, C_3[0][0],C_3[0][1]], [0, 0,C_3[1][0],C_3[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "T = 1000\n",
    "\n",
    "\n",
    "s = np.zeros(T)\n",
    "d = np.zeros(T)\n",
    "y = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "\n",
    "\n",
    "for t in range(0,T):\n",
    "    s[t] = 0.1*t\n",
    "    b = expm(s[t]*a)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_1[t] = c[0][0]\n",
    "    g_2[t] = c[2][2]\n",
    "    g_3[t] = c[1][1]\n",
    "    g_4[t] = c[3][3]\n",
    "    #print(d[t])\n",
    "    \n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a_2)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_5[t] = c[0][0]\n",
    "    g_6[t] = c[2][2]\n",
    "    g_7[t] = c[1][1]\n",
    "    g_8[t] = c[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a_3)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_9[t] = c[0][0]\n",
    "    g_10[t] = c[2][2]\n",
    "    g_11[t] = c[1][1]\n",
    "    g_12[t] = c[3][3]\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    \n",
    "plt.plot(g_2) \n",
    "plt.plot(g_6,c = \"darkorange\") \n",
    "plt.plot(g_10,c = \"maroon\") \n",
    "\n",
    "\n",
    "\n",
    "plt.legend([\"A_4\",\"A_5\",\"A_6\"])\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9aa5a1d2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "#CONTINUOUS SOLUTION,non-degenerate A\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "A = np.array([[1,-2],[-1,1]]) \n",
    "C = - np.dot(A,A.T)\n",
    "a = np.array([[0, 0, C[0][0],C[0][1]], [0, 0,C[1][0],C[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "\n",
    "A_2 = np.array([[2,-3],[-1,5]])\n",
    "C_2 = - np.dot(A_2,A_2.T)\n",
    "a_2 = np.array([[0, 0, C_2[0][0],C_2[0][1]], [0, 0,C_2[1][0],C_2[1][1]],[1,0,0,0],[0,1,0,0]])\n",
    "\n",
    "A_3 = np.array([[2,-1.5],[-2,3]]) \n",
    "C_3 = - np.dot(A_3,A_3.T)\n",
    "a_3 = np.array([[0, 0, C_3[0][0],C_3[0][1]], [0, 0,C_3[1][0],C_3[1][1]],[1,0,0,0],[0,1,0,0]]) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "T = 250\n",
    "\n",
    "\n",
    "s = np.zeros(T)\n",
    "d = np.zeros(T)\n",
    "y = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "\n",
    "\n",
    "for t in range(0,T):\n",
    "    s[t] = 0.1*t\n",
    "    b = expm(s[t]*a)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_1[t] = c[0][0]\n",
    "    g_2[t] = c[2][2]\n",
    "    g_3[t] = c[1][1]\n",
    "    g_4[t] = c[3][3]\n",
    "    #print(d[t])\n",
    "    \n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a_2)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_5[t] = c[0][0]\n",
    "    g_6[t] = c[2][2]\n",
    "    g_7[t] = c[1][1]\n",
    "    g_8[t] = c[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    s[t] = 0.01*t\n",
    "    b = expm(s[t]*a_3)\n",
    "    c_1 = np.dot(b,P_0)\n",
    "    c = np.dot(c_1,b.T)\n",
    "    g_9[t] = c[0][0]\n",
    "    g_10[t] = c[2][2]\n",
    "    g_11[t] = c[1][1]\n",
    "    g_12[t] = c[3][3]\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    \n",
    "plt.plot(g_1) \n",
    "plt.plot(g_5,c = \"darkorange\") \n",
    "plt.plot(g_9,c = \"maroon\") \n",
    "\n",
    "\n",
    "\n",
    "plt.legend([\"A_4\",\"A_5\",\"A_6\"])\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2b99e0e9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "# symplectic, non-degenate, X_11\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "eta = 0.01 \n",
    "\n",
    "A = np.array([[1,-1.1],[-1,1]])\n",
    "H = -1 * np.dot(A,A.T)\n",
    "S = np.array([[1,0, H[0][0] * eta, H[0][1] * eta], [0,1, H[1][0] * eta, H[1][1] * eta],\n",
    "     [eta, 0, 1 + H[0][0] * eta**2, H[0][1] * eta**2] , [0, eta, H[1][0] * eta**2, 1 + H[1][1] * eta**2]  ])\n",
    "\n",
    "A_2 = np.array([[1,-1.2],[-1,1]])\n",
    "H_2 = -1 * np.dot(A_2,A_2.T)\n",
    "S_2 = np.array([[1,0, H_2[0][0] * eta, H_2[0][1] * eta], [0,1, H_2[1][0] * eta, H_2[1][1] * eta],\n",
    "     [eta, 0, 1 + H_2[0][0] * eta**2, H_2[0][1] * eta**2] , [0, eta, H_2[1][0] * eta**2, 1 + H_2[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_3 = np.array([[1,-1.3],[-1,1]])\n",
    "H_3 = -1 * np.dot(A_3,A_3.T)\n",
    "S_3 = np.array([[1,0, H_3[0][0] * eta, H_3[0][1] * eta], [0,1, H_3[1][0] * eta, H_3[1][1] * eta],\n",
    "     [eta, 0, 1 + H_3[0][0] * eta**2, H_3[0][1] * eta**2] , [0, eta, H_3[1][0] * eta**2, 1 + H_3[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "c = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "T = 10000\n",
    "pc = np.zeros(T)\n",
    "lb = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "for t in range(0,T):\n",
    "    c = np.dot(c,S)\n",
    "    d = np.dot(d,S.T)\n",
    "    q = np.dot(c,P_0)\n",
    "    k = np.dot(q,d)\n",
    "    g_1[t] = k[0][0]\n",
    "    g_2[t] = k[2][2]\n",
    "    g_3[t] = k[1][1]\n",
    "    g_4[t] = k[3][3]\n",
    "\n",
    "for t in range(0,T):\n",
    "    c_2 = np.dot(c_2,S_2)\n",
    "    d_2 = np.dot(d_2,S_2.T)\n",
    "    q_2 = np.dot(c_2,P_0)\n",
    "    k_2 = np.dot(q_2,d_2)\n",
    "    g_5[t] = k_2[0][0]\n",
    "    g_6[t] = k_2[2][2]\n",
    "    g_7[t] = k_2[1][1]\n",
    "    g_8[t] = k_2[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    c_3 = np.dot(c_3,S_3)\n",
    "    d_3 = np.dot(d_3,S_3.T)\n",
    "    q_3 = np.dot(c_3,P_0)\n",
    "    k_3 = np.dot(q_3,d_3)\n",
    "    g_9[t] = k_3[0][0]\n",
    "    g_10[t] = k_3[2][2]\n",
    "    g_11[t] = k_3[1][1]\n",
    "    g_12[t] = k_3[3][3]\n",
    "    \n",
    "    \n",
    "plt.plot(g_2)\n",
    "plt.plot(g_6,c = \"darkorange\")\n",
    "plt.plot(g_10,c = \"maroon\")\n",
    "\n",
    "plt.legend([\"B_4\",\"B_5\",\"B_6\"])\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0908df4f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "# symplectic, non-degenate, y_11\n",
    "\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "eta = 0.001\n",
    "\n",
    "\n",
    "\n",
    "A = np.array([[1,-1.1],[-1,1]])\n",
    "H = -1 * np.dot(A,A.T)\n",
    "S = np.array([[1,0, H[0][0] * eta, H[0][1] * eta], [0,1, H[1][0] * eta, H[1][1] * eta],\n",
    "     [eta, 0, 1 + H[0][0] * eta**2, H[0][1] * eta**2] , [0, eta, H[1][0] * eta**2, 1 + H[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_2 = np.array([[1,-1.2],[-1,1]])\n",
    "H_2 = -1 * np.dot(A_2,A_2.T)\n",
    "S_2 = np.array([[1,0, H_2[0][0] * eta, H_2[0][1] * eta], [0,1, H_2[1][0] * eta, H_2[1][1] * eta],\n",
    "     [eta, 0, 1 + H_2[0][0] * eta**2, H_2[0][1] * eta**2] , [0, eta, H_2[1][0] * eta**2, 1 + H_2[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_3 = np.array([[1,-1.3],[-1,1]])\n",
    "H_3 = -1 * np.dot(A_3,A_3.T)\n",
    "S_3 = np.array([[1,0, H_3[0][0] * eta, H_3[0][1] * eta], [0,1, H_3[1][0] * eta, H_3[1][1] * eta],\n",
    "     [eta, 0, 1 + H_3[0][0] * eta**2, H_3[0][1] * eta**2] , [0, eta, H_3[1][0] * eta**2, 1 + H_3[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "c = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "T = 8000\n",
    "pc = np.zeros(T)\n",
    "lb = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "for t in range(0,T):\n",
    "    c = np.dot(c,S)\n",
    "    d = np.dot(d,S.T)\n",
    "    q = np.dot(c,P_0)\n",
    "    k = np.dot(q,d)\n",
    "    g_1[t] = k[0][0]\n",
    "    g_2[t] = k[2][2]\n",
    "    g_3[t] = k[1][1]\n",
    "    g_4[t] = k[3][3]\n",
    "\n",
    "for t in range(0,T):\n",
    "    c_2 = np.dot(c_2,S_2)\n",
    "    d_2 = np.dot(d_2,S_2.T)\n",
    "    q_2 = np.dot(c_2,P_0)\n",
    "    k_2 = np.dot(q_2,d_2)\n",
    "    g_5[t] = k_2[0][0]\n",
    "    g_6[t] = k_2[2][2]\n",
    "    g_7[t] = k_2[1][1]\n",
    "    g_8[t] = k_2[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    c_3 = np.dot(c_3,S_3)\n",
    "    d_3 = np.dot(d_3,S_3.T)\n",
    "    q_3 = np.dot(c_3,P_0)\n",
    "    k_3 = np.dot(q_3,d_3)\n",
    "    g_9[t] = k_3[0][0]\n",
    "    g_10[t] = k_3[2][2]\n",
    "    g_11[t] = k_3[1][1]\n",
    "    g_12[t] = k_3[3][3]\n",
    "    \n",
    "    \n",
    "plt.plot(g_1)\n",
    "plt.plot(g_5,c = \"darkorange\")\n",
    "plt.plot(g_9,c = \"maroon\")\n",
    "\n",
    "plt.legend([\"B_4\",\"B_5\",\"B_6\"])\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e34b10d1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "#symplectic, degenate, X_11\n",
    "\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "eta = 0.01 \n",
    "\n",
    "\n",
    "\n",
    "A = np.array([[1,-1],[-1,1]])\n",
    "H = -1 * np.dot(A,A.T)\n",
    "S = np.array([[1,0, H[0][0] * eta, H[0][1] * eta], [0,1, H[1][0] * eta, H[1][1] * eta],\n",
    "     [eta, 0, 1 + H[0][0] * eta**2, H[0][1] * eta**2] , [0, eta, H[1][0] * eta**2, 1 + H[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_2 = np.array([[1,-1.2],[-1,1.2]])\n",
    "H_2 = -1 * np.dot(A_2,A_2.T)\n",
    "S_2 = np.array([[1,0, H_2[0][0] * eta, H_2[0][1] * eta], [0,1, H_2[1][0] * eta, H_2[1][1] * eta],\n",
    "     [eta, 0, 1 + H_2[0][0] * eta**2, H_2[0][1] * eta**2] , [0, eta, H_2[1][0] * eta**2, 1 + H_2[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_3 = np.array([[1,-1.3],[-1,1.3]])\n",
    "H_3 = -1 * np.dot(A_3,A_3.T)\n",
    "S_3 = np.array([[1,0, H_3[0][0] * eta, H_3[0][1] * eta], [0,1, H_3[1][0] * eta, H_3[1][1] * eta],\n",
    "     [eta, 0, 1 + H_3[0][0] * eta**2, H_3[0][1] * eta**2] , [0, eta, H_3[1][0] * eta**2, 1 + H_3[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "c = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "T = 1000\n",
    "pc = np.zeros(T)\n",
    "lb = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "for t in range(0,T):\n",
    "    c = np.dot(c,S)\n",
    "    d = np.dot(d,S.T)\n",
    "    q = np.dot(c,P_0)\n",
    "    k = np.dot(q,d)\n",
    "    g_1[t] = k[0][0]\n",
    "    g_2[t] = k[2][2]\n",
    "    g_3[t] = k[1][1]\n",
    "    g_4[t] = k[3][3]\n",
    "\n",
    "for t in range(0,T):\n",
    "    c_2 = np.dot(c_2,S_2)\n",
    "    d_2 = np.dot(d_2,S_2.T)\n",
    "    q_2 = np.dot(c_2,P_0)\n",
    "    k_2 = np.dot(q_2,d_2)\n",
    "    g_5[t] = k_2[0][0]\n",
    "    g_6[t] = k_2[2][2]\n",
    "    g_7[t] = k_2[1][1]\n",
    "    g_8[t] = k_2[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    c_3 = np.dot(c_3,S_3)\n",
    "    d_3 = np.dot(d_3,S_3.T)\n",
    "    q_3 = np.dot(c_3,P_0)\n",
    "    k_3 = np.dot(q_3,d_3)\n",
    "    g_9[t] = k_3[0][0]\n",
    "    g_10[t] = k_3[2][2]\n",
    "    g_11[t] = k_3[1][1]\n",
    "    g_12[t] = k_3[3][3]\n",
    "    \n",
    "    \n",
    "plt.plot(g_2)\n",
    "plt.plot(g_6,c = \"darkorange\")\n",
    "plt.plot(g_10,c = \"maroon\")\n",
    "\n",
    "plt.legend([\"B_1\",\"B_2\",\"B_3\"])\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1f3b8382",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "#symplectic, degenate, y_11\n",
    "\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "eta = 0.01\n",
    "\n",
    "\n",
    "\n",
    "A = np.array([[1,-1],[-1,1]])\n",
    "H = -1 * np.dot(A,A.T)\n",
    "S = np.array([[1,0, H[0][0] * eta, H[0][1] * eta], [0,1, H[1][0] * eta, H[1][1] * eta],\n",
    "     [eta, 0, 1 + H[0][0] * eta**2, H[0][1] * eta**2] , [0, eta, H[1][0] * eta**2, 1 + H[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_2 = np.array([[1,-1.2],[-1,1.2]])\n",
    "H_2 = -1 * np.dot(A_2,A_2.T)\n",
    "S_2 = np.array([[1,0, H_2[0][0] * eta, H_2[0][1] * eta], [0,1, H_2[1][0] * eta, H_2[1][1] * eta],\n",
    "     [eta, 0, 1 + H_2[0][0] * eta**2, H_2[0][1] * eta**2] , [0, eta, H_2[1][0] * eta**2, 1 + H_2[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "A_3 = np.array([[1,-1.3],[-1,1.3]])\n",
    "H_3 = -1 * np.dot(A_3,A_3.T)\n",
    "S_3 = np.array([[1,0, H_3[0][0] * eta, H_3[0][1] * eta], [0,1, H_3[1][0] * eta, H_3[1][1] * eta],\n",
    "     [eta, 0, 1 + H_3[0][0] * eta**2, H_3[0][1] * eta**2] , [0, eta, H_3[1][0] * eta**2, 1 + H_3[1][1] * eta**2]  ])\n",
    "\n",
    "\n",
    "\n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "c = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "T = 1000\n",
    "pc = np.zeros(T)\n",
    "lb = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "for t in range(0,T):\n",
    "    c = np.dot(c,S)\n",
    "    d = np.dot(d,S.T)\n",
    "    q = np.dot(c,P_0)\n",
    "    k = np.dot(q,d)\n",
    "    g_1[t] = k[0][0]\n",
    "    g_2[t] = k[2][2]\n",
    "    g_3[t] = k[1][1]\n",
    "    g_4[t] = k[3][3]\n",
    "\n",
    "for t in range(0,T):\n",
    "    c_2 = np.dot(c_2,S_2)\n",
    "    d_2 = np.dot(d_2,S_2.T)\n",
    "    q_2 = np.dot(c_2,P_0)\n",
    "    k_2 = np.dot(q_2,d_2)\n",
    "    g_5[t] = k_2[0][0]\n",
    "    g_6[t] = k_2[2][2]\n",
    "    g_7[t] = k_2[1][1]\n",
    "    g_8[t] = k_2[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    c_3 = np.dot(c_3,S_3)\n",
    "    d_3 = np.dot(d_3,S_3.T)\n",
    "    q_3 = np.dot(c_3,P_0)\n",
    "    k_3 = np.dot(q_3,d_3)\n",
    "    g_9[t] = k_3[0][0]\n",
    "    g_10[t] = k_3[2][2]\n",
    "    g_11[t] = k_3[1][1]\n",
    "    g_12[t] = k_3[3][3]\n",
    "    \n",
    "    \n",
    "plt.plot(g_1)\n",
    "plt.plot(g_5,c = \"darkorange\")\n",
    "plt.plot(g_9,c = \"maroon\")\n",
    "\n",
    "plt.legend([\"B_1\",\"B_2\",\"B_3\"])\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "7e28628a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using matplotlib backend: MacOSX\n"
     ]
    }
   ],
   "source": [
    "# standard normal distribution，Euler GDA,nondegenate A\n",
    "\n",
    "from scipy.linalg import expm, sinm, cosm\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "%matplotlib auto\n",
    "plt.style.use('seaborn-white')\n",
    "%config InlineBackend.figure_format = 'svg'\n",
    "\n",
    "\n",
    "eta = 0.01 \n",
    "\n",
    "\n",
    "A = np.array([[1,1.31],[-1,1.31]])\n",
    "H = -1 * np.dot(A,A.T)\n",
    "S = np.array([[1,0,  H[0][0] * eta, H[0][1] * eta], [0,1, H[1][0] * eta, H[1][1] * eta],\n",
    "     [eta, 0, 1 , 0] , [0, eta, 0, 1 ]  ])\n",
    "\n",
    "\n",
    "A_2 = np.array([[2,-1.7],[-1.7,1.5]])\n",
    "H_2 = -1 * np.dot(A_2,A_2.T)\n",
    "S_2 = np.array([[1,0, H_2[0][0] * eta, H_2[0][1] * eta], [0,1, H_2[1][0] * eta, H_2[1][1] * eta],\n",
    "     [eta, 0, 1 , 0] , [0, eta, 0, 1 ]  ])\n",
    "\n",
    "A_3 = np.array([[1,-1.3],[-1,1.3]])\n",
    "H_3 = -1 * np.dot(A_3,A_3.T)\n",
    "S_3 = np.array([[1,0,  H_3[0][0] * eta,  H_3[0][1] * eta], [0,1, H_3[1][0] * eta, H_3[1][1] * eta],\n",
    "     [eta, 0, 1 , 0] , [0, eta, 0, 1 ]  ])\n",
    "\n",
    "\n",
    "c = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_2 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "c_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "d_3 = np.array([[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]])\n",
    "\n",
    "\n",
    "\n",
    "T = 4000\n",
    "pc = np.zeros(T)\n",
    "lb = np.zeros(T)\n",
    "g_1 = np.zeros(T)\n",
    "g_2 = np.zeros(T)\n",
    "g_3 = np.zeros(T)\n",
    "g_4 = np.zeros(T)\n",
    "g_5 = np.zeros(T)\n",
    "g_6 = np.zeros(T)\n",
    "g_7 = np.zeros(T)\n",
    "g_8 = np.zeros(T)\n",
    "g_9 = np.zeros(T)\n",
    "g_10 = np.zeros(T)\n",
    "g_11 = np.zeros(T)\n",
    "g_12 = np.zeros(T)\n",
    "\n",
    "#P_0 = np.array([[5, 2, 1,3], [2,5,7,9],[1,7,9,6],[3,9,6,10]]) \n",
    "P_0 = np.array([ [8,2,1,3],[2,13,7,9],[1,7,9,2],[3,9,2,10] ] ) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "for t in range(0,T):\n",
    "    c = np.dot(c,S)\n",
    "    d = np.dot(d,S.T)\n",
    "    q = np.dot(c,P_0)\n",
    "    k = np.dot(q,d)\n",
    "    g_1[t] = k[0][0]\n",
    "    g_2[t] = k[2][2]\n",
    "    g_3[t] = k[1][1]\n",
    "    g_4[t] = k[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    c_2 = np.dot(c_2,S_2)\n",
    "    d_2 = np.dot(d_2,S_2.T)\n",
    "    q_2 = np.dot(c_2,P_0)\n",
    "    k_2 = np.dot(q_2,d_2)\n",
    "    g_5[t] = k_2[0][0]\n",
    "    g_6[t] = k_2[2][2]\n",
    "    g_7[t] = k_2[1][1]\n",
    "    g_8[t] = k_2[3][3]\n",
    "    \n",
    "for t in range(0,T):\n",
    "    c_3 = np.dot(c_3,S_3)\n",
    "    d_3 = np.dot(d_3,S_3.T)\n",
    "    q_3 = np.dot(c_3,P_0)\n",
    "    k_3 = np.dot(q_3,d_3)\n",
    "    g_9[t] = k_3[0][0]\n",
    "    g_10[t] = k_3[2][2]\n",
    "    g_11[t] = k_3[1][1]\n",
    "    g_12[t] = k_3[3][3]\n",
    "\n",
    "plt.plot(g_1)\n",
    "plt.plot(g_2)\n",
    "#plt.plot(g_9)\n",
    "\n",
    "plt.legend([\"Cov(X_1,1)\",\"Cov(y_1,1)\"])\n",
    "plt.show()\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "83581313",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(g_5)\n",
    "plt.plot(g_6)\n",
    "#plt.plot(g_9)\n",
    "\n",
    "plt.legend([\"Cov(X_1,1)\",\"Cov(y_1,1)\"])\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b2a6053",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tensorflow",
   "language": "python",
   "name": "tensorflow"
  },
  "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
