{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "collapsed": true,
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "# Demo P4M 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": [
    "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\n",
    "import importlib"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## P4M Self-Attention Layers\n",
    "\n",
    "**Important** Note that P4M-net without rotations is equivalent to a reflection equivariant network. Examples are given bellow.\n",
    "\n",
    "In what follows we take:\n",
    "\n",
    "* a random noise image f as input\n",
    "* apply a sequence of p4m 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",
    "Afterwards, we repeat the process for rotations:\n",
    "\n",
    "* apply a sequence of p4m 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 E(2) images, which is a planar rotation and a periodic shift along the extra rotation axis.\n",
    "\n",
    "To finalize, we repeat the process for reflections:\n",
    "\n",
    "* apply a sequence of p4m self-attention layers to it f -> N(f)\n",
    "* reflect the input (M(f)) via the action of the reflection group on f and send it through the same sequence of layers and (M(f) -> N(M(f)))\n",
    "* then we test the equivariance property M'(N(f))=N(M(f)). In the above M denotes the reflection operator of 2D images, and M' denotes the reflection operator (shift-twist) of E(2) images, which is a planar reflection and a periodic shift along the extra reflection 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": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "Nxy = 9 # 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[:,:, :2, :] = 0.0 \n",
    "inputs[:,:, :, :2] = 0.0 \n",
    "inputs[:,:, -2:,:] = 0.0 \n",
    "inputs[:,:, :, -2:] = 0.0 "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Attention Layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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.E2(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.)"
   ]
  },
  {
   "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": 5,
   "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": 6,
   "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": 7,
   "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 720x360 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 720x360 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 720x360 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 720x360 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(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1.detach().numpy()[0,0,i,:,:])\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The translated input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1_trans.detach().numpy()[0,0,i,:,:])\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print('\\n SECOND LAYER:\\n')\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(2, group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2, group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2.detach().numpy()[0,0,i,:,:])\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The translated input.')\n",
    "plt.subplots(2, group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2, group.num_elements // 2, i+1)\n",
    "    plt.imshow(out_2_trans.detach().numpy()[0,0,i,:,:])\n",
    "plt.tight_layout()\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": 8,
   "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": 9,
   "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": 10,
   "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 720x360 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 720x360 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 720x360 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 720x360 with 8 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(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The rotated input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1_90.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\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(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The rotated input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2_90.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\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 in the upper 4 response channels and 1 to the left in the lower 4 response channels), and a rotation of each feature map (by a corresponding rotation to that of the input)."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test the network - Reflection Equivariance\n",
    "\n",
    "Now, let's analyze what occurs if the input image is reflected. Lets first see the input"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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_f = torch.flip(inputs, [-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_f.numpy()[0,0,:,:,]);\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Pass the original random signal to the network and then its reflected version"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_1 = sa_1(input_tensor)\n",
    "out_2 = sa_2(out_1)\n",
    "\n",
    "out_1_f = sa_1(input_tensor_f)\n",
    "out_2_f = sa_2(out_1_f)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's compare the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FIRST LAYER:\n",
      "\n",
      "The original input.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsQAAAFhCAYAAAB3bLxDAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAnOklEQVR4nO3dfZBcZ5Xf8d/pl5FmRpJlWzIIWWAbOwZDyNo7awymWIIxaxuCkxRsiQVv4UpidhN2baBqy+wfECpVm38o4iXZglXxurVenI2xdx3HgJ0CipAshrGwMbJskI1fZEl+E+hlZiRNd5/8oWFrPIzU3XOe231vP99P1ZRn1Pd5+tzn/vr2meuebnN3AQAAALmqDbsAAAAAYJhoiAEAAJA1GmIAAABkjYYYAAAAWaMhBgAAQNYahUw6PunNdaeF5vB6rAZL8OYZHv11IUEN1o5OEK8hOkd0Hed/uV/tmZkUe9KzxvikN0+JZTgqfOyl8K+8Kd6DJvpY9IEe+ROIZvjAfrVmh5Dh4Hk4WnAZ8pPkHNhJMEdQ+DkxwT7MPbf7eXffGJ+pN0nOw0N+/pISrH2KXqIEGY5KsQ+zL5w4w4U0xM11p+nc930kNMexU2I11I7FxktSe/Xwa2gejo33BEc4eiJuTcTGP/GXn45NsALNU+IZDtdwOH4WbK+KPRt0EuSnMRfbj9Z4go4muJTRDD/+xSFkeN1pOvf3YhmuBX8pS5Gf2nxwggTxqR8JBihBDcfWxSZJcT65/3MffSI8SR9SnIdbwefxaB8gSc2Z2HhrxWuoH4mNr7Xj+Yle3GjOhkvQ9FdOnGFeMgEAAICs0RADAAAgazTEAAAAyFpPDbGZXWFmj5jZLjO7seiigNTIMKqODGMUkGOUVdeG2Mzqkv5C0pWSLpD0XjO7oOjCgFTIMKqODGMUkGOUWS9XiC+WtMvdH3P3Y5JukXR1sWUBSZFhVB0ZxiggxyitXhrizZKeWvTz7oV/A6qCDKPqyDBGATlGafXSEC/3znG/9oZ0ZnadmU2b2XR7Lvime0Ba/Wd4lgyjVDgPYxR0zTHnYQxLLw3xbklbFv18pqQ9Szdy923uPuXuU/XxyVT1ASn0n+EJMoxS4TyMUdA1x5yHMSy9NMQ/lHSemZ1tZmOStkq6o9iygKTIMKqODGMUkGOUVtcP1nT3lpl9SNI3JdUlfdHddxReGZAIGUbVkWGMAnKMMuvpk+bd/S5JdxVcC1AYMoyqI8MYBeQYZcUn1QEAACBrNMQAAADIGg0xAAAAstbTa4j7ZR2peejX3iKz31lio9vBu5dUC85ROxqvYdWB2Dq2x+I1eD023lrDP5Yr0Qnud/TXzdbq2LpJUid4/DsJzhDWju1He1WCGoKnIw+ug8cPZd+sIzVnYzsefexFzx2SVJsP1pDgsk+0BvPo86HUHouFqDEbLmHgzOMZDOcnwTkwWoM6CWpoxTJYa8VriD6fWCf+ODoZrhADAAAgazTEAAAAyBoNMQAAALJGQwwAAICs0RADAAAgazTEAAAAyBoNMQAAALJGQwwAAICs0RADAAAgazTEAAAAyBoNMQAAALJGQwwAAICs0RADAAAgazTEAAAAyBoNMQAAALLWKGzmYKvdCVbmq2LjJemt7/lhaPz/+j+/Ga6hsze2kI1L94dr0N2nxcZbvIQcNY54eI4Lfm9HaPwL7wsee0mPXfOy0PiXXLonXMML98Rq8CpmuCa1Vg+38FUH4hm+/CPfC43f/p7zwjU8+oGXhMav/Xn8OLTGY+OtHS5hOIIRqgX3O8WyvebdO0Pjd/yPV4dr2P9brdD40++Nt4sWPx0UiivEAAAAyBoNMQAAALJGQwwAAICs0RADAAAga10bYjPbYmbfNrOdZrbDzK4fRGFAKmQYo4Aco+rIMMqslz8bbEn6qLtvN7O1ku4zs3vc/aGCawNSIcMYBeQYVUeGUVpdrxC7+153377w/SFJOyVtLrowIBUyjFFAjlF1ZBhl1tdriM3sLEkXSrq3kGqAgpFhjAJyjKojwyibnhtiM1sj6WuSbnD3g8vcfp2ZTZvZdOvITMoagST6yXB7jgyjnE6W4xedh8kwSooMo4x6aojNrKnj4b3Z3W9bbht33+buU+4+1Vg9mbJGIKzfDNfHyTDKp1uOX3QeJsMoITKMsurlXSZM0hck7XT3TxdfEpAWGcYoIMeoOjKMMuvlCvGlkq6R9FYzu3/h66qC6wJSIsMYBeQYVUeGUVpd33bN3b8nyQZQC1AIMoxRQI5RdWQYZcYn1QEAACBrNMQAAADIGg0xAAAAstbLRzeviA/5VUJHT/PwHNOf+s3Q+LP3HQvXUD/SCo3f/fp6uIax8AzVYx2peTiYoeBj4IzvPR+bQNLjz70qNP4X/zp+ijjnK7tD43c14x9kteZg7FjWWrGDaZ3Q8JXxBPcbfAjsv2IuWIB074di5+Gx1i/CNbzyM4+Gxu/ddlq4BvtubI6hZDABC2awEzwPjz8T7yV2bYudh1dFF0HSBZ/cExr/0H/cFK7h9H9ohsZbO1zCSXGFGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQtUYhs9ak9ioLTdFpBks4FhsvSQfecyg0fu/+iXANjRdWhcaP138ZrqG9Ojh+LFhALEpDu1+32AS7/3P84TnzWOx33vUPe7iGXf92c2h8J8FZysPHMl7DoHldOrZuuDVs/PvgyUPS4//+SGi8PfmycA0TT8cCMLsz/jiqhY9lBUOsBI+94PhaK3j/CTx/USc8x/7XvDw0vjExF65BtWBjV3CEuUIMAACArNEQAwAAIGs0xAAAAMgaDTEAAACy1nNDbGZ1M/uRmd1ZZEFAUcgwqo4MYxSQY5RRP1eIr5e0s6hCgAEgw6g6MoxRQI5ROj01xGZ2pqR3SPp8seUAxSDDqDoyjFFAjlFWvV4hvknSn0iKvxkeMBw3iQyj2m4SGUb13SRyjBLq2hCb2TslPevu93XZ7jozmzaz6dbcTLICgSgyjKpbUYZnyTDKpZcccx7GsPRyhfhSSe8ys8cl3SLprWb210s3cvdt7j7l7lON8cnEZQIhZBhV13+GJ8gwSqdrjjkPY1i6NsTu/jF3P9Pdz5K0VdK33P39hVcGJEKGUXVkGKOAHKPMeB9iAAAAZK3Rz8bu/h1J3ymkEmAAyDCqjgxjFJBjlA1XiAEAAJA1GmIAAABkjYYYAAAAWevrNcQ960iNWQ9N4XULjV/9xhdC4yWp+d9PC40fOyX++8bMmbF1nH30lHAN64LH0jqxY6nY3a/sLk1qr4rV7cHDf+yBU2MTSNry/fnQ+Odf1wzX0D5nNjT+n7/yZ+EafnDLPwuNb68OFhB8CKyEm+TRM3zwoxP2Xt4KFiCNPToeGt+eiJ9AjmyIHcDxvfEAHI09Hcnr4RIGzk3qBE9B0fGv/DePxCaQ9NzHz46Nf2O8l3jZ+c/Gaji4JlxDuxl7HNTGwiWcfP5ipwcAAADKjYYYAAAAWaMhBgAAQNZoiAEAAJA1GmIAAABkjYYYAAAAWaMhBgAAQNZoiAEAAJA1GmIAAABkjYYYAAAAWaMhBgAAQNZoiAEAAJA1GmIAAABkjYYYAAAAWaMhBgAAQNYaRUxqHak568FJYsPP+PB8bAJJz705VsT6R+M1bPrbx0PjfdPp4Rr2/8apofG1ViwL1g4NX5ma1BmLTeHBXzfPuvNQbAJJe9+0NjR+0/fnwjUc2r06NP5/v+k14Romg8dy2FkYmuB5eMP/bYZL+OX5sfEbp8Ml6Jk3xU5CGx+I1/DshliI3IIHcxhMaq+KTdEJRvDZT54Tm0DS02+JFbHm0fixq/39htD4jWPxGg6cFRvf6oRLOKmqnqYBAACAJGiIAQAAkDUaYgAAAGSNhhgAAABZ66khNrP1ZnarmT1sZjvN7A1FFwakRIYxCsgxqo4Mo6x6fZeJP5f0DXd/t5mNSZoosCagCGQYo4Aco+rIMEqpa0NsZuskvVnSByTJ3Y9JOlZsWUA6ZBijgByj6sgwyqyXl0ycI+k5SV8ysx+Z2efNbLLguoCUyDBGATlG1ZFhlFYvDXFD0kWSPuvuF0qakXTj0o3M7Dozmzaz6daRmcRlAiF9Z7g9S4ZROl1zTIZRcn1luEWGMUC9NMS7Je1293sXfr5VxwP9Iu6+zd2n3H2qsZpf+FAqfWe4PkGGUTpdc0yGUXJ9ZbhBhjFAXRtid98n6Skz+9UHaF4m6aFCqwISIsMYBeQYVUeGUWa9vsvEH0m6eeEvQh+TdG1xJQGFIMMYBeQYVUeGUUo9NcTufr+kqWJLAYpDhjEKyDGqjgyjrPikOgAAAGSNhhgAAABZoyEGAABA1nr9o7r+1KTWuIWmmF8bG7/nyk2h8ZLUXhUbf2xtM1zD2KZzQ+M7Y+ES5LFDoXYwC16P3f/K7nThKzpHwDO/tTZYQPzY7Xv9eLiGRvCtRNc8luD39iEfy/D4FTCXrBWcoxMbP/vSYAAljT8XG394S7yGdY/Exh/cEi5B9eDnudXm4zUMQzSD1o6Nf/q348/jjcPB58AEp8Bfnhvbj+g6SvFjWXSGuUIMAACArNEQAwAAIGs0xAAAAMgaDTEAAACyRkMMAACArNEQAwAAIGs0xAAAAMgaDTEAAACyRkMMAACArNEQAwAAIGs0xAAAAMgaDTEAAACyRkMMAACArNEQAwAAIGs0xAAAAMhao4hJ3aROMzZHJ1iZWWy8FN8H8+HX0GkkWIjgFO1Vw73/FXGpdmwI97tIfT5BgIIPhE47XkL9WGw/vD6MACypIXo+SnAo++ZSPZhh6wRLSHDJpX40Nj56DpUka8XG1zrxALTnY4+D6DoOg7WlsYOxtWuPxdat1o6ffxozsfG1Vjw/jbnY+Oi5QJI69dj45myxJ1KuEAMAACBrNMQAAADIGg0xAAAAskZDDAAAgKz11BCb2YfNbIeZ/cTMvmpmq4suDEiJDKPqyDBGATlGWXVtiM1ss6Q/ljTl7q+VVJe0tejCgFTIMKqODGMUkGOUWa8vmWhIGjezhqQJSXuKKwkoBBlG1ZFhjAJyjFLq2hC7+9OSPiXpSUl7JR1w97uLLgxIhQyj6sgwRgE5Rpn18pKJUyVdLelsSS+TNGlm719mu+vMbNrMpltzwXehBhJaSYbbZBglsqIMz5JhlEsvOaaXwLD08pKJt0n6ubs/5+7zkm6T9MalG7n7Nnefcvepxvhk6jqBiL4zXCfDKJf+MzxBhlE6XXNML4Fh6aUhflLSJWY2YWYm6TJJO4stC0iKDKPqyDBGATlGafXyGuJ7Jd0qabukBxfGbCu4LiAZMoyqI8MYBeQYZdboZSN3/4SkTxRcC1AYMoyqI8MYBeQYZcUn1QEAACBrNMQAAADIGg0xAAAAsmbunn5Ss+ckPXGSTTZIej75HadFjelE63yFu29MVUwvyPBAVaFOMjw8VagzlxoHmuMeMizls/ZFy6XGE2a4kIa4GzObdvepgd9xH6gxnarU2Y8q7FMVapSqUWcVauxXVfapCnVS4/BUYb+oMY2ia+QlEwAAAMgaDTEAAACyNqyGuApvxE2N6VSlzn5UYZ+qUKNUjTqrUGO/qrJPVaiTGoenCvtFjWkUWuNQXkMMAAAAlAUvmQAAAEDWaIgBAACQtcIaYjO7wsweMbNdZnbjMrebmX1m4fYfm9lFRdVykhq3mNm3zWynme0ws+uX2eYtZnbAzO5f+Pr4EOp83MweXLj/6WVuH+pamtn5i9bnfjM7aGY3LNlm6Ou4EmXPMRlOWuNI5pgMJ6211Dkmw/QTPdRJhk/E3ZN/SapLelTSOZLGJD0g6YIl21wl6euSTNIlku4topYudW6SdNHC92sl/XSZOt8i6c5B17akhsclbTjJ7UNfyyXHfp+Ov/l1qdZxhftS6hyT4UKPfeVzTIaT11qZHJPhgddZiRyT4RN/FXWF+GJJu9z9MXc/JukWSVcv2eZqSX/lx31f0noz21RQPcty973uvn3h+0OSdkraPMgaEhn6Wi5ymaRH3b3bpwtVQelzTIYLMyo5JsODVaYck+EBGqEcD30tFxlohotqiDdLemrRz7v168HoZZuBMbOzJF0o6d5lbn6DmT1gZl83s9cMtjJJkku628zuM7Prlrm9TGu5VdJXT3DbsNexX5XKMRlOalRyTIbTqlKOyfCQlDzHZPgEGikmWYYt829L39+tl20GwszWSPqapBvc/eCSm7fr+OX6w2Z2laS/k3TegEu81N33mNkZku4xs4fd/buLbi/FWprZmKR3SfrYMjeXYR37VZkck+F0RizHZDitSuSYDC+7zUBUIMdk+ASKukK8W9KWRT+fKWnPCrYpnJk1dTy8N7v7bUtvd/eD7n544fu7JDXNbMMga3T3PQv/fVbS7Tr+v5AWK8VaSrpS0nZ3f2bpDWVYxxWoRI7JcHKjlGMynFCFckyG6SeWRYZPrKiG+IeSzjOzsxe6/K2S7liyzR2Sfn/hLxovkXTA3fcWVM+yzMwkfUHSTnf/9Am2eenCdjKzi3V8zV4YYI2TZrb2V99LeruknyzZbOhrueC9OsH/3hj2Oq5Q6XNMhgsxSjkmw4lULMdkmH5iufsnwydRyEsm3L1lZh+S9E0d/yvBL7r7DjP7g4XbPyfpLh3/a8ZdkmYlXVtELV1cKukaSQ+a2f0L//ankl4u/WOd75b0h2bWkjQnaau7D/J/H7xE0u0Lx74h6W/c/RtlW0szm5B0uaQPLvq3xTUOex37VpEck+GERi3HZDipSuSYDNNPnAQZPtn9lvhxAAAAABSOT6oDAABA1miIAQAAkDUaYgAAAGSNhhgAAABZoyEGAABA1miIAQAAkDUaYgAAAGSNhhgAAABZK+ST6uoTk95cf1oRU/fOEkzRiY33EtSQYh08+GtTdB/mD+xXa3YmwZ70rjE+6c1TghkOVhxdd0mydnyOcA3RDJdAdB+OHt6v1pEBZ3j1pK9aE8uw14NFJPjcp2Gff5LMkeI8HJ0gwflk7tndz7v7xvhMvUlyHg5Kcg4Nrn2Kj0+z4CQp+pmwBBk+su/EGS6kIW6uP02v+OBHYpNEE5Bg4WpHY+PDTyaS6sEaUpyIj62LHYzm4VgRP//Ssh8LX6jmKafp3PfFMtxeFauhvTo2XpIaM7HxKZ4M6kdi42vt+NNB9GTenI2Nf+jO/xKbYAVWrTlNr7r6w6E5WpPBhUvQjEYfB+FzqKSxg7EMdprxGqLPJ+1V8SeDH//XjzwRnqQPKc7DUY2Z+PknuvYpeonGXGw/WuPD74hb4/E5Hv6zE2eYl0wAAAAgazTEAAAAyBoNMQAAALLWU0NsZleY2SNmtsvMbiy6KCA1MoyqI8MYBeQYZdW1ITazuqS/kHSlpAskvdfMLii6MCAVMoyqI8MYBeQYZdbLFeKLJe1y98fc/ZikWyRdXWxZQFJkGFVHhjEKyDFKq5eGeLOkpxb9vHvh34CqIMOoOjKMUUCOUVq9NMTLvfncr72hnZldZ2bTZjbdng2++SmQFhlG1fWd4dYRMozS6ZpjzsMYll4a4t2Stiz6+UxJe5Zu5O7b3H3K3afqE5Op6gNSIMOour4z3FhNhlE6XXPMeRjD0ktD/ENJ55nZ2WY2JmmrpDuKLQtIigyj6sgwRgE5Rml1/ehmd2+Z2YckfVNSXdIX3X1H4ZUBiZBhVB0Zxiggxyizrg2xJLn7XZLuKrgWoDBkGFVHhjEKyDHKik+qAwAAQNZoiAEAAJA1GmIAAABkrafXEPfLOtLYweAkv/YOm30OrwfvX1L9aGx8J0kNwYVIwGvLvXVk75qHYvdv7dj4ld2p1F4Vm6ITfHS1x+LHvnY0duwswa/M8eMX2wdJ6jSDFXRix8Lju9A360jN2WDdwXNYrRUbLx3fj1AN8/EaGkdiRbQ78QBEz8MKZngYzOPHL/rYS/H8U2vF1r5j8fxY8LGYYh0sGMFawb0AV4gBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFlrFDWxD7nVntvo4TnWv/aF0PjZ/7chXMPcptj4c1//RLiGJ+45KzxHJcUjFDK/oRWeo37ekdD4M74yHq7hqSssNN7mY+Mlac3j+f3u7zWptTq2dvOTsfHrnmqHxkvSD/7sL0Pj3/H6d4Zr2PvOLaHxRzbEMzyxL3ZCih7LoXBJndgUFtztdU/NxyaQ9K0vfz40/sq3bw3X8LNr14fGT+yJ56c+Fxtv8dPJSeX3LAEAAAAsQkMMAACArNEQAwAAIGs0xAAAAMha14bYzLaY2bfNbKeZ7TCz6wdRGJAKGcYoIMeoOjKMMuvlXSZakj7q7tvNbK2k+8zsHnd/qODagFTIMEYBOUbVkWGUVtcrxO6+1923L3x/SNJOSZuLLgxIhQxjFJBjVB0ZRpn19RpiMztL0oWS7i2kGqBgZBijgByj6sgwyqbnhtjM1kj6mqQb3P3gMrdfZ2bTZjbdnp1JWSOQRD8ZbpFhlNTJcvyiDB8hwyinnjM8R4YxOD01xGbW1PHw3uzuty23jbtvc/cpd5+qT0ymrBEI6zfDDTKMEuqW4xdleDUZRvn0leFxMozB6eVdJkzSFyTtdPdPF18SkBYZxiggx6g6Mowy6+UK8aWSrpH0VjO7f+HrqoLrAlIiwxgF5BhVR4ZRWl3fds3dvyfJBlALUAgyjFFAjlF1ZBhlxifVAQAAIGs0xAAAAMgaDTEAAACy1stHN6+IB18lZJ3Y+LUX7I9NIKl95+mh8RufmA/X0BmLLWTn4gQv1/Lg8OivXUN4xZm1peah2BydZmz8xv8Z3/H54NvHTT78TLiG87/9bGj8zz75T8M1NA/HQjw2ExtfC57PVsSlWjtYdyuWwf3n10PjJel3/uU1ofFHX7c6XMPGz/5DaPzPvnJRuIbJp1eFxtda4RKyNL5zX3iOy3/3A6HxL7xpPFzD+f9tT2j8Qx/fEK7h1B+MBWcothngCjEAAACyRkMMAACArNEQAwAAIGs0xAAAAMgaDTEAAACyRkMMAACArNEQAwAAIGs0xAAAAMgaDTEAAACyRkMMAACArNEQAwAAIGs0xAAAAMgaDTEAAACyRkMMAACArNEQAwAAIGuNIib1mtReFZvDOrHxh/acEptA0sZ/8Xxo/FP714RraDyxOjT+lLmJcA3tWAmqzcfGu8XGD02w7v2vjj88Z18aeyAd2rIpXINqsTk6ZxwJl2APBU9IFeR16egpsWseR9fHajh9Zzs2gaSf/rvYCciOxK/7rD3vjaHx9X0eruHo+tgJpTUeLmE4ouf/4PjHrn15sABpcm/s+B85Pf4k+Mh/CJ7LO61wDV6L7UfRvQBXiAEAAJA1GmIAAABkjYYYAAAAWaMhBgAAQNZ6bojNrG5mPzKzO4ssCCgKGUbVkWGMAnKMMurnCvH1knYWVQgwAGQYVUeGMQrIMUqnp4bYzM6U9A5Jny+2HKAYZBhVR4YxCsgxyqrXK8Q3SfoTScF3BwaG5iaRYVTbTSLDqL6bRI5RQl0bYjN7p6Rn3f2+LttdZ2bTZjbdnplJViAQtZIMt+bIMMqDDGMU9JJjMoxh6eUK8aWS3mVmj0u6RdJbzeyvl27k7tvcfcrdp+qTk4nLBEL6znBjnAyjVMgwRkHXHJNhDEvXhtjdP+buZ7r7WZK2SvqWu7+/8MqARMgwqo4MYxSQY5QZ70MMAACArDX62djdvyPpO4VUAgwAGUbVkWGMAnKMsuEKMQAAALJGQwwAAICs0RADAAAga329hrhX1pGas8FJPDZ8fEO0AKn21dND4xuvtnAN7fHYQvxix4ZwDavmYuMbwfE2hLdv95rUHo/N0WnGxh99XTzDm/92LDR+99uCD0RJZ5zzQmj8zPPrwjW0xuOPxQgfwqUHN6kTPcMH6979jnawAGlsX+yBtPr5+LGPPpYndyd4LlgVnKCCl7/c4msffewd+yfBJzBJW+6JPYnN/E787efqW2LPJ//qvAfDNdz94BtC46NZ6KaCDxEAAAAgHRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFmjIQYAAEDWaIgBAACQNRpiAAAAZI2GGAAAAFlrFDGptaXGjIfniFj/5YnYBJJmXmKh8Wfffihcw9xLY/sx+bP94Rr2Xn5GaHzzcDALndDwFd6p1GnGpmiPxcaf+s3x2ASSnn9tLMNrfh4uQUcfjuVnbYKzVPhYBs9HHjsMwxN76Orlt8evuey7JDa+eTC4E5Lm18YOYCd4LpAkBTPkVbz8VYuvXXS/z/9P8efxp94VOwee8+Xd4Rqe++3NofH3P/4b4RrawcdyksfRSVTxIQIAAAAkQ0MMAACArNEQAwAAIGs0xAAAAMhaTw2xma03s1vN7GEz22lmbyi6MCAlMoxRQI5RdWQYZdXr32//uaRvuPu7zWxMUvwtHIDBIsMYBeQYVUeGUUpdG2IzWyfpzZI+IEnufkzSsWLLAtIhwxgF5BhVR4ZRZr28ZOIcSc9J+pKZ/cjMPm9mkwXXBaREhjEKyDGqjgyjtHppiBuSLpL0WXe/UNKMpBuXbmRm15nZtJlNt47MJC4TCOk/w7NkGKXTNceLM9yeI8Monf4yzHkYA9RLQ7xb0m53v3fh51t1PNAv4u7b3H3K3acaq/mFD6XSf4YnyDBKp2uOF2e4Pk6GUTr9ZZjzMAaoa0Ps7vskPWVm5y/802WSHiq0KiAhMoxRQI5RdWQYZdbru0z8kaSbF/4i9DFJ1xZXElAIMoxRQI5RdWQYpdRTQ+zu90uaKrYUoDhkGKOAHKPqyDDKik+qAwAAQNZoiAEAAJA1GmIAAABkrdc/quuL16X5NRaaw9qxGn6xPr5r9SOx8XsvXRev4ZiHxh/asjFcw3z0nW86sSz4MH5t83gGLXbo9Mvzu2/TTfNQbHwnwRmiNj/c8VI8Q+EagllYCfMEa9+Kjd//qgTn4bnY+KOnh0tQ82DsAHojdg6UpE49Nr5WyLN9wVxSJzZFdOX3XnZGcIb44+jJ3z0zXENjNjZ+7yXj4Rqiz6lFn0e5QgwAAICs0RADAAAgazTEAAAAyBoNMQAAALJGQwwAAICs0RADAAAgazTEAAAAyBoNMQAAALJGQwwAAICs0RADAAAgazTEAAAAyBoNMQAAALJGQwwAAICs0RADAAAgazTEAAAAyFqjkFlN8uDMHmzVvR4bL0nWjI3vJFjdWttC4z02/PgcwbXsBNcxxT70f6dSbT44R7Bur8V3vH4sNj68BpLqRzw03jrxGqKPxVorNt5iS7AyLtXnY3fcPhbLYIr8RB9HSTIcfBx1PEEAOrGFqB+NlzBo1pGah4NrF8xPcyY2XpLawfyk6GfqR2LjkzyWgyz4GOiGK8QAAADIGg0xAAAAskZDDAAAgKzREAMAACBrPTXEZvZhM9thZj8xs6+a2eqiCwNSIsOoOjKMUUCOUVZdG2Iz2yzpjyVNuftrJdUlbS26MCAVMoyqI8MYBeQYZdbrSyYaksbNrCFpQtKe4koCCkGGUXVkGKOAHKOUujbE7v60pE9JelLSXkkH3P3uogsDUiHDqDoyjFFAjlFmvbxk4lRJV0s6W9LLJE2a2fuX2e46M5s2s+n2bIJ3sgYSWVGG58gwymMlGW4dIcMol15y/KIMcx7GAPXykom3Sfq5uz/n7vOSbpP0xqUbufs2d59y96n6xGTqOoGI/jM8ToZRKn1nuLGaDKN0uub4RRnmPIwB6qUhflLSJWY2YWYm6TJJO4stC0iKDKPqyDBGATlGafXyGuJ7Jd0qabukBxfGbCu4LiAZMoyqI8MYBeQYZdboZSN3/4SkTxRcC1AYMoyqI8MYBeQYZcUn1QEAACBrNMQAAADIGg0xAAAAsmbunn5Ss+ckPXGSTTZIej75HadFjelE63yFu29MVUwvyPBAVaFOMjw8VagzlxoHmuMeMizls/ZFy6XGE2a4kIa4GzObdvepgd9xH6gxnarU2Y8q7FMVapSqUWcVauxXVfapCnVS4/BUYb+oMY2ia+QlEwAAAMgaDTEAAACyNqyGuApvxE2N6VSlzn5UYZ+qUKNUjTqrUGO/qrJPVaiTGoenCvtFjWkUWuNQXkMMAAAAlAUvmQAAAEDWaIgBAACQtcIaYjO7wsweMbNdZnbjMrebmX1m4fYfm9lFRdVykhq3mNm3zWynme0ws+uX2eYtZnbAzO5f+Pr4EOp83MweXLj/6WVuH+pamtn5i9bnfjM7aGY3LNlm6Ou4EmXPMRlOWuNI5pgMJ6211Dkmw/QTPdRJhk/E3ZN/SapLelTSOZLGJD0g6YIl21wl6euSTNIlku4topYudW6SdNHC92sl/XSZOt8i6c5B17akhsclbTjJ7UNfyyXHfp+Ov/l1qdZxhftS6hyT4UKPfeVzTIaT11qZHJPhgddZiRyT4RN/FXWF+GJJu9z9MXc/JukWSVcv2eZqSX/lx31f0noz21RQPcty973uvn3h+0OSdkraPMgaEhn6Wi5ymaRH3b3bpwtVQelzTIYLMyo5JsODVaYck+EBGqEcD30tFxlohotqiDdLemrRz7v168HoZZuBMbOzJF0o6d5lbn6DmT1gZl83s9cMtjJJkku628zuM7Prlrm9TGu5VdJXT3DbsNexX5XKMRlOalRyTIbTqlKOyfCQlDzHZPgEGikmWYYt829L39+tl20GwszWSPqapBvc/eCSm7fr+OX6w2Z2laS/k3TegEu81N33mNkZku4xs4fd/buLbi/FWprZmKR3SfrYMjeXYR37VZkck+F0RizHZDitSuSYDC+7zUBUIMdk+ASKukK8W9KWRT+fKWnPCrYpnJk1dTy8N7v7bUtvd/eD7n544fu7JDXNbMMga3T3PQv/fVbS7Tr+v5AWK8VaSrpS0nZ3f2bpDWVYxxWoRI7JcHKjlGMynFCFckyG6SeWRYZPrKiG+IeSzjOzsxe6/K2S7liyzR2Sfn/hLxovkXTA3fcWVM+yzMwkfUHSTnf/9Am2eenCdjKzi3V8zV4YYI2TZrb2V99LeruknyzZbOhrueC9OsH/3hj2Oq5Q6XNMhgsxSjkmw4lULMdkmH5iufsnwydRyEsm3L1lZh+S9E0d/yvBL7r7DjP7g4XbPyfpLh3/a8ZdkmYlXVtELV1cKukaSQ+a2f0L//ankl4u/WOd75b0h2bWkjQnaau7D/J/H7xE0u0Lx74h6W/c/RtlW0szm5B0uaQPLvq3xTUOex37VpEck+GERi3HZDipSuSYDNNPnAQZPtn9lvhxAAAAABSOT6oDAABA1miIAQAAkDUaYgAAAGSNhhgAAABZoyEGAABA1miIAQAAkDUaYgAAAGTt/wOx7bhw+zFTHwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 720x360 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The reflected input.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsQAAAFhCAYAAAB3bLxDAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAnc0lEQVR4nO3de5Bc5Xnn8d/Tl9FcJAFCXCWBwFGwsXcdyJgCs3FYsBOMvcZby9pylZ21Uyk52ZAAdlUKp7bi3eSvrUpRJFWpZFU2TrIhpioYsizLNWt7XXZttB5k2SBkEoG5jCUhgUCXuWimu5/9Q5PUMIzU3fOc031Ov99PlYqZ6fO+/fR7fuf0M4eebnN3AQAAAKmq9LsAAAAAoJ9oiAEAAJA0GmIAAAAkjYYYAAAASaMhBgAAQNJquUw6Oub1M9aF5vBgq26t2PiTRQSHZ/DrhhWghug6RM2/eVjN6Snr5X3Whsd81er+ZrgIivAYvBqfI3w+CB4D80cOqzHT4wyPjPnQ2liGFVy3TB5wAc6BhXg+Ci6mNeMlTL8++Zq7nxOfqTNZ9BLRDGch/DyewYEUniKDdcziXB41++qpM5xLQ1w/Y50u+dwXQnPMr44laOhoBgkKhri5Kl5C9CTWyqCG8IEQ3BUv/be7ggV0b9Xqdbr8o3eE5pgfjdUQPYlKUqsaW/zmcLyG6EmwMRavoTobHH8iNn7vvb3P8NDaddryydh5uHoiFsIsmrDKfGz83Nr4c0H0XB7Nn6Tw/8+tTcVPKDvv+eJL4Um6UD9jnTb/aizDtZmMignVEFv7xkg8w9FjMXoukKTGWE+vCSzrmbu+cMoMF+D6DwAAANA/NMQAAABIGg0xAAAAktZRQ2xmN5rZc2a218zuzLsoIGtkGGVHhjEIyDGKqm1DbGZVSX8i6cOSLpf0KTO7PO/CgKyQYZQdGcYgIMcosk6uEF8laa+7v+Duc5Luk3RzvmUBmSLDKDsyjEFAjlFYnTTEGyS9suj7yYWfAWVBhlF2ZBiDgByjsDppiJd747i3vSGdmW0zswkzm2hMT8UrA7LTfYZnyTAKpfsMz5BhFE7bHNNLoF86aYgnJW1a9P1GSfuWbuTu29193N3Ha6MZvJM+kJ3uMzxMhlEo3Wd4hAyjcNrmmF4C/dJJQ/x9SVvM7BIzG5K0VdJD+ZYFZIoMo+zIMAYBOUZhtf3oZndvmNmtkh6XVJV0j7vvzr0yICNkGGVHhjEIyDGKrG1DLEnu/oikR3KuBcgNGUbZkWEMAnKMouKT6gAAAJA0GmIAAAAkjYYYAAAASevoNcTdsqZUPxaeJTS6fvRtb9HZc5W52GOQpEozNr45Fy5BFqwhuCtlreD9r4Cb1BiOzdFcFXvglfnY/UtSq97f8ZLkwV+7m0PxY9ka8WMxVkAf7rMlVWdia1cNnj+sFd931bnYHM2h+HWf6DmwNhsuQa3gs3V9uv/PiSsRfQ6sNGLjPYNj14I1ZPEcWGnE9n+4D1AG65BzhLlCDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIWq3fBZyKB1v18z/5UriGvTsuDo2vHw2XoNH3vxYaf/yZs8M1jByy8Bzo3tEtrfAcXvfQ+E2PxcZL0sH/MBMaP//GcLiG2sv12ATxZeg5r0jza4LH7lTsgU+fH7/mMvxarIYLHn4lXMP/2vFwaPwv3Pr5cA1HN1VD4yvz4RJ6zyVrBucInkZbI8H7l/Tm5liGt3ztjXANjz5xX2j89Z/9tXANb2wZik2Q83mYK8QAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpbRtiM9tkZt8ysz1mttvMbutFYUBWyDAGATlG2ZFhFFkn7zLRkPRFd99pZmskPWVmT7r7sznXBmSFDGMQkGOUHRlGYbW9Quzu+91958LXxyTtkbQh78KArJBhDAJyjLIjwyiyrl5DbGabJV0haUcu1QA5I8MYBOQYZUeGUTQdN8RmtlrSNyTd7u5v+8gJM9tmZhNmNtGYmcqyRiATXWV4lgyjmE6X48UZbnIeRkF1nOFpMoze6aghNrO6Tob3Xnd/YLlt3H27u4+7+3htZCzLGoGwrjM8TIZRPO1yvDjDVc7DKKCuMjxKhtE7nbzLhEn6qqQ97n5X/iUB2SLDGATkGGVHhlFknVwhvlbSZyRdb2a7Fv7dlHNdQJbIMAYBOUbZkWEUVtu3XXP370qyHtQC5IIMYxCQY5QdGUaR8Ul1AAAASBoNMQAAAJJGQwwAAICkdfLRzd0zyaOttseGtzz+MqXz/28zNL4yF3wQko4ePjs0fs1Nh8M1NL4dqyGchT6otKRVR2P7z2LxCY+XpJ/9T8/Earjg3HANZ91/Xmh8fboVruHNS2PjK/Ox8Vnsy67vU1KlEZwjWPfsz8zGJpC06Q92hsZPfeR94Rp++eOfCY0/fEM1XMPQ2945vTuVZvz5qIzMY4/72HvmwjVc/vuvhcbv/+ULwzV86BOfDY0feelAuIY3tlwUniNPJWxVAAAAgOzQEAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIWi2PSd2k5qrYHM3h2PjDM6OxCSQdeV81NL5x8Wy4hrPXvRkaf+iVs8I1jAb3pQd/7YqO7xfz2PjWuXPhGiZ/873BIsIlaPrC2CSjB+KnqUp8KUunVZVOnBGbozlkofHVA8GTh6QDt78/NP7YO5rhGnw49oS08dF4Da+/K/Z8VNbrXx6LoLwSnKAVHC/pud+8IDR+6I14DW+8ayQ0fur6i8I1DB8OT5Grch4hAAAAQEZoiAEAAJA0GmIAAAAkjYYYAAAASeu4ITazqpn9wMwezrMgIC9kGGVHhjEIyDGKqJsrxLdJ2pNXIUAPkGGUHRnGICDHKJyOGmIz2yjpI5K+km85QD7IMMqODGMQkGMUVadXiO+W9DvK5F1Jgb64W2QY5Xa3yDDK726RYxRQ24bYzD4q6aC7P9Vmu21mNmFmE82ZqcwKBKJWkuH5WTKM4ljReXiKDKNYOskxvQT6pZMrxNdK+piZvSjpPknXm9lfLd3I3be7+7i7j1dHxjIuEwjpOsP1YTKMQun+PDxGhlE4bXNML4F+adsQu/uX3H2ju2+WtFXSN93907lXBmSEDKPsyDAGATlGkfE+xAAAAEharZuN3f3bkr6dSyVAD5BhlB0ZxiAgxygarhADAAAgaTTEAAAASBoNMQAAAJLW1WuIO2UtqTYTm8ODlb2xe31sAkk+4qHxtZeHwzVUHl8VGj/y8ePhGmo/XhubwILD+/D27V6R5kdjhTdGgg88A2PXHQyNP/jC2eEaNv5d7Dja/4nZcA2rfjQaGu/V2P17vy49BO83WvfYZPwYaAZPo2teCO48SbPrYwsx+ZH5cA0jL8YeRyuXZ/ucmdSqx6ZoNWLjb7nitG/93ZGH/vFfhMb78dXhGtY9Mx0a/8Yvxk9i9Z0jofF59wJcIQYAAEDSaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJK2Wx6TWkurHPTiJhYZf9OCh2P1LmtqyLjR+5MB0uIbX3rsmNP6cPx8N1zB1XmxfejV2/9aMjV8JN6k5FJujVY+NX7NzODaBpBON2ByrV4VL0GvviY0/6/FggCQduzg8RUzsdLZiHr3kEay7FTyGJKkyHxtfPxZ8LpI0e3Zs/EUPxq89Hfq58BSl4xbPULMVG7/rjp+LTSDpjM2x8/A5/2cyXMPL/35jaPxlf3AwXsO/HQmNt+C+bIcrxAAAAEgaDTEAAACSRkMMAACApNEQAwAAIGkdNcRmdqaZ3W9mPzazPWZ2Td6FAVkiwxgE5BhlR4ZRVJ2+y8QfSXrM3W8xsyFJ8bcuAHqLDGMQkGOUHRlGIbVtiM1sraQPSPqsJLn7nKS5fMsCskOGMQjIMcqODKPIOnnJxKWSDkn6mpn9wMy+YmZjOdcFZIkMYxCQY5QdGUZhddIQ1yRdKelP3f0KSVOS7ly6kZltM7MJM5tozE5lXCYQ0n2GZ8gwCqdtjhdnuDlNhlE4ZBiF1UlDPClp0t13LHx/v04G+i3cfbu7j7v7eG2YX/hQKN1neIQMo3Da5nhxhqujZBiFQ4ZRWG0bYnc/IOkVM7ts4Uc3SHo216qADJFhDAJyjLIjwyiyTt9l4rck3bvwF6EvSPpcfiUBuSDDGATkGGVHhlFIHTXE7r5L0ni+pQD5IcMYBOQYZUeGUVR8Uh0AAACSRkMMAACApNEQAwAAIGmd/lFdV7wizY9ZaI754LutHLj+nNgEGXjzHWvDc1QasfFvXBbfxRaswav9Hb+yO5Uq87EpWvXYeGvFxkvxtWtlcIawZmz8m5e136ad2kxsfPQxyIPjV8BcqgQ/Ayw8PrpukqwRW7wTZ8eeiySpGszP4XfGD6Toc0H0fNY3wWMneuzuv3okNoGkevDtlF/+xMZwDdH9v/+Gc8M1hJ/TMnhOPB2uEAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAkkZDDAAAgKTREAMAACBpNMQAAABIGg0xAAAAklbLY1I3qVUPzlGNjW/VLDaBJPNgDcE1OFlEsIYM9rBFlzL6a1d8V3Z/ly5VGrE5KvOxAEXvX5I8/CtvfPGjx0HrRLyG6onY+Mp8sIDguWSl99nvx11pxh94tIbmXLiE8P6L7gdJarWCNQTPR/1gLal+PDZHfar/j7s6GxsfPv9IsmZsfDWD4yjaU+V9HuUKMQAAAJJGQwwAAICk0RADAAAgaTTEAAAASFpHDbGZ3WFmu83sGTP7upkN510YkCUyjLIjwxgE5BhF1bYhNrMNkn5b0ri7v0dSVdLWvAsDskKGUXZkGIOAHKPIOn3JRE3SiJnVJI1K2pdfSUAuyDDKjgxjEJBjFFLbhtjdfyrpDyW9LGm/pCPu/kTehQFZIcMoOzKMQUCOUWSdvGTiLEk3S7pE0oWSxszs08tst83MJsxsojkzlX2lwAqtJMONWTKM4ljReXiaDKNYOskxGUa/dPKSiQ9K+om7H3L3eUkPSHr/0o3cfbu7j7v7eHVkLOs6gYiuM1wbJsMolO7Pw6NkGIXTNsdkGP3SSUP8sqSrzWzUzEzSDZL25FsWkCkyjLIjwxgE5BiF1clriHdIul/STklPL4zZnnNdQGbIMMqODGMQkGMUWa2Tjdz9y5K+nHMtQG7IMMqODGMQkGMUFZ9UBwAAgKTREAMAACBpNMQAAABImrl79pOaHZL00mk2WS/ptczvOFvUmJ1onRe7+zlZFdMJMtxTZaiTDPdPGepMpcae5riDDEvprH3eUqnxlBnOpSFux8wm3H2853fcBWrMTlnq7EYZHlMZapTKUWcZauxWWR5TGeqkxv4pw+OixmzkXSMvmQAAAEDSaIgBAACQtH41xGV4I25qzE5Z6uxGGR5TGWqUylFnGWrsVlkeUxnqpMb+KcPjosZs5FpjX15DDAAAABQFL5kAAABA0miIAQAAkLTcGmIzu9HMnjOzvWZ25zK3m5n98cLtPzKzK/Oq5TQ1bjKzb5nZHjPbbWa3LbPNdWZ2xMx2Lfz7vT7U+aKZPb1w/xPL3N7XtTSzyxatzy4zO2pmty/Zpu/ruBJFzzEZzrTGgcwxGc601kLnmAzTT3RQJxk+FXfP/J+kqqTnJV0qaUjSDyVdvmSbmyQ9KskkXS1pRx61tKnzAklXLny9RtI/LFPndZIe7nVtS2p4UdL609ze97Vcsu8P6OSbXxdqHVf4WAqdYzKc674vfY7JcOa1libHZLjndZYix2T41P/yukJ8laS97v6Cu89Juk/SzUu2uVnSX/pJfy/pTDO7IKd6luXu+91958LXxyTtkbShlzVkpO9rucgNkp5393afLlQGhc8xGc7NoOSYDPdWkXJMhntogHLc97VcpKcZzqsh3iDplUXfT+rtwehkm54xs82SrpC0Y5mbrzGzH5rZo2b27t5WJklySU+Y2VNmtm2Z24u0llslff0Ut/V7HbtVqhyT4UwNSo7JcLbKlGMy3CcFzzEZPoVaFpMsw5b52dL3d+tkm54ws9WSviHpdnc/uuTmnTp5uf64md0k6W8lbelxide6+z4zO1fSk2b2Y3f/zqLbC7GWZjYk6WOSvrTMzUVYx26VJsdkODsDlmMynK1S5JgML7tNT5Qgx2T4FPK6QjwpadOi7zdK2reCbXJnZnWdDO+97v7A0tvd/ai7H1/4+hFJdTNb38sa3X3fwn8PSnpQJ/8X0mKFWEtJH5a0091fXXpDEdZxBUqRYzKcuUHKMRnOUIlyTIbpJ5ZFhk8tr4b4+5K2mNklC13+VkkPLdnmIUm/svAXjVdLOuLu+3OqZ1lmZpK+KmmPu991im3OX9hOZnaVTq7Z6z2scczM1vzT15J+SdIzSzbr+1ou+JRO8b83+r2OK1T4HJPhXAxSjslwRkqWYzJMP7Hc/ZPh08jlJRPu3jCzWyU9rpN/JXiPu+82s19fuP3PJD2ik3/NuFfStKTP5VFLG9dK+oykp81s18LPflfSRdI/13mLpN8ws4akGUlb3b2X//vgPEkPLuz7mqS/dvfHiraWZjYq6UOSPr/oZ4tr7Pc6dq0kOSbDGRq0HJPhTJUix2SYfuI0yPDp7rfAxwEAAACQOz6pDgAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJC2XT6qrjo15/cx1oTmsFSwii88bCc7h1QxqsODw6DpK8mgNzdj4+aOH1ZiZClbRndromNfPiGVYGax9lEUznMGqh6fIIsNZHIsB80f6kOGRMR9aE8uwBy+ZRI/9TGRx2WcAjqMsnhJnD06+5u7nZDBVR2rDY75qdX8zXASZPIZggLKooQh93eyrp85wLg1x/cx1uvjzXwjNUZuO1ZDFidgasfHzq+M1tIZi46uz/a9h6Ehs/N57l/1Y+FzVz1inzb/a3wzHO0mpNhM7gzRG4kVUgsdR9UT8LDi/uqe96Nv0I8NDa9bpsn93R2iO6LoNHc3gGSw4RXM4g30frKFVj5cQPY5aGfxS+MzdX3gpPkvnVq1ep8s/GszwaKyG6EUFSWpVYxlsDsdr8GC3Nz8WryHaj9Qy6GeeuevUGR6A350AAACAlaMhBgAAQNJoiAEAAJC0jhpiM7vRzJ4zs71mdmfeRQFZI8MoOzKMQUCOUVRtG2Izq0r6E0kflnS5pE+Z2eV5FwZkhQyj7MgwBgE5RpF1coX4Kkl73f0Fd5+TdJ+km/MtC8gUGUbZkWEMAnKMwuqkId4g6ZVF308u/AwoCzKMsiPDGATkGIXVSUO83Bvove2d+cxsm5lNmNlEc2oqXhmQna4z3JgmwyiU7jM8Q4ZROG1z/JYMz5Jh9E4nDfGkpE2Lvt8oad/Sjdx9u7uPu/t4dSyDd3AGstN1hmujZBiF0n2GR8gwCqdtjt+S4WEyjN7ppCH+vqQtZnaJmQ1J2irpoXzLAjJFhlF2ZBiDgByjsNp+mJ+7N8zsVkmPS6pKusfdd+deGZARMoyyI8MYBOQYRdbRp1u7+yOSHsm5FiA3ZBhlR4YxCMgxiopPqgMAAEDSaIgBAACQNBpiAAAAJK2j1xB3y5pS/WhsjtrM295is+saoqpz0RmWe8vF7rRWxcZXZ8IlyKux8fVjwX3Zit3/SrhJHjw6ovvO4/GRNWOTNIOPQYrnxy2D46genSBcQs9ZS6pNx+ZoBY+B6Hlciu9/a8VriJ6DwvlT/Dktehz2hcf3n7Vi+ak0QsNP8thjaAXP45JkwcMgi3WozMfGZ9HXnQ5XiAEAAJA0GmIAAAAkjYYYAAAASaMhBgAAQNJoiAEAAJA0GmIAAAAkjYYYAAAASaMhBgAAQNJoiAEAAJA0GmIAAAAkjYYYAAAASaMhBgAAQNJoiAEAAJA0GmIAAAAkjYYYAAAASavlNrPFhnslNoHfeDhWgKS5760LjZ++oBWu4SO/8FRo/Df/5n3hGqwZnKCkv3Z5MMPy2PD1H9wXLEB69XsXhsZf+t/jNZx9b+xYfPaed4draI5Ed2b5eEWaH4vN0RiJja+eiK/7sUti49/x56+Ga7jyb/4xNP7Ju/5VuIYTZ6SX4SxY8DzsGTx/HX5fIzR+7e56uIZ337InNH7XY+8K11CJ9hLBfdlOSVsVAAAAIBs0xAAAAEgaDTEAAACSRkMMAACApLVtiM1sk5l9y8z2mNluM7utF4UBWSHDGATkGGVHhlFknbzLREPSF919p5mtkfSUmT3p7s/mXBuQFTKMQUCOUXZkGIXV9gqxu+93950LXx+TtEfShrwLA7JChjEIyDHKjgyjyLp6DbGZbZZ0haQduVQD5IwMYxCQY5QdGUbRdNwQm9lqSd+QdLu7H13m9m1mNmFmE83pqSxrBDJBhjEITpfjxRluzJBhFFPHGT5BhtE7HTXEZlbXyfDe6+4PLLeNu29393F3H6+OBj8eCcgYGcYgaJfjxRmujZBhFE9XGV5FhtE7nbzLhEn6qqQ97n5X/iUB2SLDGATkGGVHhlFknVwhvlbSZyRdb2a7Fv7dlHNdQJbIMAYBOUbZkWEUVtu3XXP370qyHtQC5IIMYxCQY5QdGUaR8Ul1AAAASBoNMQAAAJJGQwwAAICkdfLRzaU016iG59j4neOh8c3h+PJO7Pj50PgTV3i4huFDsZd8eQlfMWYtaehYbI7adGzt9/+/C2IFSPqZv5gMjX/5lo3hGo7913ND48997rVwDQeuWx+bIHgYWSs2fkU8fr8WfNzNf/NGbAJJ79h2ODTeRkfCNey4NXYePvwfZ8I1rP7uaGyCEp6HJcmawQmCx8Dr18wHC5Au/8/7Q+MPffCicA17t78zNH5kVbyXmF8dC2ElXsLp5893egAAAKDYaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQNBpiAAAAJK2Wy6wmNYdymblj1WorPMcLH18bGt84uxGuYXTdsdD4yrOxxyBJrXpsfHOVxSbo069tHiw7Or6VwdG599c2hMavftnDNfz0A7EdOPbZ+EJUn4jtDFN8HXrNq9L8mtjjnguePlp7zopNIGnfJ9aFxk9viO87v2gmNP6c/zEcruHIpeEpyil4Ho0+f9RG48/jz912UWh8a1W8n1n/VGwhKvFlCO/L6HNqO1whBgAAQNJoiAEAAJA0GmIAAAAkjYYYAAAASeu4ITazqpn9wMwezrMgIC9kGGVHhjEIyDGKqJsrxLdJ2pNXIUAPkGGUHRnGICDHKJyOGmIz2yjpI5K+km85QD7IMMqODGMQkGMUVadXiO+W9DuS4m+GB/TH3SLDKLe7RYZRfneLHKOA2jbEZvZRSQfd/ak2220zswkzm2hMT2VWIBC1kgw3yTAKhAxjEHSS47f0ErNkGL3TyRXiayV9zMxelHSfpOvN7K+WbuTu29193N3Ha6NjGZcJhHSd4SoZRrGQYQyCtjl+Sy8xTIbRO20bYnf/krtvdPfNkrZK+qa7fzr3yoCMkGGUHRnGICDHKDLehxgAAABJq3Wzsbt/W9K3c6kE6AEyjLIjwxgE5BhFwxViAAAAJI2GGAAAAEmjIQYAAEDSunoNccdcqs3GpqjOemj80efPiBUgqRIrQWfuqodrWHVkTWj8/CdfD9fQ+N/rQ+Nr08GF7Mfbt5vUHA5O4RYaf92//mGsAEnfen5LaPyJY6PhGjY92QiNP3D1WeEahqL7shXbl8EorIxJXu3D/S4ysj/+wGdjpx+16sHzj6Tq8yOh8fs/NB+uYeQnQ7EJynj5y6TmUCxDzXpsfK3eDI2XpHP+5YHQ+FdeDB4EktZMxs7D5/z+T8I1PPM/3xmbIH4on1YZDxEAAAAgMzTEAAAASBoNMQAAAJJGQwwAAICk0RADAAAgaTTEAAAASBoNMQAAAJJGQwwAAICk0RADAAAgaTTEAAAASBoNMQAAAJJGQwwAAICk0RADAAAgaTTEAAAASBoNMQAAAJJWy2NSa0r14x6ao3oiVsOWv3gzNoEk2/96aPzMz28O13D8wtguOu+O+XANB6+L7cv6dGy8tULDV8QrUmsoNkezGRv/dzvfHZtA0nnfjf3Ou2ZyJlzDwStHQuM3P3wsXMPkDWtC48MZ7NOlB7fg+Ers2F37Svzg/enPxsaf993gIkh67b2x8eu/Vw/XMLUhPEXpeEVqDMfmiJ7Hz7k3dv6SpMpc7EGsfk88P5PB53H/L5eGa2heHRsfPZ+1wxViAAAAJI2GGAAAAEmjIQYAAEDSaIgBAACQtI4aYjM708zuN7Mfm9keM7sm78KALJFhDAJyjLIjwyiqTt/C4I8kPebut5jZkKTRHGsC8kCGMQjIMcqODKOQ2jbEZrZW0gckfVaS3H1O0ly+ZQHZIcMYBOQYZUeGUWSdvGTiUkmHJH3NzH5gZl8xs7Gc6wKyRIYxCMgxyo4Mo7A6aYhrkq6U9KfufoWkKUl3Lt3IzLaZ2YSZTTRmpzIuEwjpOsPNKTKMwmmb47ech6fJMAqnuwzPkGH0TicN8aSkSXffsfD9/ToZ6Ldw9+3uPu7u47VhfuFDoXSd4eoYGUbhtM3xW87Do2QYhdNdhkfIMHqnbUPs7gckvWJmly386AZJz+ZaFZAhMoxBQI5RdmQYRdbpu0z8lqR7F/4i9AVJn8uvJCAXZBiDgByj7MgwCqmjhtjdd0kaz7cUID9kGIOAHKPsyDCKik+qAwAAQNJoiAEAAJA0GmIAAAAkrdM/quuKV6X51Raao1X10PiD15wVGi9JlbnYHHNrY2sgSa16bPy+D18QrsGDKbFWsIB+/NrmC/8CrBkbv/qF+OF54szY+KkNI+EarBEb/+r71oRriO7Lvo9f4X1W5mNTVOdi57Cjm6qxAiStfS42/vimcAkaORQbP31+vIbovvQyXv7KIMOtodj4Yxvi52EPHgZZ7LvadOxY/ukvBpsRSdXp2PhwL9FGGQ8RAAAAIDM0xAAAAEgaDTEAAACSRkMMAACApNEQAwAAIGk0xAAAAEgaDTEAAACSRkMMAACApNEQAwAAIGk0xAAAAEgaDTEAAACSRkMMAACApNEQAwAAIGk0xAAAAEgaDTEAAACSVstlVpOaq2JTVOYtNN49dv9ZTOIZrG6rHhtvrXgNXo2Njz4Gj0VhRcyl6onYHNW5bGqJ1RDLcKsWX/xKIza+Oh8/mFuzfQjRYlmcj7pkrXiGW0Ox8dUT8Qfuldi+q8yHS8hkjqjoudxLePmr0pSGjscyFF23SjM2XoqvfRb5i57LLYMn4upMcHzw+aydEh4iAAAAQHZoiAEAAJA0GmIAAAAkjYYYAAAASeuoITazO8xst5k9Y2ZfN7PhvAsDskSGUXZkGIOAHKOo2jbEZrZB0m9LGnf390iqStqad2FAVsgwyo4MYxCQYxRZpy+ZqEkaMbOapFFJ+/IrCcgFGUbZkWEMAnKMQmrbELv7TyX9oaSXJe2XdMTdn8i7MCArZBhlR4YxCMgxiqyTl0ycJelmSZdIulDSmJl9epnttpnZhJlNNKansq8UWCEyjLJbUYZnyDCKpZMcL87w/AkyjN7p5CUTH5T0E3c/5O7zkh6Q9P6lG7n7dncfd/fx2uhY1nUCEWQYZdd9hkfIMAqnbY4XZ7i+igyjdzppiF+WdLWZjZqZSbpB0p58ywIyRYZRdmQYg4Aco7A6eQ3xDkn3S9op6emFMdtzrgvIDBlG2ZFhDAJyjCKrdbKRu39Z0pdzrgXIDRlG2ZFhDAJyjKLik+oAAACQNBpiAAAAJI2GGAAAAEkzd89+UrNDkl46zSbrJb2W+R1nixqzE63zYnc/J6tiOkGGe6oMdZLh/ilDnanU2NMcd5BhKZ21z1sqNZ4yw7k0xO2Y2YS7j/f8jrtAjdkpS53dKMNjKkONUjnqLEON3SrLYypDndTYP2V4XNSYjbxr5CUTAAAASBoNMQAAAJLWr4a4DG/ETY3ZKUud3SjDYypDjVI56ixDjd0qy2MqQ53U2D9leFzUmI1ca+zLa4gBAACAouAlEwAAAEgaDTEAAACSlltDbGY3mtlzZrbXzO5c5nYzsz9euP1HZnZlXrWcpsZNZvYtM9tjZrvN7LZltrnOzI6Y2a6Ff7/XhzpfNLOnF+5/Ypnb+7qWZnbZovXZZWZHzez2Jdv0fR1Xoug5JsOZ1jiQOSbDmdZa6ByTYfqJDuokw6fi7pn/k1SV9LykSyUNSfqhpMuXbHOTpEclmaSrJe3Io5Y2dV4g6cqFr9dI+odl6rxO0sO9rm1JDS9KWn+a2/u+lkv2/QGdfPPrQq3jCh9LoXNMhnPd96XPMRnOvNbS5JgM97zOUuSYDJ/6X15XiK+StNfdX3D3OUn3Sbp5yTY3S/pLP+nvJZ1pZhfkVM+y3H2/u+9c+PqYpD2SNvSyhoz0fS0XuUHS8+7e7tOFyqDwOSbDuRmUHJPh3ipSjslwDw1Qjvu+lov0NMN5NcQbJL2y6PtJvT0YnWzTM2a2WdIVknYsc/M1ZvZDM3vUzN7d28okSS7pCTN7ysy2LXN7kdZyq6Svn+K2fq9jt0qVYzKcqUHJMRnOVplyTIb7pOA5JsOnUMtikmXYMj9b+v5unWzTE2a2WtI3JN3u7keX3LxTJy/XHzezmyT9raQtPS7xWnffZ2bnSnrSzH7s7t9ZdHsh1tLMhiR9TNKXlrm5COvYrdLkmAxnZ8ByTIazVYock+Flt+mJEuSYDJ9CXleIJyVtWvT9Rkn7VrBN7sysrpPhvdfdH1h6u7sfdffjC18/IqluZut7WaO771v470FJD+rk/0JarBBrKenDkna6+6tLbyjCOq5AKXJMhjM3SDkmwxkqUY7JMP3EssjwqeXVEH9f0hYzu2Shy98q6aEl2zwk6VcW/qLxaklH3H1/TvUsy8xM0lcl7XH3u06xzfkL28nMrtLJNXu9hzWOmdmaf/pa0i9JembJZn1fywWf0in+90a/13GFCp9jMpyLQcoxGc5IyXJMhuknlrt/Mnwaubxkwt0bZnarpMd18q8E73H33Wb26wu3/5mkR3Tyrxn3SpqW9Lk8amnjWkmfkfS0me1a+NnvSrpI+uc6b5H0G2bWkDQjaau79/J/H5wn6cGFfV+T9Nfu/ljR1tLMRiV9SNLnF/1scY39XseulSTHZDhDg5ZjMpypUuSYDNNPnAYZPt39Fvg4AAAAAHLHJ9UBAAAgaTTEAAAASBoNMQAAAJJGQwwAAICk0RADAAAgaTTEAAAASBoNMQAAAJL2/wFQRNKqIvWaaAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 720x360 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 720x360 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The reflected input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 8 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_f[0,0,:,:,:]).item() < vmax else torch.max(out_1_f[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_1[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_1_f[0,0,:,:,:]).item() < vmin else torch.min(out_1_f[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The reflected input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1_f.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\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_f[0,0,:,:,:]).item() < vmax else torch.max(out_2_f[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_2[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_2_f[0,0,:,:,:]).item() < vmin else torch.min(out_2_f[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The reflected input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2_f.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "As we can see, the responses are equivalent for reflected versions of the same image, up to a permutation of the axes (the upper channels are permuted with the lower channels), and a reflection corresponding to that of the input."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Final Test! - Rotation and Reflection Equivariance Simultaneously\n",
    "\n",
    "Now, let's analyze what occurs if the input image is reflected and rotated at the same time. Lets first see the input"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": [
    "# A mirroring on the x axis is equivalent to a rotation by 180 degrees and a consequent mirroring over y.\n",
    "\n",
    "input_tensor = inputs\n",
    "input_tensor_rf = torch.flip(input_tensor, [-2])\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_rf.numpy()[0,0,:,:,]);\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Pass the original random signal to the network and then its mirrored+reflected version"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_1 = sa_1(input_tensor)\n",
    "out_2 = sa_2(out_1)\n",
    "\n",
    "out_1_rf = sa_1(input_tensor_rf)\n",
    "out_2_rf = sa_2(out_1_rf)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's compare the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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 720x360 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The modified input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 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 720x360 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The modified input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 8 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_rf[0,0,:,:,:]).item() < vmax else torch.max(out_1_rf[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_1[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_1_rf[0,0,:,:,:]).item() < vmin else torch.min(out_1_rf[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The modified input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_1_rf.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\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_f[0,0,:,:,:]).item() < vmax else torch.max(out_2_f[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_2[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_2_f[0,0,:,:,:]).item() < vmin else torch.min(out_2_f[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The modified input.')\n",
    "plt.subplots(2,group.num_elements // 2, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(2,group.num_elements // 2,i+1)\n",
    "    plt.imshow(out_2_rf.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Voila! :) As we can see, the responses indeed move correspondingly to a 180 degree rotation, followed by a reflection on the y axis. \n",
    "\n",
    "To see this, perform the following exercise:\n",
    "\n",
    "* Mentally take a 180 rotation of any response followed by a reflection on the y axis. You will found that mental response by shifting 2 times along the row and then changing column.\n",
    "\n",
    "Hence, the responses undergo a rotation by 180 degrees plus a permutation of 2 channels along their corresponding row, after which, the responses are reflected and the rows are permuted with one another."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Reflection-Equivariant Layers"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Now, we will analyze the effect of constructing layers equivariant only to mirroring over the y-axis."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "Nxy = 9 # 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[:,:, :2, :] = 0.0 \n",
    "inputs[:,:, :, :2] = 0.0 \n",
    "inputs[:,:, -2:,:] = 0.0 \n",
    "inputs[:,:, :, -2:] = 0.0 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Layer parameters\n",
    "num_heads = 3 ** 2\n",
    "\n",
    "# Construct the group we want to test equivariance on.\n",
    "num_elements = 2\n",
    "group = g_selfatt.groups.E2(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.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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_f = torch.flip(inputs, [-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_f.numpy()[0,0,:,:,]);\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "out_1 = sa_1(input_tensor)\n",
    "out_2 = sa_2(out_1)\n",
    "\n",
    "out_1_f = sa_1(input_tensor_f)\n",
    "out_2_f = sa_2(out_1_f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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 720x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The reflected input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 2 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 720x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The reflected input.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 2 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_f[0,0,:,:,:]).item() < vmax else torch.max(out_1_f[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_1[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_1_f[0,0,:,:,:]).item() < vmin else torch.min(out_1_f[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(10,5))\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.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The reflected input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_1_f.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "#plt.tight_layout()\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_f[0,0,:,:,:]).item() < vmax else torch.max(out_2_f[0,0,:,:,:]).item()\n",
    "vmin = torch.min(out_2[0,0,:,:,:]).item()\n",
    "vmin = vmin if torch.min(out_2_f[0,0,:,:,:]).item() < vmin else torch.min(out_2_f[0,0,:,:,:]).item()\n",
    "\n",
    "print( 'The original input.')\n",
    "\n",
    "plt.subplots(1,group.num_elements, figsize=(10,5))\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.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "print( 'The reflected input.')\n",
    "plt.subplots(1,group.num_elements, figsize=(10,5))\n",
    "for i in range(group.num_elements):\n",
    "    plt.subplot(1,group.num_elements,i+1)\n",
    "    plt.imshow(out_2_f.detach().numpy()[0,0,i,:,:], vmin=vmin, vmax=vmax)\n",
    "#plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "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
}