{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/chutianhao/opt/anaconda3/envs/bp311/lib/python3.11/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import brainstate as bst\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from Brain_state import Coupled_Net, GOP_decoding, circ_dis\n",
    "bst.environ.set(dt=0.2, platform='cpu')  # length of time step\n",
    "import time\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# 开始计时\n",
    "start_time = time.time()\n",
    "\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",
    "\n",
    "# input_strength\n",
    "alpha_p = 0.05\n",
    "alpha_g = 0.05\n",
    "noise_ratio = 0.007\n",
    "neural_noise_sigma = 0.2\n",
    "trial_num = 500\n",
    "z_truth = 30\n",
    "phi_truth = np.mod(z_truth / Lambda, 1) * 2 * np.pi\n",
    "sigma_phi = np.array([31.7,23.8,19])*neural_noise_sigma/20\n",
    "\n",
    "\n",
    "@jax.jit\n",
    "@bst.transform.jit\n",
    "def run_a_trial(key):\n",
    "  bst.random.DEFAULT.seed(key)\n",
    "\n",
    "  final_model = Coupled_Net(num_module=M)\n",
    "  bst.init_states(final_model)\n",
    "\n",
    "  z_truth = 30\n",
    "  phi_truth = np.mod(z_truth / Lambda, 1) * 2 * np.pi\n",
    "  z_e = z_truth\n",
    "  psi = phi_truth + sigma_phi * bst.random.randn((M))\n",
    "  Ig = jnp.zeros((M, num_g))\n",
    "  for j in range(M):\n",
    "    dis_theta = circ_dis(theta, psi[j])\n",
    "    Ig = Ig.at[j].set(jnp.exp(-dis_theta ** 2 / (4 * a_g[j] ** 2)) + neural_noise_sigma * bst.random.randn(num_g))\n",
    "\n",
    "  x = np.linspace(0, L, num_p, endpoint=False)\n",
    "  dis_x = x - z_e\n",
    "  Ip = np.exp(-dis_x ** 2 / (4 * a_p ** 2)) + neural_noise_sigma * bst.random.randn(num_p)\n",
    "  z_decode_n, _, up, rp, ug, rg = final_model.Net_decoding(z_truth, phi_truth, Ip, Ig)\n",
    "\n",
    "  max_up = jnp.max(up, axis=1)\n",
    "  max_rp = jnp.max(rp, axis=1)\n",
    "  Ap = jnp.max(max_up[-1])\n",
    "  Rp = jnp.max(max_rp[-1])\n",
    "  Ag = jnp.zeros(M)\n",
    "  Rg = jnp.zeros(M, )\n",
    "  for mi in range(M):\n",
    "    max_ug = jnp.max(ug[:, mi, :], axis=1)\n",
    "    max_rg = jnp.max(rg[:, mi, :], axis=1)\n",
    "    Ag = Ag.at[mi].set(jnp.max(max_ug[-1]))\n",
    "    Rg = Rg.at[mi].set(jnp.max(max_rg[-1]))\n",
    "  z_decode_g = GOP_decoding(z_t=z_truth, phi_t=phi_truth, Ip=Ip, Ig=Ig,\n",
    "                            alpha_p_infer=0.05, alpha_g_infer=0.05,\n",
    "                            Ap=Ap, Rp=Rp, Ag=Ag)\n",
    "\n",
    "  return z_decode_g, z_decode_n[-1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Elapsed time: 29.40383005142212 seconds\n"
     ]
    }
   ],
   "source": [
    "\n",
    "key = jax.random.PRNGKey(1)\n",
    "z_decode_gop, z_decode_net = jax.vmap(run_a_trial)(jax.random.split(key, trial_num))\n",
    "z_decode_all = np.concatenate([z_decode_gop, z_decode_net])\n",
    "\n",
    "end_time = time.time()\n",
    "\n",
    "# 计算运行时间\n",
    "elapsed_time = end_time - start_time\n",
    "print(f\"Elapsed time: {elapsed_time} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# 设置字体\n",
    "plt.rcParams.update({'font.size': 12, 'font.family': 'Arial'})\n",
    "\n",
    "# 画图\n",
    "plt.figure(figsize=(4, 4))\n",
    "z_decode_all = np.concatenate([z_decode_gop, z_decode_net])\n",
    "min_z = np.min(z_decode_all)\n",
    "max_z = np.max(z_decode_all)\n",
    "\n",
    "plt.plot(z_decode_net, z_decode_gop, '.', color='gray')\n",
    "plt.plot([min_z, max_z], [min_z, max_z], 'k--')\n",
    "plt.xlabel('Network decoded results')\n",
    "plt.ylabel('GOP decoded results')\n",
    "plt.axis('equal')  # 设置坐标轴比例相等\n",
    "plt.tight_layout()\n",
    "plt.savefig('net_gop_comparison.png')\n",
    "plt.show()"
   ]
  }
 ],
 "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.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
