{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Demo R8 Self-Attention\n",
    "\n",
    "In this demo, we will analyze the equivariance properties of r8 group-equivariant self-attention models (i.e., to rotations by 45 degrees).\n",
    "\n",
    "First, we will demonstrate the translation equivariance of the model and, subsequently, we will perform an analysis into the rotation 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": [
    "## R8 Self-Attention Layers\n",
    "\n",
    "In what follows we take:\n",
    "\n",
    "* a random noise image f as input\n",
    "* apply a sequence of r8 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 r8 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 = 8\n",
    "group = g_selfatt.groups.SE2(num_elements)\n",
    "\n",
    "# Construct the layers.\n",
    "sa_1 = g_selfatt.nn.LiftLocalSelfAttention(\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",
    "        attention_dropout_rate=0.,\n",
    "        patch_size=5)\n",
    "\n",
    "sa_2 = g_selfatt.nn.GroupLocalSelfAttention(\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",
    "        attention_dropout_rate=0,\n",
    "        patch_size=5)\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": [
    "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 8 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 8 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 8 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 8 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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MgFUkQmUrKM7kUfEJyR9oqZegMYjE0AVmUCpWMrlEF78V+nrkuz6u/RlK54eSK9dtHlncu3Lr7gouXbBRHoPWy79fHLtSy6/MLkWPSL9R0GHP5W+vNGR/3Z3cu1j578suXbbc4uSa4ff+mhy7fSmjPUlMr5nLM9StsuvPCe5dsH29B+cnOW2Fm9Jz+XiT96XXPuzd788uXb+jbcm1+rMX7kMrpFYygUAACATAxQAAEAmBigAAIBMDFAAAACZGKAAAAAyMUABAABkYoACAADIxAAFAACQiQEKAAAgEwMUAABAJpZyOYQdq45Ort31/fRZdOnm6eTa6ZH5ybUffNd1ybU5yw+8+cw3JtfqPemlaJ5dJw4k12793OnJtSef+Ehy7be/+NvJtW9+338m11636neSa4e3JpeicCd8+X+Ta791543JtSu//EfJtUdPpS8R88w3T0iu3XtDxjJEq16aXlsIzkABAABkmnGAsr3e9nbb9+yzbYntDba3tD4eNbttAr2DTABVZAL9KOUM1JikNfttu0TSzRGxUtLNrcdAvxgTmQD2NSYygT4z4wAVERsl7dhv89mSrmp9fpWkc+ptC+hdZAKoIhPoR+1eA3VsRGyTpNbHY+prCWgkMgFUkQkUbdYvIre91va47fGpPbtne3dAz9s3E9OTZALgOIEmaneAesz2CyWp9XH7wQojYl1EjEbE6ODwSJu7A3peW5kYGCITKBbHCRSt3QHqeknntz4/X9I36mkHaCwyAVSRCRQt5TYGV0u6VdKptidsXyDpUkmvt71F0utbj4G+QCaAKjKBfjTjncgj4ryDfGl1zb0AjUAmgCoygX7EUi6H8PTy9Hc4nb46i55cmb4cxpMr068H+OyXzklvYl566YPvOSW9GGhZsCl9GaIddyxLrj32B7uSa39yXvoffuVkGPilnN+PL7n8wuTa9PRIO1dkLLlyy3HptRmXo02sXpheXAiWcgEAAMjEAAUAAJCJAQoAACATAxQAAEAmBigAAIBMDFAAAACZGKAAAAAyMUABAABkYoACAADIxAAFAACQiaVcAHTd1HB67a4XLUiufeS6U9voBgBmxhkoAACATDMOULbX295u+559tv217c22/8f2120vntUugR5CJoAqMoF+lHIGakzSmv22bZB0ekT8hqSfSPpozX0BvWxMZALY15jIBPrMjANURGyUtGO/bTdFxFTr4X9LWjYLvQE9iUwAVWQC/aiOa6DeK+nbB/ui7bW2x22PT+3ZXcPugJ6XnInpSTKBvsBxAsXpaICy/XFJU5K+crCaiFgXEaMRMTo4PNLJ7oCel5uJgSEygbJxnECp2r6Nge3zJb1F0uqIiPpaApqJTABVZAIla2uAsr1G0kckvToi9tTbEtA8ZAKoIhMoXcptDK6WdKukU21P2L5A0t9LWihpg+27bP/DLPcJ9AwyAVSRCfSjGc9ARcR5B9h85Sz0AjQCmQCqyAT6EUu5AGiUp5exgAKA7uM3EQAAQCYGKAAAgEwMUAAAAJkYoAAAADIxQAEAAGRigAIAAMjEAAUAAJCJAQoAACATAxQAAEAmBigAAIBMDFAAAACZGKAAAAAyzThA2V5ve7vtew7wtT+3HbaXzk57QO8hE0AVmUA/SjkDNSZpzf4bbS+X9HpJD9XcE9DrxkQmgH2NiUygz8w4QEXERkk7DvClz0i6WFLU3RTQy8gEUEUm0I/augbK9lslPRIRdyfUrrU9bnt8as/udnYH9Lx2MzE9SSZQJo4TKN1g7j+wPSzp45LekFIfEeskrZOkoRcu5/9CUJyOMnEcmUB5OE6gH7RzBuoUSSsk3W37QUnLJN1p+7g6GwMahEwAVWQCxcs+AxURP5J0zC8ft8IxGhFP1NgX0BhkAqgiE+gHKbcxuFrSrZJOtT1h+4LZbwvoXWQCqCIT6EcznoGKiPNm+PpJtXUDNACZAKrIBPqRI+buej3bj0v66X6bl0oq9bQur623nRgRR3ezATJRlBJeG5mYe7y23nbQTMzpAHXABuzxiBjtahOzhNeGdpT8veW1oR0lf295bc3FWngAAACZGKAAAAAy9cIAta7bDcwiXhvaUfL3lteGdpT8veW1NVTXr4ECAABoml44AwUAANAoXR2gbK+x/WPb99u+pJu91M32g7Z/ZPsu2+Pd7qcTttfb3m77nn22LbG9wfaW1sejutljKchEM5CJuUMmel+/5qFrA5TtAUmfk/QmSadJOs/2ad3qZ5a8JiLOKODPOMckrdlv2yWSbo6IlZJubj1GB8hEo4yJTMw6MtEYY+rDPHTzDNQqSfdHxAMR8ZykaySd3cV+cBARsVHSjv02ny3pqtbnV0k6Zy57KhSZaAgyMWfIRAP0ax66OUAdL+nhfR5PtLaVIiTdZPsO22u73cwsODYitklS6+MxM9RjZmSi2chE/chEcxWfhxnXwptFPsC2kv4k8KyI2Gr7GEkbbG9uTenAwZAJoIpMoGd18wzUhKTl+zxeJmlrl3qpXURsbX3cLunrev5UdEkes/1CSWp93N7lfkpAJpqNTNSPTDRX8Xno5gB1u6SVtlfYni/pXEnXd7Gf2tgesb3wl59LeoOkew79rxrneknntz4/X9I3uthLKchEs5GJ+pGJ5io+D117Cy8ipmy/X9KNkgYkrY+Ie7vVT82OlfR129Lz3+N/jojvdLel9tm+WtLvSlpqe0LSJyRdKumrti+Q9JCkd3SvwzKQieYgE3ODTDRDv+aBO5EDAABk4k7kAAAAmRigAAAAMjFAAQAAZGKAAgAAyMQABQAAkIkBCgAAIBMDFAAAQCYGKAAAgEz/D+mF5VQWeZilAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x720 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy import ndimage \n",
    "\n",
    "angle_in_degrees = -45\n",
    "input_tensor_45 = ndimage.rotate(inputs, angle_in_degrees, reshape=False, axes=(-1,-2), order=1)\n",
    "#output = torch.from_numpy(output)\n",
    "\n",
    "input_tensor = inputs\n",
    "input_tensor_45 = torch.from_numpy(input_tensor_45)\n",
    "input_tensor_90 = inputs.rot90(k=-1, dims=[-2,-1])\n",
    "\n",
    "f,axs = plt.subplots(1,3,figsize=(10,10))\n",
    "plt.subplot(1,3,1);plt.imshow(input_tensor.numpy()[0, 0,:, :])\n",
    "plt.subplot(1,3,2);plt.imshow(input_tensor_45.numpy()[0, 0,:, :])\n",
    "plt.subplot(1,3,3);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_45 = sa_1(input_tensor_45)\n",
    "out_2_45 = sa_2(out_1_45)\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 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The 45 degrees rotated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The 90 degrees rotated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 8 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 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The 45 degrees rotated input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1080x1080 with 8 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 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print('FIRST LAYER:\\n')\n",
    "vmax = max(torch.max(out_1[0,0,:,:,:]).item(), \n",
    "           torch.max(out_1_45[0,0,:,:,:]).item(), \n",
    "           torch.max(out_1_90[0,0,:,:,:]).item())\n",
    "vmin = min(torch.min(out_1[0,0,:,:,:]).item(), \n",
    "           torch.min(out_1_45[0,0,:,:,:]).item(), \n",
    "           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 45 degrees 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_45.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.show()\n",
    "\n",
    "print( 'The 90 degrees 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 = max(torch.max(out_2[0,0,:,:,:]).item(), \n",
    "           torch.max(out_2_45[0,0,:,:,:]).item(), \n",
    "           torch.max(out_2_90[0,0,:,:,:]).item())\n",
    "vmin = min(torch.min(out_2[0,0,:,:,:]).item(), \n",
    "           torch.min(out_2_45[0,0,:,:,:]).item(), \n",
    "           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 45 degrees 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_45.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": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "**DISCLAIMER!** Though the feat.maps look similar, they are not equal. To check this, look at the following example."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(0.0197, grad_fn=<MaxBackward1>),\n",
       " tensor(0.0346, grad_fn=<MaxBackward1>))"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abs(out_1[0,0,0] - out_1[0,0,1]).max(), abs(out_1[0,0,0] - out_1[0,0,2]).max()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(0.0197, grad_fn=<MaxBackward1>),\n",
       " tensor(0.0346, grad_fn=<MaxBackward1>))"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abs(out_1_90[0,0,2] - out_1_90[0,0,3]).max(), abs(out_1_90[0,0,2] - out_1_90[0,0,4]).max()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The max. value is different accross same channels but, for rotated versions, they are equal at the corresponding permuted channel locations."
   ]
  },
  {
   "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
}