{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from Network_bayesian import Place_net, Grid_net, Coupled_Net\n",
    "import brainpy as bp\n",
    "import brainpy.math as bm\n",
    "from matplotlib.animation import FuncAnimation\n",
    "import time\n",
    "# from scipy.stats import ttest_ind, norm\n",
    "# from Decoding_method import GOP_decoding, Net_decoding\n",
    "\n",
    "# 圆周距离函数\n",
    "def circ_dis(phi_1, phi_2):\n",
    "    dis = phi_1 - phi_2\n",
    "    dis = np.where(dis > np.pi, dis - 2 * np.pi, dis)\n",
    "    dis = np.where(dis < -np.pi, dis + 2 * np.pi, dis)\n",
    "    return dis\n",
    "\n",
    "# 默认参数\n",
    "# grid spacing\n",
    "lambda_1 = 3\n",
    "lambda_2 = 4\n",
    "lambda_3 = 5\n",
    "Lambda = np.array([lambda_1, lambda_2, lambda_3])\n",
    "L = lambda_1 * lambda_2 * lambda_3\n",
    "# cell number\n",
    "num_p = int(200)\n",
    "rho_p = num_p / L\n",
    "rho_g = rho_p\n",
    "num_g = int(rho_g * 2 * np.pi)  # 为了让两个网络的rho相等\n",
    "M = len(Lambda)\n",
    "# feature space\n",
    "x = np.linspace(0, L, num_p, endpoint=False)\n",
    "theta = np.linspace(0, 2 * np.pi, num_g, endpoint=False)\n",
    "# connection range\n",
    "a_p = 0.3\n",
    "a_g = a_p / Lambda * 2 * np.pi\n",
    "# connection strength\n",
    "J_p = 20\n",
    "J_g = J_p\n",
    "J_pg = J_p / 25\n",
    "\n",
    "\n",
    "# divisive normalization\n",
    "k_p = 20.\n",
    "k_g = Lambda / 2 / np.pi * k_p\n",
    "# time constants\n",
    "tau_p = 1\n",
    "tau_g = 2 * np.pi * tau_p / Lambda\n",
    "# input_strength\n",
    "alpha_p = 0.05\n",
    "alpha_g = 0.05\n",
    "\n",
    "noise_ratio = 0.007\n",
    "\n",
    "P_CANN = Place_net(z_min=0, z_max=L, num=num_p, a_p=a_p, k=k_p, tau=tau_p, J0=J_p)\n",
    "# Grid cells\n",
    "G_CANNs = bm.NodeList()\n",
    "for i in range(M):\n",
    "    G_CANNs.append(Grid_net(z_min=0, z_max=L, num=num_g, num_hpc=num_p, L=Lambda[i], a_g=a_g[i], k_mec=k_g[i], tau=tau_g[i], J0=J_g, W0=J_pg))\n",
    "\n",
    "Coupled_model = Coupled_Net(HPC_model=P_CANN, MEC_model_list=G_CANNs, num_module=M)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Noise 1/10, Progress: 0.00%\n",
      "Noise 1/10, Progress: 12.50%\n",
      "Noise 1/10, Progress: 25.00%\n",
      "Noise 1/10, Progress: 37.50%\n",
      "Noise 1/10, Progress: 50.00%\n",
      "Noise 1/10, Progress: 62.50%\n",
      "Noise 1/10, Progress: 75.00%\n",
      "Noise 1/10, Progress: 87.50%\n",
      "Noise 2/10, Progress: 0.00%\n",
      "Noise 2/10, Progress: 12.50%\n",
      "Noise 2/10, Progress: 25.00%\n",
      "Noise 2/10, Progress: 37.50%\n",
      "Noise 2/10, Progress: 50.00%\n",
      "Noise 2/10, Progress: 62.50%\n",
      "Noise 2/10, Progress: 75.00%\n",
      "Noise 2/10, Progress: 87.50%\n",
      "Noise 3/10, Progress: 0.00%\n",
      "Noise 3/10, Progress: 12.50%\n",
      "Noise 3/10, Progress: 25.00%\n",
      "Noise 3/10, Progress: 37.50%\n",
      "Noise 3/10, Progress: 50.00%\n",
      "Noise 3/10, Progress: 62.50%\n",
      "Noise 3/10, Progress: 75.00%\n",
      "Noise 3/10, Progress: 87.50%\n",
      "Noise 4/10, Progress: 0.00%\n",
      "Noise 4/10, Progress: 12.50%\n",
      "Noise 4/10, Progress: 25.00%\n",
      "Noise 4/10, Progress: 37.50%\n",
      "Noise 4/10, Progress: 50.00%\n",
      "Noise 4/10, Progress: 62.50%\n",
      "Noise 4/10, Progress: 75.00%\n",
      "Noise 4/10, Progress: 87.50%\n",
      "Noise 5/10, Progress: 0.00%\n",
      "Noise 5/10, Progress: 12.50%\n",
      "Noise 5/10, Progress: 25.00%\n",
      "Noise 5/10, Progress: 37.50%\n",
      "Noise 5/10, Progress: 50.00%\n",
      "Noise 5/10, Progress: 62.50%\n",
      "Noise 5/10, Progress: 75.00%\n",
      "Noise 5/10, Progress: 87.50%\n",
      "Noise 6/10, Progress: 0.00%\n",
      "Noise 6/10, Progress: 12.50%\n",
      "Noise 6/10, Progress: 25.00%\n",
      "Noise 6/10, Progress: 37.50%\n",
      "Noise 6/10, Progress: 50.00%\n",
      "Noise 6/10, Progress: 62.50%\n",
      "Noise 6/10, Progress: 75.00%\n",
      "Noise 6/10, Progress: 87.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-09-17 02:21:19.970014: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m45.348469s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 03:29:19.645771: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m44.276231s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 03:46:04.772585: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m45.242564s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 03:57:15.173662: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m50.120593s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Noise 7/10, Progress: 0.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-09-17 04:38:02.433518: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m44.425983s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 04:54:48.275421: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m44.185562s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 06:13:05.658430: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m45.681826s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Noise 7/10, Progress: 12.50%\n",
      "Noise 7/10, Progress: 25.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-09-17 07:30:43.187415: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m49.088878s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 07:36:17.749321: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 4m48.110014s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n",
      "2024-09-17 08:14:05.069805: E external/xla/xla/service/slow_operation_alarm.cc:133] The operation took 36m58.71869s\n",
      "\n",
      "********************************\n",
      "[Compiling module jit_scan] Very slow compile? If you want to file a bug, run with envvar XLA_FLAGS=--xla_dump_to=/tmp/foo and attach the results.\n",
      "********************************\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Noise 7/10, Progress: 37.50%\n",
      "Noise 7/10, Progress: 50.00%\n",
      "Noise 7/10, Progress: 62.50%\n",
      "Noise 7/10, Progress: 75.00%\n",
      "Noise 7/10, Progress: 87.50%\n",
      "Noise 8/10, Progress: 0.00%\n",
      "Noise 8/10, Progress: 12.50%\n",
      "Noise 8/10, Progress: 25.00%\n",
      "Noise 8/10, Progress: 37.50%\n",
      "Noise 8/10, Progress: 50.00%\n",
      "Noise 8/10, Progress: 62.50%\n",
      "Noise 8/10, Progress: 75.00%\n",
      "Noise 8/10, Progress: 87.50%\n",
      "Noise 9/10, Progress: 0.00%\n",
      "Noise 9/10, Progress: 12.50%\n",
      "Noise 9/10, Progress: 25.00%\n",
      "Noise 9/10, Progress: 37.50%\n",
      "Noise 9/10, Progress: 50.00%\n",
      "Noise 9/10, Progress: 62.50%\n",
      "Noise 9/10, Progress: 75.00%\n",
      "Noise 9/10, Progress: 87.50%\n",
      "Noise 10/10, Progress: 0.00%\n",
      "Noise 10/10, Progress: 12.50%\n",
      "Noise 10/10, Progress: 25.00%\n",
      "Noise 10/10, Progress: 37.50%\n",
      "Noise 10/10, Progress: 50.00%\n",
      "Noise 10/10, Progress: 62.50%\n",
      "Noise 10/10, Progress: 75.00%\n",
      "Noise 10/10, Progress: 87.50%\n",
      "Total runtime: 38524.99 seconds\n"
     ]
    }
   ],
   "source": [
    "\n",
    "def GOP_decoding(z_t, phi_t, Ip, Ig, alpha_p_infer, alpha_g_infer, Ag, Ap, Rp, total_itenoise_rations=5000):\n",
    "    sigma_g = np.sqrt(np.sqrt(np.pi) * Ag ** 3 * rho_g * tau_g / (a_g * alpha_g_infer))\n",
    "    sigma_phi = np.sqrt(8 * np.pi * Ag * tau_g / (Lambda * J_pg * rho_p * Rp))\n",
    "    sigma_p = np.sqrt(np.sqrt(np.pi) * Ap ** 3 * rho_p * tau_p / (a_p * alpha_p_infer))\n",
    "    sigma_g_infer = sigma_g * noise_ratio\n",
    "    sigma_phi_infer = sigma_phi * noise_ratio\n",
    "    sigma_p_infer = sigma_p * noise_ratio\n",
    "    eta = 20. * 1e-6\n",
    "    z_ts = []\n",
    "    phi_ts = []\n",
    "    z_ts.append(z_t)\n",
    "    phi_ts.append(phi_t)\n",
    "    z_encode_space = np.linspace(0, L, num_p, endpoint=False)\n",
    "\n",
    "    for itenoise_ration in range(total_itenoise_rations):\n",
    "        fg_prime = np.zeros((M, num_g))\n",
    "        for i in range(M):\n",
    "            dis_theta = circ_dis(theta, phi_t[i])\n",
    "            fg_prime[i, :] = dis_theta / (2 * a_g[i] ** 2) * np.exp(-dis_theta ** 2 / (4 * a_g[i] ** 2))\n",
    "\n",
    "        dis_z = z_encode_space - z_t\n",
    "        fp_prime = dis_z / (2 * a_p ** 2) * np.exp(-dis_z ** 2 / (4 * a_p ** 2))\n",
    "        \n",
    "        Ig_fgprime_prod = Ig * fg_prime\n",
    "        Ig_fgprime_prod = np.sum(Ig_fgprime_prod, axis=1)\n",
    "        dphi_fr = Ig_fgprime_prod / sigma_g_infer ** 2\n",
    "\n",
    "        Ip_fp_prime_prod = Ip * fp_prime\n",
    "        Ip_fp_prime_prod = np.sum(Ip_fp_prime_prod)\n",
    "        dr_fr = Ip_fp_prime_prod / sigma_p_infer ** 2\n",
    "\n",
    "        phi_z = np.mod(z_t / Lambda, 1) * 2 * np.pi\n",
    "        dis_phi = circ_dis(phi_z, phi_t)\n",
    "        dphi_tr = 1 / sigma_phi_infer ** 2 * dis_phi\n",
    "        dr_tr = np.sum(-2 * np.pi / (Lambda * sigma_phi_infer ** 2) * dis_phi)\n",
    "\n",
    "        dphi = dphi_fr + dphi_tr\n",
    "        phi_t = phi_t + eta * dphi\n",
    "        \n",
    "        phi_t = np.mod(phi_t, 2 * np.pi)\n",
    "        \n",
    "        dr = dr_fr + dr_tr\n",
    "        z_t = z_t + eta * dr\n",
    "\n",
    "        z_ts.append(z_t)\n",
    "        phi_ts.append(phi_t)\n",
    "    return np.array(z_ts), np.array(phi_ts)\n",
    "\n",
    "def Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0.05, alpha_g=0.05, Coupled_model=Coupled_model):\n",
    "    Coupled_model.reset_state()\n",
    "    def initial_net(Ip, Ig): \n",
    "        Coupled_model.initial(alpha_p=1, alpha_g=1, Ip=Ip, Ig=Ig)\n",
    "\n",
    "    def run_net(i, Ip, Ig): \n",
    "        Coupled_model.step_run(i, alpha_p=1, alpha_g=1, Ip=Ip, Ig=Ig)\n",
    "        phi_decode = Coupled_model.phase\n",
    "        z_decode = Coupled_model.HPC_model.center\n",
    "        rp = Coupled_model.HPC_model.r\n",
    "        up = Coupled_model.HPC_model.u\n",
    "        rg = bm.zeros([M, num_g])\n",
    "        ug = bm.zeros([M, num_g])\n",
    "        for mi in range(M):\n",
    "            rg[mi, :] = Coupled_model.MEC_model_list[mi].r\n",
    "            ug[mi, :] = Coupled_model.MEC_model_list[mi].u\n",
    "        return z_decode, phi_decode, rp, up, rg, ug\n",
    "\n",
    "    T_init = 500\n",
    "    z0 = z_truth\n",
    "    phi_0 = phi_truth\n",
    "    fg = np.zeros((M, num_g))\n",
    "    for i in range(M):\n",
    "        dis_theta = circ_dis(theta, phi_0[i])\n",
    "        fg[i, :] = np.exp(-dis_theta ** 2 / (4 * a_g[i] ** 2))\n",
    "    dis_x = x - z0\n",
    "    fp = np.exp(-dis_x ** 2 / (4 * a_p ** 2))\n",
    "    I_place = 1 * np.repeat(fp[np.newaxis, :], T_init, axis=0)\n",
    "    I_grid = 1 * np.repeat(fg[np.newaxis, :, :], T_init, axis=0)\n",
    "    I_place[int(T_init / 3):, :] = 0\n",
    "    I_grid[int(T_init / 3):, :, :] = 0\n",
    "\n",
    "    bm.for_loop(initial_net, (I_place, I_grid), progress_bar=False)\n",
    "    T = 5000\n",
    "    indices = np.arange(T)\n",
    "    I_place = alpha_p * np.repeat(Ip[np.newaxis, :], T, axis=0)\n",
    "    I_grid = alpha_g * np.repeat(Ig[np.newaxis, :, :], T, axis=0)\n",
    "    z_record, phi_record, rp, up, rg, ug = bm.for_loop(run_net, (indices, I_place, I_grid), progress_bar=False)\n",
    "\n",
    "    return z_record, phi_record, up, rp, ug, rg\n",
    "\n",
    "\n",
    "start_time = time.time()  # 记录开始时间\n",
    "n_stre = 10\n",
    "trial_num = 200\n",
    "noise_stre = np.linspace(0.05, 0.2, n_stre)\n",
    "std_integrate_net = np.zeros(n_stre)\n",
    "std_motion_net = np.zeros(n_stre)\n",
    "std_visual_net = np.zeros(n_stre)\n",
    "std_integrate_gop = np.zeros(n_stre)\n",
    "std_bayes = np.zeros(n_stre)\n",
    "\n",
    "z_truth = 30\n",
    "phi_truth = np.mod(z_truth / Lambda, 1) * 2 * np.pi \n",
    "\n",
    "for noise_n in range(n_stre):\n",
    "    # 主程序\n",
    "    neural_noise_sigma = noise_stre[noise_n]\n",
    "    sigma_phi = np.array([31.7,23.8,19])*neural_noise_sigma/25\n",
    "    \n",
    "    z_decode_gop = np.zeros(trial_num)\n",
    "    z_decode_net = np.zeros(trial_num)\n",
    "    z_decode_net_motion = np.zeros(trial_num)\n",
    "    z_decode_net_visual = np.zeros(trial_num)\n",
    "\n",
    "    for i in range(trial_num):\n",
    "        z_e = z_truth\n",
    "        psi = phi_truth + sigma_phi * np.random.randn(M)\n",
    "        Ig = np.zeros((M, num_g))\n",
    "        for j in range(M):\n",
    "            dis_theta = circ_dis(theta, psi[j])\n",
    "            Ig[j, :] = np.exp(-dis_theta ** 2 / (4 * a_g[j] ** 2)) + neural_noise_sigma * np.random.randn(num_g)\n",
    "        dis_x = x - z_e\n",
    "        Ip = np.exp(-dis_x ** 2 / (4 * a_p ** 2)) + neural_noise_sigma * np.random.randn(num_p) \n",
    "        z_decode_int, _, up, rp, ug, rg = Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0.05, alpha_g=0.05)\n",
    "\n",
    "        max_up = np.max(up, axis=1)\n",
    "        max_rp = np.max(rp, axis=1)\n",
    "        Ap = np.max(max_up[-1])\n",
    "        Rp = np.max(max_rp[-1])\n",
    "        Ag = np.zeros(M,)\n",
    "        Rg = np.zeros(M,)\n",
    "        for mi in range(M):\n",
    "            max_ug = np.max(ug[:, mi, :], axis=1)\n",
    "            max_rg = np.max(rg[:, mi, :], axis=1)\n",
    "            Ag[mi] = np.max(max_ug[-1])\n",
    "            Rg[mi] = np.max(max_rg[-1])\n",
    "        z_decode_g, _ = GOP_decoding(z_t=z_truth, phi_t=phi_truth, Ip=Ip, Ig=Ig, alpha_p_infer=0.05, alpha_g_infer=0.05, Ap=Ap, Rp=Rp, Ag=Ag)\n",
    "        z_decode_mot, _, _, _, _, _ = Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0., alpha_g=0.05)\n",
    "        z_decode_vis, _, _, _, _, _ = Net_decoding(z_truth, phi_truth, Ip, Ig, alpha_p=0.05, alpha_g=0.)\n",
    "\n",
    "        z_decode_gop[i] = z_decode_g[-1]\n",
    "        z_decode_net[i] = z_decode_int[-1].item()\n",
    "        z_decode_net_motion[i] = z_decode_mot[-1].item()\n",
    "        z_decode_net_visual[i] = z_decode_vis[-1].item()\n",
    "        \n",
    "        if i % 25 == 0:\n",
    "            print(f\"Noise {noise_n + 1}/{n_stre}, Progress: {i/trial_num*100:.2f}%\")\n",
    "    \n",
    "    error_int_net = z_decode_net-z_truth\n",
    "    error_mot_net = z_decode_net_motion-z_truth\n",
    "    error_vis_net = z_decode_net_visual-z_truth\n",
    "    error_int_gop = z_decode_gop-z_truth\n",
    "    # mean_integrate_net[noise_n] = np.mean(error_int_net)\n",
    "    # mean_motion_net[noise_n] = np.mean(error_mot_net)\n",
    "    # mean_visual_net[noise_n] = np.mean(error_vis_net)\n",
    "    # mean_integrate_gop[noise_n] = np.mean(error_int_gop)\n",
    "\n",
    "    std_integrate_net[noise_n] = np.std(error_int_net)\n",
    "    sigma_1 = np.std(error_mot_net)\n",
    "    sigma_2 = np.std(error_vis_net)\n",
    "    std_motion_net[noise_n] = sigma_1\n",
    "    std_visual_net[noise_n] = sigma_2\n",
    "    std_integrate_gop[noise_n] = np.std(error_int_gop)\n",
    "    sigma_3 = np.sqrt(1/(1/sigma_1**2 + 1/sigma_2**2))\n",
    "    std_bayes[noise_n] = sigma_3\n",
    "    \n",
    "\n",
    "end_time = time.time()  # 记录结束时间\n",
    "print(f\"Total runtime: {end_time - start_time:.2f} seconds\")\n",
    "\n",
    "# 保存数据为npz文件\n",
    "np.savez('results.npz', \n",
    "         std_integrate_net=std_integrate_net,\n",
    "         std_motion_net=std_motion_net,\n",
    "         std_visual_net=std_visual_net,\n",
    "         std_integrate_gop=std_integrate_gop,\n",
    "         std_bayes = std_bayes)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plt' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mplt\u001b[49m\u001b[38;5;241m.\u001b[39mfigure()\n\u001b[1;32m      3\u001b[0m \u001b[38;5;66;03m# plt.errorbar(noise_stre, mean_motion_net, yerr=std_motion_net, fmt='-o',label='only motion')\u001b[39;00m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;66;03m# plt.errorbar(noise_stre, mean_visual_net, yerr=std_visual_net, fmt='-o',label='only visual')\u001b[39;00m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;66;03m# plt.errorbar(noise_stre, mean_integrate_net, yerr=std_integrate_net, fmt='-o',label='net integration')\u001b[39;00m\n\u001b[1;32m      6\u001b[0m \u001b[38;5;66;03m# plt.errorbar(noise_stre, mean_integrate_gop, yerr=std_integrate_gop, fmt='-o',label='Bayeian integration')\u001b[39;00m\n\u001b[1;32m      7\u001b[0m plt\u001b[38;5;241m.\u001b[39mplot(noise_stre,std_motion_net,label\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMot.\u001b[39m\u001b[38;5;124m'\u001b[39m,color\u001b[38;5;241m=\u001b[39m[\u001b[38;5;241m0.\u001b[39m,\u001b[38;5;241m0.5\u001b[39m,\u001b[38;5;241m1\u001b[39m],linewidth\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m3\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plt' is not defined"
     ]
    }
   ],
   "source": [
    "\n",
    "# 保存数据为npz文件\n",
    "np.savez('results.npz', \n",
    "         std_integrate_net=std_integrate_net,\n",
    "         std_motion_net=std_motion_net,\n",
    "         std_visual_net=std_visual_net,\n",
    "         std_integrate_gop=std_integrate_gop,\n",
    "         std_bayes = std_bayes)\n",
    "\n",
    "plt.figure()\n",
    "\n",
    "# plt.errorbar(noise_stre, mean_motion_net, yerr=std_motion_net, fmt='-o',label='only motion')\n",
    "# plt.errorbar(noise_stre, mean_visual_net, yerr=std_visual_net, fmt='-o',label='only visual')\n",
    "# plt.errorbar(noise_stre, mean_integrate_net, yerr=std_integrate_net, fmt='-o',label='net integration')\n",
    "# plt.errorbar(noise_stre, mean_integrate_gop, yerr=std_integrate_gop, fmt='-o',label='Bayeian integration')\n",
    "plt.plot(noise_stre,std_motion_net,label='Mot.',color=[0.,0.5,1],linewidth=3)\n",
    "plt.plot(noise_stre,std_visual_net,label='Env.',color=[1,0,0.1],linewidth=3)\n",
    "plt.plot(noise_stre,std_integrate_net,label='Both',color=[0,0.5,0.5],linewidth=3)\n",
    "plt.plot(noise_stre,std_bayes,label='Bayes',color=[0.2,0.8,1],linewidth=3)\n",
    "plt.xlabel('Noise level')\n",
    "plt.ylabel('Decoding error')\n",
    "plt.legend()\n",
    "\n",
    "\n",
    "# plt.errorbar(noise_stre, mean_motion_net, yerr=std_motion_net, fmt='-o')\n",
    "# plt.errorbar(noise_stre, mean_visual_net, yerr=std_visual_net, fmt='-o')\n",
    "# plt.errorbar(noise_stre, mean_integrate_net, yerr=std_integrate_net, fmt='-o')\n",
    "# plt.errorbar(noise_stre, mean_integrate_gop-30, yerr=std_integrate_gop, fmt='-o')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('standard_deviation.png')\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "plt.figure()\n",
    "plt.plot(noise_stre,std_integrate_net,label='net integration')\n",
    "plt.plot(noise_stre,std_integrate_gop,label='GOP')\n",
    "plt.plot(noise_stre,std_bayes,label='Bayeian integration')\n",
    "plt.xlabel('Noise level')\n",
    "plt.ylabel('Decoding error')\n",
    "plt.legend()\n",
    "\n",
    "\n",
    "# plt.errorbar(noise_stre, mean_motion_net, yerr=std_motion_net, fmt='-o')\n",
    "# plt.errorbar(noise_stre, mean_visual_net, yerr=std_visual_net, fmt='-o')\n",
    "# plt.errorbar(noise_stre, mean_integrate_net, yerr=std_integrate_net, fmt='-o')\n",
    "# plt.errorbar(noise_stre, mean_integrate_gop-30, yerr=std_integrate_gop, fmt='-o')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('compare.png')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
