{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Demo P4 Local Self-Attention\n",
    "\n",
    "In this demo, we will analyze the equivariance properties of p4m group-equivariant self-attention models (i.e., to rotations by 90 degrees and reflections).\n",
    "\n",
    "First, we will demonstrate the translation equivariance of the model and, subsequently, we will perform an analysis into the rotation and reflection equivariance properties of the model."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "source": [
    "## Importing Libraries\n",
    "Add the library to the system path via the relative folder structure:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os,sys\n",
    "g_selfatt_source =  os.path.join(os.getcwd(), '..')\n",
    "if g_selfatt_source not in sys.path:\n",
    "    sys.path.append(g_selfatt_source)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Import the necessary libraries:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "# project\n",
    "import g_selfatt\n",
    "# other\n",
    "from matplotlib import pyplot as plt\n",
    "import importlib"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## P4 Self-Attention Layers\n",
    "\n",
    "In what follows we take:\n",
    "\n",
    "* a random noise image f as input\n",
    "* apply a sequence of p4 self-attention layers to it f -> N(f)\n",
    "* translate the input (T(f)) via the action of the translation group on f and send it through the same sequence of layers and (T(f) -> N(T(f)))\n",
    "* then we test the equivariance property T'(N(f))=N(T(f)) In the above T denotes the translation operator of 2D images, and T' denotes the translation operator on feature maps.\n",
    "\n",
    "Subsequently, we repeat the process for rotations:\n",
    "\n",
    "* apply a sequence of p4 self-attention layers to it f -> N(f)\n",
    "* rotate the input (R(f)) via the action of the rotation group on f and send it through the same sequence of layers and (R(f) -> N(R(f)))\n",
    "* then we test the equivariance property R'(N(f))=N(R(f)) In the above R denotes the rotation operator of 2D images, and R' denotes the rotation operator (shift-twist) of SE(2) images, which is a planar rotation and a periodic shift along the extra rotation axis.\n",
    "\n",
    "\n",
    "Now, let us create a net with two self-attention layers, with a total of 3 ** 2 heads:"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The input feature map"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "Nxy = 15 # This spatial dimension\n",
    "N_in = 10 # This many feature channels\n",
    "B = 4 # Batch size\n",
    "# For now we work with a placeholder\n",
    "inputs = torch.randn([B,N_in,Nxy,Nxy], dtype=torch.float32)\n",
    "inputs[:,:, :4, :] = 0.0 \n",
    "inputs[:,:, :, :4] = 0.0 \n",
    "inputs[:,:, -4:,:] = 0.0 \n",
    "inputs[:,:, :, -4:] = 0.0 "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Attention Layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Layer parameters\n",
    "num_heads = 3 ** 2\n",
    "\n",
    "# Construct the group we want to test equivariance on.\n",
    "num_elements = 4\n",
    "group = g_selfatt.groups.SE2(num_elements)\n",
    "\n",
    "# Construct the layers.\n",
    "sa_1 = g_selfatt.nn.LiftSelfAttention(\n",
    "        group=group,\n",
    "        in_channels=N_in,\n",
    "        mid_channels=N_in,\n",
    "        out_channels=N_in * 2,\n",
    "        num_heads=num_heads,\n",
    "        max_pos_embedding=Nxy,\n",
    "        attention_dropout_rate=0.)\n",
    "\n",
    "sa_2 = g_selfatt.nn.GroupSelfAttention(\n",
    "    group=group,\n",
    "        in_channels=N_in * 2, \n",
    "        mid_channels=N_in, \n",
    "        out_channels=N_in * 4,\n",
    "        num_heads=num_heads,\n",
    "        max_pos_embedding=Nxy,\n",
    "        attention_dropout_rate=0.)\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test the network - Translation Equivariance\n",
    "\n",
    "We create random noise input and translated noise:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "input_tensor = inputs\n",
    "input_tensor_trans = torch.roll(inputs, (1,1), dims=(-2,-1))\n",
    "\n",
    "f,axs = plt.subplots(1,2,figsize=(10,10))\n",
    "plt.subplot(1,2,1);plt.imshow(input_tensor.numpy()[0, 0,:, :])\n",
    "plt.subplot(1,2,2);plt.imshow(input_tensor_trans.numpy()[0,0,:,:,])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Pass the original random signal to the network and then its translated version"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "#%%timeit\n",
    "out_1 = sa_1(input_tensor)\n",
    "out_2 = sa_2(out_1)\n",
    "\n",
    "out_1_trans = sa_1(input_tensor_trans)\n",
    "out_2_trans = sa_2(out_1_trans)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's compare the results. Recall that now all feature maps are a funtion of the group. Thus it is composed of group.num_elements 'channels'."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FIRST LAYER:\n",
      "\n",
      "The original input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The translated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2cAAADVCAYAAADToYiGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAjX0lEQVR4nO3dfZBldX3n8c/3PnTPTPfgzIDIw2AEBApikgVnXR8TE6IhxBJrtTaQRNlIdjZr+WxWcd1Kyq3KbhKTaFJaulNKRrOsbkIksoouLNFgFNCBgIDDkzzIIDAgy0PPU3ff890/+o40TT/cz7n3dJ/p+35VTU133+89v9855/c5v/Pr2307MlMAAAAAgJXVWOkOAAAAAABYnAEAAABALbA4AwAAAIAaYHEGAAAAADXA4gwAAAAAaoDFGQAAAADUQGs5G2uOjWV7w6ben+C+y7+51IyOuX1JGeYTKl7+2vvgHlNzf93j05j26iUpm2a9Oy4Kr37/Q7sezcznes+qTnNsLNsbK8yZy82MVH2fXGZ/3DEa7v5WXa8SuXGPkTkuJh+oV84kqTk+lq3DjazZB8krV1EmbCa3CXefO2YDrYqPqTtQ7TCXaKNik/fXK2vNsbFsbTJy5t53VT1GJalR8QWyam536jaHSyWy6d4Ae+WL5WxZF2ftDZv0/P/wnp7rY9o7MJ013pFpT/iDv2ib9SNen9ybuvYT3j64i6HCHCHu8Vm720/w5AZvn6fXeW0093nbv+2/vvc+6wkVa2/cpM1v7z1njalqbz7cMSSVWLSbE1k2vX1wj9HUuLt9q9w+Pu61VJKmx8zcHPC23xn16u9+//tqlTNJah2+SUd/4F0912fb/M6PudhqTpgTSAn2nGbuc+tJbx+mjzDDM+3duTf2e/XFqHmOS7ThSnMBe9/b/2OtstbatEnHvvfdPdcXo9WO0eZTfs46414blY8Jd7Ho7rIZA3eOcse05M/74S6QzRdL7nvHwjnr6+xHxFkRcXtE3BURF/azLQALI2tA9cgZUD1yBiyu9OIsIpqSPiHpVyWdJum8iDhtUB0DMIOsAdUjZ0D1yBmwtH5eOXuJpLsy8+7MnJT0BUnnDKZbAGYha0D1yBlQPXIGLKGfxdmxku6f9fmu7tcADBZZA6pHzoDqkTNgCf0szub7Tbln/bZdRGyNiB0RsaOzZ08fzQFDa8mskTOgb/6cNjGxDN0CVhXuHYEl9LM42yXpuFmfb5b0o7lFmbktM7dk5pbm2FgfzQFDa8mskTOgb/6cNj6+bJ0DVgnuHYEl9LM4+66kkyLi+IgYkXSupMsG0y0As5A1oHrkDKgeOQOWUPrvnGXmdES8XdL/0cxfQLgoM28dWM8ASCJrwHIgZ0D1yBmwtL7+CHVmXi7p8gH1BcACyBpQPXIGVI+cAYur9k+QAwAAAAB60tcrZ65spw4cM9X7E6bMtWO7sMqnD2t625eUrWe9qdCiYu20t/1ivjcyWtj02rZVH1737f1N8xyo4fVfkg5s9NrIMe8cxF5/XNRJhlSM9n7e0v0WjVmfDXPQScqWl4N53uxroLLpbb9Y6+bA299sevUNs/+S1FnjPsfrU8c9RnUUqRztfT/CvT6aiik3N/LzbM4JGvH2udjvdagx2rHq3f7bZ6zE9a5YU3EWSuS/VkIq2sacZmRSkmLEG0PFZInXNcxxWrhDouqXWtxrl3v/7l6HylxLzWy69+ODXFHxyhkAAAAA1ACLMwAAAACoARZnAAAAAFADLM4AAAAAoAZYnAEAAABADbA4AwAAAIAaYHEGAAAAADXA4gwAAAAAaoDFGQAAAADUAIszAAAAAKgBFmcAAAAAUAOtZW0tQ3Gg2XN5TIa3+cKrb+z36iUpW95ziuh9f2caMPfBPEaRVrlkbr8zavZn2iqXJLX2em1MN71z0Nx/6H/PwhlG4cbAHENZ5nCabURhbt7sU92Okd0d/1InNdyTUKaRQ1wRin29n7w0x6l74lrLcO3qjHrjwt3npjkvT+2t9jamOeEd08I8PpIUnWqzk02/T7XSSOVYp+fy5lrvxmJkxKvfN+XnrL12yqqftq+/Xrmr0fKCXLS9Y5RmBpoj7sVU/g2wef21r++LOPTvQgEAAABgFWBxBgAAAAA1UHpxFhHHRcTXI2JnRNwaEe8aZMcAzCBrQPXIGVA9cgYsrZ8f1p6W9L7MvCEi1ku6PiKuzMzvD6hvAGaQNaB65AyoHjkDllD6lbPMfDAzb+h+/JSknZKOHVTHAMwga0D1yBlQPXIGLG0gv3MWES+QdLqk6+Z5bGtE7IiIHZ2JiUE0BwythbL2jJzt2bMifQNWC+Y0oHq954w5DcOl78VZRIxL+jtJ787MJ+c+npnbMnNLZm5pjo/32xwwtBbL2jNyNja2Mh0EVgHmNKB6Xs6Y0zBc+lqcRURbM+G6ODO/OJguAZiLrAHVI2dA9cgZsLh+3q0xJH1G0s7M/PPBdQnAbGQNqB45A6pHzoCl9fPK2SskvVnSL0XEjd1/Zw+oXwCeRtaA6pEzoHrkDFhC6bfSz8x/khQD7AuAeZA1oHrkDKgeOQOW1s/fOfMVUnNP7y/WRcfcfOHVN/f714fCPmJNswFz6we8+sakt8/FSFr1UXjbb5d4s7NsmfvQ9uob5jGto8Z07/vcmPa2nWZsGiXm4TBzIG+Y2tu3643jL/m5dK+Nbr1Uok/mOHKPUS1FKtvG4GuZA9Ucd+71WioxNppmG2a9vQ/uMTW5/bHGw0FuFMz6jGqPUeUaqcZI7wO13fYG9Wjbu3jtH3EnKGl0tOKJtmLtEa//Uw3v3rcovB/ka7X8Sa3RqDYHnc5A3gBf0oDeSh8AAAAA0B8WZwAAAABQAyzOAAAAAKAGWJwBAAAAQA2wOAMAAACAGmBxBgAAAAA1wOIMAAAAAGqAxRkAAAAA1ACLMwAAAACoARZnAAAAAFADLM4AAAAAoAZYnAEAAABADbSWtbWQinb2XN7IsDZfmHsTba9ektJczmaj9/2VZC+Xs+kdo2x5/cmmVa7C3H7R9vovSUXT3AdzXLj1tRNSMWIcIzNn9hgq8S2g6JhPMPdBZi5j2jxGzvGX1DGPUWPKq3f7L0nFqHntcsvNY1RbzqH1T0PlKp/T3H0268OdDzrutcIrd68tM8zrS1R7X1E7nYbyiZGey/fv9ybxA+3ety1JetK/SZiYMk+CW1+xqTCPkTsnF155x8y9JD8HbhPF4C7w9Tr7AAAAADCk+l6cRUQzIv45Ir48iA4BeDZyBiwPsgZUj5wBCxvEK2fvkrRzANsBsDByBiwPsgZUj5wBC+hrcRYRmyX9mqRPD6Y7AOYiZ8DyIGtA9cgZsLh+Xzn7mKT3a5Ff5YuIrRGxIyJ2dCb29NkcMJQ+JnIGLIePiawBVfuYrJxNLFvHgDoovTiLiNdJ2p2Z1y9Wl5nbMnNLZm5pjo+VbQ4YSuQMWB5kDaheuZyNL1PvgHro55WzV0h6fUTcK+kLkn4pIv7HQHoF4CByBiwPsgZUj5wBSyi9OMvMD2bm5sx8gaRzJf1DZv7WwHoGgJwBy4SsAdUjZ8DS+DtnAAAAAFAD/p85n0dmfkPSNwaxLQDzI2fA8iBrQPXIGTA/XjkDAAAAgBoYyCtnPcvuvx6FUVtGY9p/TmEesVM/8oBVv+uNz7fqJzdY5Zpe4x3URsfb/tgD3nr/Fb9xg9eApKu+drpVH+Z5jgXf3PfQEIXU3Bs91zemeq+VpGx6/XHrJakx5dUf/0c3WfWP/vrPWfWH3Tfpbf9nRq36I19/v1V//7c2W/XveNOXrXpJ+uhXXmfVt/Z52+8U3rirpZDU6v2CEQ1zUjPrs1ni+63maTj1w/da9bf9pxOs+uee9ohVP3npkVb99NmPW/Wjf7/Bqv/if/kzq16SXnX5e+3nWNxxVzeRypHec9Zc5036rbZXf2DKz1l7zJtD8l7vnWA767wbl8Pu8ibmJ1/o3Qyu2+z9+YPzT77Wqr/pyeOsekm65u7jrXr3ep2dwc1pvHIGAAAAADXA4gwAAAAAaoDFGQAAAADUAIszAAAAAKgBFmcAAAAAUAMszgAAAACgBlicAQAAAEANsDgDAAAAgBpgcQYAAAAANcDiDAAAAABqgMUZAAAAANRAazkbi5SaB6L3+sLbfmtf79uWpJj26iWpUaT3hPTqnzx1yqr/11uut+ovvfl0q379pgmrft8Nh1v1V19yhlUvSa2mV59tr75hjNE6ypDSSHaaYzTNw+PWS1JhnrNi716r/tStt1r1a5teLq/afI1Vf/LVb7Hq1++yyvWn3/4V7wmSmmGOi6Z3orNhXkvrqAjF3t4vSNk299nMTmtfie+3ml3qPLzbqn/jqx6x6r+9+3ir/vFX7bfq1xbeMSrMu6RX/+3veU+Q1DDnNNeqyJqRhaJjXotaZtDMe1NJKsxxd+KF3hxy7//6Wat+7Ul7rPon7t9k1Z925ENW/aeueI1Vf+Sp3nWljHTHUZmbnQXwyhkAAAAA1EBfi7OI2BARl0TEbRGxMyJeNqiOAXgaWQOqR86A6pEzYHH9/ljjX0j6Wma+KSJGJK0bQJ8APBtZA6pHzoDqkTNgEaUXZxFxmKSfl/RvJSkzJyVNDqZbAA4ia0D1yBlQPXIGLK2fH2s8QdIjkv4qIv45Ij4dEWMD6heAp5E1oHrkDKgeOQOW0M/irCXpDEmfzMzTJe2RdOHcoojYGhE7ImJHZ4/37jAAJPWQtdk5KybIGVCCP6dNeO9mC6BEzp5iTsNw6WdxtkvSrsy8rvv5JZoJ3DNk5rbM3JKZW5pjfHMEKGHJrM3OWWOcnAEl+HPa+PiydhBYBfycrWdOw3ApvTjLzIck3R8Rp3S/dKak7w+kVwB+gqwB1SNnQPXIGbC0ft+t8R2SLu6+287dkn67/y4BmAdZA6pHzoDqkTNgEX0tzjLzRklbBtMVAAsha0D1yBlQPXIGLK6vP0INAAAAABiMfn+s0ZINaXq86Lm+cSCs7RejadU3mv7aNFteG1/5zles+p/++Nus+ntOPdyqP/kT3p8TueecTVb9RW/5uFX/9YnTrHpJ+tzlv2jVO2NOkrJxiH/PopGaXt/pvfyAt7/Z8DJQ6ltAZhO6arNV/s2dR1n17YfbVv2/ePB0q/7ou6et+h+/yLs2XvCSf7LqJekz17zKqi9GzXG0tvcxWluRypHeB2us8fY5C+88d8xzIEkKM2xm1q743POt+qdO8I7RmkeaVn0cWGvVP/6L+6z6//xib86XpA9//Q3eE9xrsDeM6icldYydcHPTMXNjbl/ys3zHX73Yqh9r77fqnzPq1T/1A28OvPu7J1v1zTO9d+Q8euxJq16SHn54g/0cR7r3LYs4xO9CAQAAAGB1YHEGAAAAADXA4gwAAAAAaoDFGQAAAADUAIszAAAAAKgBFmcAAAAAUAMszgAAAACgBlicAQAAAEANsDgDAAAAgBpgcQYAAAAANcDiDAAAAABqoLWsrRVSc0/v68HGlLf5KMKqbxzwti9J2fTaOOGSf2/Vn3rRD6z6ne2TrPpf+dR3rPo7vvViq/4Pf+3Xrfqd79po1UvS2j3eOUjzexCtfd726yY6ofbjzZ7rG5Pm8WykV997V34iOl79/f/wfKt+rbd5HXmjdzH68e/sservf+F6q/6EL+636r/1sQ1WvSS1PuxND41Jb/uFMResFmnOUSqq6cds7rx5xx3HeA2c5mXnef/oXTDe/KH/bdV//NZXW/Vrv+Nl86PffZNVL0k6edqr75jj6FCPWkiK3uedaHrBaTS8+k7TmwMlKcxTNrLOy83UrYdZ9Xed2Lbqf/+3/8aq/8ObzrbqR68ft+of2zRm1UtStCq+oE4PLmiHemQBAAAAYFXoa3EWEe+JiFsj4paI+HxErBlUxwA8jawB1SNnQPXIGbC40ouziDhW0jslbcnMF0lqSjp3UB0DMIOsAdUjZ0D1yBmwtH5/rLElaW1EtCStk/Sj/rsEYB5kDageOQOqR86ARZRenGXmA5L+VNIPJT0o6YnMvGJQHQMwg6wB1SNnQPXIGbC0fn6scaOkcyQdL+kYSWMR8Vvz1G2NiB0RsaPY472DGYDesjY7Zx1yBtjKzGmdCbIGOErl7ClyhuHSz481/rKkezLzkcyckvRFSS+fW5SZ2zJzS2ZuaYz5b30JYOmszc5Zk5wBZdhzWnOcrAEmP2fryRmGSz+Lsx9KemlErIuIkHSmpJ2D6RaAWcgaUD1yBlSPnAFL6Od3zq6TdImkGyTd3N3WtgH1C0AXWQOqR86A6pEzYGmtfp6cmX8g6Q8G1BcACyBrQPXIGVA9cgYsrt+30gcAAAAADEBfr5xVzlw6ZjOt+sjwGpDktSDFxkmrfu9fr7Hqi+94PfraV/6lVa9NhVW+58SNVv2ah/whmO63FMzTbG+/blKK6d7LG0atJGXDO6CZbmokmdnMprf5c9/4Dav+4vFfsOrXhLfPb3zld6z6mz97mlX/wNvOsOolKQpvHxrT3jkr2iXGxaGuY16MzHEU3uW61HM2bX7cqj9+w2NW/fcePcmqf3RqvVXfuWvcql//iHcO/t9r91n1khQ/HvWe4N4bmVmunZRU9J6d7HgHyL13tHMsKd1s3um9CcrtF3zSqn/TD37Zqv/mE6dY9e/5maus+ks/eqZVf//oMVa9JOUL95tPMO9DSoyLhRzqt6EAAAAAsCqwOAMAAACAGmBxBgAAAAA1wOIMAAAAAGqAxRkAAAAA1ACLMwAAAACoARZnAAAAAFADLM4AAAAAoAZYnAEAAABADbA4AwAAAIAaYHEGAAAAADXQWtbWGlJnbfZcnpNhbb4Y6X3bktSZ8rYvSdn22vizl/6tVX/v5BFW/V8+5yirXuunrPKTj3vYqr+9cay3/bd926qXpHv+28us+s4a75yFV14/IWW79/IivR1OMzZZ4ioTHa9PP/XK+6367Td4Y2jjfVa5vvAbn7bqz77kfVb9iX+yy6qfuGW9VS9JzQPm9de8Nq6Kbw1mKIx5ysnlwe07GuY5m3mSV379i//Gqn/1LW+w6kcf9/bhsh++yKr/5L/ZZtVv/dK/s+qLJ0eseklqlLgXcUSj2u1XriHFuumey1sjHWvz7ZHety1J06P+pNYe9dr41Hn/3at/3Lv3uv62463600+516r/n4+/xKp/5H3mfcj3rXJJ/rhwFe7N0SJWw/QIAAAAAIc8FmcAAAAAUANLLs4i4qKI2B0Rt8z62qaIuDIi7uz+v7HabgKrH1kDqkfOgOqRM6C8Xl452y7prDlfu1DSVZl5kqSrup8D6M92kTWgattFzoCqbRc5A0pZcnGWmVdLemzOl8+R9Nnux5+V9IbBdgsYPmQNqB45A6pHzoDyyv7O2fMy80FJ6v5/5EKFEbE1InZExI7OxJ6SzQFDq6esPSNne8gZYCo5p00sWweBVaBczp5iTsNwqfwNQTJzW2ZuycwtzfGxqpsDhtIzcjZGzoCqPHNOG1/p7gCr0jNytp45DcOl7OLs4Yg4WpK6/+8eXJcAzELWgOqRM6B65AzoQdnF2WWSzu9+fL6kLw2mOwDmIGtA9cgZUD1yBvSgl7fS/7ykaySdEhG7IuICSX8k6TURcaek13Q/B9AHsgZUj5wB1SNnQHmtpQoy87wFHjpzwH0BhhpZA6pHzoDqkTOgvCUXZwOVUmO69/LGlLn9CKu80TG3L6mQ18Z7v/abVv3Y/U2r/tS/vtuqv+d3TrDqb5862qpvHOadtD1v/FdWvSQ1D3jnIL1DqnDHXd2k1Nzf+zFqTJqbN38YOo3MHxTmcx7Z4/3C+Jr7Rq36o775Y6v+nddtterXvNY7qD/8x+db9eufsMolSQcOT6veGXOSNJ3e9mupVSg29h6gVquosDPSVGvEf5J32nTC/32rVf/mn7vOqv/mDYdb9fec+Byr/p2T51r1cdR+q37N7eusekna/4IDVr15q6NoVjvuKpdSTvV+jSxa3rWl0zEntRKHsyi8k7btoV+w6nc++jyrfuRh7/b/3udtsur3T7at+gN7vGvX6GlPWfWSlFPezaA7Q2XHDOYiKn+3RgAAAADA0licAQAAAEANsDgDAAAAgBpgcQYAAAAANcDiDAAAAABqgMUZAAAAANQAizMAAAAAqAEWZwAAAABQAyzOAAAAAKAGWJwBAAAAQA2wOAMAAACAGmBxBgAAAAA10Fr2FtMobZqbNpeaGV69JH85a+yvJO05trDq73zH8VZ9Y8oqV3t326rPhlf/xAn+SXDPWzbNk6AyA6NGQirazj5Xu79eX2aEmf191x9u1Rctr0/3vMnb/vRab/uNjlcf0945mzrMKpckFV6U7Wtdutuvo06omOh9R4oR7/quwjvPjT1mcErISW8S/Ny1L7fqm2eZ+9Catsr3PrHWqo+9Xn/2H+31Z6YN71YsG17Y0r2g1k1Kmu593GXRsTbfmTaPT8efMztTXhvX3Hai14DbpWO8m8Gpx8at+jSvXTIvjfsnRrwnSAr7XtCTxhhdCq+cAQAAAEANLLk4i4iLImJ3RNwy62sfiYjbIuJ7EXFpRGyotJfAECBrQPXIGVA9cgaU18srZ9slnTXna1dKelFm/qykOyR9cMD9AobRdpE1oGrbRc6Aqm0XOQNKWXJxlplXS3pszteuyMyDP1h9raTNFfQNGCpkDageOQOqR86A8gbxO2dvlfTVhR6MiK0RsSMidnT27BlAc8DQWjBr5AwYmN7ntAmyBpREzoAF9LU4i4gPSZqWdPFCNZm5LTO3ZOaW5thYP80BQ2uprJEzoH/2nDZO1gAXOQMWV/qt9CPifEmvk3RmZlb7/pTAECNrQPXIGVA9cgYsrdTiLCLOkvQBSb+QmXsH2yUAB5E1oHrkDKgeOQN608tb6X9e0jWSTomIXRFxgaSPS1ov6cqIuDEiPlVxP4FVj6wB1SNnQPXIGVDekq+cZeZ583z5MxX0BRhqZA2oHjkDqkfOgPIG8W6NAAAAAIA+lX5DkFJCKkZ7//3P6HibL0YLs0P+2jSbZr3bpwyrvJj0OpQN7/dvixGv3j0+RcvbX0nqrPX61FlrnoPC3Ikacs7DT/7qTK/CHBNlvgXk/pq4W+8PO0u2zGNUmB0yc1xmhwtzdmhMmdcW8xjVUhFq7u19gBfT5nkwD1Fzv3+e3Xm2405pTe962trr7UNnnXeBiY63fef8Sv6cKUmNSa9P7jXVvGTXT0hq9T7wGk1vh1ttLwTTjbZVL0lNo/9SiTnBjb45Jhptr//FlDlIG94ORNO93/fHhRsbv0cL45UzAAAAAKgBFmcAAAAAUAMszgAAAACgBlicAQAAAEANsDgDAAAAgBpgcQYAAAAANcDiDAAAAABqgMUZAAAAANQAizMAAAAAqAEWZwAAAABQAyzOAAAAAKAGWsvaWkrNfb2vBxtT3uY7HW+t2Zrw16bFSHr1U02vgfDKW/vMzU97DeQBr74Y9Y6P239JKkbMg1R456A56W2+brL7r+f6hnfO3DFqdaZkG9n0GkkzljKvRfYxci9FhVdu76+kMM9b2uPCfUINNVOd50z3XB4tc5ya52A6Skzp7nk250C1vME6VXj70FjvhbOY9sLWaXj9ydGOVS/5fbKvqe41vm6KUOzr/SI2XXjXls6Id4Fs7PEvqFPR9p4waY6JiueQjjnHutf36Jj3mm5/JBXmtUhmnwY5p/HKGQAAAADUwJKLs4i4KCJ2R8Qt8zz2exGREXFENd0DhgdZA6pHzoDqkTOgvF5eOdsu6ay5X4yI4yS9RtIPB9wnYFhtF1kDqrZd5Ayo2naRM6CUJRdnmXm1pMfmeeijkt6vcr9RAmAOsgZUj5wB1SNnQHmlfucsIl4v6YHMvGnA/QEwC1kDqkfOgOqRM6A39ls7RcQ6SR+S9Noe67dK2ipJrQ0b3eaAoeVkjZwB5fQzpzUP31Bdx4BVpK+cbdxQXceAGirzytmJko6XdFNE3Ctps6QbIuKo+Yozc1tmbsnMLY3xsfI9BYZPz1l7Rs7GyBlgKD2nNZnTgF71kbPxZewmsPLsV84y82ZJRx78vBuyLZn56AD7BQw9sgZUj5wB1SNnQO96eSv9z0u6RtIpEbErIi6ovlvA8CFrQPXIGVA9cgaUt+QrZ5l53hKPv2BgvQGGGFkDqkfOgOqRM6C8Uu/WCAAAAAAYrMhcvj81ERGPSLpvnoeOkLQSP3e8Uu2uZNvD1u5ytP1TmfncCrdvqWHOVrLtYWt3JdseqpxJtczasLW7km2v5nZrlTVyVou2h63d5Wh7wZwt6+JsIRGxIzO3DEu7K9n2sLW70m3XyTCeg2FrdyXbJmdPG7ZzwHhf/e3W0TCeg2Hb52E81hI/1ggAAAAAtcDiDAAAAABqoC6Ls21D1u5Ktj1s7a5023UyjOdg2NpdybbJ2dOG7Rww3ld/u3U0jOdg2PZ5GI91PX7nDAAAAACGXV1eOQMAAACAobasi7OIOCsibo+IuyLiwnkej4j4y+7j34uIMwbQ5nER8fWI2BkRt0bEu+apeXVEPBERN3b//X6/7Xa3e29E3Nzd5o55Hh/4/na3e8qsfbkxIp6MiHfPqRnIPkfERRGxOyJumfW1TRFxZUTc2f1/4wLPXXQ8lGz7IxFxW/d4XhoRGxZ47qLn5lA2bDnrbnvZs7acOetua0WyRs7mtxI5626XOW0VzmnkbGErkbWVzFl326t6TlupnC3Sdr2ylpnL8k9SU9IPJJ0gaUTSTZJOm1NztqSvSgpJL5V03QDaPVrSGd2P10u6Y552Xy3pyxXs872Sjljk8YHv7wLH/SHN/D2Fge+zpJ+XdIakW2Z97U8kXdj9+EJJf1xmPJRs+7WSWt2P/3i+tns5N4fqv2HMWS/ns+qsVZ2z7rZWJGvkbMHzvew5626XOW0VzmnkbNHzzZz27McP6TltpXK2SNu1ytpyvnL2Ekl3ZebdmTkp6QuSzplTc46kz+WMayVtiIij+2k0Mx/MzBu6Hz8laaekY/vZ5gANfH/ncaakH2TmfH/AsW+ZebWkx+Z8+RxJn+1+/FlJb5jnqb2MB7vtzLwiM6e7n14rabOzzVWAnM2v6qxVmjNp5bJGzua1IjmTap815jRyNmjMafM7pOc07h0Xt5yLs2Ml3T/r81169kDvpaa0iHiBpNMlXTfPwy+LiJsi4qsR8dMDajIlXRER10fE1nker3R/u86V9PkFHqtinyXpeZn5oDRzgZN05Dw1y7Hvb9XMd5bms9S5OVQNY86klc/aSuRMqkfWyNkK5ExiTpvHap7ThjFnUg2yxpz2LKs5Z1INstaqasPziHm+NvetInupKdd4xLikv5P07sx8cs7DN2jmpduJiDhb0t9LOmkAzb4iM38UEUdKujIibuuu2H/SrXmeM7C3z4yIEUmvl/TBeR6uap977t48Xxvkvn9I0rSkixcoWercHKqGMWfSCmat5jmTqt13cva0ZcuZxJw2z8MrnTVyVg3mNOa0Z3Rvnq+tunvH5XzlbJek42Z9vlnSj0rU2CKirZlwXZyZX5z7eGY+mZkT3Y8vl9SOiCP6bTczf9T9f7ekSzXzcuxslezvLL8q6YbMfHievlWyz10PH3x5vfv/7nlqKtv3iDhf0usk/WZmzhvaHs7NoWroctbd3kpmbaVyJq1g1sjZyuRMYk4bpjltyHMmMacN05zGvWPXci7OvivppIg4vrsqP1fSZXNqLpP0lpjxUklPHHyJs6yICEmfkbQzM/98gZqjunWKiJdo5rj8uM92xyJi/cGPNfPLhrfMKRv4/s5xnhZ4WbqKfZ7lMknndz8+X9KX5qnpZTzYIuIsSR+Q9PrM3LtATS/n5lA1VDnrbmuls7ZSOZNWKGvkbGVyJjGnaYjmNHImiTltmOY07h0PyorfcWT2P828u8wdmnmnlQ91v/a7kn63+3FI+kT38ZslbRlAm6/UzEue35N0Y/ff2XPafbukWzXzri/XSnr5ANo9obu9m7rbXpb9ndX+Os0E5jmzvjbwfdZMgB+UNKWZ72hcIOlwSVdJurP7/6Zu7TGSLl9sPAyg7bs08/PIB8/1p+a2vdC5WS3/hilni53P5cjacuVskfFeedbIWX1y1t0uc9rTX1s1cxo5q1fWVipni53T5cjaas/ZIm3XKmvRbRAAAAAAsIKW9Y9QAwAAAADmx+IMAAAAAGqAxRkAAAAA1ACLMwAAAACoARZnAAAAAFADLM4AAAAAoAZYnAEAAABADbA4AwAAAIAa+P8sKB4FCMpKoAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      " SECOND LAYER:\n",
      "\n",
      "The original input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The translated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print('FIRST LAYER:\\n')\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_1.detach().numpy()[0,0,i,:,:])\n",
    "plt.show()\n",
    "\n",
    "print( 'The translated input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_1_trans.detach().numpy()[0,0,i,:,:])\n",
    "plt.show()\n",
    "\n",
    "print('\\n SECOND LAYER:\\n')\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_2.detach().numpy()[0,0,i,:,:])\n",
    "plt.show()\n",
    "\n",
    "print( 'The translated input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_2_trans.detach().numpy()[0,0,i,:,:])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test the network - Rotation Equivariance\n",
    "\n",
    "Now, let's analyze what occurs if the input image is rotated. Lets first see the input"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "input_tensor = inputs\n",
    "input_tensor_90 = inputs.rot90(k=-1, dims=[-2,-1])\n",
    "\n",
    "f,axs = plt.subplots(1,2,figsize=(10,10))\n",
    "plt.subplot(1,2,1);plt.imshow(input_tensor.numpy()[0, 0,:, :])\n",
    "plt.subplot(1,2,2);plt.imshow(input_tensor_90.numpy()[0,0,:,:,]);\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Pass the original random signal to the network and then its rotated version"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_1 = sa_1(input_tensor)\n",
    "out_2 = sa_2(out_1)\n",
    "\n",
    "out_1_90 = sa_1(input_tensor_90)\n",
    "out_2_90 = sa_2(out_1_90)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's compare the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FIRST LAYER:\n",
      "\n",
      "The original input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The rotated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      " SECOND LAYER:\n",
      "\n",
      "The original input.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2cAAADVCAYAAADToYiGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAnQklEQVR4nO3da7Bld13m8ee3L+d+6/tJOp3uhEAChiihBQQFiigVkQFeODUwXqJSZnzhDM44hVCUWvNqRp1SdLB0omIzYwpqSnHIAGoQQVCTQBMSkpB70un7vfvcz9m3/7zoHXK6cy772Wevc1b3/n6qurr77Gf/11p7rWev/T/7nLUjpSQAAAAAwMYqbPQKAAAAAACYnAEAAABALjA5AwAAAIAcYHIGAAAAADnA5AwAAAAAcoDJGQAAAADkQGk9F1YeHUg9O0ZbztenvdVLPd7HAvT2Vq28JIWZn6+aD3Eyl1A38+4GFBtWfGv/jJU/c27YyktSYbBm5esL3j6IuhXXwtHDp1NK27x7Zac8OpB6d4y0fofTZWv8qrvL2vi0jnKf181ywdtps/O9Vr5Q8nrgiqmilS9UvPGrQ15ekqLH2+ahngUrPzXbZ+UrB4/kqmeSVO4dTL2Dm1vON9zTwYj5ZDTtHUeS1Oix72LpOe89AUTDy9d7s/0ec917qlC08XxX9KqjqHkLqQ57J/68ndN6xvrTwHjrJ565ee+g7u/znlDnZs2DQpJK3j4rTnn7LMxTVHGrt83VCe8xTUPec1fBfG061jPr3UHSRKXfytcq3hN27xlvJ0zNHF22Z+s6OevZMaqb/8cdLefP37fDGn9+t3ewvWrPcSsvScWC9+A/edjbhlQ3TzST5i40z90x4j2mP//991n5u//qHVZekvpff8bKTzy3ycqXJ71niad//VdfsO6Qsd4dI7rlE633rPHn263xj7/VfLFVdb8jIO189QkrPz44aeW/+fj1Vn5gs38icPR8pfVvWknS0BHvxHfszf4L2NLuaSv/I7ufs/J//+D3WfmDv/ThXPVMknoHN+uWH/1Qy/mZHd4TcPW2CStf+CfvOJKkmV3ZfuNhz+e9b7SUZrz8xA0DVt795tvEK7zuFPzv+WrsWW+les9636A88nbvhXXezmkD48P64T/5Ny3nH3lylzX+6246YOUfesg7f0iSxrwDY/M/ehPA8qx3Xh79xUNW/tj/223lq2/xzsm9Ze+Yft+e71h5SfrCYe+cc/r51r/xJkk33D1v5b/8L7++bM/W9C2niLg9Ip6MiGci4iNrGQvA8ugakD16BmSPngEra3tyFhFFSX8o6cclvUbSByLiNZ1aMQAX0DUge/QMyB49A1a3lnfO3iDpmZTScymliqTPSHpvZ1YLwCJ0DcgePQOyR8+AVaxlcrZT0uIfWj3c/BqAzqJrQPboGZA9egasYi2Ts6V+y/9lv5EYEXdGxP6I2F+byPaX6oEr1KpdW9yz6sTcOq0WcEWxz2nVBe+iKQD8nlXOc05Dd1nL5OywpMWXxLlG0tFLQymlu1JKe1NKe0uj3lWVAEhqoWuLe1Ye9S4XC0BSG+e0cm8bn1EAdDe7Zz1jnNPQXdYyOfumpFdGxHUR0SPp/ZLu6cxqAViErgHZo2dA9ugZsIq2P+cspVSLiF+W9He68OlZn0wpPdaxNQMgia4B64GeAdmjZ8Dq1vQh1CmlL0r6YofWBcAy6BqQPXoGZI+eAStb04dQAwAAAAA6Y03vnLnKhbquGpxsOX+mf7s1fqm/ZuW39ftX2hosLVj5A/2brXy97s2XK1Vzfh0vuyjSigYGK1b+ut5TVr7W762PJG0bnLHy5wZGrHytVrTyeTNSntdtVz3Zcv6zu8et8UevOWvlK208nj9x9aNWfnfPaSt/ZHrUyl834m1zIy11QbLlfWPPsDd+yXtMi9f6z3V7rzm0emiRf73lG1b+oV3e1bMPWun10ShJs1tbfw6e3+aNv3vsvJV/fov3XCdJ2uad015+Xb2VzW7vtfLlOe/Ynt3hnQMLVSuuyqaGd4c2zEx521zv8Z5fKpuz34YsLdRKevb0lpbz5dPeS9snT3mvNfuP+ee0+Zq3z8ae9XoZySvmcydbfzwladNpb/zJ094FAOfM16bfHN1t5SXp1Env+dHdz6WnD1v5lfDOGQAAAADkAJMzAAAAAMgBJmcAAAAAkANMzgAAAAAgB5icAQAAAEAOMDkDAAAAgBxgcgYAAAAAOcDkDAAAAABygMkZAAAAAOQAkzMAAAAAyAEmZwAAAACQA6X1XNjcQo++/ey1Lee3Pu2NP1UZsPL3a4+3AEmFQsPKpwOD3vh1K66B6fDuYFo4Xbbyd296o5UffcaKS5KeGrvayg8+7x3mveeTlc+bs/OD+j9P3dpy/ur9C9b4h4c3WflC1T9G/3e8wcqPDsxZ+ZMP77DyR7d726y6t83bH/byo8/MWPkjA0NWXpL+eeoGbxkzo1Z+4pEtVj6PipWk4cOtP2kXK0Vr/OdPeY/R4CErLkmaKvZZebfNwwdmrXxxyns+qvaPWfnSgvf83ih5+yzMc7gkDR3z7tR/fN7KT+7xXofkTZKUUutHnrsPwjyo23mFEOadav3ecVeernkLMBUrGb8uMt8qahjHw0t38u6TvF2g6O317rAC3jkDAAAAgBxgcgYAAAAAOdD25CwidkXEVyLi8Yh4LCI+1MkVA3ABXQOyR8+A7NEzYHVr+Z2zmqRfTSk9GBHDkr4VEV9KKX23Q+sG4AK6BmSPngHZo2fAKtp+5yyldCyl9GDz31OSHpe0s1MrBuACugZkj54B2aNnwOo68jtnEbFH0uskPbDEbXdGxP6I2F+f8q4wBuBiy3Xtop5N0jNgLVo9p1UrdA1oV8uvHSe8K34Cl7s1T84iYkjSX0n6lZTS5KW3p5TuSintTSntLQ5f3pdzBTbSSl27qGcj9Axol3NOK/fQNaAd1mvHUe9jkoDL3ZomZxFR1oVy3Z1S+mxnVgnApegakD16BmSPngErW8vVGkPSn0l6PKX0u51bJQCL0TUge/QMyB49A1a3lnfO3iLpZyS9IyIeav55V4fWC8BL6BqQPXoGZI+eAato+1L6KaV/khQdXBcAS6BrQPboGZA9egasbi2fc+ZLkuqtd7JYSdbwYYwtSfWFopWXJPV4yyjWveELVXP8ijd+Mp8SC+b6z1Z7vPGr3viSv58LNW/84ryXz5tULWjhWOu/QN134IQ1/sCxq618oeb1WJLOHR6y8nObvONu4LR3DFUq3viukQPeQVc+dNrKDx7xf6G+1l+28ocHNln5wWOX/+uzWl/o3KtaP40ubPa68IO7Dlr5+2+4ycpLUmHnnJUvlhpW/tyrvS73TPVZ+ck93g8AueeDmT3mSdCMS1Kj7L0WWRjx+jx7vflCIWfG+yb14ZvvbTm/b+TN1vg/s+t+K/+J4tutvCTtHnnZNU9W9OzsbitfmvWer//TLZ+z8r99+t1W/sdf/x0r32MW8xe3fN3KS9K+Ue+4+PutN1r5Uwe9faY/X/6mjlxKHwAAAACwNkzOAAAAACAHmJwBAAAAQA4wOQMAAACAHGByBgAAAAA5wOQMAAAAAHKAyRkAAAAA5ACTMwAAAADIASZnAAAAAJADTM4AAAAAIAeYnAEAAABADjA5AwAAAIAcKK3r0gpJpYFay/HKUNkavjqcrHzfUMXKS1JPufX1l6TpwV5vAcnbBiVvfh11b/jqcMPKbx+YsvLPDFxl5SVJw1UrXh0sWvniQlj53CkmaaT147S6Y9QavjLmrU6h1sbjOert495+L18Z7fPym83imBY2e891xfnN5vj+Pqhu8rZ5y8islZ8ZHbDyeZQGG6q8qfXnvD1bzlnj33XtvVb+Z+v+Kf2dW79r5UcKc1b+o+d/0srHvHdO23LdaSs/M99j5d+950krP1Xznlsk6Rs7r7Xyp0573fmpvQ9Y+f9qpbN3qjKs//n8j7ScP/nkNmv8TzbebOWnH99k5SXp8S3DVn7nw95rr9Ksl/+Lt73Rym96xOvlvZtvsvKumVeYr60l/cvhPVa++tSIlb/hG2es/Ep45wwAAAAAcmDNk7OIKEbEtyPi851YIQAvR8+A9UHXgOzRM2B5nXjn7EOSHu/AOACWR8+A9UHXgOzRM2AZa5qcRcQ1kn5C0p92ZnUAXIqeAeuDrgHZo2fAytb6ztnHJX1Y0rK/iRgRd0bE/ojY35iaWePigK70cRk9q9MzoF0fl9O1SboGtOHjMnpWm/AuNgRc7tqenEXEuyWdTCl9a6VcSumulNLelNLewvBgu4sDulI7PSvSM8DWVtdG6BrgaKdnpSvgyq6AYy3vnL1F0nsi4oCkz0h6R0T8RUfWCsCL6BmwPugakD16Bqyi7clZSumjKaVrUkp7JL1f0j+klH66Y2sGgJ4B64SuAdmjZ8Dq+JwzAAAAAMiBUicGSSl9VdJXOzEWgKXRM2B90DUge/QMWBrvnAEAAABADnTknbOWVQrSwf6W48OH69bwqeBtzkSPf6WtyrIXfl3awFFv/hveJqtnMnl3MOPFStHKf2f8aiu//ai5wZJmXui18sMHvY3unTB3cs6M9M/p9u97rOX8fbfeao1fvWXayjfq3jEkSe961Xet/C1Dh6z8x/UOK//abaet/ELNey46cGaXlR9+YcjKT71u3spL0k27jlv5940/ZOV/b+42K59HKUm1auv7eqHuHRdVec+Ps7UeKy9JjRRW/nzdvHJe1Ru/sODl543Hvx0zNe984+5jSarVzOfIuvcYTde9bcibWrWoEyfGWs4PHPdedx3fMmrlh457j78kVebKVn7giPcxHcXZipV/0ng8JenaQzUrP3Gk9df6kpRK3uu0h0e915qSNHfUO28Om/s5HTpm5VfCO2cAAAAAkANMzgAAAAAgB5icAQAAAEAOMDkDAAAAgBxgcgYAAAAAOcDkDAAAAABygMkZAAAAAOQAkzMAAAAAyAEmZwAAAACQA0zOAAAAACAHmJwBAAAAQA6U1nNhhbrUez5azg8cnLTGrw2MWfmFTf7cNBW9/NCRhpWPujd+edYdP5njext8/KZeKz9wcMbKS1L/7lFvGSerVr739LyVz5vJ+X797eOvaTl/w4PePlgYG7LyhZoVlyTdW7zRyv9z/3VWPj06YuUf3TJo5aPW+vOcJI0/4vVy6IC7z4atvCQ9MbnLyv/JjHdc6FF/nfKmMFdQ76P9LecPbfeeH39981ut/BOPePtMkg5PeM+n3pEtbXnQPGmaC5ia99a/uOAt4B/OvdrKK7wuS9Lg0z1efsJbxj1Dt1h56TNmPmMNKc23fhwVF8zhZ8pWvjjv7+NS2TvuijPeRsRcxcprwjsHFireibw8421vw3yamJn3OiNJhXnvNX9pztvPjakpK78S3jkDAAAAgBxY0+QsIsYi4i8j4omIeDwifqhTKwbgJXQNyB49A7JHz4CVrfXHGn9f0t+mlH4yInokDXRgnQC8HF0DskfPgOzRM2AFbU/OImJE0lsl/ZwkpZQqkswfegWwGroGZI+eAdmjZ8Dq1vJjjddLOiXpzyPi2xHxpxHh/dY8gFbQNSB79AzIHj0DVrGWyVlJ0q2S/iil9DpJM5I+cmkoIu6MiP0Rsb8261+ZD8DqXVvcs/okPQPawDkNyJ7ds/o0PUN3Wcvk7LCkwymlB5r//0tdKNxFUkp3pZT2ppT2lgb45gjQhlW7trhnxRF6BrSBcxqQPbtnxSF6hu7S9uQspXRc0qGIePEDiW6T9N2OrBWA76FrQPboGZA9egasbq1Xa/z3ku5uXm3nOUk/v/ZVArAEugZkj54B2aNnwArWNDlLKT0kaW9nVgXAcugakD16BmSPngErW9OHUAMAAAAAOmOtP9ZoSSE1jCU2Bnqs8Wt94a1P0YpLkho9ycpXB7x1KtSsuAo1d5u9+bj9GFW88RsDZXMB3jEkSfU+c5162jgw8iQ1/7TKO4QUDS/vji9JtQVvJzf6ql6+5PXY1ej3HqSi+Sk/UfXGd59XJHnHUDuyHn8d9JyvaffnTrecn909ao3/hXi9ld/1Zbec0vnrN1n5glc17fj8s1a+MTll5Te/7lVWvlCpW/mpPebnI4f/hDfy5DkrXzhx1sqX5q638i9Y6ewVexoau2qy5fz0hHdMj4x7x9zcdm98SVrY5h13C+NDVj4VvONu+NrWH09JmtwzZuXnx90Xs94J4fXjR73xJX1zwXu9OTPrdX/8mp1WXoeWv4l3zgAAAAAgB5icAQAAAEAOMDkDAAAAgBxgcgYAAAAAOcDkDAAAAABygMkZAAAAAOQAkzMAAAAAyAEmZwAAAACQA0zOAAAAACAHmJwBAAAAQA4wOQMAAACAHCit58K2bZ7QnR/4Ysv5P7jhNmv81+w5YOXv3PFtKy9Jg4UFK3/P6R+w8tO1Xit/cmbIyrtuGDtt5T+/6wtW/o1Dv2zlJelnX/tVK//5Qzdb+WMTg1ZeX/fi6yLFRq/B90Tdv09qeOtfb3jfZ0oZf1uqMGuuTyQrH8nLq43DIaruPjAXkp9DtH0pSZVqy/HydM0avjTjnaKLc37ZigtF7w7mfmvMzFr5VKlY+dLJSSsf9YaVL17d743fMLspKWbmrXzj/ISVLy3465Qn9WpB50+1/lpn+KR3kE5uH7Dym4+3sY/rXs96zs5Y+cJc689DkjR5YsTKX3fQHP8VZSvfMGcjj50a9+4gKR3xutznvfxV7fAR7w4r4J0zAAAAAMiBNU3OIuI/RsRjEfFoRHw6Ivo6tWIAXkLXgOzRMyB79AxYWduTs4jYKek/SNqbUrpZUlHS+zu1YgAuoGtA9ugZkD16BqxurT/WWJLUHxElSQOSjq59lQAsga4B2aNnQPboGbCCtidnKaUjkv67pIOSjkmaSCnd26kVA3ABXQOyR8+A7NEzYHVr+bHGTZLeK+k6SVdLGoyIn14id2dE7I+I/TNnvau9AGita4t7Vp/yrvIEoL1zWqU+t96rCVzW2ulZfZpzGrrLWn6s8UclPZ9SOpVSqkr6rKQ3XxpKKd2VUtqbUto7uNm7tCYASS10bXHPisPmRwEAkNo4p/UUvUszA/B7VhzinIbuspbJ2UFJb4qIgYgISbdJerwzqwVgEboGZI+eAdmjZ8Aq1vI7Zw9I+ktJD0p6pDnWXR1aLwBNdA3IHj0DskfPgNWZn8l9sZTSb0r6zQ6tC4Bl0DUge/QMyB49A1a21kvpAwAAAAA6YE3vnLmKamisONv6HQrJGr8QXn6wsGDlJWlbadLKlwp1K99X9K5o2VP0xs/a1qL3i7sR/jJGS8YxJKlkPkaFnD2mtnpIE61ffKd08qw1fM+kt48LNa+XkhRT3lPTXLnHyg+e8Q68hYb3faxkftur76z3XFQ4N2Xle8+NWnlJmtvmPUbTM31WfuCcFc+lylhZh99zVcv5+W1eF97wNu9Xce7rv8nKS1Jpp3clvDDPs6eqN1v5nmlv/Inrsu3m3K6alY+6f1IbvqH1Y0iSypPjVv7MD5lXyv60F89aqVzX1vHWX3udO7fFGn/bdu913dTV26y8JC1s9V5XzF4zYOWLcw0rv+kqc5t3brby1e3eMVfs8x6fV287YeUl6VuzvVZ+tupd8Kl4w3VWXk8vfxPvnAEAAABADjA5AwAAAIAcYHIGAAAAADnA5AwAAAAAcoDJGQAAAADkAJMzAAAAAMgBJmcAAAAAkANMzgAAAAAgB5icAQAAAEAOMDkDAAAAgBxgcgYAAAAAOVBaz4UdmxnTf7nvX7Wc3/r1Hmv8p6+93sr/xo07rHxbDgx4+fDiPefMO5jxY5vHrfxP1r1DauwrfVZekn5/6p1WfuAFb52GzyQrnzdRl8pTxo4+c94av2fSOyZKC/7jWZ7wvm9UTb3e+NPeOqXwitMoW3GVzs9b+XRuwsr3TF1t5SWp93zRyk9PePug9/zl3bN2JPP5d7C0YOWj4Y0vScWid6dSqe4vxNAwX5U0vMNOUfXyrlTwj+uaeRrs8epvn/fzpt4oaHqu9R1d9J5OrbGlC+dYV1S9nVCcN3s5U7Pycwve6+vRindcx7x3/qhXvXP+dNUsvqRG3dsHvTNePqZnrfxKeOcMAAAAAHKAyRkAAAAA5MCqk7OI+GREnIyIRxd9bXNEfCkinm7+vSnb1QSufHQNyB49A7JHz4D2tfLO2T5Jt1/ytY9I+nJK6ZWSvtz8P4C12Se6BmRtn+gZkLV9omdAW1adnKWUvibp7CVffq+kTzX//SlJ7+vsagHdh64B2aNnQPboGdC+dn/nbEdK6ZgkNf/evlwwIu6MiP0Rsb8+NdPm4oCu1VLXLurZDD0DTO2d02bpGmBor2eT9AzdJfMLgqSU7kop7U0p7S0OD2a9OKArXdSzQXoGZOWirg3QNSALF/VshJ6hu7Q7OTsREVdJUvPvk51bJQCL0DUge/QMyB49A1rQ7uTsHkl3NP99h6TPdWZ1AFyCrgHZo2dA9ugZ0IJWLqX/aUn3SboxIg5HxAcl/TdJPxYRT0v6seb/AawBXQOyR8+A7NEzoH2l1QIppQ8sc9NtHV4XoKvRNSB79AzIHj0D2rfq5KyTYiHU93xvy/mRAwvW+KnQY+Un+gasfDuGD5p3SF6873zDG978QdbSrHeHbz29x8pf/1zFykvS7I7WjyFJGnvWe4x6JutWPm9Kg1Xt+MHjLefPv/NGa/xTb/Iez6iGlZekPTcfsfI7+qes/H0DN1j5vrF5K5/MHh+d9T6LdfS6YSt//M3+Pihf6z2mP7HnKSv/BX2/lf/eBbhzpDzd0Pj9rV9Jbm5HnzX+vWOvtfLj37LikqTJMyNWvmEe29v/sfXnIkkK86rOAyd3WflC1Xv+On+9d74p1Ky4JGn02VkrXz4xaeVrfeNW3n3ZkrWUpFq12HK+ZJ5znLElqc/bXZKkep+3TuVJ77WRe1xX5r2X/6UFs/g1b3vDW31NLnjPpZLUmClb+aL58rQxNe3dYQWZX60RAAAAALA6JmcAAAAAkANMzgAAAAAgB5icAQAAAEAOMDkDAAAAgBxgcgYAAAAAOcDkDAAAAABygMkZAAAAAOQAkzMAAAAAyAEmZwAAAACQA0zOAAAAACAHmJwBAAAAQA6U1nNhqSRVNjdazlfGvNVbGAsrXx+uW3lJSsVk5SvnzYfYG16p4G1zNLwFVAetuAbH5qx8ZWzIW4Ck6qi3DfObvMdI6fL+nkW9UdC52f6W81smvR4Up7xjulCz4pKk83N9Vr636C2kOFm08gu9ZSvvGp7yjunylLfPyuY+k6TKvHefg7ObrHzJ3Ad5VBso6MxrB1rOz233notueOUhK3/oxC4rL0mV3Qv2fRznb91u5Uvzrb9GkKSJ673jNMzno5ld5knZW31JUnWw9WNIkgZOe8+PEzf5r3XypFRsaGxktuX8ueHWz3+StHV0xsqfH/X2lyRVR7wDY27c28fFBW/8oeFpK78w7K1PGqxa+UKvd4zuGTlj5SXp2MiolV/Y5J2jYue4ldeTy990eb8KBQAAAIArxKqTs4j4ZEScjIhHF33tdyLiiYj4TkT8dUSMZbqWQBega0D26BmQPXoGtK+Vd872Sbr9kq99SdLNKaVbJD0l6aMdXi+gG+0TXQOytk/0DMjaPtEzoC2rTs5SSl+TdPaSr92bUnrxJ7fvl3RNBusGdBW6BmSPngHZo2dA+zrxO2e/IOlvlrsxIu6MiP0Rsb8+7f3SJYCLLNu1i3o22fovTgN4mZbPabU5zmlAm1rv2QTnNHSXNU3OIuJjkmqS7l4uk1K6K6W0N6W0tzhkXvoPgKTVu3ZRz0b8K0kB8M9ppX7OaYDL7lkbV0cELmdtX0o/Iu6Q9G5Jt6WUzGvNAmgVXQOyR8+A7NEzYHVtTc4i4nZJvybpbSkl3m8GMkLXgOzRMyB79AxoTSuX0v+0pPsk3RgRhyPig5I+IWlY0pci4qGI+OOM1xO44tE1IHv0DMgePQPat+o7ZymlDyzx5T/LYF2ArkbXgOzRMyB79AxoXyeu1ggAAAAAWKO2LwjSlmJSY6S2eq5pbkvZGr4y5v1uaXHTgpWXpAhvGQtjRXsZjlQM8x5evjLqbe8rN52z8ie3jFh5SaqNtX4MSdLCJu84SnF5f8+iUS9o+lzrV7faedz70f++s6NWPrzdJUk6e8I7LqZn+6x8ecLbx5VCj5VPRa83gye8B6n36KSXP7PNyktSdbjXyr8wvMnK95xzn7vyp1GWZq9qfTsWttat8d+45YCVf2Z83MpL0viO81Y+JW+/zYxvt/KlOW/8ue1e16JhxdW4et7Kp5p//pif87rWKHvLKO+YtvJ5s6V3Rj93/X0t5/+i+AZr/H977X4r/0ezP2LlJem6Me85+9hJ7yPgigvea82fv+EBK/+JH3inlX/7zU9a+YK8Hv+7HV+x8pI0Vp6z8v/Q9yorf26veZ5d4SG6vF+FAgAAAMAVgskZAAAAAOQAkzMAAAAAyAEmZwAAAACQA0zOAAAAACAHmJwBAAAAQA4wOQMAAACAHGByBgAAAAA5wOQMAAAAAHKAyRkAAAAA5ACTMwAAAADIgdK6Li2Sir31luOpUDbH9+KFYsO7g6SenpqVnysnKx9VbyNS0YpL3uooFb07DJUXrPyxsrnTJKnkrVPDfIxSqY11ypN6KKZar3Zhes4avjg/auULFfOgk6SK932jWsXbyQOzVlz1Pu+YKFS99S/Oec8rMTtv5csz/j4oznnbPDvba+UHvMMul1I5af6qasv54R3T1vjvGX3Qyv/dzldbeUl68/bnrXzd/J7uF67eZuWL895xV9/lHUgNs5vXj5/xxk/++eNAdbuVrw55L91uueqYlX/GSmfv1PyQ/uiJt7acrzw5Yo1/1/xbrHx6xBtfkp7fPGTlr93f+vOKJBUXvNezf/KD3jZv2+8d11/tNZ+LSt76n6v0e+NLeviFa6x8zzPeMjZ//aCVXwnvnAEAAABADqw6OYuIT0bEyYh4dInb/nNEpIjYms3qAd2DrgHZo2dA9ugZ0L5W3jnbJ+n2S78YEbsk/Zikzr2PB3S3faJrQNb2iZ4BWdsnega0ZdXJWUrpa5LOLnHT70n6sOzfYgKwFLoGZI+eAdmjZ0D72vqds4h4j6QjKaWHO7w+ABaha0D26BmQPXoGtMa+WmNEDEj6mKR3tpi/U9KdklTc6l3lDehmTtcu6tmmTRmvGXDlWNM5bfNYdisGXEHW0rPSNl47oru0887ZKyRdJ+nhiDgg6RpJD0bE+FLhlNJdKaW9KaW9xeHB9tcU6D4td+2ing3RM8DAOQ3IXts9K40MrONqAhvPfucspfSIpO99KEezZHtTSqc7uF5A16NrQPboGZA9ega0rpVL6X9a0n2SboyIwxHxwexXC+g+dA3IHj0DskfPgPat+s5ZSukDq9y+p2NrA3QxugZkj54B2aNnQPvaulojAAAAAKCzIqX1+6iJiDgl6YUlbtoqaSN+7nijlruRy+625a7HsnenlLZlOL4lhz3byGV323I3ctld1TMpl13rtuVu5LKv5OXmqmv0LBfL7rblrseyl+3Zuk7OlhMR+1NKe7tluRu57G5b7kYvO0+6cR9023I3ctn07CXdtg843q/85eZRN+6DbtvmbnysJX6sEQAAAABygckZAAAAAORAXiZnd3XZcjdy2d223I1edp504z7otuVu5LLp2Uu6bR9wvF/5y82jbtwH3bbN3fhY5+N3zgAAAACg2+XlnTMAAAAA6GrrOjmLiNsj4smIeCYiPrLE7RERf9C8/TsRcWsHlrkrIr4SEY9HxGMR8aElMm+PiImIeKj55zfWutzmuAci4pHmmPuXuL3j29sc98ZF2/JQRExGxK9ckunINkfEJyPiZEQ8uuhrmyPiSxHxdPPvTcvcd8Xjoc1l/05EPNF8PP86IsaWue+K++Zy1m09a4697l1bz541x9qQrtGzpW1Ez5rjck67As9p9Gx5G9G1jexZc+wr+py2UT1bYdn56lpKaV3+SCpKelbS9ZJ6JD0s6TWXZN4l6W8khaQ3SXqgA8u9StKtzX8PS3pqieW+XdLnM9jmA5K2rnB7x7d3mcf9uC58nkLHt1nSWyXdKunRRV/7bUkfaf77I5J+q53joc1lv1NSqfnv31pq2a3sm8v1Tzf2rJX9mXXXsu5Zc6wN6Ro9W3Z/r3vPmuNyTrsCz2n0bMX9zTnt5bdf1ue0jerZCsvOVdfW852zN0h6JqX0XEqpIukzkt57Sea9kv5XuuB+SWMRcdVaFppSOpZSerD57ylJj0vauZYxO6jj27uE2yQ9m1Ja6gMc1yyl9DVJZy/58nslfar5709Jet8Sd23leLCXnVK6N6VUa/73fknXOGNeAejZ0rLuWqY9kzaua/RsSRvSMyn3XeOcRs86jXPa0i7rcxqvHVe2npOznZIOLfr/Yb38QG8l07aI2CPpdZIeWOLmH4qIhyPibyLi+zq0yCTp3oj4VkTcucTtmW5v0/slfXqZ27LYZknakVI6Jl14gpO0fYnMemz7L+jCd5aWstq+uVx1Y8+kje/aRvRMykfX6NkG9EzinLaEK/mc1o09k3LQNc5pL3Ml90zKQddKWQ28hFjia5deKrKVTHsLjxiS9FeSfiWlNHnJzQ/qwlu30xHxLkn/V9IrO7DYt6SUjkbEdklfiognmjP2763WEvfp2OUzI6JH0nskfXSJm7Pa5pZXb4mvdXLbPyapJunuZSKr7ZvLVTf2TNrAruW8Z1K2207PXrJuPZM4py1x80Z3jZ5lg3Ma57SLVm+Jr11xrx3X852zw5J2Lfr/NZKOtpGxRURZF8p1d0rps5fenlKaTClNN//9RUnliNi61uWmlI42/z4p6a914e3YxTLZ3kV+XNKDKaUTS6xbJtvcdOLFt9ebf59cIpPZtkfEHZLeLemnUkpLlraFfXO56rqeNcfbyK5tVM+kDewaPduYnkmc07rpnNblPZM4p3XTOY3Xjk3rOTn7pqRXRsR1zVn5+yXdc0nmHkk/Gxe8SdLEi29xtisiQtKfSXo8pfS7y2TGmzlFxBt04XE5s8blDkbE8Iv/1oVfNnz0kljHt/cSH9Ayb0tnsc2L3CPpjua/75D0uSUyrRwPtoi4XdKvSXpPSml2mUwr++Zy1VU9a4610V3bqJ5JG9Q1erYxPZM4p6mLzmn0TBLntG46p/Ha8UUp4yuOLP6jC1eXeUoXrrTysebXfknSLzX/HZL+sHn7I5L2dmCZP6wLb3l+R9JDzT/vumS5vyzpMV246sv9kt7cgeVe3xzv4ebY67K9i5Y/oAuFGV30tY5vsy4U+Jikqi58R+ODkrZI+rKkp5t/b25mr5b0xZWOhw4s+xld+HnkF/f1H1+67OX2zZXyp5t6ttL+XI+urVfPVjjeM+8aPctPz5rjck576WtXzDmNnuWraxvVs5X26Xp07Urv2QrLzlXXorlAAAAAAMAGWtcPoQYAAAAALI3JGQAAAADkAJMzAAAAAMgBJmcAAAAAkANMzgAAAAAgB5icAQAAAEAOMDkDAAAAgBxgcgYAAAAAOfD/AeHlyZFs3wgCAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The rotated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print('FIRST LAYER:\\n')\n",
    "vmax = torch.max(out_1[0,0,:,:,:]).item()\n",
    "vmax = vmax if torch.max(out_1_90[0,0,:,:,:]).item() < vmax else torch.max(out_1_90[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_1[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_1_90[0,0,:,:,:]).item() < vmin else torch.min(out_1_90[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_1.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.show()\n",
    "\n",
    "print( 'The rotated input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_1_90.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.show()\n",
    "\n",
    "print('\\n SECOND LAYER:\\n')\n",
    "vmax = torch.max(out_2[0,0,:,:,:]).item()\n",
    "vmax = vmax if torch.max(out_2_90[0,0,:,:,:]).item() < vmax else torch.max(out_2_90[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_2[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_2_90[0,0,:,:,:]).item() < vmin else torch.min(out_2_90[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_2.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.show()\n",
    "\n",
    "print( 'The rotated input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(15,15))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_2_90.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "As we can see, the responses are equivalent for rotated versions of the same image. Up to a permutation of the axes (1 to the right) and a rotation of each feature map (by a corresponding rotation to that of the input)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
