{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Demo P4 Self-Attention\n",
    "\n",
    "In this demo, we will analyze the equivariance properties of p4 group-equivariant self-attention models (i.e., to rotations by 90 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": [
    "## 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.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=9)\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=9)\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 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"
    },
    {
     "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": "iVBORw0KGgoAAAANSUhEUgAAA2cAAADVCAYAAADToYiGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAkeUlEQVR4nO3de5BkZ33e8efXl7nszM7uzq5mtZJWWgkkmXsEAxbG2AYBFphITuwyEoYoQKJyOSRgx8XFJCZJ5Y9gJxg7dgJboCyJVVAYcw9gqbgUdpBkLUJXVkhC6LLSalervc6lZ6a73/wxvWg0mpnup7vPzJnt76dqa2emf/O+7+lznvOet3vmTKSUBAAAAABYW4W1HgAAAAAAgMUZAAAAAOQCizMAAAAAyAEWZwAAAACQAyzOAAAAACAHWJwBAAAAQA6UVrWzwaFUHhltuT7M9pP5DVE3O5Ak8y8PuH1Ezv6yQTKX76uxD9wxuS9B1Ite/cyB/YdTSmd435UdO2fmMec+/6uRs0LNq496voJWL7rBMTtoY3PtnJljqpe9+pnH85UzaT5rfUbW3P1gZ83MgeTnP2pZZ8c9uD32nLYK57vM5zTzSi9vWctdztrYx+73FKruRnjldr17fi/14Jzm5myFa8dVXZyVR0b13N/+/Zbr3Ymm3ufVlyb9vesGrO+k10fWF5nuRWB1wKt3L7hKFX8fVPvNbdjg1c8Yc4Ak3fcffv9h7zuyVR4Z1XPf2nrOClWv/dqAV1+a8vdxYc6rHzjmBbM4443JviA1T+ozI94rAm4uS+b2StLcoNdHzRzT9JhVrvv/KF85k6S+kVFd+JbWs+ZeUNT6zfEc9/dz0cxa//E2VoCG5L5QYW7y3FC2c2A7c9qcOUfVzDlwZqtVrvs+nK+s9Y2M6rlXGXPanLcPaua5rtjGPi5WvPoNh72cudtcmPXmzFq/t7KpjHpzWq1vFea0jHNWcXP2H5fPWUc/1hgRl0fEjyPigYj4QCdtAVgeWQOyR86A7JEzYGVtL84ioijpLyW9UdLzJV0dEc/v1sAAzCNrQPbIGZA9cgY018k7Z6+Q9EBK6cGU0qykz0q6sjvDArAAWQOyR86A7JEzoIlOFmdnS3p0wef7G18D0F1kDcgeOQOyR86AJjpZnC31m3LP+g29iLg2IvZGxN7a9GQH3QE9q2nWyBnQMXtOq5I1wEXOgCY6WZztl7RzwefnSHp8cVFKaXdKaTylNF4cHOqgO6BnNc0aOQM6Zs9pJbIGuMgZ0EQni7NbJV0YEedHRJ+kqyR9pTvDArAAWQOyR86A7JEzoIm2/85ZSqkaEe+W9LeSipKuSynd07WRAZBE1oDVQM6A7JEzoLmO/gh1Sunrkr7epbEAWAZZA7JHzoDskTNgZR39EWoAAAAAQHd09M6ZK5WkytZn3ZRnWRsf9tqvV736gWOtj+WUye3eerbWv9SNiZZXmPPGVKh67bvjKc5645na7rW/9I2bVlbZXrPqBw8UrfrCnFWeO6kkzRg5GzZzpuTts/42clYZ9XI2eaa3j4sz5pjM8qibzXvD18TO5jULRdV/Ha5ylndCHTjgTSfhxTiX6iWpsq31+o0/9Q6k4qw3nsGj5oGnduY072B193PdvCqpl805xMxyZcyrj1r2c1r/IfOEsc7Vy9L0ma3vuE33e+0Xqt5BMdBGzqbGMp7TKla5ou5Oal55ddD7hsmzvPowr32l7K8d27icXRbvnAEAAABADrA4AwAAAIAcYHEGAAAAADnA4gwAAAAAcoDFGQAAAADkAIszAAAAAMgBFmcAAAAAkAMszgAAAAAgB1icAQAAAEAOsDgDAAAAgBxgcQYAAAAAOVBa1d5CSuXWyyvbwmp+6uyaVT9wqGjVS9LccLLqa8N1rwNvExQ17zmqD3odxKzXfhr22i8e8Q/B2Dxr1U+rz6ovH1/nr1mEVDc2eWbU28eT53n7uHLYz1l1g5ez6oh5XFe9bZYZY/dlr1Tytre8uWLVVw8PWvWSNLhtyqqfThus+r6n/OMib1JI1YHW9930GWbWzvWO68ED/nM6s9U7uGsbzDC4p9N+cxKsmh2EmbWhOau++tSAVS9J5TOmrfpKyeujfGR9Zy1JqhuXCpWtXs4mzvWO6bauHTea146DXr3NzIE9p/V5Oe4357TZx4asekkqjXk5m+rv99o/2r0l1Tq/CgUAAACA0wOLMwAAAADIgbYXZxGxMyK+ExH7IuKeiHhPNwcGYB5ZA7JHzoDskTOguU5+QLIq6d+mlG6LiI2SfhARN6aUftSlsQGYR9aA7JEzIHvkDGii7XfOUkoHUkq3NT4+KWmfpLO7NTAA88gakD1yBmSPnAHNdeV3ziJil6RLJN2yxGPXRsTeiNhbm5zsRndAz1oua+QM6J5W57Q6WQPaRs6ApXW8OIuIYUl/I+m9KaUTix9PKe1OKY2nlMaLQ/6tLwHMWylr5AzoDmdOK5A1oC3kDFheR4uziChrPlzXp5S+0J0hAViMrAHZI2dA9sgZsLJO7tYYkj4laV9K6aPdGxKAhcgakD1yBmSPnAHNdfLO2askvV3SayPi9sa/N3VpXACeRtaA7JEzIHvkDGii7Vvpp5T+XlJ0cSwAlkDWgOyRMyB75AxorpO/c+arS6WJ1jPZdzxZzU+PeXkvzFrlkqRixesjlcxzUN2rj7rXfCqa40lmfXj7LGptnKOLXh/1slefilZ57kRNKp9o/XktT3jPT2HG22fFaatckpTM9/Rr/d43lKazvTZwx18dqWUzkIaY87e3WvU2Iqrm+beNMeVN1KXyZOvbUZoy2zfPj4U5r/357zH3w5R3XCTzKqNeMOeQWXc8Xvs1MweFaf8HkuZm3CfJ7GCdRy3qUtm4diyfNOc0MzfudZckFc3rTftazbz2qpfda1Mzl33ek1Que3PgnDccSVK9Zl7cude/Xbn/fdebAgAAAAC0i8UZAAAAAOQAizMAAAAAyAEWZwAAAACQAyzOAAAAACAHWJwBAAAAQA6wOAMAAACAHGBxBgAAAAA5wOIMAAAAAHKAxRkAAAAA5ACLMwAAAADIARZnAAAAAJADpdXsrDgrbXw4ZdZ+/1PeWrM03UYfR73xb//2Qau+vnvWqn/NGfdZ9e/fer9V/9afvsaqPzY7aNX/ZMM2q16Stm8+adXvr26x6usni1Z93hTmpKHHjOM0vPbLx72cFape++3Y9dU5q/6RX+2z6v/JZTdb9TcdOt+qLxdrVv1Dj5xh1cdW77wiSZuGK1b94WMDVn06DV4aLM5KGx/Kz5zWTta23e6NvzLqnTD2vP9PvfaTd/79xomXWPUzde+y59sHLrLqD9XNE6qkjSPexciJqY1eB9kdoqvCzVmh6m1w3zEvZ1G3yiVJ/Ue942LH97057Tc/+k2r/uWDD1r1t05fYNW/oP8xq/6df/cOq17b/Dlt88ikVX90zstZ6uK142kwPQIAAADA+tfx4iwiihHxw4j4WjcGBODZyBmwOsgakD1yBiyvG++cvUfSvi60A2B55AxYHWQNyB45A5bR0eIsIs6R9GuSPtmd4QBYjJwBq4OsAdkjZ8DKOn3n7GOS3idp2V+PjIhrI2JvROytVrxfxgMgiZwBq+VjImtA1j4mcgYsq+3FWUS8WdKhlNIPVqpLKe1OKY2nlMZLA0Ptdgf0JHIGrA6yBmSPnAHNdfLO2askXRERD0n6rKTXRsRfdWVUAE4hZ8DqIGtA9sgZ0ETbi7OU0gdTSueklHZJukrSt1NKb+vayACQM2CVkDUge+QMaI6/cwYAAAAAOVDqRiMppe9K+m432gKwNHIGrA6yBmSPnAFL450zAAAAAMiBrrxz1qp6UapsjZbrk7l0TGVzPG1sfXW09fFL0kNX7bDqBz6XrPpP7TrXqt/znEut+pmDG6z6Sy+5z6qfneiz6iXpoDZa9XHE66M4Y5XnTr0kTZ/R+nHqbm+9zztGU8XLjCSN3Vaz6p/4+X6rfvRubxu+lLzcVIe98RenvZPdG159h1V/w20vsuol6Xh50KovHy1a9aUpqzyX6iVpanvrx3ep4rXvzoHyDmtJ0uFLvHxWNy579/Ml/cbnfs+qT+bpIpXM85FZv2XXUateE+aFiKST5jaXTnhZK8745+A8qZek6TFjTjPnnLq5ywpzXr3kX28++jpvH3/sq2+26kvT3nO08eVPWvVPHR226t/3im9a9R/53q9Z9ZJ00pzTCoe9A6M82b2c8c4ZAAAAAOQAizMAAAAAyAEWZwAAAACQAyzOAAAAACAHWJwBAAAAQA6wOAMAAACAHGBxBgAAAAA5wOIMAAAAAHKAxRkAAAAA5ACLMwAAAADIARZnAAAAAJADpdXsrN4vTeyqt1xfnA6r/ah54ynOeu1L0sQFXidpqGrV9x/rt+qrZ85Y9bp/2KsfaX1/SdKRd59l1ZffN2fVS9ILdhyw6n949Hyrfq7gHxd5Uu+TJne2vt/KJ7ztTeZZozjt1UvSwZcVvT7MGJRmklW/62WPWfWP/v1Oq77W743nhnueb9Wrz8uxJJ03dsSq/8nhAau+NrC+cyZJ9bI0vaP157Y04b0eGuZuGzjiHUeSNLvJ2w/1nbNWff8jg1b9zKi3DQMHved0cpc3J8/8v21WfTLbl6Qzzzhu1R887o2pXlrfWav3e9depZPeMZHMp6f/mP98Tp3pHde1zd5xNLx1yqo/b8tRq/7evedZ9fVRb/z/58Nvtup1uXnBL2l006RVf8ic02ZL/jy7HN45AwAAAIAc6GhxFhGbI+LzEXFvROyLiFd2a2AAnkbWgOyRMyB75AxYWac/1vhnkr6ZUvrNiOiTtKELYwLwbGQNyB45A7JHzoAVtL04i4gRSb8k6Z9LUkppVpL3w+gAmiJrQPbIGZA9cgY018mPNV4g6UlJ/ysifhgRn4yIoS6NC8DTyBqQPXIGZI+cAU10sjgrSXqppP+ZUrpE0qSkDywuiohrI2JvROytTXh3SgEgqYWskTOgY/6cNknWAFMb144Tqz1GYE11sjjbL2l/SumWxuef13zgniGltDulNJ5SGi8O8+II0IamWSNnQMf8OW2IrAGmNq4dzT8BBKxzbS/OUkpPSHo0Ii5ufOkyST/qyqgA/AxZA7JHzoDskTOguU7v1vivJV3fuNvOg5Le0fmQACyBrAHZI2dA9sgZsIKOFmcppdsljXdnKACWQ9aA7JEzIHvkDFhZR3+EGgAAAADQHZ3+WKMnpFROLZen2fCar3vDqbex9Rft8e7O9fD7vW3YdMVTVv0vb91v1e9/zmav/hPPteofvmKTVa/w78JUqZW9b2j9kJMkRd3bZ7mTpEK19fKimbNktC1JpYq5AyT1nfTGNPFz3p/JKVT7rPpj391p1c9eWLHqN/xowKov1Lzxz26tWfWSNFP1TpBRM4+jon9c5E5IqWiUu5ts1jtjOeXc//R9q7783R1W/R9c+rdW/ReOvsyq/8FhL5tTBzdb9UpmDgbNE6Sk4T7v/PWEcR0lyT6OcieSUqn1C7yome87mLkptjGn7fi+dw5+9E3e+XT6Ae/aa/oS79pr5KKjVv2xhzdb9cefY+6EqnnB34ZU8vazs75phnfOAAAAACAHWJwBAAAAQA6wOAMAAACAHGBxBgAAAAA5wOIMAAAAAHKAxRkAAAAA5ACLMwAAAADIARZnAAAAAJADLM4AAAAAIAdYnAEAAABADrA4AwAAAIAcKK1qb0lSvfXyeilZzUc9vPG04f73lK36XR/31r8H/9WQVf/Vu8et+j9845es+j8/4yKrXt4uU3XWPwSn5vqs+pjzjouoWuX5ZOyHZMYmmS/p1Mp+Ljc84R1I1UHvmJgeM05EkupDNavePRfNXTLh1Ve83IS7kyUVwgyz95SqVOm91warg+acZu6CuSF/Pz/4x6+06rf/hbej3/G6f2HV/9bP/4NV/98u+mur/u13vtuqr7xkyqpX1T+uC+7E6Woj/7lSD0Wl2HJ5YSbb7S1U/f31+Ku942LzHeZxZJbvP3ezVb9jywmr/uS0N6Cps7w5VkV/H9Tq3piiZh5H5hy4kt6bHQEAAAAghzpanEXE70XEPRFxd0R8JiIGujUwAE8ja0D2yBmQPXIGrKztxVlEnC3p30gaTym9UFJR0lXdGhiAeWQNyB45A7JHzoDmOv2xxpKkwYgoSdog6fHOhwRgCWQNyB45A7JHzoAVtL04Syk9Jum/SnpE0gFJx1NKN3RrYADmkTUge+QMyB45A5rr5Mcat0i6UtL5ks6SNBQRb1ui7tqI2BsRe2sT3h3JALSWtWfkbHJyLYYJrGvtzWlkDXCQM6C5Tn6s8XWSfppSejKlNCfpC5J+YXFRSml3Smk8pTReHB7uoDugZzXN2jNyNuT9OQYAktqa08gaYCJnQBOdLM4ekXRpRGyIiJB0maR93RkWgAXIGpA9cgZkj5wBTXTyO2e3SPq8pNsk3dVoa3eXxgWggawB2SNnQPbIGdBcqZNvTil9WNKHuzQWAMsga0D2yBmQPXIGrKzTW+kDAAAAALqgo3fO/N6StGmu5fJ0rGw1n2bDqp9r43dMi+WaVf8v/8eXrPp/97W3WPWv/cW7rPo/+/FrrPp6n1Wu9MKTVv35o8e9DiQ9b9NBq/7h4W1WfX2iaNXnTrmuOKvScnll2NvJYeYs6v7zWX29d1zUZ71TWTmSVX+2eZwenvBOLiee9G6WVH7S297Rf/SkVS9JL9xywKrfv32LVT933Du/51KprsJY61mrHe23mi9UvKzNjnj1klQbm7XqX//vb7Lqf3hsp1V/ZNbLzu/e/VarfuzF3vwxV/POXwOlqlUvSc/b/IRVf//Adqs+Kuv8dfhSXTE603J5pd87t7hzWir6c1r5PO9u5cc2e+eKmPLG9Paf+4FV/60DF1v15770Mav+p/t2WPUbtkxb9ZI03N/6MSRJhwe86/2Y7t614zpPLAAAAACcHlicAQAAAEAOsDgDAAAAgBxgcQYAAAAAOcDiDAAAAABygMUZAAAAAOQAizMAAAAAyAEWZwAAAACQAyzOAAAAACAHWJwBAAAAQA6wOAMAAACAHCitam+1kE6WWy5PwzWv+aI7IH9tWrxvyKr/w8o/teq3XHTEqv/O373Iqv/dy2+w6v/7ocus+led86hVf/NDu6x6SXpywtsHmguv3izPnWpB9YMDrdcP1K3mo+Y9QamYrHpJmn5gk1Xff8EJq/4F25+w6u86cJZVf87oMau++M3NVv3V7/ZyvPvOV1v1knRL/Tyrvmac2yUp0noPmqRaQbWj/S2XFzbPes1XvEmtEv6UXn6sz6q/fmDcqv/wJf/Xqv/rJ7z233bBrVb9Xz34cqv+uaOHrfq9D3q5kaSjU4NWfTKPi3WftFqoPmmcX8w5J5mxqZf9Oa1v70arfmD8pFV/4YVPWvWPTI9a9Vef6+XsE5/8x1b9a37rTqv+23c9z6qXpEdnvDlKVW+N0M61znJ45wwAAAAAcoDFGQAAAADkQNPFWURcFxGHIuLuBV8bjYgbI+L+xv9bsh0mcPoja0D2yBmQPXIGtK+Vd872SLp80dc+IOlbKaULJX2r8TmAzuwRWQOytkfkDMjaHpEzoC1NF2cppe9JWnyXiislfbrx8acl/Xp3hwX0HrIGZI+cAdkjZ0D72v2ds+0ppQOS1Ph/bLnCiLg2IvZGxN7axESb3QE9q6WsPTNnk6s6QOA0wJwGZK/NnDGnobdkfkOQlNLulNJ4Smm8ODycdXdAT3pmzsw/NQCgZcxpQPaY09DL2l2cHYyIHZLU+P9Q94YEYAGyBmSPnAHZI2dAC9pdnH1F0jWNj6+R9OXuDAfAImQNyB45A7JHzoAWtHIr/c9IuknSxRGxPyLeJem/SHp9RNwv6fWNzwF0gKwB2SNnQPbIGdC+UrOClNLVyzx0WZfHAvQ0sgZkj5wB2SNnQPuaLs66KylFark6JotW60OPePXFGatckjR1Vuvjl6TBH/db9dNFr74vrHJ94su/atWPHPY6+OFDz7fqa+dWrXpJmqh6P407cKBs1c9uqlv1uRNJ9QFjG8xjaPAJ7/k3Iv8z1UHvm2YfGLHq77x7k1VfM8fz6D7vRhH1c61yXfc5L8fVM/2cHZ7wcjO435tO5kbaODByx5vT6oe98/vIQ17WyhP+c3ryPK++dJd3bP/nH73Fqi/MWeW6d/ACq7484Z3wflTYatXHmf784c5pPZk1Z0qrec/nhkfNa8dpq1ySNGv+ue24c6NVf3/Bq7/XnNNunnqRVV/f4rX/D194sVUfZ/s5q8152e8/7B0Xcxu7l7PM79YIAAAAAGiOxRkAAAAA5ACLMwAAAADIARZnAAAAAJADLM4AAAAAIAdYnAEAAABADrA4AwAAAIAcYHEGAAAAADnA4gwAAAAAcoDFGQAAAADkAIszAAAAAMgBFmcAAAAAkAOlVe2tIGmg3nr5QNVqvnZog1Wfilb5fB8DyaovVsKqrxe99pO5B2v9Xvv1sjf+qFnlUqn14+Fn6t6YXMncB7lTlGKo9ewU7O31DrrUzu4qmGMyO3H3cb3s1RdmvfEUvFOdijNefVsvw5XNbJr7uTbYRvbzpuBlzZYGrPJaXzthM+ccc960szNnzpl9VrktzN1bN65xTin0eRNnvey17+6D3ClIsaH15yiK3j6olwa98ZjlkjQ74o3JnUPcc7x7LeiyrwXN2KT+NuYP87oiqu75tHvPKe+cAQAAAEAONF2cRcR1EXEoIu5e8LU/iYh7I+LOiPhiRGzOdJRADyBrQPbIGZA9cga0r5V3zvZIunzR126U9MKU0osl3Sfpg10eF9CL9oisAVnbI3IGZG2PyBnQlqaLs5TS9yQdWfS1G1JKp34S+2ZJ52QwNqCnkDUge+QMyB45A9rXjd85e6ekbyz3YERcGxF7I2Jv7eRkF7oDetayWXtGzk6QM6ADzGlA9sgZsIyOFmcR8SFJVUnXL1eTUtqdUhpPKY0XNw510h3Qs5pl7Rk5GyFnQDuY04DskTNgZW3fSj8irpH0ZkmXpZTW+X1agfwia0D2yBmQPXIGNNfW4iwiLpf0fkm/nFKa6u6QAJxC1oDskTMge+QMaE0rt9L/jKSbJF0cEfsj4l2S/kLSRkk3RsTtEfHxjMcJnPbIGpA9cgZkj5wB7Wv6zllK6eolvvypDMYC9DSyBmSPnAHZI2dA+7pxt0YAAAAAQIfaviFIOzYPTunKl9zecv1th3da7T8+MmjV9x8Jq16SYs77nr6jXvvVIa/94ozX/txGr/2xvV4H02Nlq17R59VLqmyrW/Xlk177M1v84yJPRgcnddWL9rZc//0nL7Da3z/Wb9X3H/ZfA3JzNuBm2TuEVKx47ZemvfY3PlLzviG88aSCf6qfGS1a9SX3N0jWd8wkSaMbJnXVi1vP2u3HvD/r9OOnzrXqhx9t4/VWcz+UJ7z66mC22al5075G91WbFy0wO2w+p21kbXrM68PdB7Oj6/u+G1sGp/QbL76t5fp7ju+w2r/3uHetOfSwd26U/Dlk4LBXX/OmZdX7vfYL5rXmyEPeJFua8errZT9nc5u8HLjX192c03jnDAAAAABygMUZAAAAAOQAizMAAAAAyAEWZwAAAACQAyzOAAAAACAHWJwBAAAAQA6wOAMAAACAHGBxBgAAAAA5wOIMAAAAAHKAxRkAAAAA5ACLMwAAAADIgdJqdjZZ7dPeJ89tuf7Q0Y1W+5HcEWVvbtirr4zVrfryybDq5zZ57R+7sM+qnx3xxlM5wxuPJJV2Tlr1JzcMeu1vnrXq82ai2q+bDp/fcv2hE95BWpjz9nH4u1jFGa+P6oDXfr3PO1lUh7362oQ3/lQsWvWu6TPbyNnYtFU/WTZzts1rP48mq3269ch5LdfvP7LZaj9q5nHUxsutdfMqoNbv1Vd21Lz2j3sbMTfiHdvHz/c2eG7IKtfMqH8hEmdVrPqpknfCK52xvrM2We3TrYdbz9mBoyNW+8Up75grtHGJUKx4WXZzNjdizmkbvHp3/Mef4z2nxRmrXNPmeUWSYtTbcZMjZau+m9eOvHMGAAAAADnQdHEWEddFxKGIuHuJx/4gIlJEbMtmeEDvIGtA9sgZkD1yBrSvlXfO9ki6fPEXI2KnpNdLeqTLYwJ61R6RNSBre0TOgKztETkD2tJ0cZZS+p6kI0s89KeS3icph7/pBaw/ZA3IHjkDskfOgPa19TtnEXGFpMdSSnd0eTwAFiBrQPbIGZA9cga0xr5bY0RskPQhSW9osf5aSddKUt+YdwcdoJc5WVuYs/4x7y6nQC/rZE7r307WgFZ0lDPmNPSYdt45e46k8yXdEREPSTpH0m0RceZSxSml3Sml8ZTSeHmTd6tloMe1nLVn5GzzhlUeJrCutT2n9TGnAa3q4NqROQ29xX7nLKV0l6SxU583QjaeUjrcxXEBPY+sAdkjZ0D2yBnQulZupf8ZSTdJujgi9kfEu7IfFtB7yBqQPXIGZI+cAe1r+s5ZSunqJo/v6tpogB5G1oDskTMge+QMaF9bd2sEAAAAAHRXpLR6f2oiIp6U9PASD22TtBY/d7xW/a5l373W72r0fV5K6YwM27fkMGdr2Xev9buWffdUzqRcZq3X+l3Lvk/nfnOVNXKWi757rd/V6HvZnK3q4mw5EbE3pTTeK/2uZd+91u9a950nvbgPeq3fteybnD2t1/YBx/vp328e9eI+6LVt7sXnWuLHGgEAAAAgF1icAQAAAEAO5GVxtrvH+l3Lvnut37XuO096cR/0Wr9r2Tc5e1qv7QOO99O/3zzqxX3Qa9vci891Pn7nDAAAAAB6XV7eOQMAAACAnraqi7OIuDwifhwRD0TEB5Z4PCLizxuP3xkRL+1Cnzsj4jsRsS8i7omI9yxR8ysRcTwibm/8+6NO+220+1BE3NVoc+8Sj3d9exvtXrxgW26PiBMR8d5FNV3Z5oi4LiIORcTdC742GhE3RsT9jf+3LPO9Kx4Pbfb9JxFxb+P5/GJEbF7me1fcN+tZr+Ws0faqZ201c9Zoa02yRs6WthY5a7TLnHYazmnkbHlrkbW1zFmj7dN6TlurnK3Qd76yllJalX+SipJ+IukCSX2S7pD0/EU1b5L0DUkh6VJJt3Sh3x2SXtr4eKOk+5bo91ckfS2DbX5I0rYVHu/69i7zvD+h+b+n0PVtlvRLkl4q6e4FX/tjSR9ofPwBSR9p53hos+83SCo1Pv7IUn23sm/W679ezFkr+zPrrGWds0Zba5I1crbs/l71nDXaZU47Dec0crbi/mZOe/bj63pOW6ucrdB3rrK2mu+cvULSAymlB1NKs5I+K+nKRTVXSvrfad7NkjZHxI5OOk0pHUgp3db4+KSkfZLO7qTNLur69i7hMkk/SSkt9QccO5ZS+p6kI4u+fKWkTzc+/rSkX1/iW1s5Huy+U0o3pJSqjU9vlnSO0+ZpgJwtLeusZZozae2yRs6WtCY5k3KfNeY0ctZtzGlLW9dzGteOK1vNxdnZkh5d8Pl+PftAb6WmbRGxS9Ilkm5Z4uFXRsQdEfGNiHhBl7pMkm6IiB9ExLVLPJ7p9jZcJekzyzyWxTZL0vaU0gFp/gQnaWyJmtXY9ndq/pWlpTTbN+tVL+ZMWvusrUXOpHxkjZytQc4k5rQlnM5zWi/mTMpB1pjTnuV0zpmUg6yVsmp4CbHE1xbfKrKVmvY6jxiW9DeS3ptSOrHo4ds0/9btRES8SdKXJF3YhW5flVJ6PCLGJN0YEfc2Vuw/G9YS39O122dGRJ+kKyR9cImHs9rmloe3xNe6ue0fklSVdP0yJc32zXrVizmT1jBrOc+ZlO22k7OnrVrOJOa0JR5e66yRs2wwpzGnPWN4S3zttLt2XM13zvZL2rng83MkPd5GjS0iypoP1/UppS8sfjyldCKlNNH4+OuSyhGxrdN+U0qPN/4/JOmLmn87dqFMtneBN0q6LaV0cImxZbLNDQdPvb3e+P/QEjWZbXtEXCPpzZJ+O6W0ZGhb2DfrVc/lrNHeWmZtrXImrWHWyNna5ExiTuulOa3HcyYxp/XSnMa1Y8NqLs5ulXRhRJzfWJVfJekri2q+IumfxbxLJR0/9RZnuyIiJH1K0r6U0keXqTmzUaeIeIXmn5enOux3KCI2nvpY879sePeisq5v7yJXa5m3pbPY5gW+IumaxsfXSPryEjWtHA+2iLhc0vslXZFSmlqmppV9s171VM4aba111tYqZ9IaZY2crU3OJOY09dCcRs4kMaf10pzGteMpKeM7jiz8p/m7y9yn+TutfKjxtd+R9DuNj0PSXzYev0vSeBf6/EXNv+V5p6TbG//etKjfd0u6R/N3fblZ0i90od8LGu3d0Wh7VbZ3Qf8bNB+YTQu+1vVt1nyAD0ia0/wrGu+StFXStyTd3/h/tFF7lqSvr3Q8dKHvBzT/88in9vXHF/e93L45Xf71Us5W2p+rkbXVytkKx3vmWSNn+clZo13mtKe/dtrMaeQsX1lbq5yttE9XI2une85W6DtXWYtGhwAAAACANbSqf4QaAAAAALA0FmcAAAAAkAMszgAAAAAgB1icAQAAAEAOsDgDAAAAgBxgcQYAAAAAOcDiDAAAAABygMUZAAAAAOTA/wfBNG8cSwrTmgAAAABJRU5ErkJggg==\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 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": []
  },
  {
   "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
}
