{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "collapsed": true,
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Demo Z2 Self-Attention\n",
    "\n",
    "In this demo, we will analyze the equivariance properties of (conventional) z2 self-attention models.\n",
    "\n",
    "First, we will demonstrate the translation equivariance of the model and, subsequently, we will perform an analysis into the rotation and flipping 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": [
    "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": 2,
   "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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Z2 Self-Attention Layers\n",
    "\n",
    "In what follows we take:\n",
    "\n",
    "* a random noise image f as input\n",
    "* apply a sequence of z2 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(R(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",
    "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": 7,
   "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": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5080\n",
      "9600\n"
     ]
    }
   ],
   "source": [
    "# Layer parameters\n",
    "num_heads = 3 ** 2\n",
    "\n",
    "# construct layers\n",
    "sa_1 = g_selfatt.nn.RdSelfAttention(N_in, N_in, N_in * 2, num_heads, Nxy, 0.0, 0)\n",
    "sa_2 = g_selfatt.nn.RdSelfAttention(N_in * 2, N_in, N_in * 4, num_heads, Nxy, 0.0, 0)\n",
    "\n",
    "# Check number of parameters\n",
    "from utils.check_utils import num_params\n",
    "num_params(sa_1)\n",
    "num_params(sa_2)"
   ]
  },
  {
   "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": 12,
   "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, (2,2), 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": 13,
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "First layer:\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Second layer:\n"
     ]
    },
    {
     "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": [
    "print('First layer:')\n",
    "f,axs = plt.subplots(1,2,figsize=(10,10))\n",
    "plt.subplot(1,2,1);plt.imshow(out_1.detach().numpy()[0, 0,:, :])\n",
    "plt.subplot(1,2,2);plt.imshow(out_1_trans.detach().numpy()[0,0,:,:,])\n",
    "plt.show()\n",
    "\n",
    "print('Second layer:')\n",
    "f,axs = plt.subplots(1,2,figsize=(10,10))\n",
    "plt.subplot(1,2,1);plt.imshow(out_2.detach().numpy()[0, 0,:, :])\n",
    "plt.subplot(1,2,2);plt.imshow(out_2_trans.detach().numpy()[0,0,:,:,])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test the network - Roration 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": 15,
   "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": 16,
   "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": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "First layer:\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Second layer:\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlAAAAEdCAYAAADDzFlqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAbJklEQVR4nO3da4xc9XnH8d8zl73vendtbHyDdQgYKC0N2ka5lbYhF5JQiHoTqKmgQXJf9JKkSRMipEbtq1aJUqq2SmQRCmoQUUSSBtEkDSUh5EIhi4PBYMCEAF5j4/vaXnt35/L0xY7rtWN7/Z/nzMXL9yNZ3p2d+Z1nzpx59pkzZ86auwsAAABnLtfqAgAAAM42DFAAAACJGKAAAAASMUABAAAkYoACAABIxAAFAACQqNDMhXUUery7YzCU4VPT4TosH58bvasjXsfh+H1RsRjPKJVit89ZuITyQFc4ozJUCWd4KR/OKBwKR8ja5OwiVo0Xcmhi2253PyeDcloq39vrheHhVpehYgbbV2kw/rhaKf6879xTDmcUR2L96+Ch7nANWejsmQlnTJfiv9I7i/HHZHo6/nspi+3L4+1cM1vHT9m/mjpAdXcM6i0X3RzK8M0vhuvIDfSFM0qXnR/OKGx4IZxhy5eGM3zbjlgN3fHhZ997LgxnTPxe/DfL1I7ecMayn8Sf+Pnp+C84z8frKE7Gh9If3v+pl8MhbaAwPKyVf/3RWEg1/pgsf6Qazth2bfyXZGF7/EXkG+/cFc5Ydtdrodv/6OHLwjV4Pv58veDXx8MZP98Rf53yxuU7wxnPbVkRzuh8LT6ezAzGnysv/+XfnLJ/8RYeAABAIgYoAACARAxQAAAAiUIDlJldbWbPmdkLZnZLVkUBQDPQwwDUq+4Byszykv5N0vskXSrpBjO7NKvCAKCR6GEAIiJ7oN4s6QV3f9HdZyR9RdJ12ZQFAA1HDwNQt8gAtVLS1jnfj9cuA4CzAT0MQN0iA9TJTmjySyfDMLN1ZjZmZmMz5cnA4gAgU/P2sLn9qzJJ/wJwTGSAGpe0es73qyS9euKV3H29u4+6+2hHIX6SQgDIyLw9bG7/yvfSvwAcExmgfirpQjNbY2Ydkq6XdF82ZQFAw9HDANSt7nOlu3vZzP5C0n9Lyku6w92fzqwyAGggehiAiNAfm3H3b0n6Vka1AEBT0cMA1IszkQMAACRigAIAAEjEAAUAAJAodAxUqnJ3Xvt/ZTCU0d97SbiO6YFiOGNiTTxjsd4Yzji8rDOc0bVqMHT7avFkp9NJs+/ieMZ1F2wKZ/ygJ/6Y7DlwTjijeDD+2qYa30RVnMzgNdb98Yi2UKzKlk+FIspT8ZZ7aEVHOGNweH84Y1+5P5wxs2IgnHFx78bQ7R8aujhcg3VUwhmXDf7SWYCSHZiJ/z64cskL4YyXdg+HM6ZzXeGMzkWx5+t82AMFAACQiAEKAAAgEQMUAABAIgYoAACARAxQAAAAiRigAAAAEjFAAQAAJGKAAgAASMQABQAAkIgBCgAAIBEDFAAAQCIGKAAAgEQMUAAAAIkYoAAAABIxQAEAACRigAIAAEhUaObCKp3SxAWxmc3z3eE6ZvotnHFwJByh/HRXOGNqcfy+TA90hDPCNayeCWf80eBj4YyuXCmc8R+7BsIZpel8OEMFD0dMH8mgjgWis1jWG5btDmXMVOPrc3zninDGH67eHM54tGcknDExsjKcsW5wY+j23xm5NFzD4q7JcMYfDv00nFHy+PZ1zUBsfUrSlvOWhjOe339OOOOiwV3hjC2n+Rl7oAAAABIxQAEAACRigAIAAEhU9wBlZqvN7PtmttnMnjazj2RZGAA0Ej0MQETkIPKypI+7+wYz65f0uJk94O7PZFQbADQSPQxA3ereA+Xu2919Q+3rg5I2S4p/pAIAmoAeBiAik2OgzGxE0pskPZpFHgA0Ez0MQKrwAGVmfZK+Jumj7n7gJD9fZ2ZjZjZWORw/VwYAZOl0PWxu/ypNHGlNgQDaUmiAMrOiZhvP3e7+9ZNdx93Xu/uou4/me3ojiwOATM3Xw+b2r+Ki+El8ASwckU/hmaQvSdrs7p/PriQAaDx6GICIyB6ot0v6E0nvNLMnav/en1FdANBo9DAAdav7NAbu/iNJ8T/EBgAtQA8DEMGZyAEAABIxQAEAACRigAIAAEjEAAUAAJAo8rfwkplLuVIswy1+zGe1EM8w93CG58MRqhbjGR4dozM4DNdy8fU55fHN+XClI5yRxX3xShYrNR6h+F1ZMKanOrTl2eBfeqnE61j2ZPxB+ep5V4Qzqrs7wxkX/3BHOOMT294Tuv34hhXhGl7uqYYz/r78u+GM519dFs6Yrsb76ENPrw1n5PfH63h1aDiccTrsgQIAAEjEAAUAAJCIAQoAACARAxQAAEAiBigAAIBEDFAAAACJGKAAAAASMUABAAAkYoACAABIxAAFAACQiAEKAAAgEQMUAABAIgYoAACARAxQAAAAiRigAAAAEjFAAQAAJCo0c2EdExWt/s6+UEZ14+ZwHfnFw+GM6cvXhDM6fvp8OCO3eCic4RMHwxlRHQfWhjP+rP9PwhmHt/eFM5Y+YuGM/LSHM6rF+OujjoPVcMbL4YT20Nk1o4suGQ9lFHLx9fnc1Eg44/cveSKc8dju88MZu35zRTjjtuVfDt3+ldF4D+0ulMIZH17xo3DGQwMXhzNuGv5xOKP8K/lwxpaJc8IZIwN7whl3n+Zn7IECAABIxAAFAACQiAEKAAAgUXiAMrO8mf3MzO7PoiAAaBb6F4B6ZbEH6iOS4kd2A0Dz0b8A1CU0QJnZKkkfkHR7NuUAQHPQvwBERPdA3Sbpk5Lin80FgOa6TfQvAHWqe4Ays2sk7XT3x+e53jozGzOzsZny4XoXBwCZqad/lSaONKk6AGeDyB6ot0u61sxekvQVSe80s186o5m7r3f3UXcf7Sj0BBYHAJlJ7l/FRd3NrhFAG6t7gHL3T7v7KncfkXS9pO+5+4cyqwwAGoT+BSCK80ABAAAkyuRv4bn7Q5IeyiILAJqJ/gWgHuyBAgAASMQABQAAkIgBCgAAIBEDFAAAQKJMDiI/U1NL8nr+pkWhjL6X3xauo9QfjtCR82fCGb1v/tVwxtQ58ZMod+6JzdHVYrgE9f3G7nDGpiu+Gs742qGBcMY/jrw3nLHvUPycQz1d8W1012RXOEP3xSPawXSpqOfHl7W6DA1stXDG91+9MJyx67VYL5ektZsOhTPuPxjroy88tzxcg7riffjH/fHH5Cc71oQzlhYPxuvYGq9jak+8B+5e0hvOOB32QAEAACRigAIAAEjEAAUAAJCIAQoAACARAxQAAEAiBigAAIBEDFAAAACJGKAAAAASMUABAAAkYoACAABIxAAFAACQiAEKAAAgEQMUAABAIgYoAACARAxQAAAAiRigAAAAEhWaubCOA67V/1MJZfQ8vzNcR3WwN5yx/6J4xtBTe8MZ5aHucEZh/1QsoOLhGrYdWhLO+GD/e8MZz762NJxRfKw/nNFzOByhakc8Y/BQ/LFdMMom2xNcqRYvo2dXNZyxY098G83vKYYzcocmwhlPH1oRun3+SHw/gk/HM57aH7sfkrR710A447G+kXDG1J7476WO3flwxpFqTzjjdNgDBQAAkIgBCgAAIBEDFAAAQKLQAGVmg2Z2r5k9a2abzeytWRUGAI1GDwNQr+hB5P8s6Tvu/gdm1iGpsUdsAUC26GEA6lL3AGVmA5KulHSTJLn7jKSZbMoCgMaihwGIiLyF9wZJuyT9u5n9zMxuN7P4Z/sBoDnoYQDqFhmgCpKukPQFd3+TpElJt5x4JTNbZ2ZjZjZWmpkMLA4AMjVvD5vbvyqH6F8AjokMUOOSxt390dr392q2GR3H3de7+6i7jxY7eHEHoG3M28Pm9q98H/0LwDF1D1DuvkPSVjNbW7voKknPZFIVADQYPQxARPRTeH8p6e7ap1delPSn8ZIAoGnoYQDqEhqg3P0JSaPZlAIAzUUPA1AvzkQOAACQiAEKAAAgEQMUAABAIgYoAACARNFP4SVxM1U6YzOb93SG66h05sMZ1YLF6+iN35dST/whzE0XQ7f3fHwOL2Vwip2eQvyvcHR2lMMZ5djqlCRVO+IZ5e54hlXj2/lCkeuoqHfNRCijUok/Vw6+uiiccdGq18IZL3UNhzMOjwyGM9626Ieh2//g3AvDNeTzlXDGO5b8PJyRMw9nXH/uY+GM3UfiDX3nYF8445z+I+GMV07zM/ZAAQAAJGKAAgAASMQABQAAkIgBCgAAIBEDFAAAQCIGKAAAgEQMUAAAAIkYoAAAABIxQAEAACRigAIAAEjEAAUAAJCIAQoAACARAxQAAEAiBigAAIBEDFAAAACJCk1dmkneBiNbtTMfzyjG67BKNZxR6Y6v0OrBWEauHL8fVglHaLjjcDgjn4vfl1IGz6osnicWvyuYo79jWleufDGUcaQSbxzfG7k0nPF7y38Wr6Pz4nDGM5fEM25etCN0+2+ftzVcw+LOyXDGTYNj4YxF+SPhjGt6t4czNp27JZzxZPfKcMYlA7FtQ5IeP83P2mCcAQAAOLswQAEAACRigAIAAEjEAAUAAJAoNECZ2cfM7Gkz22Rm95hZV1aFAUCj0cMA1KvuAcrMVkr6K0mj7n6ZpLyk67MqDAAaiR4GICL6Fl5BUreZFST1SHo1XhIANA09DEBd6h6g3H2bpM9JekXSdkkT7v7drAoDgEaihwGIiLyFNyTpOklrJK2Q1GtmHzrJ9daZ2ZiZjZWmD9VfKQBk6Ex62Nz+dWTfVCvKBNCmIm/hvUvSL9x9l7uXJH1d0ttOvJK7r3f3UXcfLXb2BRYHAJmat4fN7V/dQxxfDuCYyAD1iqS3mFmPmZmkqyRtzqYsAGg4ehiAukWOgXpU0r2SNkh6qpa1PqO6AKCh6GEAIkJ/9tTdPyPpMxnVAgBNRQ8DUC/ORA4AAJCIAQoAACARAxQAAECi0DFQyVyySizCytVwGfmpYBGK34/ZjAzuy5F4Ri6DdRqvIZ5xoNwZzihV8uGMTLYNb5OMDO7LQjFxuFv/tfFXYyH5+IMyvDG+jX5h5ZXhjP2746elufCRyXDG5/e+IXT7x5+O3V6SVIz30KrH92ds2LkynDG+aiic8Y1nLw9nlPbF+/mzQ8vCGbOfMzk59kABAAAkYoACAABIxAAFAACQiAEKAAAgEQMUAABAIgYoAACARAxQAAAAiRigAAAAEjFAAQAAJGKAAgAASMQABQAAkIgBCgAAIBEDFAAAQCIGKAAAgEQMUAAAAIkYoAAAABIVmr5Ei93cCxnMfFWPZwTvhyRVu4ptUYfnYiFejD8m1eZviSeVs/i2Uc2gDs9iM89gnWZRx4KRc+V7yqGIDJ6uKnfFU/o6Z8IZE8X4ll7tyoczpqrBPtpZCddgGTywnbnYtiVJXcV4xqL8kXgd3fHtqzwT3zYKxfhjezq0RwAAgEQMUAAAAIkYoAAAABIxQAEAACSad4AyszvMbKeZbZpz2bCZPWBmW2r/DzW2TACoDz0MQCOcyR6oOyVdfcJlt0h60N0vlPRg7XsAaEd3ih4GIGPzDlDu/rCkvSdcfJ2ku2pf3yXpg9mWBQDZoIcBaIR6j4Fa5u7bJan2/9LsSgKAhqOHAQhp+EHkZrbOzMbMbKw0fajRiwOAzMztX5WDk60uB0AbqXeAes3MlktS7f+dp7qiu69391F3Hy129tW5OADI1Bn1sLn9K9/f29QCAbS3egeo+yTdWPv6RknfzKYcAGgKehiAkDM5jcE9kh6RtNbMxs3sZkn/IOndZrZF0rtr3wNA26GHAWiEef/cqLvfcIofXZVxLQCQOXoYgEbgTOQAAACJGKAAAAASMUABAAAkmvcYqCzlylV17ZoJZdiOPeE6CoMD4YzuPZ3hjOJ4/L6oOhyvY/u+0O29kA/X0LWnK5zx4sSScMaBvfGPqg/t83BG4XA4QtWOeEZxMn5fFgqbyqljc08soxyv45yNU+GMX5wfP29o74746+/i2FPhjG+8cnno9n3PxHt5JYPn2oO9F4UzZrbG+9c9R+K9eOaZReGMvr0Wzpgeij+2p8MeKAAAgEQMUAAAAIkYoAAAABIxQAEAACRigAIAAEjEAAUAAJCIAQoAACARAxQAAEAiBigAAIBEDFAAAACJGKAAAAASMUABAAAkYoACAABIxAAFAACQiAEKAAAgEQMUAABAokKzF2hVjwXMlOI1lMrxjGo4QqrEQ3LlLAqJCT+mymh9ZiF+V7LJyEIG69Qq8YyFwlzKzURD4nXkZuIPSm4mXojF26iqBw+GM6bLq0K3z0+HS5BnsCtiaib+6zhXjj+ulUr8zuSm43WEn2uScqUMnnCny29oOgAAwALEAAUAAJCIAQoAACARAxQAAECieQcoM7vDzHaa2aY5l33WzJ41syfN7BtmNtjQKgGgTvQwAI1wJnug7pR09QmXPSDpMnf/NUnPS/p0xnUBQFbuFD0MQMbmHaDc/WFJe0+47LvufvRDrP8rKfY5UgBoEHoYgEbI4hioD0v6dgY5ANAK9DAAyUIDlJndKqks6e7TXGedmY2Z2VipNBlZHABkar4eNrd/lQ/TvwAcU/cAZWY3SrpG0h+7+ynPvezu69191N1Hi8XeehcHAJk6kx42t38VeuhfAI6p69zxZna1pE9J+i13P5xtSQDQWPQwAFFnchqDeyQ9ImmtmY2b2c2S/lVSv6QHzOwJM/tig+sEgLrQwwA0wrx7oNz9hpNc/KUG1AIAmaOHAWgEzkQOAACQiAEKAAAgEQMUAABAoro+hVevajGnyRWdoYyByeXhOkp9HeGMyaX5cEbn6iXhjOnFsfUpSZ2F2BztwdtL0tQSC2eMDm8PZxyciq/PqSVD4YzCkXCEKvHNXOXe+OOyUFS7XJNrZ2Ihpzzhy5nbs7cnnNF/6d75rzSPfcMD4Yxz33p5OOOmN/4wdPt/2fGucA3qrIQjPnDRM+GMn/SPhDN+Z+WWcMb9lcvCGQd2dYczCksyaKSnwR4oAACARAxQAAAAiRigAAAAEjFAAQAAJGKAAgAASMQABQAAkIgBCgAAIBEDFAAAQCIGKAAAgEQMUAAAAIkYoAAAABIxQAEAACRigAIAAEjEAAUAAJCIAQoAACARAxQAAECiQjMXVumQDq7OB1P6w3XM9MfnxslVFs4oTHWHM6aG4/ela1Esw/PxdXH4vHI44z2DT4czqh5fn/9zXl84IzcZfZ5IXvRwxvQRXmP9P6/9iyjF16dVwxGaLmfQ+ivx532uHL8zr5UGQre3cvx+eC6D3ymVjnDGTBaPawYq5Xj/ymL7qpQyqOM06I4AAACJGKAAAAASMUABAAAkmneAMrM7zGynmW06yc8+YWZuZksaUx4AxNDDADTCmeyBulPS1SdeaGarJb1b0isZ1wQAWbpT9DAAGZt3gHL3hyXtPcmP/knSJxX/XAoANAw9DEAj1HUMlJldK2mbu2/MuB4AaDh6GICo5JNGmFmPpFslvecMr79O0jpJKvYPpS4OADKV0sPm9q/84sHGFgbgrFLPHqgLJK2RtNHMXpK0StIGMzv3ZFd29/XuPuruo/me3vorBYBsnHEPO65/9dG/AByTvAfK3Z+StPTo97UGNOruuzOsCwAagh4GIAtnchqDeyQ9ImmtmY2b2c2NLwsAskEPA9AI8+6Bcvcb5vn5SGbVAEDG6GEAGoEzkQMAACRigAIAAEjEAAUAAJCIAQoAACCRuTfvrxiY2S5JL5/mKksktcNHianjeNTRXjVIZ1cd57v7Oc0oppHOoH9JZ9fj8nqoQaKOE1FHWg2n7F9NHaDmY2Zj7j5KHdTRrnW0Qw3U0b7aZX20Qx3tUAN1UEcja+AtPAAAgEQMUAAAAInabYBa3+oCaqjjeNRxTDvUIFFHu2qX9dEOdbRDDRJ1nIg6jgnV0FbHQAEAAJwN2m0PFAAAQNtrmwHKzK42s+fM7AUzu6VFNaw2s++b2WYze9rMPtKKOmq15M3sZ2Z2fwtrGDSze83s2do6eWuL6vhY7fHYZGb3mFlXk5Z7h5ntNLNNcy4bNrMHzGxL7f+hFtXx2drj8qSZfcPMBltRx5yffcLM3MyWNLqOdkT/Omk99DC1rn/Vlt3yHraQ+1dbDFBmlpf0b5LeJ+lSSTeY2aUtKKUs6ePufomkt0j68xbVIUkfkbS5Rcs+6p8lfcfdL5Z0eSvqMbOVkv5K0qi7XyYpL+n6Ji3+TklXn3DZLZIedPcLJT1Y+74VdTwg6TJ3/zVJz0v6dIvqkJmtlvRuSa80oYa2Q/86pdd9D2tx/5Lao4edrIYF0b/aYoCS9GZJL7j7i+4+I+krkq5rdhHuvt3dN9S+PqjZJ9vKZtdhZqskfUDS7c1e9pwaBiRdKelLkuTuM+6+v0XlFCR1m1lBUo+kV5uxUHd/WNLeEy6+TtJdta/vkvTBVtTh7t9193Lt2/+VtKoVddT8k6RPSnq9HlBJ/zoBPew4LelfUnv0sIXcv9plgFopaeuc78fVoif+UWY2IulNkh5tweJv0+wDWm3Bso96g6Rdkv69thv+djPrbXYR7r5N0uc0++pgu6QJd/9us+uYY5m7b6/Vtl3S0hbWctSHJX27FQs2s2slbXP3ja1Yfpugf/2y20QPa8f+JbVfDztr+1e7DFB2ksta9mrWzPokfU3SR939QJOXfY2kne7+eDOXexIFSVdI+oK7v0nSpJrzdtVxau/PXydpjaQVknrN7EPNrqNdmdmtmn3r5u4WLLtH0q2S/rbZy24z9K/jl08Pq6F/nd7Z3r/aZYAal7R6zver1MTdnHOZWVGzzedud/96C0p4u6Rrzewlzb4V8E4z+3IL6hiXNO7uR1/B3qvZZtRs75L0C3ff5e4lSV+X9LYW1HHUa2a2XJJq/+9sVSFmdqOkayT9sbfmfCQXaPYXw8ba9rpK0gYzO7cFtbQS/et49LBj2q1/SW3SwxZC/2qXAeqnki40szVm1qHZg+zua3YRZmaafb98s7t/vtnLlyR3/7S7r3L3Ec2uh++5e9Nfsbj7DklbzWxt7aKrJD3T7Do0u+v7LWbWU3t8rlJrD0y9T9KNta9vlPTNVhRhZldL+pSka939cCtqcPen3H2pu4/UttdxSVfUtp3XE/rXHPSw47Rb/5LaoIctmP7l7m3xT9L7NXs0/s8l3dqiGt6h2V3vT0p6ovbv/S1cJ78t6f4WLv/XJY3V1sd/ShpqUR1/J+lZSZsk/YekziYt9x7NHrdQqj25bpa0WLOfXNlS+3+4RXW8oNnjbo5up19sRR0n/PwlSUtasY20+h/965Q1ve57WKv6V23ZLe9hC7l/cSZyAACARO3yFh4AAMBZgwEKAAAgEQMUAABAIgYoAACARAxQAAAAiRigAAAAEjFAAQAAJGKAAgAASPR/IPmdMDztZekAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print('First layer:')\n",
    "f,axs = plt.subplots(1,2,figsize=(10,10))\n",
    "plt.subplot(1,2,1);plt.imshow(out_1.detach().numpy()[0, 0,:, :])\n",
    "plt.subplot(1,2,2);plt.imshow(out_1_90.detach().numpy()[0,0,:,:,])\n",
    "plt.show()\n",
    "\n",
    "print('Second layer:')\n",
    "f,axs = plt.subplots(1,2,figsize=(10,10))\n",
    "plt.subplot(1,2,1);plt.imshow(out_2.detach().numpy()[0, 0,:, :])\n",
    "plt.subplot(1,2,2);plt.imshow(out_2_90.detach().numpy()[0,0,:,:,])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "As we can see, the responses are very different for rotated versions of the same image."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Important!\n",
    "If you are interested in seeing how to utilize rotationally equivariant layers, *please check the **demo_p4_selfattention.ipynb** notebook*."
   ]
  },
  {
   "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": 1
}
