{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b02fa7be-240c-435a-9f18-1ab32c993f95",
   "metadata": {},
   "source": [
    "# Panichello & Buschmann, 2021\n",
    "\n",
    "Let's get the fitted representations and make:\n",
    "1. The sexy subspace plot\n",
    "2. Calucate the correlation between subspaces and the angle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1c0b1f29-54e0-402d-bb1c-e348441ea43f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "from jax import vmap, value_and_grad, grad, jit, random\n",
    "from jax.example_libraries import optimizers\n",
    "import jax.nn as jnn\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "from mpl_toolkits.mplot3d.art3d import Poly3DCollection\n",
    "import matplotlib\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f4a46cfd-2be5-4446-8125-1f0e181fd4ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x135c93810>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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It15551qamqKmXIhSQsWLAh7me/Ro0eVl5fnKNHgPv/8cyUnh/56TElJcf4y1bPJz89XVlZWyGPq9OnTqq+vj6nHFBIHKxhwprKyUnfffbeKiopUXFys2tpatba2atmyZa6jBZWXl2vLli169dVX5fV6gysuPp9P48aNc5zuS16vN+yckPHjx2vixIkxd67IQw89pPnz52vdunX60Y9+pLfeeku1tbWqra11HS3EkiVL9MQTT2jy5MmaOXOmGhsbtWHDBt17771Oc3322Wf68MMPg5dbWlrU1NSkCRMmaPLkyaqoqNC6des0ZcoUTZkyRevWrdMFF1ygH//4xw5TI2G5fRELEt0zzzxj8vLyTGpqqrn88stj7uWfkgbdNm/e7DraWcXqy1SNMeZvf/ubKSgoMB6Px0ybNs3U1ta6jhSmq6vLrFy50kyePNmkpaWZSy65xKxZs8b09vY6zbV79+5B52NZWZkx5suXqq5du9ZkZWUZj8djrrzyStPc3Ow0MxIXH9cOAACs4xwMAABgHQUDAABYR8EAAADWUTAAAIB1FAwAAGAdBQMAAFhHwQAAANZRMAAAgHUUDAAAYB0FAwAAWEfBAAAA1lEwAACAdf8Xyii3fpmHltIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "biased = 1\n",
    "\n",
    "# Num of stim\n",
    "Q = 4\n",
    "thetas = [np.pi*2/Q*i for i in range(Q)]\n",
    "\n",
    "targets = np.zeros([2, 3*Q**2])\n",
    "regressors = np.zeros([2*Q, Q**2])\n",
    "counter = 0\n",
    "for q in range(Q):\n",
    "    targets[0,Q**2+q*Q:Q**2+Q+q*Q] = np.cos(thetas[q])\n",
    "    targets[1,Q**2+q*Q:Q**2+Q+q*Q] = np.sin(thetas[q])\n",
    "\n",
    "    targets[0,2*Q**2+q:3*Q**2:Q] = np.cos(thetas[q])\n",
    "    targets[1,2*Q**2+q:3*Q**2:Q] = np.sin(thetas[q])\n",
    "\n",
    "\n",
    "    for qp in range(Q):\n",
    "        regressors[q, counter] = 1\n",
    "        regressors[qp+Q,counter] = 1\n",
    "        counter+=1\n",
    "\n",
    "\n",
    "if biased == 1:\n",
    "    remove_indices = []\n",
    "\n",
    "    for trial in range(Q*Q):\n",
    "        first_target = np.where(regressors[:Q, trial]==1)[0]\n",
    "        second_target = np.where(regressors[Q:, trial]==1)[0]\n",
    "        if first_target == second_target:\n",
    "            remove_indices.append(trial)\n",
    "\n",
    "    remove_timepoints = remove_indices + [i + Q*Q for i in remove_indices] + [i + 2*Q*Q for i in remove_indices]\n",
    "\n",
    "    regressors = np.delete(regressors, remove_indices, axis = 1)\n",
    "    targets = np.delete(targets, remove_timepoints, axis = 1)\n",
    "    num_trials = Q*Q - len(remove_indices)\n",
    "    \n",
    "    g = np.load('./data/P&B_Biased.npy', allow_pickle = True)[()]\n",
    "else:\n",
    "    g = np.load('./data/P&B_Unbiased.npy', allow_pickle = True)[()]\n",
    "\n",
    "N = g.shape[0]\n",
    "plt.subplot(2,1,1)\n",
    "plt.imshow(targets)\n",
    "\n",
    "plt.subplot(2,1,2)\n",
    "plt.imshow(regressors)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "616af101-5467-4bac-9592-dd2fe086e4a4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Proportion negative: 1.87852365343133e-05\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x135cd0f90>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhgAAABHCAYAAABFwz4bAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAALdUlEQVR4nO3db0xb9RoH8G+ZUMwsjXMbpcIaLgvqBnIjTC0RnTP22sRlXm4M84WpmZrMORMue7O5a1iMCUQT7kxwW4xe/7zaXoztmoi5NpE/LoRkkOIIGjOljhpAsiWOygI4eO4LL73rDv/62+k5bc/3kzQZpz2cZ1+e0z07nNNjExEBERERkY6yzC6AiIiIMg8HDCIiItIdBwwiIiLSHQcMIiIi0h0HDCIiItIdBwwiIiLSHQcMIiIi0h0HDCIiItLdbUZvcH5+HqOjo3A4HLDZbEZvnoiIiBSICKLRKNxuN7KyVj4+YfiAMTo6iqKiIqM3S0RERDqIRCIoLCxc8XWGDxgOhwMAUNj4D2Tl5hq9ebIChQNj39T+S/86kqCibU/iK6neDEDxAOOfDp5X3KBxhpu2qa2YBgddVfNXzeSbv6ntO38tLVdab7g58TpV9++K0wr7G6DcJyp1Kr0nQK1PruN3nEN77N/xlSgNGMeOHcM777yDsbExbN26FUePHkVNTc2q1l34tUhWbi4HDEoOhZ07z5EepyMp7TMGDxi32bIVN2gc5feeNBgwVPNXzUR13zGyTtUaje4TlTpVa1TK/3/vJas9vSHhv82pU6dQX1+Pw4cPIxQKoaamBn6/HyMjI4l+KyIiIspQCQ8YLS0tePHFF/HSSy/hvvvuw9GjR1FUVITjx48noz4iIiJKQwkNGLOzs+jv74fP54tb7vP50NPTo2thRERElL4SOgfj8uXLmJubQ35+ftzy/Px8jI+PL7rOzMwMZmZmYl9PTk4qlElERETpROnMl5tP8BCRJU/6aGpqgtPpjD14iSoREVHmS2jAWL9+PdasWaM5WjExMaE5qrHg0KFDuHr1auwRiUTUqyUiIqK0kNCAkZOTg8rKSgSDwbjlwWAQ1dXVi65jt9uRl5cX9yAiIqLMlvDnYDQ0NOD5559HVVUVvF4v3n//fYyMjGDv3r3JqI+IiIjSUMIDRl1dHa5cuYI333wTY2NjKCsrQ3t7OzweTzLqIyIiojSk9Eme+/btw759+/SuhYiIiDKE4fciyXiqHyWs+nHOpKWQZclJg3/Fp9gnP9ad0LeOJCgRxSwN/BjuzX/vNW5jt+A/owMJr6Oa/+YGtUxKbIo/73+qrabys1PN5MfdavvbX9x/VlqvBInXqfqeoLKt+elp4OC/V/369LgBAxEREaUVDhhERESku4QHjO7ubuzcuRNutxs2mw1nz55NQllERESUzhIeMKamplBRUYHW1tZk1ENEREQZIOGTPP1+P/x+fzJqISIiogyR9KtIeLMzIiIi60n6SZ682RkREZH1JH3A4M3OiIiIrCfpvyKx2+2w2+3J3gwRERGlEH4OBhEREeku4SMYv/32G3744YfY1+FwGAMDA1i3bh02bdqka3FERESUnhIeMPr6+vD444/Hvm5oaAAABAIBfPzxx7oVRkREROkr4QFj+/btEFG/M9fCuvPT08rfI6XxZme0Gop9Mhmd17eOJFDetw282dl1+d24jd0ClZ+3av6qmRj9Xq5Sp2qNqvubkVmq1qiyrYV1VjsD2ORWpgUFP//8My9VJSIiSlORSASFhYUrvs7wAWN+fh6jo6NwOByw2f7/X5bJyUkUFRUhEokgLy/PyJJSFjPRYiZazESLmWgxEy1morVcJiKCaDQKt9uNrKyVrxFJ+mWqN8vKylp28snLy+MP+ibMRIuZaDETLWaixUy0mInWUpk4nc5Vfw9epkpERES644BBREREukuZAcNut6OxsZGf+nkDZqLFTLSYiRYz0WImWsxES89MDD/Jk4iIiDJfyhzBICIioszBAYOIiIh0xwGDiIiIdMcBg4iIiHSXMgPGsWPHUFxcjNzcXFRWVuLrr782uyTTHDlyBDabLe7hcrnMLstQ3d3d2LlzJ9xuN2w2G86ePRv3vIjgyJEjcLvduP3227F9+3YMDQ2ZU6xBVsrkhRde0PTNww8/bE6xBmhqasK2bdvgcDiwceNGPPPMM/j+++/jXmO1PllNJlbrk+PHj+P++++PfXCU1+vFF198EXveaj0CrJyJXj2SEgPGqVOnUF9fj8OHDyMUCqGmpgZ+vx8jIyNml2aarVu3YmxsLPYYHBw0uyRDTU1NoaKiAq2trYs+//bbb6OlpQWtra04f/48XC4XnnzySUSjUYMrNc5KmQDAU089Fdc37e3tBlZorK6uLrz66qvo7e1FMBjE9evX4fP5MDU1FXuN1fpkNZkA1uqTwsJCNDc3o6+vD319fdixYwd27doVGyKs1iPAypkAOvWIpIAHH3xQ9u7dG7fs3nvvlYMHD5pUkbkaGxuloqLC7DJSBgA5c+ZM7Ov5+XlxuVzS3NwcWzY9PS1Op1NOnDhhQoXGuzkTEZFAICC7du0ypZ5UMDExIQCkq6tLRNgnItpMRNgnIiJ33nmnfPDBB+yRGyxkIqJfj5h+BGN2dhb9/f3w+Xxxy30+H3p6ekyqynwXL16E2+1GcXExdu/ejeHhYbNLShnhcBjj4+NxPWO32/HYY49ZumcAoLOzExs3bkRpaSlefvllTExMmF2SYa5evQoAWLduHQD2CaDNZIFV+2Rubg4nT57E1NQUvF4vewTaTBbo0SOG3+zsZpcvX8bc3Bzy8/Pjlufn52N8fNykqsz10EMP4dNPP0VpaSl++eUXvPXWW6iursbQ0BDuuusus8sz3UJfLNYzly5dMqOklOD3+/Hss8/C4/EgHA7jjTfewI4dO9Df35/xn1QoImhoaMAjjzyCsrIyAOyTxTIBrNkng4OD8Hq9mJ6exh133IEzZ85gy5YtsSHCij2yVCaAfj1i+oCx4MZbtwN/7Bw3L7MKv98f+3N5eTm8Xi9KSkrwySefoKGhwcTKUgt7Jl5dXV3sz2VlZaiqqoLH48Hnn3+O2tpaEytLvv379+PChQs4d+6c5jmr9slSmVixT+655x4MDAzg119/xenTpxEIBNDV1RV73oo9slQmW7Zs0a1HTP8Vyfr167FmzRrN0YqJiQnNVGlVa9euRXl5OS5evGh2KSlh4Yoa9szyCgoK4PF4Mr5vXnvtNXz22Wfo6OhAYWFhbLmV+2SpTBZjhT7JycnB5s2bUVVVhaamJlRUVODdd9+1dI8slcliVHvE9AEjJycHlZWVCAaDccuDwSCqq6tNqiq1zMzM4LvvvkNBQYHZpaSE4uJiuFyuuJ6ZnZ1FV1cXe+YGV65cQSQSydi+ERHs378fbW1t+Oqrr1BcXBz3vBX7ZKVMFpPpfbIYEcHMzIwle2QpC5ksRrlHbvk0UR2cPHlSsrOz5cMPP5Rvv/1W6uvrZe3atfLTTz+ZXZopDhw4IJ2dnTI8PCy9vb3y9NNPi8PhsFQe0WhUQqGQhEIhASAtLS0SCoXk0qVLIiLS3NwsTqdT2traZHBwUJ577jkpKCiQyclJkytPnuUyiUajcuDAAenp6ZFwOCwdHR3i9Xrl7rvvzthMXnnlFXE6ndLZ2SljY2Oxx7Vr12KvsVqfrJSJFfvk0KFD0t3dLeFwWC5cuCCvv/66ZGVlyZdffiki1usRkeUz0bNHUmLAEBF57733xOPxSE5OjjzwwANxl1VZTV1dnRQUFEh2dra43W6pra2VoaEhs8syVEdHhwDQPAKBgIj8cQliY2OjuFwusdvt8uijj8rg4KC5RSfZcplcu3ZNfD6fbNiwQbKzs2XTpk0SCARkZGTE7LKTZrEsAMhHH30Ue43V+mSlTKzYJ3v27In927JhwwZ54oknYsOFiPV6RGT5TPTsEd6unYiIiHRn+jkYRERElHk4YBAREZHuOGAQERGR7jhgEBERke44YBAREZHuOGAQERGR7jhgEBERke44YBAREZHuOGAQERGR7jhgEBERke44YBAREZHuOGAQERGR7v4LuwuBhPNmgX0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# First check that the neural representation is positive and fits the data\n",
    "negative_activity = g[g<0]\n",
    "print(f'Proportion negative: {np.linalg.norm(negative_activity)/np.linalg.norm(g)}')\n",
    "\n",
    "def generate_R(g, targets):\n",
    "    g_bias = jnp.vstack([g, jnp.ones(g.shape[1])[None,:]])\n",
    "    Q = jnp.matmul(g_bias, g_bias.T)\n",
    "    R = jnp.matmul(g_bias, targets.T)\n",
    "    P = jnp.matmul(jnp.linalg.inv(Q + 0.0001*jnp.eye(g.shape[0]+1)), R)\n",
    "    return P\n",
    "\n",
    "R = generate_R(g, targets)\n",
    "\n",
    "preds = R[:-1,:].T@g + R[-1,:][:,None]\n",
    "\n",
    "plt.imshow(preds)"
   ]
  },
  {
   "cell_type": "raw",
   "id": "ba42d0d6-bf0b-4cd1-a3e1-61db46c28091",
   "metadata": {},
   "source": [
    "def get_delay_avgs(g, regressors):\n",
    "    avg = np.zeros([N,2*Q])\n",
    "    for position in range(2):\n",
    "        for q in range(Q):\n",
    "            indices = np.where(regressors[position*Q+q,:] == 1)[0]\n",
    "            avg[:,position*Q+q] = np.mean(g[:,indices], axis = 1)\n",
    "    return avg\n",
    "    \n",
    "g_avg = get_delay_avgs(g, regressors)\n",
    "plt.imshow(g_avg)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5b52b5dd-cab7-498b-aabe-a2afcb0ad725",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Propotion of Activity Kept: 0.9968421459197998\n",
      "Propotion of Activity Kept: 0.9949382543563843\n",
      "Angles: [83.53724077 85.00206529]\n",
      "Correlation between subspaces: 0.09491489243676855\n",
      "Subspace Ration: 1.0025362840630336\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxoAAAFwCAYAAAA/sA1HAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAx/klEQVR4nO3de3TU1b338c9MhiRCICY0ELwAuZ0eggrm5FEPrXgCjTYRenFZjrU+agXk4gXt8vQ5ahB6CnXZqudYtIY2UvXR2mO7bJ9ySTWUVPS0omnkovGSG4pVaEoiGDSBSfbzx/iLTJJJMpP9SzKT92stFmbmN3vviVkkn3x/3709xhgjAAAAALDIO9wLAAAAABB7CBoAAAAArCNoAAAAALCOoAEAAADAOoIGAAAAAOsIGgAAAACsI2gAAAAAsI6gAQAAAMA6ggYAAAAA6wgaAIacx+MZ0J8//vGPQ7qu6dOny+Px6F/+5V96ff7xxx8ftrWNFMeOHdM999yjWbNmacKECRo/fryysrK0aNEiPf/88xGNOX36dC1YsMDySgEAw8033AsAMPr8+c9/Dvr4+9//viorK7Vjx46gx3Nzc4dyWZKk8ePHa+fOnaqvr1dWVlbQc5s2bdKECRN09OjRIV/XSNDR0aGLL75Y+/bt07/927/pvPPOkyTV1tZq8+bNeuGFF3TRRRcN8yoBACMFQQPAkLvggguCPk5LS5PX6+3x+HD44he/qH379mnTpk1av3591+P19fXauXOnlixZop/97GfDuMLIGGPU1tamU045JeIxdu7cqT/96U/atGmTvv3tb3c9fskll+jGG29UZ2enjaUCAGIEt04BGHG+8Y1vaObMmUGPLVy4UB6PR7/61a+6HquurpbH49HmzZu7Hnvttdf01a9+VSkpKUpMTNTs2bP12GOPDXhur9erq6++Wo899ljQD86bNm3SmWeeqS996Uu9vq6qqkpf+cpXlJqaqsTERJ177rl6+umng6559NFH5fF4tGPHDi1dulQTJ07UhAkTdPXVV+vYsWM6ePCgFi1apFNPPVVTpkzRbbfdphMnTgSN0dzcrJUrV+r0009XfHy8MjMzdeedd6q9vT3oOo/HoxtvvFGlpaWaMWOGEhIS9OijjyonJ0eXXHJJj/W3trYqOTlZN9xwQ8jPzeHDhyVJU6ZMCfm5c6xdu1Yej6fHNc7nYP/+/T2e+81vfqNzzjlHiYmJyszM1I9//OOg5zs7O7Vu3Tp9/vOf1ymnnKJTTz1V55xzjh544IEe87766qu67LLLNGHCBCUnJ+uqq65SU1NT0Hj//d//rYsvvlhTpkzRKaecohkzZujf//3fdezYsR5r27VrlxYuXKiJEycqMTFRWVlZuuWWW4Kuqa2t1ZVXXqlJkyYpISFBM2bM0EMPPRT2ewCAWEFFA8CI86UvfUm//vWv9cEHH2jKlCny+/16/vnndcopp6iiokLf+MY3JEnbt2+Xz+fr6ql46623NGfOHE2aNEk//vGPNXHiRD3xxBO69tprdejQIX33u98d0PzXXXed7r77bj377LMqKipSR0eHHnvsMS1evDjoh2lHZWWlvvzlL+v8889XaWmpkpOT9ctf/lL/+q//qo8//ljXXntt0PVLlizRZZddpl/+8pd69dVXdccdd8jv9+utt97SZZddpuuvv17bt2/XPffco9NOO03f+c53JEltbW0qKChQfX29vve97+mcc87RCy+8oLvvvlu7d+/W1q1bg+b57W9/qxdeeEF33XWX0tPTNWnSJJ04cUK33HKLamtrlZOT03Xt448/rqNHj/YZNPLz8zVmzBitWrVKd911l+bNmxcydIRr9+7duuWWW7R27Vqlp6frySef1KpVq3T8+HHddtttkqQf/vCHWrt2rUpKSjR37lydOHFCb775pj788MMe433961/XokWLtHz5cr3++utavXq1ampqtGvXLo0ZM0ZSIBgUFxfrlltu0bhx4/Tmm2/qnnvu0csvvxx0G9+zzz6rhQsXasaMGbr//vs1depU7d+/X88991zXNTU1NZozZ46mTp2q++67T+np6Xr22Wd188036+9//7vWrFkT9nsAgKhnAGCYXXPNNWbcuHFdH9fV1RlJ5vHHHzfGGPPiiy8aSea73/2uycjI6LqusLDQzJkzp+vjK664wiQkJJh33303aPyioiIzduxY8+GHH/a5jmnTpplLL73UGGPMRRddZC6//HJjjDFbt241Ho/HNDY2ml/96ldGkqmsrOx63T/+4z+ac88915w4cSJovAULFpgpU6aYjo4OY4wxP//5z40kc9NNNwVd97Wvfc1IMvfff3/Q47NnzzZ5eXldH5eWlhpJ5umnnw667p577jGSzHPPPdf1mCSTnJxsmpubg649evSoGT9+vFm1alXQ47m5uaagoKDPz48xxjzyyCMmKSnJSDKSzJQpU8zVV19tdu7cGXTdmjVrTG/fYpzPQWNjY9dj06ZNMx6Px+zevTvo2sLCQjNhwgRz7NgxY0zg8zl79uw+1+fMe+uttwY9/uSTTxpJ5oknnuj1dZ2dnebEiRPm+eefN5LMnj17up7LysoyWVlZ5pNPPgk57yWXXGLOOOMMc+TIkaDHb7zxRpOYmNj1/2Eg7wEAYgW3TgEYcbKysjR9+nRt375dklRRUaGzzz5bV111lRobG1VfX6/29na9+OKLQbcy7dixQ/Pnz9eZZ54ZNN61116rjz/+uEcTel+uu+46/e53v9Phw4f1yCOPqKCgQNOnT+9xXV1dnd58801961vfkiT5/f6uP8XFxfrggw/01ltvBb2m+w5LM2bMkCRdeumlPR5/5513gt7fuHHjdPnll/d4f5L0hz/8IejxefPmKSUlJeix8ePH69vf/rYeffTRrluEduzYoZqaGt144419fUokBT4v7733nn7xi1/o5ptv1plnnqknnnhCF110kX70ox/1+/pQZs6cqVmzZgU9duWVV+ro0aOqrq6WJJ133nnas2ePVq5cqWeffbbPpnzn/4dj0aJF8vl8qqys7HqsoaFBV155pdLT0xUXF6cxY8Z0NbO/8cYbkqS3335b9fX1Wrx4sRITE3udq62tTX/4wx/09a9/XWPHju3xNdDW1qaXXnop7PcAANGOoAFgRJo/f37XD87bt29XYWGhzj77bE2ePFnbt2/X//zP/+iTTz4JChqHDx/u9Vae0047rev5gbr88suVmJio//zP/9TmzZu1ePHiXq87dOiQJOm2227TmDFjgv6sXLlSkvT3v/896DWpqalBH8fHx4d8vK2tLej9paen9+h9mDRpknw+X4/3F+q2pptuukkfffSRnnzySUnSgw8+qDPOOENf/epXe72+u+TkZH3zm9/UAw88oF27dmnv3r2aPHmy7rzzzohvAUpPTw/5mPO+br/9dt1777166aWXVFRUpIkTJ2r+/Pmqqqrqdzyfz6eJEyd2jdXa2qoLL7xQu3bt0rp16/THP/5Rr7zyip555hlJ0ieffCJJXX0dZ5xxRsi1Hz58WH6/Xxs2bOjxNVBcXCzps6+BcN4DAEQ7ggaAEWn+/Pn661//qpdfflm7du1SYWGhpMBv6SsqKrR9+3YlJSUF7VQ1ceJEffDBBz3Gev/99yVJn/vc5wY8/9ixY3XFFVfo7rvv1rhx43TZZZf1ep0z5u23365XXnml1z+zZ88e8Lx9mThxog4dOiRjTNDjf/vb3+T3+3u8v96asSUpOztbRUVFeuihh3TgwAH97ne/0/LlyxUXFxfRumbOnKkrrrhCJ06c0Ntvvy1JXb/9796k3j10OQ4ePBjysYkTJ0oKhIXvfOc7qq6uVnNzs5566ikdOHBAl1xyiT7++OM+x/P7/Tp8+HDXWDt27ND777+vTZs2acmSJZo7d67y8/M1fvz4oNelpaVJkt57772Q7z8lJUVxcXG69tprQ34NOIEjnPcAANGOoAFgRJo/f748Ho9Wr14tr9eruXPnSgo0ildWVqqiokJz587taux1XuP8AHmyxx9/XGPHjg17+9wVK1Zo4cKFuuuuu0LeNvP5z39eOTk52rNnj/Lz83v90/2H10jNnz9fra2t+u1vfxv0+OOPP971/ECtWrVKe/fu1TXXXKO4uDgtXbq039ccPnxYx48f7/W5N998U9Jn1SPnNrO9e/cGXXfyDmEne/3117Vnz56gx37xi19o/PjxysvL63H9qaeeqssvv1w33HCDmpube+xi5VRrHE8//bT8fn/XxgFOCEtISAi6buPGjUEf/8M//IOysrK0adOmHqHJMXbsWBUUFOjVV1/VOeec0+vXgBNwwnkPABDt2HUKwIg0adIknXXWWXruuedUUFCgsWPHSgoEjebmZjU3N+v+++8Pes2aNWu0ZcsWFRQU6K677lJqaqqefPJJbd26VT/84Q+VnJwc1hpmz57d44f63mzcuFFFRUW65JJLdO211+r0009Xc3Oz3njjDVVXVwdtyTsYV199tR566CFdc8012r9/v84++2y9+OKL+sEPfqDi4uKQW+/2prCwULm5uaqsrNRVV12lSZMm9fuayspKrVq1St/61rc0Z84cTZw4UX/729/01FNP6fe//72uvvrqrluMiouLlZqaqsWLF+s//uM/5PP59Oijj+rAgQO9jn3aaafpK1/5itauXaspU6boiSeeUEVFhe65556u//cLFy7UWWedpfz8fKWlpemdd97Rf/3Xf2natGlBO2hJ0jPPPCOfz6fCwsKuXadmzZqlRYsWSZLmzJmjlJQULV++XGvWrNGY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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g_delay = g[:,:regressors.shape[1]]\n",
    "\n",
    "# PC extracting function\n",
    "def get_PCs(vecs, num_eigs = 2):\n",
    "    vecs = vecs - np.mean(vecs, axis = 1)[:,None]\n",
    "    covar = vecs@vecs.T\n",
    "    eigvals, eigvecs = np.linalg.eig(covar)\n",
    "    \n",
    "    ordering = np.argsort(eigvals)[::-1]\n",
    "    print(f\"Propotion of Activity Kept: {np.sum(eigvals[ordering[:2]])/np.sum(eigvals)}\")\n",
    "    return np.real(eigvecs[:,ordering[:num_eigs]])\n",
    "\n",
    "# We extract 3 to use in the next section, only two are used here\n",
    "PCs = np.zeros([N, 2, 2])\n",
    "for order in range(2):\n",
    "    diff_vec = []\n",
    "    for q in range(Q):\n",
    "        q_not_in_other_rank = np.where(regressors[(1-order)*Q+q,:] != 1)[0]\n",
    "        q_in_this_rank = np.where(regressors[Q*order+q,:] == 1)[0]\n",
    "        for qp in range(Q):\n",
    "            if qp != q:\n",
    "                qp_not_in_other_rank = np.where(regressors[(1-order)*4+qp,:] != 1)[0]\n",
    "                qp_in_this_rank = np.where(regressors[Q*order+qp,:] == 1)[0]\n",
    "\n",
    "                other_rank_not_q_or_qp = np.intersect1d(q_not_in_other_rank, qp_not_in_other_rank)\n",
    "                q_this_rank_avg_ind = np.intersect1d(q_in_this_rank, other_rank_not_q_or_qp)\n",
    "                qp_this_rank_avg_ind = np.intersect1d(qp_in_this_rank, other_rank_not_q_or_qp)\n",
    "\n",
    "                diff_vec.append(np.mean(g_delay[:,q_this_rank_avg_ind],axis=1) - np.mean(g_delay[:,qp_this_rank_avg_ind], axis = 1))\n",
    "    diff_vec = np.stack(diff_vec).T\n",
    "    PCs[:,order,:] = get_PCs(diff_vec)\n",
    "\n",
    "# Regenerate the encoding of each colour in each position\n",
    "extracted_encodings = np.zeros([Q, N, 2, Q])\n",
    "for order in range(2):\n",
    "    for base in range(Q):\n",
    "        Base_q_not_in_other_rank = np.where(regressors[(1-order)*Q+base,:] != 1)[0]\n",
    "        Base_q_in_this_rank = np.where(regressors[Q*order+base,:] == 1)[0]\n",
    "        for q in range(Q):\n",
    "            if q != base:\n",
    "                q_not_in_other_rank = np.where(regressors[(1-order)*Q+q,:] != 1)[0]\n",
    "                q_in_this_rank = np.where(regressors[Q*order+q,:] == 1)[0]\n",
    "        \n",
    "                other_rank_not_q_or_base_q = np.intersect1d(q_not_in_other_rank, Base_q_not_in_other_rank)\n",
    "                q_this_rank_avg_ind = np.intersect1d(q_in_this_rank, other_rank_not_q_or_base_q)\n",
    "                Base_q_this_rank_avg_ind = np.intersect1d(Base_q_in_this_rank, other_rank_not_q_or_base_q)\n",
    "        \n",
    "                extracted_encodings[base,:,order,q] = np.mean(g_delay[:,q_this_rank_avg_ind],axis=1) - np.mean(g_delay[:,Base_q_this_rank_avg_ind], axis = 1)\n",
    "\n",
    "# Now really that was a set of difference vectors, let's make each order mean zero\n",
    "for order in range(2):\n",
    "    for base in range(Q):\n",
    "        extracted_encodings[base,:,order,:] = extracted_encodings[base,:,order,:] - np.mean(extracted_encodings[base,:,order,:], axis = 1)[:,None]\n",
    "\n",
    "# And average over base\n",
    "extracted_encodings = np.mean(extracted_encodings, axis = 0)\n",
    "\n",
    "# Now we project the encodings into the PC space\n",
    "subspace_coefficients = np.zeros([2, 2, Q, 2]) # num subspaces, by which points project, by num points, by dim subspace\n",
    "for subspace in range(2):\n",
    "    for encoding_order in range(2):\n",
    "        for q in range(Q):\n",
    "            subspace_coefficients[subspace, encoding_order, q, :] = PCs[:,subspace,:2].T@extracted_encodings[:,encoding_order,q]\n",
    "\n",
    "# Now do simple 2D plots\n",
    "plt.figure(figsize = (10, 4))\n",
    "markers = ['o', '^']\n",
    "colours = ['green', 'orange', 'purple', 'blue']\n",
    "for order in range(2):\n",
    "    plt.subplot(1,2,1+order)\n",
    "    ax = plt.gca()\n",
    "    ax.axis('off')\n",
    "    for encoding_order in range(2):\n",
    "        for q in range(Q):\n",
    "            plt.scatter(subspace_coefficients[order, encoding_order,q,0], subspace_coefficients[order, encoding_order,q,1], c = colours[q], s = 300, marker = markers[encoding_order])\n",
    "plt.suptitle('Two Memory Subspaces')\n",
    "\n",
    "U, S, V = np.linalg.svd(PCs[:,0,:].T@PCs[:,1,:])\n",
    "angles = np.arccos(S)/np.pi*180\n",
    "print(f'Angles: {angles}')\n",
    "\n",
    "# Now let's try to calculate their correlation measure.\n",
    "rho = 0\n",
    "for l in range(2):\n",
    "    for q in range(Q):\n",
    "        rho += np.corrcoef(extracted_encodings[:,l,q], extracted_encodings[:,1-l,q])[0,1]\n",
    "rho = rho/(2*Q)\n",
    "print(f'Correlation between subspaces: {rho}')\n",
    "\n",
    "subspace_sizes = np.array([np.linalg.norm(extracted_encodings[:,i,:]) for i in range(2)])\n",
    "subspace_ratio = subspace_sizes[0]/subspace_sizes[1]\n",
    "print(f'Subspace Ration: {subspace_ratio}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 277,
   "id": "95002121-e6bf-4dac-b903-9876249b724f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Propotion of Activity Kept: (0.5100451329649097-1.642695987739212e-34j)\n",
      "Propotion of Activity Kept: 0.9999999725076935\n",
      "Propotion of Activity Kept: 0.9999999410250471\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.92, 'Cosine of Angle Between Planes: 0.000')"
      ]
     },
     "execution_count": 277,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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2wqejyKbzZLe3l7S2trKCIoG4ueff15w7D333EMAkEceeUTw+Jvf/GayZMkS9m+6RX766acFx33sYx+bNehfuHCBqFQq8vd///eC14ZCIWK32wVbZCnQv4f4P4VCQb785S8Ljt29ezcBQP71X/9V8PjY2BjR6/XkC1/4AnssX3rnueeeIwDIK6+8QgiZydPW1NSQj3/84+T6669nx/X19QkC580330za2trI9PS04Hyf/OQniU6nI4FAgBBCyHe/+12iUCjI/v37Bcc9+uijOWkAAKSpqYkEg0H2mMvlIgqFgnz3u98t+HujgfH73/8+SaVSJB6Pk4MHD5KNGzeyBQH/OoXSO+l0mqRSKXLjjTeSO++8M+caK1euFCyG9u3bRwCQnTt3ssf6+/vJ2rVrSSqVEpz79ttvJ83NzSSTyRBCCFmxYsWs9bvR0VGiVCrJhz70oYLHEUKIWq0mH/vYx3Ie37Vrl2SKhY+JiQkCQPJ3/eCDDwrSRnSh5XQ6c45905veRBYvXsz+3dfXR26++eac4xwOB6tfVRPzIr1TCl588UUAyFHcbNq0CUuXLmWpld7eXlgsFnzxi1/EAw88gMHBwZKuw08nAcCqVasAXNwW79q1C4FAAPfccw/S6TT7L5vN4pZbbsH+/ftztut8vPDCC1i2bBk2bdokePwDH/gACCF44YUXSrpfipdffhmnT5/GPffcA6VSCWBm28hxHP7rv/4r53iO43DHHXfkvFf+9v/ll19GTU0NbrnlFsFx73nPe2a9n7/85S9Ip9N4//vfL/g96XQ6XHfddXjppZeKel/f//73sX//fuzfvx9//etf8YUvfAHf+9738PnPf54d88QTT4DjONx1112Ca9ntdqxevbqoa23btg06nQ7PPfccAOCvf/0rduzYgVtuuQW7du1CNBrF2NgYRkZG8MY3vhEAEI/H8fzzz+POO++EwWAQXPvNb34z4vE4S3c88cQTWLFiBdasWSM47uabbwbHcTn3eP3116Ompob9u6mpCY2NjQXTM3x88YtfhFqthk6nw/r163HhwgX84he/wJvf/OaCr3vggQewbt066HQ6qFQqqNVqPP/88xgaGso59rbbbmOfNSD3u3L69GmcPHkS73vf+wAg5/fjdDpZ6nTTpk14+umn8aUvfQkvvfQSYrFYzvU6OzuRTqfxn//5n0X9DgqpyYpRmpXy+nzHFntcsfdUDlRVPXsRoDKqc+fOFXW83+8HADQ3N+c819LSwj5odXV1ePnll/Htb38b//RP/4TJyUk0NzfjIx/5CL7yla/k5ILFqK+vF/yb1hroh9DtdgMA3vnOd+Y9RyAQgNFozPs+urq6JN8DfX4uoF+EO++8E1NTUwBmfhfbt2/HH//4R/z0pz+F2WxmxxsMBuh0OsE5tFot4vG44F6bmppyriX1mBj097Rx40bJ5xWK4tYdixYtwoYNG9i/3/jGN2JychL/+q//ir/9279Ff38/3G43CCF572vRokWzXken02Hbtm147rnn8I1vfAPPP/88vvCFL2DHjh3IZDJ49dVXWR6YBn2/3490Oo2f/OQn+MlPfiJ5Xp/PB2Dm93H69Om8nz96HIX4cwjM/H2kgqEU/uEf/gF33XUXFAoFzGYzuru7Zw0q999/Pz772c/i7/7u7/Ctb30LNpsNSqUSX/3qVyWDfrHflc997nP43Oc+J3lN+r7//d//HW1tbXj44Yfx/e9/HzqdDjfffDN++MMfoq+vr6j3LL43qe8SlYBbrda8r7VYLOA4rqjX09+B1HclEAgIrlPOPVUClz3oK5VK3HjjjXj66acxPj6Otra2gsfTX67T6cw51uFwwGazsX+vXLkSDz30EAghOHbsGH71q1/hm9/8JvR6Pb70pS+Vdd/0Oj/5yU9YcUyMQkGxvr4eTqcz53GHwyE4fymYnp7GH//4RwD5g+yDDz6Ij3/84yWdt76+Hvv27ct53OVyzfpa+j4effRRQTGsEli1ahX72/b398Nms4HjOLz66quSggCpx6Rw44034mtf+xr27duH8fFx3HTTTaipqcHGjRvx17/+FQ6HA4sXL0Z7ezuAmeCgVCpx99134xOf+ITkObu7uwHM/D70er3kros+X0m0tbUJyLIY/O53v8OOHTvwH//xH4LHQ6HQnO6Bvqd//Md/xNvf/nbJY5YsWQIAMBqN+MY3voFvfOMbcLvdbNV/xx134OTJkyVfe+XKlYJiOwV9bMWKFXlfq9fr0dvbm/f1er2eLSRWrlzJHl+2bBk7Lp1O4+TJk4Jd8cqVK7Fz506k02moVCrBOWe7p0pgXqR3/vEf/xGEEHzkIx9BMpnMeT6VSuHPf/4zAOCGG24AMPPB5GP//v0YGhrCjTfemPN6juOwevVq/OhHP4LZbM7bWFEKtm3bBrPZjMHBQWzYsEHyP41Gk/f1N954IwYHB3Pu5Te/+Q04jsP1119f8j09+OCDiMVi+Na3voUXX3wx5z+bzZY32BTCddddh1AohKefflrweDHNJDfffDNUKhXOnDmT9/c0Vxw5cgQA0NjYCAC4/fbbQQjBxMSE5HXoFxMovFp+4xvfiHQ6ja9+9atoa2tDf38/e/y5557DCy+8wFb5wMxu6frrr8fhw4exatUqyWvTxcrtt9+OM2fOoL6+XvI4qd3fpQbHcTkEeezYsZymrmKxZMkS9PX14ejRo3k/A/wUFkVTUxM+8IEP4D3veQ+Gh4cRjUZLvvadd96JkydPChQx6XQav/vd77B582a2sy70+hdeeAFjY2PssVAohMceewxvectbWNDevHkzmpubc5Rsjz76KMLhsIDs7rzzToTDYbZAo/j1r3+NlpYWbN68ueT3WQou+0ofALZu3Yr/+I//wMc//nGsX78e9957L5YvX45UKoXDhw/jl7/8JVasWIE77rgDS5YswUc/+lH85Cc/gUKhwK233orR0VF89atfRXt7Oz7zmc8AmMmd/vznP8fb3vY2LFq0CIQQPPbYY5iamsJNN91U9j2bTCb85Cc/wT333INAIIB3vvOdaGxshNfrxdGjR+H1enNWSnx85jOfwW9+8xvcdttt+OY3v4nOzk48+eST+PnPf457770XixcvLvme/vM//xMWiwWf+9znclI2APD+978f999/P44ePYrVq1cXfd577rkHP/rRj3DXXXfhn//5n9Hb24unn34af/nLXwAUTtF0dXXhm9/8Jr785S/j7NmzuOWWW2CxWOB2u7Fv3z62spsNIyMjLC8+PT2N5557Dv/5n/+JDRs24A1veAOAGSL+6Ec/ig9+8IM4cOAArr32WhiNRjidTrz22mtYuXIl7r33XgAzq63HHnsM//Ef/4H169dDoVAwAlq/fj0sFgueffZZgQTvjW98I771rW+xn/n4t3/7N2zfvh1veMMbcO+996KrqwuhUAinT5/Gn//8Z1aj+fSnP40//vGPuPbaa/GZz3wGq1atQjabxYULF/Dss8/is5/9bNW/9LPh9ttvx7e+9S18/etfx3XXXYfh4WF885vfRHd3N5Molopf/OIXuPXWW3HzzTfjAx/4AFpbWxEIBDA0NIRDhw7hD3/4A4CZ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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plane_plotter(normal, points):\n",
    "    center = points.mean(axis=1)\n",
    "    d = center.dot(normal)\n",
    "    X = np.arange(points[0,:].min(), points[0,:].max(), (points[0,:].max() - points[0,:].min()) / 10)\n",
    "    Y = np.arange(points[1,:].min(), points[1,:].max(), (points[1,:].max() - points[1,:].min()) / 10)\n",
    "    xx, yy = np.meshgrid(X, Y)\n",
    "    z = (-normal[0] * xx - normal[1] * yy + d) * 1. / normal[2]\n",
    "    return xx, yy, z, \n",
    "\n",
    "colours = ['green', 'orange', 'purple', 'blue']\n",
    "\n",
    "# Let's get the 3D PCs of the pre subspace\n",
    "PCs_3D_pre = get_PCs(np.reshape(extracted_encodings, [N, 2*Q]), num_eigs = 3)\n",
    "Encodings_3D_pre = np.einsum('ij,ikl->jkl', PCs_3D_pre, extracted_encodings)\n",
    "\n",
    "# Get the two plane vectors and normals\n",
    "plane_vectors_1 = get_PCs(Encodings_3D_pre[:,0,:])\n",
    "plane_vectors_2 = get_PCs(Encodings_3D_pre[:,1,:])\n",
    "normal_1 = np.cross(plane_vectors_1[:,0], plane_vectors_1[:,1])\n",
    "normal_2 = np.cross(plane_vectors_2[:,0], plane_vectors_2[:,1])\n",
    "\n",
    "fig = plt.figure(figsize = (10,5))\n",
    "ax = fig.add_subplot(121, projection='3d')\n",
    "xx, yy, z = plane_plotter(normal_1, Encodings_3D_pre[:,0,:])\n",
    "ax.plot_surface(xx, yy, z, alpha=0.15, color='k', linewidth=0)\n",
    "\n",
    "xx, yy, z = plane_plotter(normal_2, Encodings_3D_pre[:,1,:])\n",
    "ax.plot_surface(xx, yy, z, alpha=0.15, color='k', linewidth=0)\n",
    "\n",
    "ax.scatter(Encodings_3D_pre[0,0,:], Encodings_3D_pre[1,0,:], Encodings_3D_pre[2,0,:], c = colours, marker = 'o', s = 100)\n",
    "ax.scatter(Encodings_3D_pre[0,1,:], Encodings_3D_pre[1,1,:], Encodings_3D_pre[2,1,:], c = colours, marker = '^', s = 100)\n",
    "\n",
    "for plot in range(2):\n",
    "    for q in range(4):\n",
    "        ax.plot([Encodings_3D_pre[0,plot,q], Encodings_3D_pre[0,plot,np.mod(q+1,4)]], [Encodings_3D_pre[1,plot,q], Encodings_3D_pre[1,plot,np.mod(q+1,4)]], [Encodings_3D_pre[2,plot,q], Encodings_3D_pre[2,plot,np.mod(q+1,4)]], 'gray')\n",
    "ax.view_init(elev=70, azim=20)\n",
    "#ax.set_xticks([-0.2, 0, 0.2])\n",
    "#ax.set_yticks([-0.2, 0, 0.2])\n",
    "#ax.set_zticks([-0.2, 0, 0.2])\n",
    "\n",
    "ax.set_title(f\"Cosine of Angle Between Planes: {np.dot(normal_1, normal_2):.3f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "id": "9be3bec8-b08a-48f7-b1cf-3a76e738b67f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3, 2, 4)"
      ]
     },
     "execution_count": 145,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Encodings_3D_pre.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "43fb86af-4a22-4087-93ba-18ead2eac09a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20, 2, 4)"
      ]
     },
     "execution_count": 99,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "\n",
    "eigvecs_plane_1 = plane_extract(pre_act_3D_subspace[:,:Q])\n",
    "eigvecs_plane_2 = plane_extract(pre_act_3D_subspace[:,Q:])\n",
    "\n",
    "normal_1 = np.cross(eigvecs_plane_1[:,0], eigvecs_plane_1[:,1])\n",
    "normal_2 = np.cross(eigvecs_plane_2[:,0], eigvecs_plane_2[:,1])\n",
    "\n",
    "fig = plt.figure(figsize = (10,5))\n",
    "ax = fig.add_subplot(121, projection='3d')\n",
    "xx, yy, z = plane_plotter(normal_1, pre_act_3D_subspace[:,:Q])\n",
    "ax.plot_surface(xx, yy, z, alpha=0.15, color='k', linewidth=0)\n",
    "\n",
    "xx, yy, z = plane_plotter(normal_2, pre_act_3D_subspace[:,Q:])\n",
    "ax.plot_surface(xx, yy, z, alpha=0.15, color='k', linewidth=0)\n",
    "\n",
    "ax.scatter(pre_act_3D_subspace[0,:Q], pre_act_3D_subspace[1,:Q], pre_act_3D_subspace[2,:Q], c = colours, marker = 'o', s = 100)\n",
    "ax.scatter(pre_act_3D_subspace[0,Q:], pre_act_3D_subspace[1,Q:], pre_act_3D_subspace[2,Q:], c = colours, marker = '^', s = 100)\n",
    "\n",
    "for plot in range(2):\n",
    "    for q in range(4):\n",
    "        ax.plot([pre_act_3D_subspace[0,q+plot*4], pre_act_3D_subspace[0,np.mod(q+1,4)+plot*4]], [pre_act_3D_subspace[1,q+plot*4], pre_act_3D_subspace[1,np.mod(q+1,4)+plot*4]], [pre_act_3D_subspace[2,q+plot*4], pre_act_3D_subspace[2,np.mod(q+1,4)+plot*4]], 'gray')\n",
    "ax.view_init(elev=20., azim=150)\n",
    "ax.set_xticks([-0.2, 0, 0.2])\n",
    "ax.set_yticks([-0.2, 0, 0.2])\n",
    "ax.set_zticks([-0.2, 0, 0.2])\n",
    "\n",
    "ax.set_title(f\"Cosine of Angle Between Planes: {np.dot(normal_1, normal_2):.3f}\")\n",
    "\n",
    "eigvecs_plane_3 = plane_extract(post_act_3D_subspace[:,:Q])\n",
    "eigvecs_plane_4 = plane_extract(post_act_3D_subspace[:,Q:])\n",
    "\n",
    "normal_3 = np.cross(eigvecs_plane_3[:,0], eigvecs_plane_3[:,1])\n",
    "normal_4 = np.cross(eigvecs_plane_4[:,0], eigvecs_plane_4[:,1])\n",
    "\n",
    "ax = fig.add_subplot(122, projection='3d')\n",
    "xx, yy, z = plane_plotter(normal_3, post_act_3D_subspace[:,:Q])\n",
    "ax.plot_surface(xx, yy, z, alpha=0.15, color='k', linewidth=0)\n",
    "\n",
    "xx, yy, z = plane_plotter(normal_4, post_act_3D_subspace[:,Q:])\n",
    "ax.plot_surface(xx, yy, z, alpha=0.15, color='k', linewidth=0)\n",
    "\n",
    "ax.scatter(post_act_3D_subspace[0,:Q], post_act_3D_subspace[1,:Q], post_act_3D_subspace[2,:Q], c = colours, marker = 'o', s = 100)\n",
    "ax.scatter(post_act_3D_subspace[0,Q:], post_act_3D_subspace[1,Q:], post_act_3D_subspace[2,Q:], c = colours, marker = '^', s = 100)\n",
    "for plot in range(2):\n",
    "    for q in range(4):\n",
    "        ax.plot([post_act_3D_subspace[0,q+plot*4], post_act_3D_subspace[0,np.mod(q+1,4)+plot*4]], [post_act_3D_subspace[1,q+plot*4], post_act_3D_subspace[1,np.mod(q+1,4)+plot*4]], [post_act_3D_subspace[2,q+plot*4], post_act_3D_subspace[2,np.mod(q+1,4)+plot*4]], 'gray')\n",
    "ax.view_init(elev=-0., azim=30)\n",
    "ax.set_title(f\"Cosine of Angle Between Planes: {np.dot(normal_3, normal_4):.3f}\")\n",
    "ax.set_zlim([-0.0005, 0.0005])\n",
    "demeaned_act =  pre_act_3D_subspace[0,:Q] - np.mean(pre_act_3D_subspace[:,:Q])\n",
    "ax.set_xticks([-0.2, 0, 0.2])\n",
    "ax.set_yticks([-0.2, 0, 0.2])\n",
    "ax.set_zticks([-0.0005, 0, 0.0005])\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rep_theo",
   "language": "python",
   "name": "rep_theo"
  },
  "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": 5
}
