{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "aa89eacd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import numpy.matlib\n",
    "from numpy.random import default_rng\n",
    "import seaborn as sns\n",
    "\n",
    "import pandas as pd\n",
    "import seaborn as sn\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython.display import display, clear_output\n",
    "from matplotlib import colors\n",
    "from matplotlib.collections import LineCollection\n",
    "from matplotlib.colors import ListedColormap, LinearSegmentedColormap\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ec81425b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def netparam():\n",
    "    tau = 1\n",
    "    xmax = 180\n",
    "    xmin = -180\n",
    "    xrange = xmax - xmin\n",
    "    a = 40\n",
    "    N = 180\n",
    "    T = 100\n",
    "    dt = 0.01\n",
    "    F = 0.5\n",
    "    k = 0.0005\n",
    "    gain = 10\n",
    "    \n",
    "    #density\n",
    "    rho = N/(xrange)\n",
    "    kmax = 1/(12*rho)\n",
    "    Wc = np.sqrt(8*np.sqrt(2*np.pi)*k*a/rho)\n",
    "    Wee = 0.5*Wc\n",
    "    Wie = 0.5*Wc\n",
    "    Ufd = Wc / (2 * (np.sqrt(np.pi)) * k * a)\n",
    "    l = 0.8*Ufd\n",
    "\n",
    "    PrefStim = np.linspace(xmin, xmax,N+1)\n",
    "    PrefStim = PrefStim[1:N+1]\n",
    "\n",
    "    return {'max glob inhibition':kmax, 'feedforward':l, 'density':rho,'CriticalW': Wc, 'Recurrent Weight':Wee, \n",
    "            'E to I Weight': Wie, 'Neuron':N, 'Time':T, 'dist_range':xrange, 'gaussian_width':a, 'xmin': xmin, 'xmax':xmax, \n",
    "            'FanoFactor': F,'time scale':dt, 'time constant':tau, 'Gaussian Width': a,'space':PrefStim, 'inhibitory gain': gain,'k': k}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e6cee026",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'max glob inhibition': 0.16666666666666666,\n",
       " 'feedforward': 10.105900443937035,\n",
       " 'density': 0.5,\n",
       " 'CriticalW': 0.895612107936198,\n",
       " 'Recurrent Weight': 0.447806053968099,\n",
       " 'E to I Weight': 0.447806053968099,\n",
       " 'Neuron': 180,\n",
       " 'Time': 100,\n",
       " 'dist_range': 360,\n",
       " 'gaussian_width': 40,\n",
       " 'xmin': -180,\n",
       " 'xmax': 180,\n",
       " 'FanoFactor': 0.5,\n",
       " 'time scale': 0.01,\n",
       " 'time constant': 1,\n",
       " 'Gaussian Width': 40,\n",
       " 'space': array([-178., -176., -174., -172., -170., -168., -166., -164., -162.,\n",
       "        -160., -158., -156., -154., -152., -150., -148., -146., -144.,\n",
       "        -142., -140., -138., -136., -134., -132., -130., -128., -126.,\n",
       "        -124., -122., -120., -118., -116., -114., -112., -110., -108.,\n",
       "        -106., -104., -102., -100.,  -98.,  -96.,  -94.,  -92.,  -90.,\n",
       "         -88.,  -86.,  -84.,  -82.,  -80.,  -78.,  -76.,  -74.,  -72.,\n",
       "         -70.,  -68.,  -66.,  -64.,  -62.,  -60.,  -58.,  -56.,  -54.,\n",
       "         -52.,  -50.,  -48.,  -46.,  -44.,  -42.,  -40.,  -38.,  -36.,\n",
       "         -34.,  -32.,  -30.,  -28.,  -26.,  -24.,  -22.,  -20.,  -18.,\n",
       "         -16.,  -14.,  -12.,  -10.,   -8.,   -6.,   -4.,   -2.,    0.,\n",
       "           2.,    4.,    6.,    8.,   10.,   12.,   14.,   16.,   18.,\n",
       "          20.,   22.,   24.,   26.,   28.,   30.,   32.,   34.,   36.,\n",
       "          38.,   40.,   42.,   44.,   46.,   48.,   50.,   52.,   54.,\n",
       "          56.,   58.,   60.,   62.,   64.,   66.,   68.,   70.,   72.,\n",
       "          74.,   76.,   78.,   80.,   82.,   84.,   86.,   88.,   90.,\n",
       "          92.,   94.,   96.,   98.,  100.,  102.,  104.,  106.,  108.,\n",
       "         110.,  112.,  114.,  116.,  118.,  120.,  122.,  124.,  126.,\n",
       "         128.,  130.,  132.,  134.,  136.,  138.,  140.,  142.,  144.,\n",
       "         146.,  148.,  150.,  152.,  154.,  156.,  158.,  160.,  162.,\n",
       "         164.,  166.,  168.,  170.,  172.,  174.,  176.,  178.,  180.]),\n",
       " 'inhibitory gain': 10,\n",
       " 'k': 0.0005}"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "netparam()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4db72ec8",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Global variables:\n",
    "param_dict = netparam()\n",
    "\n",
    "rho = param_dict[\"density\"]\n",
    "F = param_dict[\"FanoFactor\"]\n",
    "xmin = param_dict[\"xmin\"]\n",
    "xmax = param_dict[\"xmax\"]\n",
    "PrefStim = param_dict['space']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "07da4663",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Conn():\n",
    "\n",
    "    param_dict = netparam()\n",
    "    N = param_dict[\"Neuron\"]\n",
    "    T = param_dict[\"Time\"]\n",
    "    a = param_dict[\"gaussian_width\"]\n",
    "    xrange = param_dict['dist_range']\n",
    "    ai = 20\n",
    "    \n",
    "    ## Connection kernel\n",
    "    W_angle = np.angle(np.exp((1j*(PrefStim-PrefStim[0])*(2*np.pi/xrange)))) * xrange/(2*np.pi)\n",
    "    W_kerFt = np.exp(-W_angle**2/(2*a**2))/(np.sqrt(2*np.pi)*a)    \n",
    "    W = np.fft.fft(W_kerFt)\n",
    "    Wki = np.exp(-W_angle**2/(2*ai**2))/(np.sqrt(2*np.pi)*ai)\n",
    "    Wi = np.fft.fft(Wki) \n",
    "    \n",
    "    return {\"We\": W, \"Wi\": Wi}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "1ee04ca3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'We': array([ 4.99996587e-01+0.00000000e+00j, -3.91867081e-01+2.71050543e-20j,\n",
       "         1.88635312e-01-4.33680869e-19j, -5.57799540e-02-1.73472348e-18j,\n",
       "         1.01274581e-02-1.63985579e-18j, -1.13230691e-03+1.50771865e-18j,\n",
       "         7.54741211e-05-1.51237733e-18j, -4.94428339e-06+7.68428290e-18j,\n",
       "        -1.36685247e-06+4.33680869e-19j, -1.25367412e-06+4.33680869e-19j,\n",
       "        -1.08549240e-06-8.67361738e-19j, -9.46011168e-07-1.21430643e-17j,\n",
       "        -8.29339224e-07-8.94015152e-18j, -7.31474670e-07+1.64929707e-18j,\n",
       "        -6.49023238e-07+1.91990605e-18j, -5.79192112e-07+3.77470036e-19j,\n",
       "        -5.19714952e-07+2.44727498e-18j, -4.68763978e-07+1.87500603e-18j,\n",
       "        -4.24867318e-07-1.63484455e-18j, -3.86838068e-07-4.05052882e-18j,\n",
       "        -3.53716095e-07+1.23740157e-18j, -3.24721416e-07+1.65926926e-18j,\n",
       "        -2.99217309e-07-4.98985786e-18j, -2.76681287e-07+1.10392132e-17j,\n",
       "        -2.56682316e-07+4.74229924e-18j, -2.38862894e-07+3.24223520e-19j,\n",
       "        -2.22924941e-07-1.36160546e-18j, -2.08618633e-07+1.15993116e-18j,\n",
       "        -1.95733544e-07+2.07683056e-18j, -1.84091569e-07+5.03482340e-19j,\n",
       "        -1.73541262e-07-3.61495316e-18j, -1.63953267e-07+7.69414354e-19j,\n",
       "        -1.55216626e-07+2.85808876e-18j, -1.47235769e-07-5.08796599e-18j,\n",
       "        -1.39928063e-07+1.73472348e-17j, -1.33221788e-07-2.20865874e-17j,\n",
       "        -1.27054476e-07+0.00000000e+00j, -1.21371530e-07+1.32675452e-17j,\n",
       "        -1.16125080e-07-6.76115845e-19j, -1.11273018e-07-1.13539126e-18j,\n",
       "        -1.06778198e-07-1.00689482e-18j, -1.02607758e-07+4.06618386e-19j,\n",
       "        -9.87325441e-08-9.48056135e-20j, -9.51266260e-08+6.61379484e-18j,\n",
       "        -9.17668838e-08-7.87992514e-19j, -8.86326537e-08+1.44501600e-18j,\n",
       "        -8.57054250e-08-4.90240212e-18j, -8.29685800e-08+5.34814263e-18j,\n",
       "        -8.04071687e-08-7.82991502e-19j, -7.80077158e-08+1.54777184e-19j,\n",
       "        -7.57580511e-08+3.38322285e-19j, -7.36471639e-08+1.14218101e-18j,\n",
       "        -7.16650752e-08-9.26990914e-19j, -6.98027264e-08-3.16804450e-19j,\n",
       "        -6.80518812e-08+3.47330933e-19j, -6.64050403e-08-4.02985264e-18j,\n",
       "        -6.48553660e-08-3.13353427e-18j, -6.33966154e-08+1.62986769e-18j,\n",
       "        -6.20230819e-08-1.22200905e-18j, -6.07295432e-08+1.43637783e-17j,\n",
       "        -5.95112151e-08-6.00928136e-18j, -5.83637107e-08-1.51588502e-18j,\n",
       "        -5.72830038e-08-7.82061730e-21j, -5.62653962e-08-5.81481691e-20j,\n",
       "        -5.53074893e-08+3.83825389e-18j, -5.44061577e-08-2.79195374e-19j,\n",
       "        -5.35585262e-08+2.19805618e-19j, -5.27619486e-08-5.73794194e-19j,\n",
       "        -5.20139898e-08+2.84651419e-18j, -5.13124084e-08-2.77138505e-18j,\n",
       "        -5.06551420e-08-7.05522787e-18j, -5.00402934e-08-9.84361530e-18j,\n",
       "        -4.94661186e-08+0.00000000e+00j, -4.89310160e-08+8.07462181e-18j,\n",
       "        -4.84335160e-08-1.91245893e-19j, -4.79722728e-08-1.65651352e-19j,\n",
       "        -4.75460559e-08+8.85109878e-20j, -4.71537433e-08+1.60335060e-18j,\n",
       "        -4.67943147e-08-5.30363735e-19j, -4.64668462e-08-4.63746634e-19j,\n",
       "        -4.61705047e-08+1.29149239e-19j, -4.59045437e-08-4.66072243e-19j,\n",
       "        -4.56682993e-08-1.02249177e-18j, -4.54611861e-08+2.09745673e-18j,\n",
       "        -4.52826948e-08+8.45625411e-18j, -4.51323890e-08+1.19344671e-17j,\n",
       "        -4.50099034e-08-3.12733749e-19j, -4.49149415e-08+4.08741201e-19j,\n",
       "        -4.48472741e-08-2.43858124e-18j, -4.48067386e-08-3.20009770e-18j,\n",
       "        -4.47932375e-08-7.04725750e-20j, -4.48067386e-08-6.32514817e-20j,\n",
       "        -4.48472741e-08+2.25654982e-18j, -4.49149415e-08+4.06165386e-18j,\n",
       "        -4.50099034e-08-2.68803961e-18j, -4.51323890e-08+7.50455365e-18j,\n",
       "        -4.52826948e-08-8.45625677e-18j, -4.54611861e-08-1.21925718e-17j,\n",
       "        -4.56682993e-08+2.62620560e-18j, -4.59045437e-08-7.74516704e-20j,\n",
       "        -4.61705047e-08-3.12382336e-19j, -4.64668462e-08+5.63867319e-19j,\n",
       "        -4.67943147e-08+1.49095813e-19j, -4.71537433e-08+1.11749302e-18j,\n",
       "        -4.75460559e-08-4.93993741e-19j, -4.79722728e-08+7.68009853e-19j,\n",
       "        -4.84335160e-08+6.24124113e-18j, -4.89310160e-08+1.69535506e-18j,\n",
       "        -4.94661186e-08+0.00000000e+00j, -5.00402934e-08-8.23969620e-18j,\n",
       "        -5.06551420e-08-1.91245893e-19j, -5.13124084e-08-1.65651352e-19j,\n",
       "        -5.20139898e-08-2.58095395e-18j, -5.27619486e-08-5.15130243e-19j,\n",
       "        -5.35585261e-08+1.52425448e-18j, -5.44061578e-08-1.34347532e-18j,\n",
       "        -5.53074893e-08-3.54136506e-18j, -5.62653962e-08+7.34101761e-19j,\n",
       "        -5.72830038e-08+2.42591254e-18j, -5.83637107e-08-2.76006214e-18j,\n",
       "        -5.95112151e-08+6.00923710e-18j, -6.07295432e-08+1.48874339e-18j,\n",
       "        -6.20230819e-08-1.51012831e-18j, -6.33966154e-08-8.09262550e-19j,\n",
       "        -6.48553660e-08+3.08708203e-18j, -6.64050403e-08-1.82837919e-18j,\n",
       "        -6.80518812e-08-1.88285047e-18j, -6.98027264e-08+3.02432964e-18j,\n",
       "        -7.16650752e-08+7.55296850e-19j, -7.36471639e-08-1.72976537e-18j,\n",
       "        -7.57580511e-08+2.71101665e-18j, -7.80077158e-08-1.58300732e-17j,\n",
       "        -8.04071687e-08+7.83055409e-19j, -8.29685800e-08-6.56405820e-20j,\n",
       "        -8.57054250e-08+6.52364510e-19j, -8.86326537e-08+1.12863126e-18j,\n",
       "        -9.17668838e-08+5.58101784e-19j, -9.51266260e-08-8.33394006e-19j,\n",
       "        -9.87325441e-08+2.49022009e-19j, -1.02607758e-07+8.80817119e-20j,\n",
       "        -1.06778198e-07+2.33548871e-19j, -1.11273018e-07+2.80729960e-18j,\n",
       "        -1.16125080e-07-1.10358989e-17j, -1.21371530e-07+1.39310936e-17j,\n",
       "        -1.27054476e-07+0.00000000e+00j, -1.33221788e-07-1.31295759e-17j,\n",
       "        -1.39928063e-07-6.76115845e-19j, -1.47235769e-07-1.13539126e-18j,\n",
       "        -1.55216626e-07-1.63707001e-18j, -1.63953267e-07+1.35966229e-18j,\n",
       "        -1.73541262e-07+1.75255151e-18j, -1.84091569e-07-1.78435933e-18j,\n",
       "        -1.95733544e-07-1.65448340e-18j, -2.08618633e-07-2.14672639e-18j,\n",
       "        -2.22924941e-07+4.36634309e-18j, -2.38862894e-07-9.88970765e-18j,\n",
       "        -2.56682316e-07-4.74234820e-18j, -2.76681287e-07-2.04138774e-19j,\n",
       "        -2.99217309e-07+6.48835895e-19j, -3.24721416e-07-8.28618602e-19j,\n",
       "        -3.53716095e-07-1.59749294e-18j, -3.86838068e-07+9.95744659e-19j,\n",
       "        -4.24867318e-07+1.43150404e-18j, -4.68763978e-07+3.23554643e-19j,\n",
       "        -5.19714952e-07-2.39573170e-18j, -5.79192112e-07-1.86523894e-18j,\n",
       "        -6.49023238e-07+6.18888987e-18j, -7.31474670e-07+6.61929144e-18j,\n",
       "        -8.29339224e-07+8.94018348e-18j, -9.46011168e-07-1.57327206e-18j,\n",
       "        -1.08549240e-06-8.24941861e-19j, -1.25367412e-06+1.89333501e-18j,\n",
       "        -1.36685247e-06+4.41677641e-20j, -4.94428339e-06-1.84244930e-18j,\n",
       "         7.54741211e-05+3.66710303e-18j, -1.13230691e-03-7.31194267e-18j,\n",
       "         1.01274581e-02+1.25687050e-18j, -5.57799540e-02+5.28255083e-19j,\n",
       "         1.88635312e-01-5.49734912e-18j, -3.91867081e-01+9.95422549e-18j]),\n",
       " 'Wi': array([ 5.00000000e-01+0.00000000e+00j, -4.70447615e-01-6.50521303e-19j,\n",
       "         3.91863734e-01+6.50521303e-19j, -2.88962448e-01-1.73472348e-18j,\n",
       "         1.88638475e-01-2.05998413e-18j, -1.09018871e-01+8.67361738e-19j,\n",
       "         5.57770601e-02-2.60208521e-18j, -2.52634171e-02+1.30104261e-18j,\n",
       "         1.01300386e-02+6.93889390e-18j, -3.59594168e-03-1.38777878e-17j,\n",
       "         1.13004754e-03+1.73472348e-18j, -3.14386091e-04-6.93889390e-18j,\n",
       "         7.74305718e-05-3.98105485e-19j, -1.68827871e-05+2.08740682e-19j,\n",
       "         3.25880486e-06+2.62714367e-18j, -5.56871641e-07+1.02839064e-18j,\n",
       "         8.42431081e-08-4.57651777e-18j, -1.12822624e-08-9.59085665e-20j,\n",
       "         1.33764398e-09-4.63920059e-18j, -1.40400089e-10+2.88270795e-18j,\n",
       "         1.30459685e-11-9.89109444e-18j, -1.07317612e-12+5.74000720e-18j,\n",
       "         7.81651736e-14+1.22988125e-17j, -5.05859342e-15+5.52456906e-18j,\n",
       "         3.02970133e-16+1.05540305e-18j, -2.56142763e-17-1.21972744e-19j,\n",
       "        -2.71050543e-18-4.52251224e-18j,  1.06251813e-17+2.92734587e-18j,\n",
       "        -5.20417043e-18-6.28837260e-18j, -1.73472348e-18+8.82930181e-19j,\n",
       "         0.00000000e+00-5.65341974e-18j,  6.93889390e-18+5.99994728e-18j,\n",
       "        -6.93889390e-18+8.55741294e-18j,  0.00000000e+00-2.05842728e-17j,\n",
       "        -2.77555756e-17+4.16333634e-17j,  0.00000000e+00-2.47509464e-17j,\n",
       "         0.00000000e+00-1.31985605e-17j,  8.41374698e-18+4.14128379e-20j,\n",
       "        -3.97424695e-17-2.83847814e-19j,  1.63318772e-17-5.58437844e-18j,\n",
       "         7.17656613e-18+7.06502360e-18j, -2.68960118e-18-7.84309174e-18j,\n",
       "         8.76306794e-19-7.95032918e-19j,  6.59733757e-18+2.56263671e-19j,\n",
       "        -7.05048481e-18+6.34497680e-18j,  2.02835708e-19+6.31612305e-18j,\n",
       "        -4.62842539e-19-2.27240000e-18j,  2.69656653e-17+1.29439808e-18j,\n",
       "        -1.24846463e-17-1.23332902e-17j,  2.35098413e-17+5.68270744e-19j,\n",
       "        -2.91522211e-17+1.38833507e-18j,  3.00080289e-17+9.49569442e-18j,\n",
       "        -1.03873655e-17-2.12026961e-18j,  1.54108401e-17+1.78164315e-18j,\n",
       "         6.95228699e-18-4.50009524e-18j,  6.48656508e-18-2.20584574e-18j,\n",
       "         6.90120094e-18+2.22570501e-18j, -2.43521972e-19+7.01637574e-18j,\n",
       "         9.93739054e-18-5.51890657e-18j, -1.72303442e-17-3.05996892e-18j,\n",
       "         6.77626358e-21-1.20198318e-17j, -5.96311195e-19-3.26085508e-19j,\n",
       "         1.36609474e-17-4.15776955e-18j, -1.10588622e-17+8.44385982e-18j,\n",
       "        -5.20417043e-18+9.65063863e-19j, -1.21430643e-17-7.55132746e-18j,\n",
       "        -1.04083409e-17+1.46530247e-18j, -1.38777878e-17-4.12387028e-18j,\n",
       "        -2.77555756e-17-6.59211283e-18j,  0.00000000e+00+6.79483816e-18j,\n",
       "         2.77555756e-17-2.63234191e-17j,  0.00000000e+00-2.84859136e-17j,\n",
       "        -6.93889390e-18-8.15715901e-18j, -4.87390577e-18+2.83847814e-19j,\n",
       "         1.15994693e-17-4.14128379e-20j, -3.02018943e-17+8.97244094e-18j,\n",
       "        -2.81292309e-17-4.21892361e-18j, -1.11876571e-19-4.35265107e-18j,\n",
       "        -9.71839127e-18-3.41900257e-18j, -7.67850636e-19-8.84079771e-18j,\n",
       "        -8.67643981e-18+2.17635744e-18j,  1.37339720e-17-3.26770975e-18j,\n",
       "         6.25085107e-18+9.41343308e-18j, -7.77974317e-18-2.53370582e-18j,\n",
       "         1.35335556e-17+1.76651064e-18j, -9.97605895e-18-3.30411360e-19j,\n",
       "         1.71970837e-17+2.07488398e-18j, -7.16832983e-18+2.66862523e-18j,\n",
       "         1.76968619e-17+1.67929268e-18j,  8.02355850e-18-2.70237364e-18j,\n",
       "        -7.19520471e-19-5.89886202e-18j,  7.42596639e-18+3.58406702e-18j,\n",
       "         1.69335071e-17-6.86163130e-18j, -2.40092151e-18+1.24592270e-17j,\n",
       "         1.06484747e-17-7.83010942e-18j,  1.42401062e-17+1.13481845e-17j,\n",
       "         1.35321984e-17-1.76241495e-18j,  3.27971157e-18-3.27783462e-19j,\n",
       "         1.70761842e-18-3.19311090e-18j,  1.39862080e-17-6.30184372e-18j,\n",
       "        -1.43114687e-17-2.08874804e-18j,  5.20417043e-18+8.74433374e-19j,\n",
       "        -9.54097912e-18+1.20107058e-18j,  1.56125113e-17-6.41363562e-18j,\n",
       "        -2.77555756e-17+2.06787327e-19j,  2.08166817e-17-9.12024008e-18j,\n",
       "         1.38777878e-17+1.05481389e-17j,  6.93889390e-18+4.77779031e-17j,\n",
       "        -6.93889390e-18+8.15715901e-18j, -9.00388204e-18+2.83847814e-19j,\n",
       "         1.61561063e-17-4.14128379e-20j, -2.53092569e-17-4.22611959e-18j,\n",
       "        -2.04430265e-17+8.97963692e-18j, -2.41742521e-17+3.80450794e-18j,\n",
       "         9.71839127e-18+7.25885720e-18j, -1.83141076e-17+2.85670693e-18j,\n",
       "        -1.29822018e-18+1.54618225e-18j, -6.36139719e-18+1.53298627e-18j,\n",
       "        -8.29840204e-19+3.29556383e-18j, -5.85409914e-18-1.75476645e-18j,\n",
       "         2.03091399e-21+1.20164768e-17j,  5.57052572e-19-3.26954582e-19j,\n",
       "         1.93042130e-17+4.83216254e-18j, -6.40794072e-18-9.41307686e-18j,\n",
       "         3.50551100e-18-5.35314220e-18j,  1.16746224e-17+8.51185850e-18j,\n",
       "        -1.21783217e-18+2.38412562e-18j,  1.34768703e-17+5.95097515e-18j,\n",
       "        -9.43963129e-18+1.18725113e-18j,  1.35496618e-17-2.72970353e-18j,\n",
       "        -3.30300498e-18-1.41069791e-18j,  3.15797176e-17-4.14190166e-19j,\n",
       "        -1.24886538e-17+1.23317956e-17j,  1.00559751e-17+5.70596066e-19j,\n",
       "        -6.31547765e-18-1.14807482e-18j,  8.99887803e-18-7.64723047e-18j,\n",
       "        -1.08420217e-17-1.54173455e-18j,  3.46944695e-18+1.77372550e-18j,\n",
       "        -6.07153217e-18+9.60365081e-19j,  1.56125113e-17+8.82421465e-18j,\n",
       "         0.00000000e+00-1.29917732e-17j, -6.93889390e-18+1.22354795e-17j,\n",
       "        -1.38777878e-17-1.58489822e-17j,  6.93889390e-18+3.14082001e-18j,\n",
       "         0.00000000e+00+1.31985605e-17j, -8.41374698e-18+4.14128379e-20j,\n",
       "        -1.57686818e-17-2.83847814e-19j, -1.63318772e-17+2.57278057e-18j,\n",
       "         6.70122168e-18-1.09213541e-18j, -1.11881866e-17+5.35546879e-18j,\n",
       "        -8.76306794e-19+1.72566784e-18j,  3.41556333e-19+4.42678450e-18j,\n",
       "        -2.49049430e-18+9.01444174e-18j, -1.01774957e-17-8.05084653e-18j,\n",
       "         1.75932369e-17-1.21713204e-17j, -2.89443343e-17+9.93296810e-18j,\n",
       "         3.02976290e-16-1.05159183e-18j, -5.05927318e-15-1.19645485e-19j,\n",
       "         7.81514727e-14+4.10062073e-18j, -1.07316027e-12-3.77963344e-18j,\n",
       "         1.30459777e-11+6.03382821e-18j, -1.40400108e-10+1.10055572e-18j,\n",
       "         1.33764398e-09+4.05825706e-18j, -1.12822624e-08-5.51717125e-18j,\n",
       "         8.42431082e-08-3.42644296e-18j, -5.56871641e-07-6.30071605e-18j,\n",
       "         3.25880486e-06+2.46090138e-18j, -1.68827871e-05-2.84217404e-17j,\n",
       "         7.74305718e-05+3.95048051e-19j, -3.14386091e-04+2.05245648e-19j,\n",
       "         1.13004754e-03-2.00167848e-18j, -3.59594168e-03+2.57786850e-18j,\n",
       "         1.01300386e-02+4.61698263e-18j, -2.52634171e-02-2.40713242e-18j,\n",
       "         5.57770601e-02+8.45405242e-18j, -1.09018871e-01-8.98138915e-18j,\n",
       "         1.88638475e-01+1.56504618e-18j, -2.88962448e-01+1.18362397e-17j,\n",
       "         3.91863734e-01-1.00091011e-17j, -4.70447615e-01+1.73412829e-17j])}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Conn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d8cfbf96",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Ut2(ff,wei,seed,Iext,**kwargs):\n",
    "\n",
    "    #Call previous functions and assign variables\n",
    "    param_dict = netparam()\n",
    "\n",
    "    N = param_dict[\"Neuron\"]\n",
    "    T = param_dict[\"Time\"]\n",
    "    dt = param_dict[\"time scale\"]\n",
    "    tau = param_dict[\"time constant\"]\n",
    "    a = param_dict[\"gaussian_width\"]\n",
    "    k = param_dict[\"k\"]\n",
    "    gain = param_dict[\"inhibitory gain\"]\n",
    "\n",
    "    Wdict = Conn()\n",
    "    W = Wdict[\"We\"]\n",
    "    Wi = Wdict[\"Wi\"]\n",
    "    Wie = param_dict[\"E to I Weight\"]\n",
    "    Wee = param_dict[\"Recurrent Weight\"]\n",
    "    \n",
    "    ti = 0\n",
    "    t = np.arange(0,T/dt,1)\n",
    "    \n",
    "    \n",
    "    U = np.zeros([N,int(T/dt)])\n",
    "    V = np.zeros([N,int(T/dt)])\n",
    "    FR = np.zeros([N,2,int(T/dt)])\n",
    "    Oc = np.zeros([N,int(T/dt)])\n",
    "    Vc = np.zeros([N,int(T/dt)])\n",
    "    \n",
    "    s = np.zeros([1,int(T/dt)])\n",
    "    z = np.zeros([1,int(T/dt)])\n",
    "        \n",
    "    np.random.seed(seed)\n",
    "\n",
    "    counter = 0\n",
    "    \n",
    "    for i in range(ti,int(T/dt) -1):\n",
    "        \n",
    "        #noise\n",
    "        noisevr = U[:,i]\n",
    "        noisevr[noisevr < 0]= 0\n",
    "        noiseI = V[:,i]\n",
    "        noiseI[noiseI < 0]= 0\n",
    "        \n",
    "        \n",
    "        ##Firing Rates for this time point\n",
    "        O = np.array(Oc[:,i])\n",
    "        Oin = np.array(Vc[:,i])\n",
    "        \n",
    "        FRE = np.real(np.fft.ifft(W * np.fft.fft(O)))\n",
    "        FRE = np.roll(FRE, int(len(FRE)/2))\n",
    "        FRI = np.real(np.fft.ifft(Wi * np.fft.fft(Oin)))\n",
    "        FRI = np.roll(FRI, int(len(FRI)/2))\n",
    "\n",
    "        U[:,i+1] = ((1-dt/tau)* U[:,i]) + (Wee* FRE*dt/tau) + (wei*FRI*dt/tau) + (ff*Iext*dt/tau) + (np.sqrt(F*noisevr*dt/tau) * np.random.normal(0,1,N))\n",
    "        V[:,i+1] = ((1-dt/tau)* V[:,i]) + (Wie*FRE*(dt/tau)) #+ (np.sqrt(F*noiseI*dt) * np.random.normal(0,1,N))\n",
    "\n",
    "        \n",
    "        #Divisive normalization calculation\n",
    "        Ocn = U[:,i+1]\n",
    "        Ocn[Ocn<0]=0\n",
    "        Ocn = np.square(Ocn)\n",
    "        Ocd = np.multiply(k, (np.sum(Ocn, axis=0)))\n",
    "        Oc[:,i+1] = np.divide(Ocn,(Ocd+1))\n",
    "        \n",
    "        #Inhibitory\n",
    "        Vc[:,i+1] = gain*V[:,i+1]       \n",
    "\n",
    "        counter += 1\n",
    "        #break\n",
    "\n",
    "    #Check for negative firing rate\n",
    "    O_filtered = np.any(Oc[:,:] < 0)\n",
    "    Oc[Oc < 0]= 0\n",
    "\n",
    "    \n",
    "    ## Stimulus response calculations\n",
    "    e1 = np.exp(1j*PrefStim.transpose() * np.pi/ 180) @ (Oc)\n",
    "    S1 = np.angle(e1, deg=True)\n",
    "    Sn1 = np.nan_to_num(S1)\n",
    "      \n",
    "    e2 = np.exp(1j*PrefStim.transpose() * np.pi/ 180) @ (Vc)\n",
    "    S2 = np.angle(e2, deg=True)\n",
    "    Sn2 = np.nan_to_num(S2)\n",
    "   \n",
    "\n",
    "    return {'E stim': Sn1, 'E Firing Rate': Oc , 'I FR': Vc, 'E Synaptic': U}\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3f93dd94",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Prec():\n",
    "    \n",
    "    kmax = param_dict['k'] \n",
    "    a = param_dict['gaussian_width']\n",
    "    T = param_dict['Time']\n",
    "    dt = param_dict['time scale']\n",
    "    k = param_dict['k']\n",
    "    N = param_dict[\"Neuron\"]\n",
    "    \n",
    "    Wc = np.sqrt(8*np.sqrt(2*np.pi)*k*a/rho)\n",
    "    Ufd = Wc / (2 * (np.sqrt(np.pi)) * k * a)\n",
    "    ll = 0.58214787#0.6 * Wc\n",
    "    lh =1.3*Wc\n",
    "    weil = 0.0\n",
    "    weih = 0.6*Wc\n",
    "\n",
    "    l_timestep = 0.1*Ufd\n",
    "    lm = np.arange(0,2*Ufd,l_timestep)\n",
    "    t = np.arange(0,int(T/dt),1)\n",
    "\n",
    "    x1 =  np.repeat(0,N)\n",
    "    pos1 = np.subtract(x1,PrefStim)\n",
    "    pos1 = np.angle(np.exp(1j*pos1 * np.pi/N)) * N/np.pi\n",
    "    \n",
    "    #P = []\n",
    "    prec_bumppos_s = []\n",
    "\n",
    "    prec_bumpl = []\n",
    "    seed = 1\n",
    "    \n",
    "    for index, i in enumerate(lm):\n",
    "        Ipos1 = i*np.exp(-(pos1**2) / (4*a**2))\n",
    "        Ut_dict =  Ut2(lh, -weih, seed, Ipos1)\n",
    "        Ul =  Ut2(ll, weil, seed, Ipos1)\n",
    "        \n",
    "        Sf = Ut_dict[\"E stim\"]\n",
    "\n",
    "        Sl = Ul[\"E stim\"]\n",
    "\n",
    "        sv = np.var(Sf[1000:int(T/dt)])\n",
    "        meanSf = np.mean(Sf)\n",
    "        prec_pos = 1/sv\n",
    "\n",
    "        svl = np.var(Sl[1000:int(T/dt)])\n",
    "        spl = 1/svl\n",
    "                \n",
    "        prec_bumppos_s.append(prec_pos)\n",
    "        prec_bumpl.append(spl)\n",
    "\n",
    "        print('Loop complete',index)\n",
    "    \n",
    "    return { 'FFIntensity':lm, 'Prec_Bump pos sim':prec_bumppos_s, 'langevin precision': prec_bumpl}\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "16dc5589",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_17819/1071676561.py:80: RuntimeWarning: invalid value encountered in divide\n",
      "  ss1 = e1 / sd1\n",
      "/tmp/ipykernel_17819/1071676561.py:86: RuntimeWarning: invalid value encountered in divide\n",
      "  ss2 = e2 / sd2\n",
      "/tmp/ipykernel_17819/3951844482.py:42: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  prec_pos = 1/sv\n",
      "/tmp/ipykernel_17819/3951844482.py:46: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  spl = 1/svl\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bump position precision:  inf\n",
      "Loop complete 0\n",
      "bump position precision:  0.04865172346636795\n",
      "Loop complete 1\n",
      "bump position precision:  0.09131573091084698\n",
      "Loop complete 2\n",
      "bump position precision:  0.12874855788780742\n",
      "Loop complete 3\n",
      "bump position precision:  0.16413890023437686\n",
      "Loop complete 4\n",
      "bump position precision:  0.19932797807268618\n",
      "Loop complete 5\n",
      "bump position precision:  0.2355740555761795\n",
      "Loop complete 6\n",
      "bump position precision:  0.2738245198808241\n",
      "Loop complete 7\n",
      "bump position precision:  0.3148328267545714\n",
      "Loop complete 8\n",
      "bump position precision:  0.3591322859821061\n",
      "Loop complete 9\n",
      "bump position precision:  0.4071425005624237\n",
      "Loop complete 10\n",
      "bump position precision:  0.45902984928279267\n",
      "Loop complete 11\n",
      "bump position precision:  0.5148252754981217\n",
      "Loop complete 12\n",
      "bump position precision:  0.5743508703458459\n",
      "Loop complete 13\n",
      "bump position precision:  0.6373109814128007\n",
      "Loop complete 14\n",
      "bump position precision:  0.7033629744757256\n",
      "Loop complete 15\n",
      "bump position precision:  0.7720858332426195\n",
      "Loop complete 16\n",
      "bump position precision:  0.843066808888583\n",
      "Loop complete 17\n",
      "bump position precision:  0.9159332930434315\n",
      "Loop complete 18\n",
      "bump position precision:  0.9903415641105838\n",
      "Loop complete 19\n"
     ]
    }
   ],
   "source": [
    "Prec_dict = Prec()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f659337d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def I_intensity_graphs():\n",
    "    lm = Prec_dict[\"FFIntensity\"]\n",
    "    prec_bumppos_s = Prec_dict[\"Prec_Bump pos sim\"]\n",
    "    prec_bumpl = Prec_dict[\"langevin precision\"]\n",
    "    \n",
    "    prec_bumppos_s[0] = 0\n",
    "    prec_bumpl[0] = 0\n",
    "    a = param_dict['Gaussian Width']\n",
    "    \n",
    "    #Precision matrix theory\n",
    "    PreMat_T = np.sqrt(2*np.pi)*rho*(1/a)*lm\n",
    "    print('PreMat_T', PreMat_T)\n",
    "    print('lm: ', lm)\n",
    "    print(\"HMC precision\", prec_bumppos_s)\n",
    "    \n",
    "    figP, axP = plt.subplots(figsize=(5,5))    \n",
    "    figP = axP.scatter(lm,prec_bumppos_s, label='1/Bump posi var. (sim)')\n",
    "    figP = axP.plot(lm,PreMat_T, label='Precision Mat Theory', linewidth=3,alpha=0.5, color='black')\n",
    "    figP = axP.scatter(lm,prec_bumpl, label='1/Bump Posi Var. Langevin', linewidth=3,alpha=0.5)    \n",
    "    axP.set_ylabel('Precision of samples')\n",
    "    axP.set_xlabel(r'$I^f$ (Input Intensity)')\n",
    "    axP.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "86318614",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PreMat_T [0.         0.03958084 0.07916167 0.11874251 0.15832335 0.19790419\n",
      " 0.23748502 0.27706586 0.3166467  0.35622753 0.39580837 0.43538921\n",
      " 0.47497005 0.51455088 0.55413172 0.59371256 0.63329339 0.67287423\n",
      " 0.71245507 0.75203591]\n",
      "lm:  [ 0.          1.26323756  2.52647511  3.78971267  5.05295022  6.31618778\n",
      "  7.57942533  8.84266289 10.10590044 11.369138   12.63237555 13.89561311\n",
      " 15.15885067 16.42208822 17.68532578 18.94856333 20.21180089 21.47503844\n",
      " 22.738276   24.00151355]\n",
      "HMC precision [0, 0.04865172346636795, 0.09131573091084698, 0.12874855788780742, 0.16413890023437686, 0.19932797807268618, 0.2355740555761795, 0.2738245198808241, 0.3148328267545714, 0.3591322859821061, 0.4071425005624237, 0.45902984928279267, 0.5148252754981217, 0.5743508703458459, 0.6373109814128007, 0.7033629744757256, 0.7720858332426195, 0.843066808888583, 0.9159332930434315, 0.9903415641105838]\n"
     ]
    },
    {
     "data": {
      "image/png": "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u3YF4MKFC/j4+KBWV/9fZPPmzfTq1eu6+/72229xcXFh586d/Oc//+G1114jNja20jp2dnbs3LmTjz76iPfff5//+7//q3H8H374IdHR0Tz44IPodDp0Oh0hISE13r66GK+135deeolvvvmGefPmcfToUZ5++mnuueceNm3aVKPXrtPpuOuuu5g5cybx8fFs3LiR8ePHU9VVperiiImJQa/Xs3LlStO6GRkZ/Prrr9x3332mtt69e7Nr165KiVaIGyF34QoB7Nu3jw4dOuDs7AwYu287dep0zW2Sk5Np0aLFdffdpUsX5syZA0Dbtm35+OOP+fPPPxk2bJhpnZCQEN5//31UKhXt27fn8OHDvP/++zz44IM1it/DwwMHBwecnZ0JDAys0TY1jbGq/RYUFPDee++xfv160xl469at2bp1K59//jkDBw687n51Oh3l5eWMHz+e0NBQAKKioix6fU5OTtx999188803xMTEAPDjjz/SsmVLBg0aZFovODiYkpIS0tLSTMcS4kZJAhUC4xnoldc/hwwZwpAhQ665TVFREVqt9rr77tKli9nzoKAg0tPTzdpuvvlmVCqV6Xl0dDTvvvsuer0ejUZTk5dwQ2oS45Xi4uIoLi42+xIAUFpaSvfu3Wu0365du3LrrbcSFRXFbbfdxvDhw5k4cSJeXl4Wxf7ggw9y0003kZqaSnBwMN988w0zZswwez+dnJwAKCwstGjfQlyLJFAhgP3793PHHXdYtI2vry8XL1687nr29vZmz1UqFQaDwaJjqdXqSl2bZWVlFu3jWiyNsWLZ6tWrCQ4ONlvm6OhYo/1qNBpiY2PZvn0769at43//+x8vvvgiO3fuJDw8vMaxd+/ena5du/Ldd99x2223cfjwYVatWmW2TlZWFgB+fn413q8Q1yPXQEWzd+rUKbKzs81uIKqJ7t27ExcXZ5UY/vrrr0rP27Ztazr79PPzQ6fTmZbn5uaSlJRkto2DgwN6vd4q8Vxvv5GRkTg6OpKSkkJERITZw5JrryqVin79+jF37lz279+Pg4MDy5Ytq3EcFR544AG++eYbvv76a4YOHVophiNHjtCyZUt8fX1rHJsQ1yMJVDR7e/fuRaVS0a1bN4u2u+222zh69GiNzkKv58yZM8yePZvjx4/z888/87///Y+//e1vpuVDhgzh+++/Z8uWLRw5coTp06dX6toNCwtj586dJCcnk5GRYfFZbnWq2q+bmxvPPPMMTz/9NN9++y2JiYns37+fTz75hG+//bZG+925cydvvfUWe/bsISUlhaVLl3LhwgU6duxY4zgqTJ06ldTUVL788ktmzpxZadstW7YwfPjw2r0BQlRDEqho9vbt20fbtm0tHnMYFRVFr169WLhw4Q3HMG3aNIqKiujduzePP/44Tz75JA899JBp+fPPP8+AAQO4/fbbGTVqFOPGjas0xOaZZ55Bo9EQGRmJn58fKSkpNxzXtfb7+uuv88orr/D222/TsWNHbrvtNlatWlXj7ld3d3c2b97MqFGjaNeuHS+99BLvvvsuI0eOtCiOin1NmDABV1dXxo0bZ7ZdcXExy5Ytq/ENWULUlMxEJMQNWLNmDc888wxHjhy55pCXa7HVTD9NzbBhw+jYsSMfffSRWfsnn3zCihUrWLdunY0iE02V3EQkxA0YNWoUCQkJpKamWnTtT1hPVlYW69atY/369Xz88ceVltvb2/O///3PBpGJpk4SqBA36MprlaL+9ejRg4sXL/Lvf/+b9u3bV1p+ZVe4ENYkXbhCCCFELchNREIIIUQtSAIVQgghakESqBBCCFELkkCFEEKIWpAEKoQQQtSCJFAhhBCiFiSBCiGEELUgCVQIIYSoBUmgQgghRC1IAhVCCCFqQRKoEEIIUQuSQIUQQoha+H9f4nxA1mP/AQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "I_intensity_graphs()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3193ff0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2afac07",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
