{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:34:26.064636Z",
     "start_time": "2020-08-30T04:34:25.550961Z"
    }
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import math\n",
    "torch.manual_seed(2020)\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:34:26.684178Z",
     "start_time": "2020-08-30T04:34:26.651820Z"
    },
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "class EquiCtsConv2d(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, radius, num_radii, num_theta, matrix_dim=2, use_attention=True):\n",
    "        super(EquiCtsConv2d, self).__init__()\n",
    "        self.num_theta = num_theta\n",
    "        self.num_radii = num_radii\n",
    "        \n",
    "        kernel_basis_outer, kernel_bullseye = self.GenerateKernelBasis(num_radii, num_theta, matrix_dim)\n",
    "        self.register_buffer('kernel_basis_outer', kernel_basis_outer)\n",
    "        self.register_buffer('kernel_bullseye', kernel_bullseye)\n",
    "        \n",
    "        outer_weights = torch.rand(in_channels, out_channels, num_radii, matrix_dim, matrix_dim)\n",
    "        outer_weights -= 0.5\n",
    "        k = 1 / torch.sqrt(torch.tensor(in_channels, dtype=torch.float))\n",
    "        outer_weights *= 1 * k\n",
    "        self.outer_weights = torch.nn.parameter.Parameter(outer_weights)\n",
    "        \n",
    "        bullseye_weights = torch.rand(in_channels, out_channels)\n",
    "        bullseye_weights -= 0.5\n",
    "        bullseye_weights *= 1 * k\n",
    "        self.bullseye_weights = torch.nn.parameter.Parameter(bullseye_weights)\n",
    "        \n",
    "        self.radius = radius\n",
    "\n",
    "        self.use_attention = use_attention\n",
    "    \n",
    "    def computeKernel(self):\n",
    "        # print(\"[r, d, d, r, theta, d, d] \",self.kernel_basis.shape)\n",
    "        # print(\"[c_in,c_out, r, d , d]\", self.weights.shape)\n",
    "        kernel = (torch.einsum('pabrtij,xypab->yxrtij',self.kernel_basis_outer, self.outer_weights) +\n",
    "                 torch.einsum('rtij,xy->yxrtij',self.kernel_bullseye,self.bullseye_weights))\n",
    "        return kernel\n",
    "    \n",
    "    def GetAttention(self, relative_field):\n",
    "        r = torch.sum(relative_field ** 2, axis=-1)\n",
    "        return torch.relu((1 - r) ** 3).unsqueeze(-1)\n",
    "    \n",
    "    def GenerateKernelBasis(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: KB : [r+1, d, d, r+1, theta, d, d]  \n",
    "        KB_bullseye : \n",
    "        \"\"\" \n",
    "        d = matrix_dim\n",
    "        KB_outer = torch.zeros(r, d, d, r+1, theta, d, d, requires_grad=False)\n",
    "        K_bullseye = self.GenerateKernelBullseyeElement(r+1, theta, d)\n",
    "        \n",
    "        for i in range(d):\n",
    "            for j in range(d):\n",
    "                for r1 in range(0, r):\n",
    "                    KB_outer[r1,i,j] = self.GenerateKernelBasisElement(r+1, theta, i, j, r1+1, d) \n",
    "            \n",
    "        return KB_outer, K_bullseye\n",
    "    \n",
    "    def GenerateKernelBasisElement(self, r, theta, i, j, r1, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, d, d]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        K = torch.zeros(r, theta, d, d, requires_grad=False)\n",
    "        K[r1] = self.GenerateKernelBasisElementColumn(theta, i, j, d)\n",
    "        return K\n",
    "        \n",
    "    \n",
    "    def GenerateKernelBasisElementColumn(self, theta, i, j, matrix_dim=2):\n",
    "        # d = matrix_dim\n",
    "        # 0 <= i,j <= d-1\n",
    "        # C = kernelcolumn: [theta, d, d]\n",
    "        # C[0,:,:] = 0\n",
    "        # C[0,i,j] = 1\n",
    "        # for k in range(1,theta):\n",
    "        #   C[k] = RotMat(k*2*pi/theta) * C[0] * RotMat(-k*2*pi/theta) \n",
    "        # # K[g v] = g K[v] g^{-1}\n",
    "        d = matrix_dim\n",
    "        C = torch.zeros(theta, d, d, requires_grad=False)\n",
    "        C[0,i,j] = 1\n",
    "        # TODO: rho 1 -> rho n\n",
    "        for k in range(1, theta):\n",
    "            theta_i = torch.tensor(k*2*math.pi/theta)\n",
    "            C[k] = self.RotMat(theta_i).matmul(C[0]).matmul(self.RotMat(-theta_i))\n",
    "        return C\n",
    "    \n",
    "    def GenerateKernelBullseyeElement(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, d, d]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        K = torch.zeros(r, theta, d, d, requires_grad=False)\n",
    "        K[0] = self.GenerateKernelBullseyeElementColumn(theta, d)\n",
    "        return K\n",
    "    \n",
    "    def GenerateKernelBullseyeElementColumn(self, theta, matrix_dim=2):\n",
    "        d = matrix_dim\n",
    "        C = torch.zeros(theta, d, d, requires_grad=False)\n",
    "        C[:,0,0] = 1\n",
    "        C[:,1,1] = 1\n",
    "        return C\n",
    "            \n",
    "    @classmethod\n",
    "    def RotMat(cls, theta):\n",
    "        m = torch.tensor([\n",
    "                [torch.cos(theta), -torch.sin(theta)], \n",
    "                [torch.sin(theta), torch.cos(theta)]\n",
    "            ], requires_grad=False)\n",
    "        return m\n",
    "        \n",
    "        \n",
    "    def PolarCoords(self, vec, epsilon = 1e-9):\n",
    "        # vec: [batch, num_m, num_n, pos_dim]\n",
    "        # Convert to Polar\n",
    "        r = torch.sqrt(vec[...,0] **2 + vec[...,1] **2 + epsilon) \n",
    "         \n",
    "        cond_nonzero = ~((vec[...,0] == 0.) & (vec[...,1] == 0.))\n",
    "    \n",
    "        theta = torch.zeros(vec[...,0].shape, device=self.outer_weights.device)\n",
    "        theta[cond_nonzero] = torch.atan2(vec[...,1][cond_nonzero], vec[...,0][cond_nonzero])\n",
    "        \n",
    "        out = [r, theta]\n",
    "        out = torch.stack(out, -1)\n",
    "        return out\n",
    "    \n",
    "    def InterpolateKernel(self, kernel, pos):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2] -> [batch, C=c_out*c_in*4, r, theta]\n",
    "        @pos: [batch, num_m, num_n, 2] -> [batch, num_m, num_n, 2]\n",
    "        \n",
    "        return out: [batch, C=c_out*c_in*4, num_m, num_n] -> [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \"\"\"\n",
    "        # kernel:  [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        kernels = kernel.permute(0, 1, 4, 5, 2, 3)\n",
    "        # kernels: [c_out, c_in=feat_dim, 2, 2, r, theta]\n",
    "        \n",
    "        kernels = kernels.reshape(-1, *kernels.shape[4:]).unsqueeze(0)\n",
    "        # kernels: [1, c_out*c_in*2*2, r, theta]\n",
    "        \n",
    "        kernels = kernels.expand((pos.shape[0], *kernels.shape[1:]))\n",
    "        # kernels: [batch_size, c_out*c_in*2*2, r, theta]\n",
    "                  #[N, C, H, W]\n",
    "        \n",
    "\n",
    "        # Copy first and last column to wrap thetas.\n",
    "        padded_kernels = torch.cat([\n",
    "            kernels[..., -1].unsqueeze(-1), \n",
    "            kernels, \n",
    "            kernels[..., 0].unsqueeze(-1)\n",
    "        ],dim = -1)\n",
    "        padded_kernels = padded_kernels.permute(0,1,3,2)\n",
    "        # padded_kernels: [batch, C=c_out*c_in*4, theta+2, r]\n",
    "        \n",
    "        \n",
    "        grid = pos\n",
    "        # adjust radii [0,1] -> [-1,1]\n",
    "        grid[...,0] = 2*grid[...,0] - 1\n",
    "        # adjust angles [-pi,pi] -> [-1,1]\n",
    "        grid[...,1] *= 1/math.pi\n",
    "        # shrink thetas slightly to account for padding\n",
    "        grid[...,1] *= self.num_theta / (self.num_theta + 2)\n",
    "        # grid [batch, num_m, num_n, 2]\n",
    "        #      [N, H_out, W_out, 2]\n",
    "        \n",
    "        # print(\"grid\",grid)\n",
    "        # print(\"padded_kernels_shape [batch_size, c_out*c_in*2*2, theta+2, r]:\",padded_kernels.shape)\n",
    "        #print(\"kernels\",padded_kernels)\n",
    "        \n",
    "        out = F.grid_sample(padded_kernels, grid, padding_mode='zeros', \n",
    "                            mode='bilinear', align_corners=False)  #bilinear\n",
    "        # out: [batch, C=c_out*c_in*4, num_m, num_n]\n",
    "        #      [N, C, H_out, W_out]\n",
    "        \n",
    "        out = out.permute(0, 2, 3, 1)\n",
    "        # out: [batch, num_m, num_n, C=c_out*c_in*4]\n",
    "        out = out.reshape(*pos.shape[:-1], *kernel.shape[0:2], *kernel.shape[-2:])\n",
    "        # out: [batch, num_m, num_n, c_out, c_in, 2, 2]     \n",
    "        return out\n",
    "    \n",
    "    def ContinuousConv(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @ctr_feat: [batch, 1, feat_dim]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "        \"\"\"\n",
    "        kernel = self.computeKernel()\n",
    "        \n",
    "        relative_field = (field.unsqueeze(1) - center.unsqueeze(2)) / self.radius\n",
    "        # relative_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "\n",
    "        polar_field = self.PolarCoords(relative_field)\n",
    "        # polar_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "        kernel_on_field = self.InterpolateKernel(kernel, polar_field)\n",
    "        # kernel_on_field: [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \n",
    "        if self.use_attention:\n",
    "            # print(relative_field.shape)\n",
    "            # print(field_mask.unsqueeze(1).shape)\n",
    "            attention = self.GetAttention(relative_field) * field_mask.unsqueeze(1)\n",
    "            # attention: [batch, num_m, num_n, 1]\n",
    "\n",
    "            psi = torch.sum(attention, axis=2) if normalize_attention else 1\n",
    "        else:\n",
    "            attention = torch.ones(*relative_field.shape[0:3],1)\n",
    "            \n",
    "            psi = 1.0\n",
    "        \n",
    "        attention_field_feat = field_feat.unsqueeze(1)*attention.unsqueeze(-1)\n",
    "        # attention_field_feat: [batch, num_m, num_n, c_in, 2]\n",
    "\n",
    "        out = torch.einsum('bmnoiyx,bmnix->bmoy', kernel_on_field, attention_field_feat)\n",
    "        # out: [batch, num_m, c_out, 2]\n",
    "        \n",
    "        return out / psi\n",
    "        \n",
    "    \n",
    "    \n",
    "    def forward(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        out = self.ContinuousConv(\n",
    "            field, center, field_feat, field_mask, \n",
    "            ctr_feat, normalize_attention\n",
    "        )\n",
    "        return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:34:27.303520Z",
     "start_time": "2020-08-30T04:34:27.299583Z"
    },
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "class EquiLinear(nn.Module):\n",
    "    def __init__(self, in_features, out_features):\n",
    "        super(EquiLinear, self).__init__()\n",
    "        self.linear = nn.Linear(in_features, out_features, bias=False)\n",
    "    \n",
    "    def forward(self, field_feat):\n",
    "        \"\"\"\n",
    "        inputs:\n",
    "        @field_feat: [batch, num_part, in_feat, 2]\n",
    "        \n",
    "        output:\n",
    "        [batch, num_part, out_feat, 2]\n",
    "        \"\"\"\n",
    "        return self.linear(field_feat.permute(0, 1, 3, 2)).permute(0, 1, 3, 2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Reg -> Reg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-09-09T21:49:56.453331Z",
     "start_time": "2020-09-09T21:49:56.447341Z"
    }
   },
   "outputs": [],
   "source": [
    "def RegRot(field_feat, theta):\n",
    "    k = field_feat.shape[-1]\n",
    "    rotmat = EquiCtsConv2dRho1ToReg.RegRotMat(theta, k)\n",
    "    print(rotmat)\n",
    "    return torch.einsum('ij, ...j->...i', rotmat, field_feat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-09-09T21:58:11.978730Z",
     "start_time": "2020-09-09T21:58:11.966919Z"
    }
   },
   "outputs": [],
   "source": [
    "#TODO: Implement, Test, Answer ??? \n",
    "# Reg --> Reg    \n",
    "class EquiLinearRegToReg(nn.Module):\n",
    "    def __init__(self, in_features, out_features, k):\n",
    "        super(EquiLinearRegToReg, self).__init__()\n",
    "        self.k = k\n",
    "        self.weights = nn.parameter.Parameter(torch.rand(in_features, out_features, k) / in_features)\n",
    "        print(self.weights)\n",
    "        self.kernel = self.update_kernel()\n",
    "        print(self.kernel)\n",
    "    \n",
    "    def update_kernel(self):\n",
    "            # i or -i ???   stack -2 or -1 ???   torch.flip ???\n",
    "        return torch.stack([torch.roll(self.weights, i, 2) for i in range(0,self.k)],-1)\n",
    "        \n",
    "    def forward(self, field_feat):\n",
    "        \"\"\"\n",
    "        inputs:\n",
    "        k: int -- number of slices of the circle for regular rep\n",
    "        @field_feat: [batch, num_part, in_feat, k]\n",
    "        kernel: [in_feat, out_feat, k, k]\n",
    "        \n",
    "        f*k(\\theta) = \\sum_\\psi K(\\psi)f(\\theta - \\psi)\n",
    "\n",
    "        output:\n",
    "        [batch, num_part, out_feat, k]\n",
    "        \"\"\"\n",
    "        # x or y ??? \n",
    "        return torch.einsum('ijyx,...ix->...jy',self.kernel,field_feat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "#### test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-09-09T21:58:12.758372Z",
     "start_time": "2020-09-09T21:58:12.744400Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter containing:\n",
      "tensor([[[0.4869, 0.1052, 0.5883, 0.1161, 0.4949, 0.2824, 0.5899, 0.8105]]],\n",
      "       requires_grad=True)\n",
      "tensor([[[[0.4869, 0.8105, 0.5899, 0.2824, 0.4949, 0.1161, 0.5883, 0.1052],\n",
      "          [0.1052, 0.4869, 0.8105, 0.5899, 0.2824, 0.4949, 0.1161, 0.5883],\n",
      "          [0.5883, 0.1052, 0.4869, 0.8105, 0.5899, 0.2824, 0.4949, 0.1161],\n",
      "          [0.1161, 0.5883, 0.1052, 0.4869, 0.8105, 0.5899, 0.2824, 0.4949],\n",
      "          [0.4949, 0.1161, 0.5883, 0.1052, 0.4869, 0.8105, 0.5899, 0.2824],\n",
      "          [0.2824, 0.4949, 0.1161, 0.5883, 0.1052, 0.4869, 0.8105, 0.5899],\n",
      "          [0.5899, 0.2824, 0.4949, 0.1161, 0.5883, 0.1052, 0.4869, 0.8105],\n",
      "          [0.8105, 0.5899, 0.2824, 0.4949, 0.1161, 0.5883, 0.1052, 0.4869]]]],\n",
      "       grad_fn=<StackBackward>)\n",
      "tensor([[0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.]])\n",
      "tensor([[0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(tensor([[[[0.4869, 0.1052, 0.5883, 0.1161, 0.4949, 0.2824, 0.5899, 0.8105]]]],\n",
       "        grad_fn=<ViewBackward>),\n",
       " tensor([[[[0.4869, 0.1052, 0.5883, 0.1161, 0.4949, 0.2824, 0.5899, 0.8105]]]],\n",
       "        grad_fn=<ViewBackward>))"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "field_feat = torch.zeros(1, 1, 1, 8)\n",
    "field_feat[...,0] = 1.0\n",
    "\n",
    "linear_reg_reg = EquiLinearRegToReg(1, 1, 8)\n",
    "linear_reg_reg(field_feat)\n",
    "\n",
    "RegRot(linear_reg_reg(RegRot(field_feat, 2 * math.pi / 8)), -2 * math.pi / 8), linear_reg_reg(field_feat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Rho1 -> Reg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Rho1Rot(field_feat, theta):\n",
    "    rotmat = EquiCtsConv2dRho1ToReg.Rho1RotMat(torch.tensor(theta))\n",
    "    print(rotmat)\n",
    "    return torch.einsum('ij, ...j->...i', rotmat, field_feat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "class EquiLinearRho1ToReg(nn.Module):\n",
    "    def __init__(self, k):\n",
    "        super(EquiLinearRho1ToReg, self).__init__()\n",
    "        self.k = k\n",
    "        SinVec = torch.tensor([math.sin(i * 2 * math.pi / self.k) for i in range(k)],requires_grad=False)\n",
    "        CosVec = torch.tensor([math.cos(i * 2 * math.pi / self.k) for i in range(k)],requires_grad=False)\n",
    "        Rho1ToReg = torch.stack([CosVec,SinVec],1)  #[k,2]\n",
    "        self.register_buffer('Rho1ToReg', Rho1ToReg)\n",
    "    \n",
    "    def forward(self, field_feat):\n",
    "        \"\"\"\n",
    "            k: int -- number of slices of the circle for regular rep\n",
    "            inputs:\n",
    "                @field_feat: [batch, num_part, in_feat, 2]\n",
    "            output: [batch, num_part, in_feat, k]\n",
    "        \n",
    "            (a,b) --> a Sin + b Cos\n",
    "        \"\"\"\n",
    "        return torch.einsum('yx,...x->...y',self.Rho1ToReg, field_feat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[ 0.7071, -0.7071],\n",
      "        [ 0.7071,  0.7071]])\n",
      "tensor([[0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[-5.9605e-08,  0.0000e+00, -6.1232e-17,  0.0000e+00,  5.9605e-08,\n",
       "            0.0000e+00,  1.8370e-16,  0.0000e+00]]]])"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "field_feat = torch.zeros(1, 1, 1, 2)\n",
    "field_feat[...,0] = 1.0\n",
    "\n",
    "linear_rho1_reg = EquiLinearRho1ToReg(8)\n",
    "linear_rho1_reg(field_feat)\n",
    "\n",
    "RegRot(linear_rho1_reg(Rho1Rot(field_feat, 2 * math.pi / 8)), -2 * math.pi / 8) - linear_rho1_reg(field_feat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Reg -> Rho1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "class EquiLinearRegToRho1(nn.Module):\n",
    "    def __init__(self, k):\n",
    "        super(EquiLinearRegToRho1, self).__init__()\n",
    "        self.k = k\n",
    "        SinVec = torch.tensor([math.sin(i * 2 * math.pi / self.k) for i in range(k)],requires_grad=False)\n",
    "        CosVec = torch.tensor([math.cos(i * 2 * math.pi / self.k) for i in range(k)],requires_grad=False)\n",
    "        RegToRho1 = torch.stack([CosVec,SinVec],0)  #[2,k]\n",
    "        self.register_buffer('RegToRho1', RegToRho1)\n",
    "    \n",
    "    def forward(self, field_feat):\n",
    "        '''\n",
    "           k: int -- number of slices of the circle for regular rep\n",
    "           inputs:\n",
    "               @field_feat: [batch, num_part, in_feat, k]\n",
    "           output: \n",
    "               retval:      [batch, num_part, in_feat, 2]\n",
    "\n",
    "           f is a function on circle divided into k parts\n",
    "           f(i) means f(2\\pi *i /k) \n",
    "           f --> ( \\sum_{i=0}^k  ( f(i) cos(2 \\pi i /k) , f(i) sin(2 \\pi i /k) )\n",
    "           This is a fourier transform. \n",
    "        '''\n",
    "        return torch.einsum('yx,...x->...y',self.RegToRho1, field_feat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.]])\n",
      "tensor([[ 0.7071,  0.7071],\n",
      "        [-0.7071,  0.7071]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(1.7881e-07)"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "field_feat = torch.rand(3, 2, 2, 8)\n",
    "\n",
    "\n",
    "linear_reg_rho1 = EquiLinearRegToRho1(8)\n",
    "linear_reg_rho1(field_feat)\n",
    "\n",
    "torch.max(Rho1Rot(linear_reg_rho1(RegRot(field_feat, 2 * math.pi / 8)), -2 * math.pi / 8) - linear_reg_rho1(field_feat))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Reg -> Rho1 cong1 ming2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "class EquiCtsConv2dRegToRho1(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, radius, num_radii, num_theta, k, matrix_dim=2, use_attention=True):\n",
    "        super(EquiCtsConv2dRegToRho1, self).__init__()\n",
    "        self.num_theta = num_theta\n",
    "        self.num_radii = num_radii\n",
    "        self.k = k\n",
    "\n",
    "        RegToRho1Mat = EquiLinearRegToRho1(k).RegToRho1    #[2,k]\n",
    "        self.register_buffer('RegToRho1Mat', RegToRho1Mat)\n",
    "    \n",
    "        \n",
    "        kernel_basis_outer, kernel_bullseye = self.GenerateKernelBasis(num_radii, num_theta, matrix_dim)\n",
    "        self.register_buffer('kernel_basis_outer', kernel_basis_outer)\n",
    "        self.register_buffer('kernel_bullseye', kernel_bullseye)\n",
    "        \n",
    "        outer_weights = torch.rand(in_channels, out_channels, num_radii, matrix_dim, k)\n",
    "        outer_weights -= 0.5\n",
    "        scale_norm = 1 / torch.sqrt(torch.tensor(in_channels, dtype=torch.float))\n",
    "        outer_weights *= 1 * scale_norm\n",
    "        self.outer_weights = torch.nn.parameter.Parameter(outer_weights)\n",
    "        \n",
    "        bullseye_weights = torch.rand(in_channels, out_channels)\n",
    "        bullseye_weights -= 0.5\n",
    "        bullseye_weights *= 1 * scale_norm\n",
    "        self.bullseye_weights = torch.nn.parameter.Parameter(bullseye_weights)\n",
    "        \n",
    "        self.radius = radius\n",
    "\n",
    "        self.use_attention = use_attention\n",
    "        \n",
    "\n",
    "    def computeKernel(self):\n",
    "        # print(\"[r, d, d, r, theta, d, k] \",self.kernel_basis.shape)\n",
    "        # print(\"[c_in,c_out, r, d, k]\", self.weights.shape)\n",
    "        kernel = (torch.einsum('pabrtij,xypab->yxrtij',self.kernel_basis_outer, self.outer_weights) +\n",
    "                 torch.einsum('rtij,xy->yxrtij',self.kernel_bullseye,self.bullseye_weights))\n",
    "        return kernel\n",
    "    \n",
    "    def GetAttention(self, relative_field):\n",
    "        r = torch.sum(relative_field ** 2, axis=-1)\n",
    "        return torch.relu((1 - r) ** 3).unsqueeze(-1)\n",
    "    \n",
    "    def GenerateKernelBasis(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: KB : [r+1, d, k, r+1, theta, d, k]  \n",
    "        KB_bullseye : \n",
    "        \"\"\" \n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        KB_outer = torch.zeros(r, d, k, r+1, theta, d, k, requires_grad=False)\n",
    "        K_bullseye = self.GenerateKernelBullseyeElement(r+1, theta, d)\n",
    "        \n",
    "        for i in range(d):\n",
    "            for j in range(k):\n",
    "                for r1 in range(0, r):\n",
    "                    KB_outer[r1,i,j] = self.GenerateKernelBasisElement(r+1, theta, i, j, r1+1, d) \n",
    "            \n",
    "        return KB_outer, K_bullseye\n",
    "    \n",
    "    def GenerateKernelBasisElement(self, r, theta, i, j, r1, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, d, k]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        K = torch.zeros(r, theta, d, k, requires_grad=False)\n",
    "        K[r1] = self.GenerateKernelBasisElementColumn(theta, i, j, d)\n",
    "        return K\n",
    "        \n",
    "    def GenerateKernelBasisElementColumn(self, theta, i, j, matrix_dim=2):\n",
    "        # d = matrix_dim\n",
    "        # 0 <= i,j <= d-1\n",
    "        # C = kernelcolumn: [theta, d, d]\n",
    "        # C[0,:,:] = 0\n",
    "        # C[0,i,j] = 1\n",
    "        # for k in range(1,theta):\n",
    "        #   C[k] = RotMat(k*2*pi/theta) * C[0] * RotMat(-k*2*pi/theta) \n",
    "        # # K[g v] = g K[v] g^{-1}\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        C = torch.zeros(theta, d, k, requires_grad=False)\n",
    "        C[0,i,j] = 1\n",
    "        # TODO: rho 1 -> rho n\n",
    "        for ind in range(1, theta):\n",
    "            theta_i = torch.tensor(ind*2*math.pi/theta)\n",
    "            C[ind] = self.Rho1RotMat(theta_i).matmul(C[0]).matmul(self.RegRotMat(-theta_i.numpy(), k))\n",
    "        return C\n",
    "    \n",
    "    def GenerateKernelBullseyeElement(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, d, k]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        K = torch.zeros(r, theta, d, k, requires_grad=False)\n",
    "        K[0] = self.GenerateKernelBullseyeElementColumn(theta, d)\n",
    "        return K\n",
    "    \n",
    "    def GenerateKernelBullseyeElementColumn(self, theta, matrix_dim=2):\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        C = torch.zeros(theta, d, k, requires_grad=False)\n",
    "        C[:] = self.RegToRho1Mat\n",
    "        return C\n",
    "            \n",
    "    @classmethod\n",
    "    def Rho1RotMat(cls, theta):\n",
    "        m = torch.tensor([\n",
    "                [torch.cos(theta), -torch.sin(theta)], \n",
    "                [torch.sin(theta), torch.cos(theta)]\n",
    "            ], requires_grad=False)\n",
    "        return m\n",
    "    \n",
    "    @classmethod\n",
    "    def RegRotMat(cls, theta, k):\n",
    "        slice_angle = 2 * math.pi / k\n",
    "        index_shift = theta / slice_angle\n",
    "        i = np.floor(index_shift).astype(np.int)\n",
    "        # divide weights between i and i+1   first_col = [ 0 0 0 ... 0 w_i w_{i+1} 0 0 0 ... 0 0 0] \n",
    "        first_col = torch.zeros(k)\n",
    "        \n",
    "        offset = (theta - slice_angle * i) / slice_angle\n",
    "        w_i = 1 - offset\n",
    "        w_ip = offset\n",
    "        first_col[np.mod(i,8)], first_col[np.mod(i+1,8)] = w_i, w_ip\n",
    "        \n",
    "        m = torch.stack([torch.roll(first_col, i, 0) for i in range(k)], -1)\n",
    "        #like a permuation matrix which sends i -> i + \\theta / ( 2 \\pi / k ) \n",
    "        #Note if k = num_theta, then it is a permutation matrix \n",
    "        return m\n",
    "    \n",
    "        \n",
    "    def PolarCoords(self, vec, epsilon = 1e-9):\n",
    "        # vec: [batch, num_m, num_n, pos_dim]\n",
    "        # Convert to Polar\n",
    "        r = torch.sqrt(vec[...,0] **2 + vec[...,1] **2 + epsilon) \n",
    "         \n",
    "        cond_nonzero = ~((vec[...,0] == 0.) & (vec[...,1] == 0.))\n",
    "    \n",
    "        theta = torch.zeros(vec[...,0].shape, device=self.outer_weights.device)\n",
    "        theta[cond_nonzero] = torch.atan2(vec[...,1][cond_nonzero], vec[...,0][cond_nonzero])\n",
    "        \n",
    "        out = [r, theta]\n",
    "        out = torch.stack(out, -1)\n",
    "        return out\n",
    "    \n",
    "    def InterpolateKernel(self, kernel, pos):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2] -> [batch, C=c_out*c_in*4, r, theta]\n",
    "        @pos: [batch, num_m, num_n, 2] -> [batch, num_m, num_n, 2]\n",
    "        \n",
    "        return out: [batch, C=c_out*c_in*4, num_m, num_n] -> [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \"\"\"\n",
    "        # kernel:  [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        kernels = kernel.permute(0, 1, 4, 5, 2, 3)\n",
    "        # kernels: [c_out, c_in=feat_dim, 2, 2, r, theta]\n",
    "        \n",
    "        kernels = kernels.reshape(-1, *kernels.shape[4:]).unsqueeze(0)\n",
    "        # kernels: [1, c_out*c_in*2*2, r, theta]\n",
    "        \n",
    "        kernels = kernels.expand((pos.shape[0], *kernels.shape[1:]))\n",
    "        # kernels: [batch_size, c_out*c_in*2*2, r, theta]\n",
    "                  #[N, C, H, W]\n",
    "        \n",
    "\n",
    "        # Copy first and last column to wrap thetas.\n",
    "        padded_kernels = torch.cat([\n",
    "            kernels[..., -1].unsqueeze(-1), \n",
    "            kernels, \n",
    "            kernels[..., 0].unsqueeze(-1)\n",
    "        ],dim = -1)\n",
    "        padded_kernels = padded_kernels.permute(0,1,3,2)\n",
    "        # padded_kernels: [batch, C=c_out*c_in*4, theta+2, r]\n",
    "        \n",
    "        \n",
    "        grid = pos\n",
    "        # adjust radii [0,1] -> [-1,1]\n",
    "        grid[...,0] = 2*grid[...,0] - 1\n",
    "        # adjust angles [-pi,pi] -> [-1,1]\n",
    "        grid[...,1] *= 1/math.pi\n",
    "        # shrink thetas slightly to account for padding\n",
    "        grid[...,1] *= self.num_theta / (self.num_theta + 2)\n",
    "        # grid [batch, num_m, num_n, 2]\n",
    "        #      [N, H_out, W_out, 2]\n",
    "        \n",
    "        # print(\"grid\",grid)\n",
    "        # print(\"padded_kernels_shape [batch_size, c_out*c_in*2*2, theta+2, r]:\",padded_kernels.shape)\n",
    "        #print(\"kernels\",padded_kernels)\n",
    "        \n",
    "        out = F.grid_sample(padded_kernels, grid, padding_mode='zeros', \n",
    "                            mode='bilinear', align_corners=False)  #bilinear\n",
    "        # out: [batch, C=c_out*c_in*4, num_m, num_n]\n",
    "        #      [N, C, H_out, W_out]\n",
    "        \n",
    "        out = out.permute(0, 2, 3, 1)\n",
    "        # out: [batch, num_m, num_n, C=c_out*c_in*4]\n",
    "        out = out.reshape(*pos.shape[:-1], *kernel.shape[0:2], *kernel.shape[-2:])\n",
    "        # out: [batch, num_m, num_n, c_out, c_in, 2, 2]     \n",
    "        return out\n",
    "    \n",
    "    def ContinuousConv(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @ctr_feat: [batch, 1, feat_dim]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "        \"\"\"\n",
    "        kernel = self.computeKernel()\n",
    "        \n",
    "        relative_field = (field.unsqueeze(1) - center.unsqueeze(2)) / self.radius\n",
    "        # relative_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "\n",
    "        polar_field = self.PolarCoords(relative_field)\n",
    "        # polar_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "        kernel_on_field = self.InterpolateKernel(kernel, polar_field)\n",
    "        # kernel_on_field: [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \n",
    "        if self.use_attention:\n",
    "            # print(relative_field.shape)\n",
    "            # print(field_mask.unsqueeze(1).shape)\n",
    "            attention = self.GetAttention(relative_field) * field_mask.unsqueeze(1)\n",
    "            # attention: [batch, num_m, num_n, 1]\n",
    "\n",
    "            psi = torch.sum(attention, axis=2) if normalize_attention else 1\n",
    "        else:\n",
    "            attention = torch.ones(*relative_field.shape[0:3],1)\n",
    "            \n",
    "            psi = 1.0\n",
    "        \n",
    "        attention_field_feat = field_feat.unsqueeze(1)*attention.unsqueeze(-1)\n",
    "        # attention_field_feat: [batch, num_m, num_n, c_in, 2]\n",
    "\n",
    "        out = torch.einsum('bmnoiyx,bmnix->bmoy', kernel_on_field, attention_field_feat)\n",
    "        # out: [batch, num_m, c_out, 2]\n",
    "        \n",
    "        return out / psi\n",
    "    \n",
    "    def forward(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        out = self.ContinuousConv(\n",
    "            field, center, field_feat, field_mask, \n",
    "            ctr_feat, normalize_attention\n",
    "        )\n",
    "        return out"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRegToRho1(in_channels = 5, out_channels = 7, radius = 1, num_radii = 2, num_theta = 16, k = 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[-0.0110, -0.0162],\n",
       "          [-0.0337,  0.0448],\n",
       "          [ 0.0043, -0.0281],\n",
       "          [-0.0325,  0.0421],\n",
       "          [-0.0373, -0.0234],\n",
       "          [ 0.0455,  0.1175],\n",
       "          [ 0.0350, -0.0169]]],\n",
       "\n",
       "\n",
       "        [[[ 0.0109,  0.0402],\n",
       "          [-0.0884,  0.0507],\n",
       "          [ 0.1173, -0.0311],\n",
       "          [-0.0180, -0.0268],\n",
       "          [ 0.0743, -0.1294],\n",
       "          [ 0.0052,  0.1095],\n",
       "          [-0.0583, -0.0237]]],\n",
       "\n",
       "\n",
       "        [[[ 0.1198,  0.1822],\n",
       "          [-0.0085,  0.1940],\n",
       "          [ 0.0638, -0.2009],\n",
       "          [ 0.0737,  0.0653],\n",
       "          [ 0.0979, -0.3460],\n",
       "          [ 0.1768,  0.0098],\n",
       "          [-0.0912, -0.0023]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 3\n",
    "num_part = 1\n",
    "feat_dim = 5\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(batch_size,num_part,2)\n",
    "center = torch.rand(batch_size,num_part,2)\n",
    "field_feat = torch.rand(batch_size,num_part,feat_dim,8)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "model(field, center, field_feat, field_mask)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRegToRho1(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, k=8, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[-0.2855,  0.5211]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "#field = torch.tensor([[[-.2,.2],[0.,1.]]])\n",
    "field = torch.tensor([[[-.2*6,.2*6],[0.,1.]]])\n",
    "#field = torch.tensor([[[-1.99,0.01],[0.,1.]]])\n",
    "\n",
    "center = torch.tensor([[[0.,0.]]])\n",
    "field_feat = torch.tensor([[[[1., 0., 0., 0., 0., 0., 0., 0.]],[[0., 1., 0., 0., 0., 0., 0., 0.]]]])\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[-4.3711e-08,  1.0000e+00],\n",
      "        [-1.0000e+00, -4.3711e-08]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[-0.2855,  0.5211]]]], grad_fn=<ViewBackward>)"
      ]
     },
     "execution_count": 75,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "theta = math.pi/2\n",
    "rotated_field = Rho1Rot(field, theta)\n",
    "rotated_feat  = RegRot(field_feat, theta)\n",
    "rotated_center = Rho1Rot(center, theta)\n",
    "Rho1Rot(model(rotated_field, rotated_center, rotated_feat, field_mask),-theta)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRegToRho1(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, k=8, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.2711, -0.1076]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(1,2,2)\n",
    "\n",
    "center = torch.rand(1,1,2)\n",
    "field_feat = torch.rand(1, 2, 1, 8)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[-4.3711e-08,  1.0000e+00],\n",
      "        [-1.0000e+00, -4.3711e-08]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.2711, -0.1076]]]], grad_fn=<ViewBackward>)"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "theta = math.pi/2\n",
    "rotated_field = Rho1Rot(field, theta)\n",
    "rotated_feat  = RegRot(field_feat, theta)\n",
    "rotated_center = Rho1Rot(center, theta)\n",
    "Rho1Rot(model(rotated_field, rotated_center, rotated_feat, field_mask),-theta)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Cts Conv Rho1 -> Reg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "class EquiCtsConv2dRho1ToReg(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, radius, num_radii, num_theta, k, matrix_dim=2, use_attention=True):\n",
    "        super(EquiCtsConv2dRho1ToReg, self).__init__()\n",
    "        self.num_theta = num_theta\n",
    "        self.num_radii = num_radii\n",
    "        self.k = k\n",
    "\n",
    "        Rho1ToRegMat = EquiLinearRho1ToReg(k).Rho1ToReg    #[k,2]\n",
    "        self.register_buffer('Rho1ToRegMat', Rho1ToRegMat)\n",
    "    \n",
    "        kernel_basis_outer, kernel_bullseye = self.GenerateKernelBasis(num_radii, num_theta, matrix_dim)\n",
    "        self.register_buffer('kernel_basis_outer', kernel_basis_outer)\n",
    "        self.register_buffer('kernel_bullseye', kernel_bullseye)\n",
    "        \n",
    "        outer_weights = torch.rand(in_channels, out_channels, num_radii, k, matrix_dim)\n",
    "        outer_weights -= 0.5\n",
    "        scale_norm = 1 / torch.sqrt(torch.tensor(in_channels, dtype=torch.float))\n",
    "        outer_weights *= 1 * scale_norm\n",
    "        self.outer_weights = torch.nn.parameter.Parameter(outer_weights)\n",
    "        \n",
    "        bullseye_weights = torch.rand(in_channels, out_channels)\n",
    "        bullseye_weights -= 0.5\n",
    "        bullseye_weights *= 1 * scale_norm\n",
    "        self.bullseye_weights = torch.nn.parameter.Parameter(bullseye_weights)\n",
    "        \n",
    "        self.radius = radius\n",
    "\n",
    "        self.use_attention = use_attention\n",
    "        \n",
    "\n",
    "    def computeKernel(self):\n",
    "        # print(\"[r, d, d, r, theta, k, d] \",self.kernel_basis.shape)\n",
    "        # print(\"[c_in,c_out, r, k, d]\", self.weights.shape)\n",
    "        kernel = (torch.einsum('pabrtij,xypab->yxrtij',self.kernel_basis_outer, self.outer_weights) +\n",
    "                 torch.einsum('rtij,xy->yxrtij',self.kernel_bullseye,self.bullseye_weights))\n",
    "        return kernel\n",
    "    \n",
    "    def GetAttention(self, relative_field):\n",
    "        r = torch.sum(relative_field ** 2, axis=-1)\n",
    "        return torch.relu((1 - r) ** 3).unsqueeze(-1)\n",
    "    \n",
    "    def GenerateKernelBasis(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: KB : [r+1, k, d, r+1, theta, k, d]  \n",
    "        KB_bullseye : \n",
    "        \"\"\" \n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        KB_outer = torch.zeros(r, k, d, r+1, theta, k, d, requires_grad=False)\n",
    "        K_bullseye = self.GenerateKernelBullseyeElement(r+1, theta, d)\n",
    "        \n",
    "        for i in range(k):\n",
    "            for j in range(d):\n",
    "                for r1 in range(0, r):\n",
    "                    KB_outer[r1,i,j] = self.GenerateKernelBasisElement(r+1, theta, i, j, r1+1, d) \n",
    "            \n",
    "        return KB_outer, K_bullseye\n",
    "    \n",
    "    def GenerateKernelBasisElement(self, r, theta, i, j, r1, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, d, k]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        K = torch.zeros(r, theta, k, d, requires_grad=False)\n",
    "        K[r1] = self.GenerateKernelBasisElementColumn(theta, i, j, d)\n",
    "        return K\n",
    "        \n",
    "    def GenerateKernelBasisElementColumn(self, theta, i, j, matrix_dim=2):\n",
    "        # d = matrix_dim\n",
    "        # 0 <= i,j <= d-1\n",
    "        # C = kernelcolumn: [theta, d, d]\n",
    "        # C[0,:,:] = 0\n",
    "        # C[0,i,j] = 1\n",
    "        # for k in range(1,theta):\n",
    "        #   C[k] = RotMat(k*2*pi/theta) * C[0] * RotMat(-k*2*pi/theta) \n",
    "        # # K[g v] = g K[v] g^{-1}\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        C = torch.zeros(theta, k, d, requires_grad=False)\n",
    "        C[0,i,j] = 1\n",
    "        # TODO: rho 1 -> rho n\n",
    "        for ind in range(1, theta):\n",
    "            theta_i = torch.tensor(ind*2*math.pi/theta)\n",
    "            C[ind] = self.RegRotMat(theta_i.numpy(), k).matmul(C[0]).matmul(self.Rho1RotMat(-theta_i))\n",
    "        return C\n",
    "    \n",
    "    def GenerateKernelBullseyeElement(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, d, k]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        K = torch.zeros(r, theta, k, d, requires_grad=False)\n",
    "        K[0] = self.GenerateKernelBullseyeElementColumn(theta, d)\n",
    "        return K\n",
    "    \n",
    "    def GenerateKernelBullseyeElementColumn(self, theta, matrix_dim=2):\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        C = torch.zeros(theta, k, d, requires_grad=False)\n",
    "        C[:] = self.Rho1ToRegMat\n",
    "        return C\n",
    "            \n",
    "    @classmethod\n",
    "    def Rho1RotMat(cls, theta):\n",
    "        m = torch.tensor([\n",
    "                [torch.cos(theta), -torch.sin(theta)], \n",
    "                [torch.sin(theta), torch.cos(theta)]\n",
    "            ], requires_grad=False)\n",
    "        return m\n",
    "    \n",
    "    @classmethod\n",
    "    def RegRotMat(cls, theta, k):\n",
    "        slice_angle = 2 * math.pi / k\n",
    "        index_shift = theta / slice_angle\n",
    "        i = np.floor(index_shift).astype(np.int)\n",
    "        # divide weights between i and i+1   first_col = [ 0 0 0 ... 0 w_i w_{i+1} 0 0 0 ... 0 0 0] \n",
    "        first_col = torch.zeros(k)\n",
    "        \n",
    "        offset = (theta - slice_angle * i) / slice_angle\n",
    "        w_i = 1 - offset\n",
    "        w_ip = offset\n",
    "        first_col[np.mod(i,8)], first_col[np.mod(i+1,8)] = w_i, w_ip\n",
    "        \n",
    "        m = torch.stack([torch.roll(first_col, i, 0) for i in range(k)], -1)\n",
    "        #like a permuation matrix which sends i -> i + \\theta / ( 2 \\pi / k ) \n",
    "        #Note if k = num_theta, then it is a permutation matrix \n",
    "        return m\n",
    "    \n",
    "        \n",
    "    def PolarCoords(self, vec, epsilon = 1e-9):\n",
    "        # vec: [batch, num_m, num_n, pos_dim]\n",
    "        # Convert to Polar\n",
    "        r = torch.sqrt(vec[...,0] **2 + vec[...,1] **2 + epsilon) \n",
    "         \n",
    "        cond_nonzero = ~((vec[...,0] == 0.) & (vec[...,1] == 0.))\n",
    "    \n",
    "        theta = torch.zeros(vec[...,0].shape, device=self.outer_weights.device)\n",
    "        theta[cond_nonzero] = torch.atan2(vec[...,1][cond_nonzero], vec[...,0][cond_nonzero])\n",
    "        \n",
    "        out = [r, theta]\n",
    "        out = torch.stack(out, -1)\n",
    "        return out\n",
    "    \n",
    "    def InterpolateKernel(self, kernel, pos):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2] -> [batch, C=c_out*c_in*4, r, theta]\n",
    "        @pos: [batch, num_m, num_n, 2] -> [batch, num_m, num_n, 2]\n",
    "        \n",
    "        return out: [batch, C=c_out*c_in*4, num_m, num_n] -> [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \"\"\"\n",
    "        # kernel:  [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        kernels = kernel.permute(0, 1, 4, 5, 2, 3)\n",
    "        # kernels: [c_out, c_in=feat_dim, 2, 2, r, theta]\n",
    "        \n",
    "        kernels = kernels.reshape(-1, *kernels.shape[4:]).unsqueeze(0)\n",
    "        # kernels: [1, c_out*c_in*2*2, r, theta]\n",
    "        \n",
    "        kernels = kernels.expand((pos.shape[0], *kernels.shape[1:]))\n",
    "        # kernels: [batch_size, c_out*c_in*2*2, r, theta]\n",
    "                  #[N, C, H, W]\n",
    "        \n",
    "\n",
    "        # Copy first and last column to wrap thetas.\n",
    "        padded_kernels = torch.cat([\n",
    "            kernels[..., -1].unsqueeze(-1), \n",
    "            kernels, \n",
    "            kernels[..., 0].unsqueeze(-1)\n",
    "        ],dim = -1)\n",
    "        padded_kernels = padded_kernels.permute(0,1,3,2)\n",
    "        # padded_kernels: [batch, C=c_out*c_in*4, theta+2, r]\n",
    "        \n",
    "        \n",
    "        grid = pos\n",
    "        # adjust radii [0,1] -> [-1,1]\n",
    "        grid[...,0] = 2*grid[...,0] - 1\n",
    "        # adjust angles [-pi,pi] -> [-1,1]\n",
    "        grid[...,1] *= 1/math.pi\n",
    "        # shrink thetas slightly to account for padding\n",
    "        grid[...,1] *= self.num_theta / (self.num_theta + 2)\n",
    "        # grid [batch, num_m, num_n, 2]\n",
    "        #      [N, H_out, W_out, 2]\n",
    "        \n",
    "        # print(\"grid\",grid)\n",
    "        # print(\"padded_kernels_shape [batch_size, c_out*c_in*2*2, theta+2, r]:\",padded_kernels.shape)\n",
    "        #print(\"kernels\",padded_kernels)\n",
    "        \n",
    "        out = F.grid_sample(padded_kernels, grid, padding_mode='zeros', \n",
    "                            mode='bilinear', align_corners=False)  #bilinear\n",
    "        # out: [batch, C=c_out*c_in*4, num_m, num_n]\n",
    "        #      [N, C, H_out, W_out]\n",
    "        \n",
    "        out = out.permute(0, 2, 3, 1)\n",
    "        # out: [batch, num_m, num_n, C=c_out*c_in*4]\n",
    "        out = out.reshape(*pos.shape[:-1], *kernel.shape[0:2], *kernel.shape[-2:])\n",
    "        # out: [batch, num_m, num_n, c_out, c_in, 2, 2]     \n",
    "        return out\n",
    "    \n",
    "    def ContinuousConv(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @ctr_feat: [batch, 1, feat_dim]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "        \"\"\"\n",
    "        kernel = self.computeKernel()\n",
    "        \n",
    "        relative_field = (field.unsqueeze(1) - center.unsqueeze(2)) / self.radius\n",
    "        # relative_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "\n",
    "        polar_field = self.PolarCoords(relative_field)\n",
    "        # polar_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "        kernel_on_field = self.InterpolateKernel(kernel, polar_field)\n",
    "        # kernel_on_field: [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \n",
    "        if self.use_attention:\n",
    "            # print(relative_field.shape)\n",
    "            # print(field_mask.unsqueeze(1).shape)\n",
    "            attention = self.GetAttention(relative_field) * field_mask.unsqueeze(1)\n",
    "            # attention: [batch, num_m, num_n, 1]\n",
    "\n",
    "            psi = torch.sum(attention, axis=2) if normalize_attention else 1\n",
    "        else:\n",
    "            attention = torch.ones(*relative_field.shape[0:3],1)\n",
    "            \n",
    "            psi = 1.0\n",
    "        \n",
    "        attention_field_feat = field_feat.unsqueeze(1)*attention.unsqueeze(-1)\n",
    "        # attention_field_feat: [batch, num_m, num_n, c_in, 2]\n",
    "\n",
    "        out = torch.einsum('bmnoiyx,bmnix->bmoy', kernel_on_field, attention_field_feat)\n",
    "        # out: [batch, num_m, c_out, 2]\n",
    "        \n",
    "        return out / psi\n",
    "    \n",
    "    def forward(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        out = self.ContinuousConv(\n",
    "            field, center, field_feat, field_mask, \n",
    "            ctr_feat, normalize_attention\n",
    "        )\n",
    "        return out"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRho1ToReg(in_channels = 5, out_channels = 7, radius = 1, num_radii = 2, num_theta = 16, k = 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 5.1238e-02,  2.8663e-02, -9.7029e-03, -1.9899e-02,  6.5804e-05,\n",
       "            1.4370e-02,  2.0235e-02,  4.0023e-02],\n",
       "          [ 4.5422e-03, -1.2942e-02,  7.0901e-03, -4.2827e-03, -2.3854e-02,\n",
       "           -2.5684e-02, -2.6259e-02, -1.9087e-04],\n",
       "          [ 9.8601e-04, -1.5184e-02, -7.6291e-03, -8.0180e-03, -1.4686e-02,\n",
       "           -3.9251e-03,  1.0553e-02,  1.3259e-02],\n",
       "          [-7.2286e-03,  1.7221e-02, -1.0084e-02, -3.3754e-02, -4.5856e-03,\n",
       "           -1.0604e-02, -2.8473e-02, -1.9899e-02],\n",
       "          [-7.3973e-04, -1.1184e-02, -4.3599e-02, -1.4668e-02, -7.1112e-03,\n",
       "           -2.6495e-02,  8.3062e-03,  1.4056e-02],\n",
       "          [-5.0515e-03, -6.5483e-03, -8.5407e-03, -3.1567e-03,  2.1508e-03,\n",
       "            1.1066e-02,  1.8941e-02, -7.1670e-03],\n",
       "          [ 2.4033e-03, -1.0879e-02, -1.7283e-02, -2.4157e-02, -5.4295e-03,\n",
       "            9.6279e-04, -8.8090e-03,  1.1843e-02]]],\n",
       "\n",
       "\n",
       "        [[[ 3.9227e-02,  4.4469e-02,  1.7724e-02, -3.2394e-02, -1.8883e-02,\n",
       "            1.7535e-02, -1.0719e-02, -4.4969e-03],\n",
       "          [ 8.6293e-03, -2.6623e-02,  3.0686e-02,  5.5546e-02,  5.9169e-03,\n",
       "           -4.3216e-02, -2.8722e-02,  3.0455e-02],\n",
       "          [ 9.2264e-03,  7.9060e-03, -1.2563e-02, -2.1607e-02, -3.4204e-02,\n",
       "           -5.7763e-02, -3.2094e-02,  1.6648e-03],\n",
       "          [ 2.2054e-02,  2.8016e-02,  5.5237e-02, -3.7787e-02, -5.1100e-02,\n",
       "           -1.1063e-02,  7.9645e-03,  5.4742e-02],\n",
       "          [-1.3777e-03,  1.7502e-02, -5.4061e-02, -6.1800e-02,  3.0084e-02,\n",
       "            3.4326e-02, -2.1199e-02, -3.5926e-02],\n",
       "          [ 3.1944e-02, -2.5375e-02, -4.4360e-02, -3.5675e-02, -5.4787e-02,\n",
       "           -4.7882e-02, -1.8028e-02,  1.6534e-02],\n",
       "          [ 2.1952e-02,  5.2621e-03, -2.2741e-02, -6.0148e-02, -5.7868e-02,\n",
       "           -1.7417e-02, -2.3273e-02, -1.4301e-02]]],\n",
       "\n",
       "\n",
       "        [[[ 9.9775e-02, -2.3344e-02, -1.7456e-02,  3.7706e-02,  5.0557e-02,\n",
       "           -1.1075e-02,  5.2127e-02,  1.1632e-01],\n",
       "          [-1.7458e-02,  5.3215e-02,  1.6772e-01,  1.0806e-01, -4.2236e-02,\n",
       "           -8.2480e-02,  6.2317e-03,  4.4166e-02],\n",
       "          [ 6.3131e-02, -4.0075e-02,  2.9613e-03,  5.4357e-02, -9.5503e-02,\n",
       "           -6.2894e-02,  6.1431e-02,  1.3103e-01],\n",
       "          [ 2.2462e-02,  8.7228e-02, -6.7527e-02, -1.3502e-01,  2.9666e-02,\n",
       "           -1.8296e-02,  5.3459e-02,  8.7945e-02],\n",
       "          [-1.8900e-02,  2.4132e-02, -3.6986e-02,  4.1905e-02,  6.1717e-02,\n",
       "           -1.1412e-02, -1.7639e-03, -6.7782e-02],\n",
       "          [ 4.4987e-02, -1.1971e-01, -6.3714e-03, -7.2487e-02, -7.9443e-02,\n",
       "           -3.0019e-02,  1.3578e-01,  1.6487e-01],\n",
       "          [-1.0390e-02, -5.6845e-02, -4.5309e-02, -8.4689e-02, -7.0159e-03,\n",
       "            2.2601e-02, -2.2750e-03, -2.3400e-02]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 3\n",
    "num_part = 1\n",
    "feat_dim = 5\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(batch_size,num_part,2)\n",
    "center = torch.rand(batch_size,num_part,2)\n",
    "field_feat = torch.rand(batch_size,num_part,feat_dim,2)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "model(field, center, field_feat, field_mask)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRho1ToReg(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, k=8, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[-0.1708, -0.0751, -0.2329, -0.0919, -0.1943, -0.2617, -0.2580,\n",
       "           -0.1544]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "#field = torch.tensor([[[-.2,.2],[0.,1.]]])\n",
    "field = torch.tensor([[[-.2*6,.2*6],[0.,1.]]])\n",
    "#field = torch.tensor([[[-1.99,0.01],[0.,1.]]])\n",
    "\n",
    "center = torch.tensor([[[0.,0.]]])\n",
    "field_feat = torch.tensor([[[[1., 0.]],[[0., 1.]]]])\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[-0.1708, -0.0751, -0.2329, -0.0919, -0.1943, -0.2617, -0.2580,\n",
       "           -0.1544]]]], grad_fn=<ViewBackward>)"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "theta = math.pi/2\n",
    "rotated_field = Rho1Rot(field, theta)\n",
    "rotated_feat  = Rho1Rot(field_feat, theta)\n",
    "rotated_center = Rho1Rot(center, theta)\n",
    "RegRot(model(rotated_field, rotated_center, rotated_feat, field_mask),-theta)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRho1ToReg(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, k=8, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.2626,  0.5053,  0.4519,  0.1339, -0.2626, -0.5053, -0.4519,\n",
       "           -0.1339]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(1,2,2)\n",
    "\n",
    "center = torch.rand(1,1,2)\n",
    "field_feat = torch.rand(1, 2, 1, 2)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.2626,  0.5053,  0.4519,  0.1339, -0.2626, -0.5053, -0.4519,\n",
       "           -0.1339]]]], grad_fn=<ViewBackward>)"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "theta = math.pi/2\n",
    "rotated_field = Rho1Rot(field, theta)\n",
    "rotated_feat  = Rho1Rot(field_feat, theta)\n",
    "rotated_center = Rho1Rot(center, theta)\n",
    "RegRot(model(rotated_field, rotated_center, rotated_feat, field_mask),-theta)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CtsConv Reg -> Reg\n",
    "\n",
    "in progress"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "class EquiCtsConv2dRegToReg(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, radius, num_radii, num_theta, k, matrix_dim=2, use_attention=True):\n",
    "        super(EquiCtsConv2dRegToReg, self).__init__()\n",
    "        self.num_theta = num_theta\n",
    "        self.num_radii = num_radii\n",
    "        self.k = k\n",
    "    \n",
    "        \n",
    "        kernel_basis_outer, kernel_bullseye = self.GenerateKernelBasis(num_radii, num_theta, matrix_dim)\n",
    "        self.register_buffer('kernel_basis_outer', kernel_basis_outer)\n",
    "        self.register_buffer('kernel_bullseye', kernel_bullseye)\n",
    "        \n",
    "        outer_weights = torch.rand(in_channels, out_channels, num_radii, k, k)\n",
    "        outer_weights -= 0.5\n",
    "        scale_norm = 1 / torch.sqrt(torch.tensor(in_channels, dtype=torch.float))\n",
    "        outer_weights *= 1 * scale_norm\n",
    "        self.outer_weights = torch.nn.parameter.Parameter(outer_weights)\n",
    "        \n",
    "        \n",
    "        \n",
    "        bullseye_weights = torch.rand(in_channels, out_channels, k)\n",
    "        bullseye_weights -= 0.5\n",
    "        bullseye_weights *= 1 * scale_norm\n",
    "        self.bullseye_weights = torch.nn.parameter.Parameter(bullseye_weights)\n",
    "        \n",
    "        self.radius = radius\n",
    "\n",
    "        self.use_attention = use_attention\n",
    "        \n",
    "\n",
    "    def computeKernel(self):\n",
    "        # print(\"[r, d, d, r, theta, d, k] \",self.kernel_basis.shape)\n",
    "        # print(\"[c_in,c_out, r, d, k]\", self.weights.shape)\n",
    "        kernel = (torch.einsum('pabrtij,xypab->yxrtij',self.kernel_basis_outer, self.outer_weights) +\n",
    "                 torch.einsum('lrtij,xyl->yxrtij',self.kernel_bullseye,self.bullseye_weights))\n",
    "        return kernel\n",
    "    \n",
    "    def GetAttention(self, relative_field):\n",
    "        r = torch.sum(relative_field ** 2, axis=-1)\n",
    "        return torch.relu((1 - r) ** 3).unsqueeze(-1)\n",
    "    \n",
    "    def GenerateKernelBasis(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: KB : [r+1, k, k, r+1, theta, k, k]  \n",
    "        KB_bullseye : \n",
    "        \"\"\" \n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        KB_outer = torch.zeros(r, k, k, r+1, theta, k, k, requires_grad=False)\n",
    "        K_bullseye = self.GenerateKernelBullseyeBasis(r+1, theta, d)\n",
    "        \n",
    "        for i in range(k):\n",
    "            for j in range(k):\n",
    "                for r1 in range(0, r):\n",
    "                    KB_outer[r1,i,j] = self.GenerateKernelBasisElement(r+1, theta, i, j, r1+1, d) \n",
    "            \n",
    "        return KB_outer, K_bullseye\n",
    "    \n",
    "    def GenerateKernelBasisElement(self, r, theta, i, j, r1, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [r, theta, k, k]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        K = torch.zeros(r, theta, k, k, requires_grad=False)\n",
    "        K[r1] = self.GenerateKernelBasisElementColumn(theta, i, j, d)\n",
    "        return K\n",
    "        \n",
    "    def GenerateKernelBasisElementColumn(self, theta, i, j, matrix_dim=2):\n",
    "        # d = matrix_dim\n",
    "        # 0 <= i,j <= d-1\n",
    "        # C = kernelcolumn: [theta, d, d]\n",
    "        # C[0,:,:] = 0\n",
    "        # C[0,i,j] = 1\n",
    "        # for k in range(1,theta):\n",
    "        #   C[k] = RotMat(k*2*pi/theta) * C[0] * RotMat(-k*2*pi/theta) \n",
    "        # # K[g v] = g K[v] g^{-1}\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        C = torch.zeros(theta, k, k, requires_grad=False)\n",
    "        C[0,i,j] = 1\n",
    "        # TODO: rho 1 -> rho n\n",
    "        for ind in range(1, theta):\n",
    "            theta_i = torch.tensor(ind*2*math.pi/theta)\n",
    "            C[ind] = self.RegRotMat(theta_i.numpy(), k).matmul(C[0]).matmul(self.RegRotMat(-theta_i.numpy(), k))\n",
    "        return C\n",
    "    \n",
    "    def GenerateKernelBullseyeBasis(self, r, theta, matrix_dim=2):\n",
    "        \"\"\"\n",
    "        output: K: [k, r, theta, k, k]\n",
    "        \"\"\"\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        K = torch.zeros(k, r, theta, k, k, requires_grad=False)\n",
    "        for l in range(k):\n",
    "            K[l,0] = self.GenerateKernelBullseyeElementColumn(theta, l, d)\n",
    "        return K\n",
    "    \n",
    "    def GenerateKernelBullseyeElementColumn(self, theta, l, matrix_dim=2):\n",
    "        d = matrix_dim\n",
    "        k = self.k\n",
    "        \n",
    "        first_col = torch.zeros(k)\n",
    "        first_col[l] = 1.\n",
    "        C = torch.zeros(theta, k, k, requires_grad=False)\n",
    "        C[:] = torch.stack([torch.roll(first_col, i, 0) for i in range(0,self.k)],-1)\n",
    "        return C\n",
    "            \n",
    "    @classmethod\n",
    "    def Rho1RotMat(cls, theta):\n",
    "        m = torch.tensor([\n",
    "                [torch.cos(theta), -torch.sin(theta)], \n",
    "                [torch.sin(theta), torch.cos(theta)]\n",
    "            ], requires_grad=False)\n",
    "        return m\n",
    "    \n",
    "    @classmethod\n",
    "    def RegRotMat(cls, theta, k):\n",
    "        slice_angle = 2 * math.pi / k\n",
    "        index_shift = theta / slice_angle\n",
    "        i = np.floor(index_shift).astype(np.int)\n",
    "        # divide weights between i and i+1   first_col = [ 0 0 0 ... 0 w_i w_{i+1} 0 0 0 ... 0 0 0] \n",
    "        first_col = torch.zeros(k)\n",
    "        \n",
    "        offset = (theta - slice_angle * i) / slice_angle\n",
    "        w_i = 1 - offset\n",
    "        w_ip = offset\n",
    "        first_col[np.mod(i,8)], first_col[np.mod(i+1,8)] = w_i, w_ip\n",
    "        \n",
    "        m = torch.stack([torch.roll(first_col, i, 0) for i in range(k)], -1)\n",
    "        #like a permuation matrix which sends i -> i + \\theta / ( 2 \\pi / k ) \n",
    "        #Note if k = num_theta, then it is a permutation matrix \n",
    "        return m\n",
    "    \n",
    "        \n",
    "    def PolarCoords(self, vec, epsilon = 1e-9):\n",
    "        # vec: [batch, num_m, num_n, pos_dim]\n",
    "        # Convert to Polar\n",
    "        r = torch.sqrt(vec[...,0] **2 + vec[...,1] **2 + epsilon) \n",
    "         \n",
    "        cond_nonzero = ~((vec[...,0] == 0.) & (vec[...,1] == 0.))\n",
    "    \n",
    "        theta = torch.zeros(vec[...,0].shape, device=self.outer_weights.device)\n",
    "        theta[cond_nonzero] = torch.atan2(vec[...,1][cond_nonzero], vec[...,0][cond_nonzero])\n",
    "        \n",
    "        out = [r, theta]\n",
    "        out = torch.stack(out, -1)\n",
    "        return out\n",
    "    \n",
    "    def InterpolateKernel(self, kernel, pos):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2] -> [batch, C=c_out*c_in*4, r, theta]\n",
    "        @pos: [batch, num_m, num_n, 2] -> [batch, num_m, num_n, 2]\n",
    "        \n",
    "        return out: [batch, C=c_out*c_in*4, num_m, num_n] -> [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \"\"\"\n",
    "        # kernel:  [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        kernels = kernel.permute(0, 1, 4, 5, 2, 3)\n",
    "        # kernels: [c_out, c_in=feat_dim, 2, 2, r, theta]\n",
    "        \n",
    "        kernels = kernels.reshape(-1, *kernels.shape[4:]).unsqueeze(0)\n",
    "        # kernels: [1, c_out*c_in*2*2, r, theta]\n",
    "        \n",
    "        kernels = kernels.expand((pos.shape[0], *kernels.shape[1:]))\n",
    "        # kernels: [batch_size, c_out*c_in*2*2, r, theta]\n",
    "                  #[N, C, H, W]\n",
    "        \n",
    "\n",
    "        # Copy first and last column to wrap thetas.\n",
    "        padded_kernels = torch.cat([\n",
    "            kernels[..., -1].unsqueeze(-1), \n",
    "            kernels, \n",
    "            kernels[..., 0].unsqueeze(-1)\n",
    "        ],dim = -1)\n",
    "        padded_kernels = padded_kernels.permute(0,1,3,2)\n",
    "        # padded_kernels: [batch, C=c_out*c_in*4, theta+2, r]\n",
    "        \n",
    "        \n",
    "        grid = pos\n",
    "        # adjust radii [0,1] -> [-1,1]\n",
    "        grid[...,0] = 2*grid[...,0] - 1\n",
    "        # adjust angles [-pi,pi] -> [-1,1]\n",
    "        grid[...,1] *= 1/math.pi\n",
    "        # shrink thetas slightly to account for padding\n",
    "        grid[...,1] *= self.num_theta / (self.num_theta + 2)\n",
    "        # grid [batch, num_m, num_n, 2]\n",
    "        #      [N, H_out, W_out, 2]\n",
    "        \n",
    "        # print(\"grid\",grid)\n",
    "        # print(\"padded_kernels_shape [batch_size, c_out*c_in*2*2, theta+2, r]:\",padded_kernels.shape)\n",
    "        #print(\"kernels\",padded_kernels)\n",
    "        \n",
    "        out = F.grid_sample(padded_kernels, grid, padding_mode='zeros', \n",
    "                            mode='bilinear', align_corners=False)  #bilinear\n",
    "        # out: [batch, C=c_out*c_in*4, num_m, num_n]\n",
    "        #      [N, C, H_out, W_out]\n",
    "        \n",
    "        out = out.permute(0, 2, 3, 1)\n",
    "        # out: [batch, num_m, num_n, C=c_out*c_in*4]\n",
    "        out = out.reshape(*pos.shape[:-1], *kernel.shape[0:2], *kernel.shape[-2:])\n",
    "        # out: [batch, num_m, num_n, c_out, c_in, 2, 2]     \n",
    "        return out\n",
    "    \n",
    "    def ContinuousConv(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        \"\"\"\n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @ctr_feat: [batch, 1, feat_dim]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "        \"\"\"\n",
    "        kernel = self.computeKernel()\n",
    "        \n",
    "        relative_field = (field.unsqueeze(1) - center.unsqueeze(2)) / self.radius\n",
    "        # relative_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "\n",
    "        polar_field = self.PolarCoords(relative_field)\n",
    "        # polar_field: [batch, num_m, num_n, pos_dim]\n",
    "        \n",
    "        kernel_on_field = self.InterpolateKernel(kernel, polar_field)\n",
    "        # kernel_on_field: [batch, num_m, num_n, c_out, c_in, 2, 2]\n",
    "        \n",
    "        if self.use_attention:\n",
    "            # print(relative_field.shape)\n",
    "            # print(field_mask.unsqueeze(1).shape)\n",
    "            attention = self.GetAttention(relative_field) * field_mask.unsqueeze(1)\n",
    "            # attention: [batch, num_m, num_n, 1]\n",
    "\n",
    "            psi = torch.sum(attention, axis=2) if normalize_attention else 1\n",
    "        else:\n",
    "            attention = torch.ones(*relative_field.shape[0:3],1)\n",
    "            \n",
    "            psi = 1.0\n",
    "        \n",
    "        attention_field_feat = field_feat.unsqueeze(1)*attention.unsqueeze(-1)\n",
    "        # attention_field_feat: [batch, num_m, num_n, c_in, 2]\n",
    "\n",
    "        out = torch.einsum('bmnoiyx,bmnix->bmoy', kernel_on_field, attention_field_feat)\n",
    "        # out: [batch, num_m, c_out, 2]\n",
    "        \n",
    "        return out / psi\n",
    "    \n",
    "    def forward(\n",
    "        self, field, center, field_feat, \n",
    "        field_mask, ctr_feat=None, normalize_attention=False\n",
    "    ):\n",
    "        out = self.ContinuousConv(\n",
    "            field, center, field_feat, field_mask, \n",
    "            ctr_feat, normalize_attention\n",
    "        )\n",
    "        return out"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRegToReg(in_channels = 5, out_channels = 7, radius = 1, num_radii = 2, num_theta = 16, k = 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.0032, -0.0466, -0.0717, -0.0375, -0.0059,  0.0329,  0.0436,\n",
       "            0.0142],\n",
       "          [ 0.0112, -0.0068, -0.0022,  0.0216,  0.0461,  0.0335,  0.0152,\n",
       "           -0.0043],\n",
       "          [-0.0125, -0.0684, -0.0338,  0.0463,  0.0117, -0.0182,  0.0365,\n",
       "            0.0383],\n",
       "          [ 0.0170, -0.0391, -0.0812, -0.0129,  0.0098,  0.0357,  0.0065,\n",
       "           -0.0324],\n",
       "          [ 0.0092, -0.0251, -0.0459, -0.0409, -0.0362, -0.0010,  0.0227,\n",
       "            0.0068],\n",
       "          [ 0.0528,  0.0152, -0.0020,  0.0117, -0.0197, -0.0115,  0.0582,\n",
       "            0.0481],\n",
       "          [ 0.0054,  0.0013,  0.0076, -0.0054, -0.0113,  0.0052,  0.0360,\n",
       "            0.0463]]],\n",
       "\n",
       "\n",
       "        [[[-0.0018, -0.0285, -0.1049, -0.1327, -0.0705, -0.0318,  0.0283,\n",
       "            0.0436],\n",
       "          [ 0.0138,  0.0439,  0.0502,  0.0294,  0.0754,  0.0901,  0.0745,\n",
       "            0.0512],\n",
       "          [ 0.0149, -0.0147, -0.0795, -0.0685,  0.0815, -0.0036, -0.0450,\n",
       "            0.0579],\n",
       "          [-0.0121,  0.0317, -0.0550, -0.0820, -0.0372, -0.0233,  0.0044,\n",
       "           -0.0310],\n",
       "          [-0.0285, -0.0480, -0.0944, -0.0955, -0.0440, -0.0066, -0.0128,\n",
       "           -0.0226],\n",
       "          [ 0.0331,  0.0872,  0.0185, -0.0288,  0.0374, -0.0267, -0.0443,\n",
       "            0.0078],\n",
       "          [ 0.0502, -0.0240, -0.0720, -0.0312, -0.0304, -0.0159,  0.0492,\n",
       "            0.0657]]],\n",
       "\n",
       "\n",
       "        [[[-0.0516, -0.1509, -0.2010, -0.0556, -0.0521, -0.0088,  0.0188,\n",
       "            0.0421],\n",
       "          [ 0.1142,  0.0978,  0.0426,  0.1382,  0.1386,  0.0404,  0.1509,\n",
       "            0.1682],\n",
       "          [ 0.0218, -0.0198, -0.1399,  0.0695,  0.0478, -0.0444,  0.1396,\n",
       "            0.1040],\n",
       "          [ 0.0515, -0.0818,  0.0013, -0.0212,  0.0161,  0.0141, -0.1413,\n",
       "           -0.1447],\n",
       "          [-0.1301, -0.1743, -0.1862, -0.1010,  0.0086,  0.0121,  0.0118,\n",
       "            0.0218],\n",
       "          [ 0.0497, -0.0006, -0.0840,  0.0545,  0.1332,  0.0150, -0.0228,\n",
       "           -0.0310],\n",
       "          [-0.0316, -0.1732, -0.0819, -0.0469,  0.0317,  0.1080,  0.0857,\n",
       "            0.1072]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 3\n",
    "num_part = 1\n",
    "feat_dim = 5\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(batch_size,num_part,2)\n",
    "center = torch.rand(batch_size,num_part,2)\n",
    "field_feat = torch.rand(batch_size,num_part,feat_dim,8)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "model(field, center, field_feat, field_mask)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRegToReg(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, k=8, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.6229, -0.3149, -0.3189,  0.0649,  0.0059,  0.1531,  0.2592,\n",
       "            0.2655]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "#field = torch.tensor([[[-.2,.2],[0.,1.]]])\n",
    "field = torch.tensor([[[-.2*6,.2*6],[0.,1.]]])\n",
    "#field = torch.tensor([[[-1.99,0.01],[0.,1.]]])\n",
    "\n",
    "center = torch.tensor([[[0.,0.]]])\n",
    "field_feat = torch.tensor([[[[1., 0., 0., 0., 0., 0., 0., 0.]],[[0., 1., 0., 0., 0., 0., 0., 0.]]]])\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.6229, -0.3149, -0.3189,  0.0649,  0.0059,  0.1531,  0.2592,\n",
       "            0.2655]]]], grad_fn=<ViewBackward>)"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "theta = math.pi/2\n",
    "rotated_field = Rho1Rot(field, theta)\n",
    "rotated_feat  = RegRot(field_feat, theta)\n",
    "rotated_center = Rho1Rot(center, theta)\n",
    "RegRot(model(rotated_field, rotated_center, rotated_feat, field_mask),-theta)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = EquiCtsConv2dRegToReg(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, k=8, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[-16.2342, -10.9079,  -9.1914,  -6.0500, -15.2147,  -4.6762, -19.5473,\n",
       "           -10.4190]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size = 1\n",
    "num_part = 50\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(1,num_part,2)\n",
    "\n",
    "center = torch.rand(1,1,2)\n",
    "field_feat = torch.rand(1, num_part, 1, 8)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.]])\n",
      "tensor([[-4.3711e-08, -1.0000e+00],\n",
      "        [ 1.0000e+00, -4.3711e-08]])\n",
      "tensor([[0., 0., 1., 0., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 1., 0., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 1., 0., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 1., 0., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 1., 0.],\n",
      "        [0., 0., 0., 0., 0., 0., 0., 1.],\n",
      "        [1., 0., 0., 0., 0., 0., 0., 0.],\n",
      "        [0., 1., 0., 0., 0., 0., 0., 0.]])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.0000e+00, -2.8610e-06,  2.8610e-06,  0.0000e+00, -1.9073e-06,\n",
       "            4.7684e-07, -1.9073e-06,  0.0000e+00]]]], grad_fn=<SubBackward0>)"
      ]
     },
     "execution_count": 99,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "theta = math.pi/2\n",
    "rotated_field = Rho1Rot(field, theta)\n",
    "rotated_feat  = RegRot(field_feat, theta)\n",
    "rotated_center = Rho1Rot(center, theta)\n",
    "RegRot(model(rotated_field, rotated_center, rotated_feat, field_mask),-theta) - unrotated_result"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Older Parts"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "### Test 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-18T22:16:47.292539Z",
     "start_time": "2020-08-18T22:16:47.272285Z"
    },
    "hidden": true
   },
   "outputs": [],
   "source": [
    "model = EquiCtsConv2d(in_channels = 5, out_channels = 7, radius = 1, num_radii = 2, num_theta = 16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-18T22:16:47.821026Z",
     "start_time": "2020-08-18T22:16:47.798129Z"
    },
    "code_folding": [
     0
    ],
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[-1.4748e+00, -4.9326e-01],\n",
       "          [ 1.1590e+00,  3.5536e-01],\n",
       "          [-5.8022e-02, -1.8015e-02],\n",
       "          [-4.2285e-01, -6.5017e-01],\n",
       "          [-2.1472e+00,  2.9976e-01],\n",
       "          [ 9.5943e-01,  4.7213e-01],\n",
       "          [-7.7849e-01, -4.3810e-01]],\n",
       "\n",
       "         [[-1.1518e+00, -1.4164e-01],\n",
       "          [ 1.1119e+00,  1.9077e-01],\n",
       "          [ 2.7518e-01,  3.6194e-01],\n",
       "          [-4.3223e-01, -2.8753e-01],\n",
       "          [-1.6503e+00,  2.0425e-01],\n",
       "          [ 7.2792e-01,  2.9498e-01],\n",
       "          [-2.6092e-01, -6.0683e-01]],\n",
       "\n",
       "         [[-1.0599e+00, -4.9294e-01],\n",
       "          [ 1.0493e+00,  1.8238e-01],\n",
       "          [ 6.2256e-02,  3.0920e-02],\n",
       "          [-4.2681e-01, -3.3434e-01],\n",
       "          [-1.3251e+00, -1.7871e-01],\n",
       "          [ 8.9895e-01,  7.4992e-01],\n",
       "          [-3.6620e-01, -7.3675e-01]]],\n",
       "\n",
       "\n",
       "        [[[-6.1297e-01, -1.6366e-01],\n",
       "          [ 7.9331e-01,  4.0896e-02],\n",
       "          [ 1.8789e-01,  1.0814e-01],\n",
       "          [-8.8424e-01, -4.7086e-01],\n",
       "          [-1.8555e+00,  5.2545e-01],\n",
       "          [ 8.9260e-01,  5.7123e-01],\n",
       "          [-6.8313e-01, -1.0463e+00]],\n",
       "\n",
       "         [[-7.1262e-01, -3.1276e-01],\n",
       "          [ 5.8572e-01,  2.9075e-01],\n",
       "          [-5.2847e-02, -1.4570e-01],\n",
       "          [-5.0291e-01, -6.8819e-04],\n",
       "          [-8.8652e-01, -9.9924e-02],\n",
       "          [ 1.5615e-01,  6.7592e-01],\n",
       "          [-5.0592e-01, -1.6813e-01]],\n",
       "\n",
       "         [[-5.5301e-01, -4.0993e-01],\n",
       "          [ 2.7551e-01,  3.3738e-01],\n",
       "          [ 3.0170e-01, -4.4573e-01],\n",
       "          [-4.0292e-01, -9.3109e-02],\n",
       "          [-8.4912e-01, -2.4614e-01],\n",
       "          [ 1.0814e-01,  6.4191e-01],\n",
       "          [-5.2617e-01, -3.4399e-01]]],\n",
       "\n",
       "\n",
       "        [[[-6.6853e-01, -5.7951e-01],\n",
       "          [ 3.4747e-01,  2.6496e-01],\n",
       "          [-2.2568e-01, -1.3302e-01],\n",
       "          [-2.5872e-02,  7.0155e-02],\n",
       "          [-1.0598e+00, -5.3386e-02],\n",
       "          [ 5.4979e-01,  4.1309e-01],\n",
       "          [-7.3159e-01, -4.3164e-01]],\n",
       "\n",
       "         [[-4.7726e-01, -1.7913e-01],\n",
       "          [ 2.5290e-01,  2.4820e-01],\n",
       "          [-2.1203e-01, -1.8738e-01],\n",
       "          [ 1.7057e-01, -6.0630e-03],\n",
       "          [-6.3562e-01, -3.0390e-02],\n",
       "          [ 2.8409e-01,  3.3393e-01],\n",
       "          [-4.7686e-01, -2.2383e-01]],\n",
       "\n",
       "         [[-1.0758e+00, -3.3532e-01],\n",
       "          [ 9.7693e-01, -9.0115e-02],\n",
       "          [ 3.7835e-01,  2.7370e-02],\n",
       "          [-7.2694e-01, -1.8515e-01],\n",
       "          [-1.4603e+00,  1.5066e-01],\n",
       "          [ 9.9537e-01,  6.8962e-01],\n",
       "          [-8.0480e-01, -6.9320e-01]]],\n",
       "\n",
       "\n",
       "        [[[-1.3724e+00, -1.0924e+00],\n",
       "          [ 1.3464e+00,  9.0674e-01],\n",
       "          [-4.2805e-01, -3.2183e-01],\n",
       "          [-6.1748e-01, -7.2842e-01],\n",
       "          [-2.2162e+00, -3.5990e-01],\n",
       "          [ 9.4920e-01,  1.6453e+00],\n",
       "          [-3.9252e-01, -1.1446e+00]],\n",
       "\n",
       "         [[-1.4891e+00, -1.3505e+00],\n",
       "          [ 1.3569e+00,  1.1565e+00],\n",
       "          [-4.2833e-01, -5.2816e-01],\n",
       "          [-6.0634e-01, -6.0025e-01],\n",
       "          [-1.9732e+00, -5.7523e-01],\n",
       "          [ 1.1109e+00,  1.5892e+00],\n",
       "          [-6.2341e-01, -1.5349e+00]],\n",
       "\n",
       "         [[-1.7650e+00, -1.3448e+00],\n",
       "          [ 1.4719e+00,  1.3605e+00],\n",
       "          [-5.4524e-01, -7.3362e-01],\n",
       "          [-3.4951e-01, -7.0175e-01],\n",
       "          [-1.8091e+00, -8.1781e-01],\n",
       "          [ 1.1155e+00,  1.4149e+00],\n",
       "          [-8.5738e-01, -1.5971e+00]]],\n",
       "\n",
       "\n",
       "        [[[-1.1833e+00, -5.6017e-01],\n",
       "          [ 1.1549e+00,  9.1562e-01],\n",
       "          [-3.1489e-01, -4.8423e-01],\n",
       "          [-6.9231e-01, -6.3661e-01],\n",
       "          [-1.4974e+00, -1.3474e-01],\n",
       "          [ 7.4081e-01,  9.3244e-01],\n",
       "          [-1.0129e+00, -1.1179e+00]],\n",
       "\n",
       "         [[-5.5387e-01, -5.9408e-01],\n",
       "          [ 6.0670e-01,  4.8976e-01],\n",
       "          [-2.1775e-01, -2.0498e-01],\n",
       "          [-1.0630e-02, -2.0084e-01],\n",
       "          [-7.4049e-01, -1.4662e-01],\n",
       "          [ 5.9686e-03,  6.0395e-01],\n",
       "          [-2.6352e-01, -2.7800e-01]],\n",
       "\n",
       "         [[-1.4408e+00, -6.9777e-01],\n",
       "          [ 1.3986e+00,  9.8276e-01],\n",
       "          [-2.2022e-01, -4.9951e-01],\n",
       "          [-7.8112e-01, -5.6393e-01],\n",
       "          [-1.6327e+00, -3.6529e-02],\n",
       "          [ 9.3230e-01,  1.1366e+00],\n",
       "          [-1.1145e+00, -1.1552e+00]]],\n",
       "\n",
       "\n",
       "        [[[-6.8066e-01, -2.6382e-01],\n",
       "          [ 5.9179e-01,  3.9594e-01],\n",
       "          [-5.4731e-02, -1.9649e-01],\n",
       "          [-1.3770e-02, -1.7245e-01],\n",
       "          [-9.0382e-01,  7.7667e-02],\n",
       "          [ 2.6761e-01,  4.5316e-01],\n",
       "          [-6.1776e-01, -1.7315e-01]],\n",
       "\n",
       "         [[-6.3969e-01, -2.5861e-01],\n",
       "          [ 2.6435e-01,  1.2572e-01],\n",
       "          [-5.2466e-02,  7.5444e-03],\n",
       "          [ 7.7776e-02, -8.4133e-02],\n",
       "          [-6.5440e-01, -6.1381e-02],\n",
       "          [ 2.9140e-01,  1.2203e-01],\n",
       "          [-3.2579e-01, -6.5611e-03]],\n",
       "\n",
       "         [[-4.0368e-01, -2.8976e-02],\n",
       "          [ 4.9542e-01, -5.2629e-02],\n",
       "          [ 2.9634e-01,  2.9798e-02],\n",
       "          [-3.8510e-01, -3.1746e-01],\n",
       "          [-1.1561e+00,  3.2535e-01],\n",
       "          [ 2.7521e-01,  5.2089e-01],\n",
       "          [-9.6266e-02, -2.4593e-01]]],\n",
       "\n",
       "\n",
       "        [[[-1.2355e+00, -7.9683e-01],\n",
       "          [ 1.1026e+00,  5.1427e-01],\n",
       "          [-9.5831e-02,  6.6697e-02],\n",
       "          [-8.6040e-01, -3.4638e-01],\n",
       "          [-1.7411e+00, -4.8292e-02],\n",
       "          [ 8.8210e-01,  8.9844e-01],\n",
       "          [-2.9750e-01, -5.8197e-01]],\n",
       "\n",
       "         [[-8.8964e-01, -7.7131e-01],\n",
       "          [ 9.2475e-01,  7.5944e-01],\n",
       "          [-3.9703e-01,  5.4911e-02],\n",
       "          [-4.3457e-01, -6.0850e-01],\n",
       "          [-1.2359e+00, -2.1563e-01],\n",
       "          [ 3.1366e-01,  9.4685e-01],\n",
       "          [-3.6587e-01, -4.0496e-01]],\n",
       "\n",
       "         [[-1.0356e+00, -5.7955e-01],\n",
       "          [ 1.0172e+00,  3.7708e-01],\n",
       "          [-2.6610e-01,  1.9661e-01],\n",
       "          [-6.2361e-01, -2.6388e-01],\n",
       "          [-1.5238e+00, -5.1270e-02],\n",
       "          [ 1.0587e+00,  5.0185e-01],\n",
       "          [-4.6673e-01, -8.2965e-01]]],\n",
       "\n",
       "\n",
       "        [[[-5.7435e-01, -4.0209e-01],\n",
       "          [ 6.0844e-01,  3.4220e-01],\n",
       "          [-1.2061e-01, -1.7529e-01],\n",
       "          [-3.2063e-01, -2.1234e-01],\n",
       "          [-6.7926e-01, -8.5341e-02],\n",
       "          [ 2.3327e-01,  3.7062e-01],\n",
       "          [-4.8399e-01, -1.6149e-01]],\n",
       "\n",
       "         [[-6.1670e-01, -8.9906e-02],\n",
       "          [ 4.3287e-01, -8.2226e-02],\n",
       "          [ 1.1681e-01,  5.1653e-02],\n",
       "          [-1.8801e-01,  1.2330e-02],\n",
       "          [-6.8849e-01,  3.1168e-01],\n",
       "          [ 2.7578e-01,  4.1730e-01],\n",
       "          [-2.1129e-01, -1.1096e-01]],\n",
       "\n",
       "         [[-8.5147e-01, -3.3263e-01],\n",
       "          [ 8.2477e-01,  3.1738e-01],\n",
       "          [ 2.4419e-02,  2.4416e-01],\n",
       "          [-1.5930e-01, -6.2970e-01],\n",
       "          [-1.3485e+00, -9.0959e-02],\n",
       "          [ 6.2138e-01,  7.5317e-01],\n",
       "          [-6.5167e-02, -6.7240e-01]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "''' \n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "'''\n",
    "\n",
    "batch_size = 8\n",
    "num_part = 12\n",
    "feat_dim = 5\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "field = torch.rand(batch_size,num_part,2)\n",
    "center = field[:,2:5]\n",
    "field_feat = torch.rand(batch_size,num_part,feat_dim,2)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "model(field, center, field_feat, field_mask)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-16T19:35:35.724881Z",
     "start_time": "2020-08-16T19:35:35.557764Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fe5e2571280>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#np.round(field.numpy(),3)\n",
    "plt.scatter(field[0,:,0],field[0,:,1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### To Do\n",
    "\n",
    "- ~make sure top-left ---> bottom-right is indexed correctly for grid sample.~  \n",
    "H, W but y,x\n",
    "- ~turn attention off to double check~\n",
    "- ~run some more checks on cts conv~\n",
    "- ~check equivariant.~ \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "### Small Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:19.971633Z",
     "start_time": "2020-08-27T21:55:19.955622Z"
    },
    "hidden": true
   },
   "outputs": [],
   "source": [
    "model = EquiCtsConv2d(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, use_attention=False)\n",
    "\n",
    "model.weights.data = torch.tensor([[[[[1.,0.05],[0.,0.]],[[2.,.1],[0.,0.]],[[3.,0.2],[0.,0.]]]]])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:23.855854Z",
     "start_time": "2020-08-27T21:55:23.846505Z"
    },
    "hidden": true,
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[[[ 1.0000e+00,  5.0000e-02],\n",
       "            [ 0.0000e+00,  0.0000e+00]],\n",
       "\n",
       "           [[ 2.1856e-09, -4.3711e-08],\n",
       "            [-5.0000e-02,  1.0000e+00]],\n",
       "\n",
       "           [[ 1.0000e+00,  5.0000e-02],\n",
       "            [ 8.7423e-08,  4.3711e-09]],\n",
       "\n",
       "           [[ 5.9624e-10, -1.1925e-08],\n",
       "            [-5.0000e-02,  1.0000e+00]]],\n",
       "\n",
       "\n",
       "          [[[ 2.0000e+00,  1.0000e-01],\n",
       "            [ 0.0000e+00,  0.0000e+00]],\n",
       "\n",
       "           [[ 4.3711e-09, -8.7423e-08],\n",
       "            [-1.0000e-01,  2.0000e+00]],\n",
       "\n",
       "           [[ 2.0000e+00,  1.0000e-01],\n",
       "            [ 1.7485e-07,  8.7423e-09]],\n",
       "\n",
       "           [[ 1.1925e-09, -2.3850e-08],\n",
       "            [-1.0000e-01,  2.0000e+00]]],\n",
       "\n",
       "\n",
       "          [[[ 3.0000e+00,  2.0000e-01],\n",
       "            [ 0.0000e+00,  0.0000e+00]],\n",
       "\n",
       "           [[ 8.7423e-09, -1.3113e-07],\n",
       "            [-2.0000e-01,  3.0000e+00]],\n",
       "\n",
       "           [[ 3.0000e+00,  2.0000e-01],\n",
       "            [ 2.6227e-07,  1.7485e-08]],\n",
       "\n",
       "           [[ 2.3850e-09, -3.5775e-08],\n",
       "            [-2.0000e-01,  3.0000e+00]]]]]], grad_fn=<ViewBackward>)"
      ]
     },
     "execution_count": 177,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.computeKernel()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:30.739665Z",
     "start_time": "2020-08-27T21:55:30.723604Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 2.2763e-09, -1.9088e-01]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 178,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "''' \n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "'''\n",
    "\n",
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "\n",
    "\n",
    "#field = torch.tensor([[[-.2,.2],[0.,1.]]])\n",
    "field = torch.tensor([[[-.2*6,.2*6],[0.,1.]]])\n",
    "#field = torch.tensor([[[-1.99,0.01],[0.,1.]]])\n",
    "\n",
    "center = torch.tensor([[[0.,0.]]])\n",
    "field_feat = torch.tensor([[[[1., 0.]],[[0., 0.]]]])\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "model(field, center, field_feat, field_mask)\n",
    "\n",
    "# 2.3850e-09, -2.0000e-01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:31.399166Z",
     "start_time": "2020-08-27T21:55:31.388759Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[2.8632e+00, 2.5031e-07]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 179,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "field = torch.tensor([[[.2*6,.2*6],[0.,1.]]])\n",
    "model(field, center, field_feat, field_mask)\n",
    "#3.0000e+00, 2.6227e-07"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:32.105999Z",
     "start_time": "2020-08-27T21:55:32.096046Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[9.2426e-01, 8.0802e-08]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 180,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "field = torch.tensor([[[.2,.2],[0.,1.]]])\n",
    "model(field, center, field_feat, field_mask)\n",
    "#1.0000e+00, 8.7423e-08"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:33.215131Z",
     "start_time": "2020-08-27T21:55:33.115712Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f8288df8860>"
      ]
     },
     "execution_count": 181,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(field[0,:,0],field[0,:,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T17:53:00.528017Z",
     "start_time": "2020-06-09T17:53:00.502964Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 1, 2])"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "center.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "metadata": {
    "hidden": true
   },
   "outputs": [],
   "source": [
    "kernel=torch.rand([3,3,3,3,3])\n",
    "shrink_factor=2\n",
    "grid = torch.meshgrid(torch.linspace(-1, 1, kernel.shape[2])*(shrink_factor**2),\n",
    "                              torch.linspace(-1, 1, kernel.shape[3])*shrink_factor, \n",
    "                              torch.linspace(-1, 1, kernel.shape[4])*shrink_factor)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Equivariance Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:34:32.196630Z",
     "start_time": "2020-08-30T04:34:32.189187Z"
    }
   },
   "outputs": [],
   "source": [
    "def rotate_field(theta, field, field_feat=None):\n",
    "    rot_mat = EquiCtsConv2d.RotMat(torch.tensor(theta)).to(field.device)\n",
    "    rotated_field = torch.einsum('ij,bnj->bni', rot_mat, field)\n",
    "    if not field_feat is None:\n",
    "        rotated_feat = torch.einsum('ij,bncj->bnci', rot_mat, field_feat)\n",
    "        return rotated_field, rotated_feat\n",
    "    else:\n",
    "        return rotated_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "#### Toy Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:53.425395Z",
     "start_time": "2020-08-27T21:55:53.411525Z"
    },
    "hidden": true
   },
   "outputs": [],
   "source": [
    "model = EquiCtsConv2d(in_channels = 1, out_channels = 1, radius = 2, num_radii = 3, num_theta = 4, use_attention=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:55:58.993386Z",
     "start_time": "2020-08-27T21:55:58.976879Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[ 0.2894, -0.1248]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 183,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "''' \n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "'''\n",
    "\n",
    "batch_size = 1\n",
    "num_part = 2\n",
    "feat_dim = 1\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "\n",
    "\n",
    "#field = torch.tensor([[[-.2,.2],[0.,1.]]])\n",
    "field = torch.tensor([[[-.2*6,.2*6],[0.,1.]]])\n",
    "#field = torch.tensor([[[-1.99,0.01],[0.,1.]]])\n",
    "\n",
    "center = torch.tensor([[[0.,0.]]])\n",
    "field_feat = torch.tensor([[[[1., 0.]],[[0., 0.]]]])\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "unrotated_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:56:00.235237Z",
     "start_time": "2020-08-27T21:56:00.227063Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-4.3711e-08, -1.0000e+00],\n",
       "        [ 1.0000e+00, -4.3711e-08]])"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Test.RotMat(torch.tensor(np.pi/2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-27T21:56:01.383021Z",
     "start_time": "2020-08-27T21:56:01.371567Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.1248, 0.2894]]]], grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 185,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rotated_field, rotated_feat = rotate_field(np.pi/2, field, field_feat)\n",
    "rotated_center = rotate_field(np.pi/2, center)\n",
    "model(rotated_field, rotated_center, rotated_feat, field_mask)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "#### Test 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:02:36.898930Z",
     "start_time": "2020-08-28T23:02:36.870270Z"
    },
    "hidden": true
   },
   "outputs": [],
   "source": [
    "batch_size = 16\n",
    "num_part = 60\n",
    "feat_dim = 32\n",
    "rotate_angle = np.pi/8\n",
    "model = EquiCtsConv2d(in_channels = feat_dim, out_channels = 1, radius = 2, num_radii = 10, num_theta = 8, use_attention=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:02:40.885546Z",
     "start_time": "2020-08-28T23:02:40.874773Z"
    },
    "hidden": true
   },
   "outputs": [],
   "source": [
    "''' \n",
    "        @kernel: [c_out, c_in=feat_dim, r, theta, 2, 2]\n",
    "        @field: [batch, num_n, pos_dim=2] -> [batch, 1, num_n, pos_dim]\n",
    "        @center: [batch, num_m, pos_dim=2] -> [batch, num_m, 1, pos_dim]\n",
    "        @field_feat: [batch, num_n, c_in=feat_dim, 2] -> [batch, 1, num_n, c_in, 2]\n",
    "        @field_mask: [batch, num_n, 1]\n",
    "'''\n",
    "\n",
    "\n",
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "\n",
    "field = torch.rand(batch_size, num_part, 2)\n",
    "\n",
    "center = torch.rand(batch_size, 1, 2)\n",
    "field_feat = torch.rand(batch_size, num_part, feat_dim, 2)\n",
    "center_feat = torch.rand(batch_size, 1, feat_dim, 2)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "center_mask = torch.ones(batch_size,1,1)\n",
    "\n",
    "# rotated_result = rotate_field(rotate_angle, center, unrotated_result)[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:02:41.220432Z",
     "start_time": "2020-08-28T23:02:41.199981Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.1301, grad_fn=<NormBackward0>)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unrotated_result = model(field, center, field_feat, field_mask)\n",
    "rotated_field, rotated_feat = rotate_field(rotate_angle, field, field_feat)\n",
    "rotated_center = rotate_field(rotate_angle, center)\n",
    "result_rot_field = model(rotated_field, rotated_center, rotated_feat, field_mask)\n",
    "unrot_result_rot_field = rotate_field(-rotate_angle, field, result_rot_field)[1]\n",
    "torch.norm(unrot_result_rot_field - unrotated_result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:02:41.975630Z",
     "start_time": "2020-08-28T23:02:41.913392Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(8.4034, grad_fn=<NormBackward0>)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unrotated_result = model(field, field, field_feat, field_mask)\n",
    "rotated_field, rotated_feat = rotate_field(rotate_angle, field, field_feat)\n",
    "rotated_center = rotate_field(rotate_angle, center)\n",
    "result_rot_field = model(rotated_field, rotated_field, rotated_feat, field_mask)\n",
    "unrot_result_rot_field = rotate_field(-rotate_angle, field, result_rot_field)[1]\n",
    "torch.norm(unrot_result_rot_field - unrotated_result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:02:42.579417Z",
     "start_time": "2020-08-28T23:02:42.565074Z"
    },
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(4.7461e-08, grad_fn=<NormBackward0>)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unrotated_result = model(center, center, center_feat, center_mask)\n",
    "rotated_center, rotated_feat = rotate_field(rotate_angle, center, center_feat)\n",
    "result_rot_field = model(rotated_center, rotated_center, rotated_feat, center_mask)\n",
    "unrot_result_rot_field = rotate_field(-rotate_angle, field, result_rot_field)[1]\n",
    "torch.norm(unrot_result_rot_field - unrotated_result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:11:40.541221Z",
     "start_time": "2020-08-28T23:11:32.369294Z"
    },
    "hidden": true
   },
   "outputs": [],
   "source": [
    "equ_errors = []\n",
    "angles = np.arange(0, 2*np.pi + np.pi/256, np.pi/256, dtype=np.float32)\n",
    "#angles = [np.pi/2]*10\n",
    "unrotated_result = model(field, field, field_feat, field_mask)\n",
    "for rotate_angle in angles:\n",
    "    rotated_field, rotated_feat = rotate_field(rotate_angle, field, field_feat)\n",
    "    rotated_center = rotate_field(rotate_angle, center)\n",
    "    result_rot_field = model(rotated_field, rotated_field, rotated_feat, field_mask)\n",
    "    unrot_result_rot_field = rotate_field(-rotate_angle, field, result_rot_field)[1]\n",
    "    equ_errors.append(torch.norm(unrot_result_rot_field - unrotated_result).item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-28T23:02:53.698739Z",
     "start_time": "2020-08-28T23:02:53.584322Z"
    },
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, '#theta = 8')"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(angles, equ_errors)\n",
    "plt.ylabel('Equivariance Error')\n",
    "plt.xlabel('Relative Angle')\n",
    "plt.title('#theta = 8')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Test 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:34:42.472686Z",
     "start_time": "2020-08-30T04:34:42.291495Z"
    }
   },
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "import pandas as pd\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:37:01.828650Z",
     "start_time": "2020-08-30T04:37:01.821084Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 4,  6,  8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_thetas = np.arange(2, 17) * 2\n",
    "num_radiis = np.arange(2, 16)\n",
    "num_thetas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-29T01:39:11.973569Z",
     "start_time": "2020-08-29T01:39:11.969291Z"
    }
   },
   "outputs": [],
   "source": [
    "batch_size = 16\n",
    "num_part = 60\n",
    "feat_dim = 32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-29T01:39:12.649785Z",
     "start_time": "2020-08-29T01:39:12.645881Z"
    }
   },
   "outputs": [],
   "source": [
    "ee_result = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-29T04:36:10.651890Z",
     "start_time": "2020-08-29T01:51:09.869955Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.10it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.01it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.01it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.00it/s]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.01it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.00it/s]\n",
      "100%|██████████| 50/50 [00:50<00:00,  1.00s/it]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.01it/s]\n",
      "100%|██████████| 50/50 [00:50<00:00,  1.01s/it]\n",
      "100%|██████████| 50/50 [00:50<00:00,  1.01s/it]\n",
      "100%|██████████| 50/50 [00:50<00:00,  1.02s/it]\n",
      "100%|██████████| 50/50 [00:51<00:00,  1.02s/it]\n",
      "100%|██████████| 50/50 [00:45<00:00,  1.09it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.08it/s]\n",
      "100%|██████████| 50/50 [00:46<00:00,  1.07it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.06it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:47<00:00,  1.05it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.04it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.03it/s]\n",
      "100%|██████████| 50/50 [00:48<00:00,  1.02it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.01it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.01it/s]\n",
      "100%|██████████| 50/50 [00:49<00:00,  1.00it/s]\n",
      "100%|██████████| 50/50 [00:50<00:00,  1.01s/it]\n",
      "100%|██████████| 50/50 [00:50<00:00,  1.01s/it]\n"
     ]
    }
   ],
   "source": [
    "device = torch.device('cuda')\n",
    "angles = np.arange(0, 2*np.pi + np.pi/256, np.pi/256, dtype=np.float32)\n",
    "for num_theta in num_thetas.tolist():\n",
    "    for num_radii in num_radiis.tolist():\n",
    "        ee = []\n",
    "        for i in tqdm(range(50)):\n",
    "            model = EquiCtsConv2d(in_channels=feat_dim, out_channels=1, radius=2, \n",
    "                                  num_radii=num_radii, num_theta = num_theta, use_attention=True)\n",
    "            model = model.to(device)\n",
    "            field = torch.rand(batch_size, num_part, 2).to(device)\n",
    "            center = torch.rand(batch_size, 1, 2).to(device)\n",
    "            field_feat = torch.rand(batch_size, num_part, feat_dim, 2).to(device)\n",
    "            center_feat = torch.rand(batch_size, 1, feat_dim, 2).to(device)\n",
    "            field_mask = torch.ones(batch_size,num_part,1).to(device)\n",
    "            center_mask = torch.ones(batch_size,1,1).to(device)\n",
    "\n",
    "            equ_errors = []\n",
    "            unrotated_result = model(field, field, field_feat, field_mask)\n",
    "            for rotate_angle in angles:\n",
    "                rotated_field, rotated_feat = rotate_field(rotate_angle, field, field_feat)\n",
    "                rotated_center = rotate_field(rotate_angle, center)\n",
    "                result_rot_field = model(rotated_field, rotated_field, rotated_feat, field_mask)\n",
    "                unrot_result_rot_field = rotate_field(-rotate_angle, field, result_rot_field)[1]\n",
    "                equ_errors.append(torch.norm(unrot_result_rot_field - unrotated_result).item())\n",
    "\n",
    "            ee.append(np.mean(equ_errors))\n",
    "        ee_result.append((num_theta, num_radii, np.mean(ee), np.std(ee)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:36:41.082754Z",
     "start_time": "2020-08-30T04:36:41.034315Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>num_theta</th>\n",
       "      <th>num_radii</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>21.988744</td>\n",
       "      <td>11.668487</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>4</td>\n",
       "      <td>3</td>\n",
       "      <td>23.994751</td>\n",
       "      <td>11.074618</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>27.590490</td>\n",
       "      <td>12.589984</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>5</td>\n",
       "      <td>25.177566</td>\n",
       "      <td>8.153829</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>6</td>\n",
       "      <td>27.428070</td>\n",
       "      <td>9.330124</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>205</th>\n",
       "      <td>32</td>\n",
       "      <td>11</td>\n",
       "      <td>0.258087</td>\n",
       "      <td>0.062010</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>206</th>\n",
       "      <td>32</td>\n",
       "      <td>12</td>\n",
       "      <td>0.263573</td>\n",
       "      <td>0.047718</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>207</th>\n",
       "      <td>32</td>\n",
       "      <td>13</td>\n",
       "      <td>0.261501</td>\n",
       "      <td>0.052699</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>208</th>\n",
       "      <td>32</td>\n",
       "      <td>14</td>\n",
       "      <td>0.269117</td>\n",
       "      <td>0.045836</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>209</th>\n",
       "      <td>32</td>\n",
       "      <td>15</td>\n",
       "      <td>0.260596</td>\n",
       "      <td>0.044872</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>210 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     num_theta  num_radii       mean        std\n",
       "0            4          2  21.988744  11.668487\n",
       "1            4          3  23.994751  11.074618\n",
       "2            4          4  27.590490  12.589984\n",
       "3            4          5  25.177566   8.153829\n",
       "4            4          6  27.428070   9.330124\n",
       "..         ...        ...        ...        ...\n",
       "205         32         11   0.258087   0.062010\n",
       "206         32         12   0.263573   0.047718\n",
       "207         32         13   0.261501   0.052699\n",
       "208         32         14   0.269117   0.045836\n",
       "209         32         15   0.260596   0.044872\n",
       "\n",
       "[210 rows x 4 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('simulated_result.pickle', 'rb') as f:\n",
    "    ee_result = pickle.load(f)\n",
    "sim_result = pd.DataFrame(ee_result, columns=['num_theta', 'num_radii', 'mean', 'std'])\n",
    "sim_result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-29T04:38:30.901536Z",
     "start_time": "2020-08-29T04:38:30.895733Z"
    }
   },
   "outputs": [],
   "source": [
    "# with open('simulated_result.pickle', 'wb') as f:\n",
    "#     pickle.dump(sim_result, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:37:05.400543Z",
     "start_time": "2020-08-30T04:37:05.074665Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.YTick at 0x7fcf2b58c9e8>,\n",
       "  <matplotlib.axis.YTick at 0x7fcf2b58c2b0>,\n",
       "  <matplotlib.axis.YTick at 0x7fcf2b27c438>,\n",
       "  <matplotlib.axis.YTick at 0x7fcf2b640550>,\n",
       "  <matplotlib.axis.YTick at 0x7fcf2b0f6cf8>,\n",
       "  <matplotlib.axis.YTick at 0x7fcf2b10a128>],\n",
       " <a list of 6 Text yticklabel objects>)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAd4AAAEGCAYAAADL8/SBAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nOy9eXgc1Z3v/T21dqu7tdpaLFuWsbFZjDHYIRCCY/CFDCEE8mRCLssEwx18MyTkJpmQsATzZuYNgVyGQJjhZbjDnYEkDCYOYXsyNzeDARMIAwaPWYKNsfGCZVmWLFnqtbbz/lF1SqdLVa3uVqullutj11OnTp2qOlVdOt/6ne1HKKUICQkJCQkJqQ7CVGcgJCQkJCTkWCIU3pCQkJCQkCoSCm9ISEhISEgVCYU3JCQkJCSkioTCGxISEhISUkWkqc5AqcyaNYt2d3dPdTZCQkJCaoo333yzn1I6e6rzEVKDwtvd3Y0tW7ZMdTZCQkJCagpCyN6pzkOITVjVHBISEhISUkVqRngJIRcTQh46evToVGclJCQkJCSkbGqmqplS+iyAZ1euXHndVOclJCQkZCbx1ltvXSqK4t8BEKc6LzMAC8C7hmH85YoVK/r8EtSM8IaEhISETA6SJN20cOHCTCwWy051Xmody7LI4cOHT+rt7f0nAF/wS1MzVc0hISEhIZMDpbS9rq4uFN0KIAgCnT179lEASwPTVDE/ISEhISHTFELIVGdhxiAIAkUBfQ2FNyQkJCQkpIqEwhsSEhISMuWsWbNm4eDgoHDFFVfMf/vtt1UA6O/vF++5555ZLM3Pfvazluuvv76z2HM+99xzic2bN9dNNG933nnnbELIinQ6XZFqgZoR3mNtOBGlFKZpQtM0ZDIZJJNJZDIZ6LqO0IdySEjITCOTyYhNTU3Wrl271GXLluUAYGBgQHzkkUdmjXdsEJs2bUq89tprsYnkq7+/X3zuuecaOzo6tImch6dmejXP5OFElmXBsiwYhgHDMGCaJkzTzBNYQRCQy+XcbVmWIcsyJEmCJElh+0xISMiEuXHjtnkf9I5M2EJkLG5PpP/nn5+6v1Ca73//++2vvfZa/MCBA8r555+/cN++fernP//54370ox8duOuuu9p27doVPeOMM5ZcdtllA4qi0N27d6sXXnjhcbt27Ypcc801h2+++ebDg4ODwtVXXz2/r69PzuVywq233tpzxhlnpDds2NAiyzLduHFj8y9/+cuPfvWrXzU888wzTel0Wli0aFH2V7/61R5RFHHLLbe0n3766ek///M/H/bm73vf+96cm2+++eC6desWVOq51IzwzgQopbAsyxVWXddhmiYsy3LTEEIgCAJEURwjpqIo5p0nnU67+3ghFkURgjC9KjO8Vjq/XWhfMWkJIYHLdIBSmrdYluWG2e/NlumS55CQanHXXXf1rl+/vu26667rz2az5IILLjh644039gPA7bff3vvee+/Vvf766zsAu6p5aGhIeuWVVz4YGhoSTzzxxJNvvvnmw+vXr+9YtWrVyHe/+93+I0eOCCtXrjxx586d733lK18ZaG9v17/3ve8dBoBvfOMbA7fccsthAPjc5z533K9//ev6yy67bPiOO+7o9cvb1q1bI729vfJFF12UrOQ9h8I7SfACyyxZVuACcIWBiWwp8McC00OI2b2x++bvn7/vQvfEPxsAedv88d5tPp4/jhczXtxYXLlC7RVSXlC9C7+/0L3zYVEU8363UJRDqsV41mmlefnll+v++q//et7OnTsjxx13XHb//v1qR0eHtmfPHvUf/uEfDvgdc9ppp6VEUURLS4tpWRYBgHfeeSf64osv1j/xxBMtgD2WtqenZ4y+/eIXv2j853/+59kA0NPTo+zdu3eMhcvz3e9+t/Pee+/9eOJ3mk8ovEXiLUD9wkxkeSuWFZZBVmwlKEaIJUmCoihlCzFvqfGi6lctzueJCUm1RYP/bVg1Ph/P55MXaj8L1E9Q2bHec/ICzs5VqqCz94hZxHz+mCizcCjKIbXMOeeck/7jH/+445xzzln86quvfnDGGWcsYdYtAKiqSk3TzHu5/d71pUuXZhYvXjz4zW9+cwAAstksiUQiVFEUi/3tA8Btt90278MPP3ynqanJuvDCC4+jlBb8w9m3b1/k+uuv7wKAgYEB+fzzz1+0efPmnaUaS16OKeH1WiHAWEFh6bzbwPiW10Ss2EriJ8SU0oJCzO6FFxdeWC3LGnO/rMCfCmEdD178ioF/H/w+JvhnOllCV8jqZnlhoszHAaOizC/e38svXOhDkk8bdB6vtR60za+Dfhu/+PHC0+29Cymdt956K7JkyZJMb2+v2NzcrPP75s2bp7e0tOgXXHDBwi9+8YuD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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for num_theta, df in sim_result.groupby('num_theta'):\n",
    "    df = df.sort_values('num_radii')\n",
    "    df['mps'] = df['mean'] + df['std']\n",
    "    df['mms'] = df['mean'] - df['std']\n",
    "    plt.plot(num_radiis, df['mean'], label='#theta: {}'.format(num_theta))\n",
    "    plt.fill_between(num_radiis, df['mps'], df['mms'], color='lightgrey', alpha=0.3)\n",
    "plt.yscale('log')\n",
    "plt.legend(loc=[1.02,.02], fontsize=9.5)\n",
    "plt.xlabel('# radii')\n",
    "plt.ylabel('Equivariance Error')\n",
    "plt.yticks([0.1, 0.5, 1, 5, 10, 20], [0.1, 0.5, 1, 5, 10, 20])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:47:11.279624Z",
     "start_time": "2020-08-30T04:47:11.155593Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, '#theta: 16')"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = sim_result[sim_result.num_theta==16]\n",
    "df = df.sort_values('num_radii')\n",
    "df['mps'] = df['mean'] + df['std']\n",
    "df['mms'] = df['mean'] - df['std']\n",
    "plt.plot(num_radiis, df['mean'], label='#theta: {}'.format(num_theta), color='skyblue')\n",
    "plt.fill_between(num_radiis, df['mps'], df['mms'], color='orange', alpha=0.2)\n",
    "plt.xlabel('# radii')\n",
    "plt.ylabel('Equivariance Error')\n",
    "plt.suptitle('Equivariance Error - Number of Radii')\n",
    "plt.title('#theta: 16', fontsize=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T05:03:00.264176Z",
     "start_time": "2020-08-30T05:02:59.980973Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.XTick at 0x7fcf26016f60>,\n",
       "  <matplotlib.axis.XTick at 0x7fcf26016860>,\n",
       "  <matplotlib.axis.XTick at 0x7fcf26016748>,\n",
       "  <matplotlib.axis.XTick at 0x7fcf25d36400>,\n",
       "  <matplotlib.axis.XTick at 0x7fcf25d368d0>,\n",
       "  <matplotlib.axis.XTick at 0x7fcf25d28668>,\n",
       "  <matplotlib.axis.XTick at 0x7fcf25d36cf8>],\n",
       " <a list of 7 Text xticklabel objects>)"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for num_radii, df in sim_result.groupby('num_radii'):\n",
    "    df = df.sort_values('num_theta')\n",
    "    df['mps'] = df['mean'] + df['std']\n",
    "    df['mms'] = df['mean'] - df['std']\n",
    "    plt.plot(num_thetas, df['mean'], label='#radii: {}'.format(num_radii), alpha=0.4)\n",
    "    plt.fill_between(num_thetas, df['mps'], df['mms'], color='lightgrey', alpha=0.1)\n",
    "plt.legend(loc=[1.02,.02], fontsize=9.5)\n",
    "plt.xlabel('# theta')\n",
    "plt.ylabel('Equivariance Error')\n",
    "plt.xscale('log')\n",
    "plt.xticks([4, 6, 8, 16, 20, 30, 32], [4, None, 8, 16, None, None, 32])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-30T04:54:46.945121Z",
     "start_time": "2020-08-30T04:54:46.574768Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, 'Equivariance Error - Number of Theta (#radii: 4)')"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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iwLf433cfQq4iJApshf4d+Cd7v7oCvubj38m/J59J/q9/QkhQcnsGtJPAD+K1laeQfj7OBkYIiSHmfu3NNeVhMybuSNoJxEupBC1teMle81vwWNH7+EbCUlzBoDL8ugbsK8w+d75HovW8+2Z/SL8bWWj+7NTdd9OCI5FRNYd83lLyoiIlL9o2tTTQLJUo0ciEpjZF4Hr3f1ra92XYovW+d0JnOTuE2vdHxGRuRTUiciGpaBORERENgNNvxQRERERESljGqkTEREREREpYxqpExERERERKWMK6kRERERERMqYgjoREREREZEypqBORERERESkjCmoExERERERKWMK6kRERERERMqYgjoREREREZEypqBORERERESkjCmoExERERERKWMK6kRERERERMqYgjoREREREZEypqBORERERESkjCmoExERERERKWMK6kRERERERMqYgjoREREREZEypqBOZBFm9vtmVl3E9p4xs5YV7P9qM7ulWP2Z0/a7zOxfS9G2iIhILjPbW6R2Djazh4vRlkg5U1AnsrjfB4oW1C2XmcXX6tgiIiIiUh4U1IkAZlZjZt8wswfN7GEzu8zMPgBsBW43s9uj5/1fM9tuZo+Y2cdy9n/GzD5mZveZ2UNmdmS0vdnMvmNm95vZfwKWs8/XzGxH1NYVOdv3mtnHzexu4Ewze52ZPWpm24A3LtD/Y8zsHjN7wMx2mtlh0fZ3RvcfNLPPR9suNLO7oz59z8za52mv1cy+Ymb3Rl9nF+FtFhEReREL/j469z5kZpdF22Nm9u/ROfIWM7vVzC5doq2UmX02aud+M3tNtL3azK6PzofXRefAU1fj9YmslsRad0BknXgdsNvd3wBgZml3HzKzPwRe4+690fP+3N37oxG028zseHffGT3W6+4nm9nvAH8EvA/4K2Cbu3/czN4AXJFzzPdEbVUB95rZV9y9D6gBHnb3vzSzFPA4cC7wBHDdAv3/LeCf3f0aM6sA4mZ2DPDnwNnu3mtmTdFztwFnuLub2fuADwMfmtPePwOfdvdtZnYg8G3gqGW9oyIiIkt7I3AicALQQjgf/gA4GzgYOA5oA3YBVy3R1u8CuPtx0cXV75jZ4cDvAAPufryZHQs8UIoXIrKWNFInEjwEnGdmf2dmr3T3oQWe92Yzuw+4HzgGODrnsRuj7zsIJyKAVwFfAHD3bwAD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\n",
      "text/plain": [
       "<Figure size 1080x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = sim_result[sim_result.num_radii==4]\n",
    "df = df.sort_values('num_theta')\n",
    "df['mps'] = df['mean'] + df['std']\n",
    "df['mms'] = df['mean'] - df['std']\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(1,2, figsize=(15, 6))\n",
    "ax1.plot(num_thetas, df['mean'], label='#radii: {}'.format(num_radii), color='skyblue')\n",
    "ax1.fill_between(num_thetas, df['mps'], df['mms'], color='orange', alpha=0.2)\n",
    "ax1.set_xlabel('# theta')\n",
    "ax1.set_ylabel('Equivariance Error')\n",
    "ax1.set_title('standard scale', fontsize=10)\n",
    "\n",
    "ax2.plot(num_thetas, df['mean'], label='#radii: {}'.format(num_radii), color='skyblue')\n",
    "ax2.fill_between(num_thetas, df['mps'], df['mms'], color='orange', alpha=0.2)\n",
    "ax2.set_xlabel('# theta')\n",
    "ax2.set_ylabel('Equivariance Error')\n",
    "ax2.set_title('log-log', fontsize=10)\n",
    "ax2.set_xscale('log')\n",
    "ax2.set_xticks([4, 6, 8, 10, 12, 14, 16, 18, 20, 24, 26, 30])\n",
    "ax2.set_xticklabels([4, 6, 8, 10, 12, 14, 16, 18, 20, 24, 26, 30])\n",
    "ax2.set_yscale('log')\n",
    "ax2.set_yticks([0.1, 0.5, 1, 5, 10, 20])\n",
    "ax2.set_yticklabels([0.1, 0.5, 1, 5, 10, 20])\n",
    "\n",
    "fig.suptitle('Equivariance Error - Number of Theta (#radii: 4)')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-29T01:18:40.006185Z",
     "start_time": "2020-08-29T01:18:39.900892Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PolyCollection at 0x7fce8468b2b0>"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAD4CAYAAAD1jb0+AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nO3deYwk533e8e+vqvqae2Z3drW8xMNLWqJsLbkTWbaU2LoMmTEiGbBiC7FAIQZoJJYjJQYSxUEQOYkB2fCBHIICKpJN2zosS3KkJIptipZ1xAqtJcVThEjxkLgHd2d3556+quqXP6qmd46ePWdnprqfDzDo7reqp9/axj71zltvva+5OyIiUjzBTldAREQujwJcRKSgFOAiIgWlABcRKSgFuIhIQUXb+WF79+71G2+8cTs/UkSk8B566KHT7j65vnxbA/zGG2/kyJEj2/mRIiKFZ2bf61auLhQRkYJSgIuIFJQCXESkoBTgIiIFpQAXESkoBbiISEEpwEVECkoBLiJSUIUJ8JNLDeI03elqiIjsGoUJ8LlGTD1WgIuIrChMgMfuNONkp6shIrJrFCbA3Z16WwEuIrKiMAEOsKQWuIhIR6ECvN5O0SLMIiKZQgV4O01JFOAiIkDBAtwdmolGooiIQNECHKepoYQiIkDBAtzMaCjARUSAggV4aMZSO97paoiI7AqFCvAoMJbVAhcRAS4iwM2samZ/a2aPmtmTZvbreflNZvagmT1jZn9iZuWrXlmDdpKSpBqJIiJyMS3wJvBGd381cAh4q5m9FvhN4Pfc/SAwA/zi1avmOQa0NBJFROTCAe6ZxfxlKf9x4I3AZ/Ly+4C3X5UadqGhhCIiF9kHbmahmT0CnALuB54FZt195YriUeDaTd57j5kdMbMj09PTW1FnGrqlXkTk4gLc3RN3PwRcB7wGeEW33TZ5773uPuXuU5OTk5df01xgxrImtRIRubRRKO4+C/w18FpgzMyifNN1wPGtrVp3YQDLaoGLiFzUKJRJMxvLn9eANwNPAV8Gfjbf7W7g81erkquFZjRjTWolIhJdeBcOAPeZWUgW+J929/9lZt8GPmVm/xH4FvDRq1jPDjPDyS5kVqNwOz5SRGRXumCAu/tjwB1dyp8j6w/fditDCRXgItLPCnUn5gpNaiUiUtAAD8x0IVNE+l4hAzzUUEIRkYIGeGDU40QjUUSkrxUywAMz3KGtSa1EpI8VMsAhu+1Tk1qJSD8rbICD5kQRkf5W2AA3g7oCXET6WGEDXCNRRKTfFTbAo8Co62YeEeljhQ1wA+LUiVOFuIj0p+IGuJmWVxORvlbYAM+4llcTkb5V6AB3jHpbAS4i/anQAR4FxlI7vvCOIiI9qNABHppGoohI/yp0gAeWXcRMNamViPShQgf4ykgUXcgUkX5U6ACHfFIrdaOISB8qfICD00h0S72I9J/CB3hoxpLmRBGRPnTBADez683sy2b2lJk9aWbvzcs/YGbHzOyR/Oeuq1/djcLAqCvARaQPRRexTwz8qrs/bGbDwENmdn++7ffc/bevXvXOCeJFknBwQ3loRiNOcXfMbDuqIiKyK1ywBe7uJ9z94fz5AvAUcO3Vrtga3/xlbvnGa7tuWgntVqKhhCLSXy6pD9zMbgTuAB7Mi95jZo+Z2cfMbHyT99xjZkfM7Mj09PTl1XLoFsqNF4maJzfdpakLmSLSZy46wM1sCPgs8D53nwc+DNwCHAJOAL/T7X3ufq+7T7n71OTk5OXVcu+PADAw/1DXzY7T1FBCEekzFxXgZlYiC++Pu/vnANz9pLsn7p4CHwFec9VqOX4HbiG1uYe7bg7MWNbyaiLSZy5mFIoBHwWecvffXVV+YNVuPwM8sfXVy0UDNIZeycD8ka6btbyaiPSjixmF8jrgXcDjZvZIXvZrwDvN7BDZzZAvAL90VWqYq49MMXrys+Ap2NrzThgY9TjRSBQR6SsXDHB3/zrZCmbrfXHrq7O5+uhhJo79PuXlZ2kNHlyzLTAj9WyJtVKoABeR/lCYOzHro1MA1Oa+2XW7JrUSkX5TmABvDt5KEg5Rm9tsJAo0dSFTRPpIYQIcC6mPHKI21/1CpoEWdxCRvlKcAAeWR6aoLjyBJY0N28JAQwlFpL8UK8BH78S8TXXh8Q3bwkBDCUWkvxQqwOsjhwG6dqMEQJymxKnmRBGR/lCoAG9Xr6VdOUC1yy312fJqRksjUUSkTxQqwCEbD775SBTXUEIR6RvFC/CRw1SWnyVon+2y1WioH1xE+kTxArxzQ8/Gia3CQMuriUj/KFyAN0bvwLGu3SiRZXOiiIj0g8IFeBqN0By8rftIFMtup09dI1FEpPcVLsABGisXMtcFdTYSRXOiiEh/KGSA10cPE7VPU2p8v+t2DSUUkX5Q0ABfuZC5sRslW15N/eAi0vsKGeCNodtJg0rXC5mhaSSKiPSHQgY4QYnG8Ku7tsA1J4qI9ItiBjhZN0p1/lFI22vKQzMacYprJIqI9LgCB/hhgrROZfGpNeUra2K2NKmViPS4Qgc4bHYhE1pa3EFEelxhA7xdu4m4NEGty8yE4DQS9YOLSG8rbIBjtunMhIHpQqaI9L4LBriZXW9mXzazp8zsSTN7b14+YWb3m9kz+eP41a/uWvXRKSqLTxHEC2vKQzPqCnAR6XEX0wKPgV9191cArwV+2cxeCbwfeMDdDwIP5K+3VWPkMIZTnX9kTXkYGHWNRBGRHnfBAHf3E+7+cP58AXgKuBZ4G3Bfvtt9wNuvViU3c+5C5tpulMCM1F3Lq4lIT7ukPnAzuxG4A3gQ2O/uJyALeWDfJu+5x8yOmNmR6enpK6vtOkl5D63aTV1HooDmRBGR3nbRAW5mQ8Bngfe5+/zFvs/d73X3KXefmpycvJw6ntdmFzIdzUooIr3togLczEpk4f1xd/9cXnzSzA7k2w8Ap65OFc+vPnqYUvMYUePEmnIDLe4gIj3tYkahGPBR4Cl3/91Vm74A3J0/vxv4/NZX78I6MxOuGw+u5dVEpNddTAv8dcC7gDea2SP5z13AB4G3mNkzwFvy19uuMfzDuEUbulE0lFBEel10oR3c/etkPRLdvGlrq3PpPKzRGP6hDRcyV5ZXS1InDDarvohIcRX3TsxV6iN3Up17GPzcRctseTXThUwR6Vm9EeCjU4TJAuWlZ9aUO66hhCLSs3omwKHbzIRGQyNRRKRH9USAtwYPkoTDGwJcI1FEpJf1RIBjAY3RO6nNP7ymONSshCLSw3ojwMmXWFt4HEvqnbIwH4mSalIrEelBPRTghzGPqS481inLRqJoThQR6U29E+Aj3WcmBM2JIiK9qTABPlyOaCebd4XE1QO0K9duuJDpOE2NRBGRHlSYAB+vlrlQT3a3mQmz5dXUAheR3lOYAB8sh52FGjZTH52iXH+esHWmUxYFxnI73o4qiohsq8IEeGDGeLV03guS3VboCU3Lq4lIbypMgANMVEucb5W0xsghHKO6ampZM8Nx2lpeTUR6TKECfKgcYbBpazqNhmkOvWLDhUxNaiUivahQAR4Gxmg1onWe0SidC5mrQt5BI1FEpOcUKsABJqplEj9PP/jIYaL2WUr1FzplgaHFHUSk5xQuwIcrEWCbdqN0m5kwNGNJLXAR6TGFC/BSEDBcDje9KNkceiVpUFs7EiUw6m2NRBGR3lK4AAfYUysTb9YPHkQ0Rg6tWeQ4MCNxJ1aAi0gPKWSAj1RKYJuPRqmPHqY6/yik7U6ZAa1YI1FEpHcUMsDLYcBAKSTepBulPnqYIG1QXXyyU+ZoUisR6S2FDHCAPbXSpv3g3S5kGlBXC1xEesgFA9zMPmZmp8zsiVVlHzCzY2b2SP5z19Wt5kajlRLQvRulXb2BuLR3w4VMzYkiIr3kYlrgfwC8tUv577n7ofzni1tbrQurhAGVMCDp1g9ulvWDr5sTZVlDCUWkh1wwwN39q8DZbajLJTEz9tbKm05uVR+dorL0HYJ4Hshu5mknTqI5UUSkR1xJH/h7zOyxvItlfLOdzOweMztiZkemp6ev4OM2Gq1mN/V0Ux89jOFU5761Ug8MXcgUkd5xuQH+YeAW4BBwAvidzXZ093vdfcrdpyYnJy/z47qrRSGlwLq2quujd2b7zK9d4EHrY4pIr7isAHf3k+6euHsKfAR4zdZW6+KYGXs26UZJSxM0B27ZMDNhQ/3gItIjLivAzezAqpc/Azyx2b5X21i1tOlSa+uXWAvMWNKkViLSIy5mGOEngW8At5nZUTP7ReC3zOxxM3sMeAPwz69yPTc1UAoJN1lqrT46Ral5gqhxHMjnRFELXER6RHShHdz9nV2KP3oV6nJZAjPGayXO1ltUo3DNtsbIyhJrR1io/gNCy27mSd0JrPvFTxGRoijsnZirZUutbWyBN4Z/CLdSpxtlZSSKLmSKSC/oiQAfLEVdV6z3sEpj+IfW9IM7CnAR6Q09EeBhYIxWuq9Yn81M+DD4St+309ScKCLSA3oiwGHzFevro4cJk0UqS08D+UgUXcgUkR7QMwE+XOm+Yn199O8A52YmDANjuaUAF5Hi65kAj4KA4UpEa10zvDVwC0k02pnYKjKjkSRaXk1ECq9nAhxgT7VEkq7r37aA+sida0aipM6mc4mLiBRFTwX4SKVEtxXr66OHqS4+gSXLABpKKCI9oacCvBQGDJU2rlhfH53CPKE6/xiQDSXUnCgiUnQ9FeCQr1i/IcDzOzLnswuZZuiWehEpvJ4L8JFKBPiabpSksp9W9fpzI1HMWNakViJScD0X4OUwoBqFxOv6wRujh6nNPQxAFBj1ONVIFBEptJ4L8JWl1trrLlLWR6co118gbJ3GgDj17utpiogURM8FOKysWL92tsH6qpkJtbyaiPSCngzwahRQDoM1FzPrI6/GCTrjwR00J4qIFFpPBni3bhSPhmgOvfLcDT1AQwEuIgXWkwEOMFqJNiy1ls1M+BC4EwbGUjvekbqJiGyFng3wgVJItG7F+vroFFF7hlL9OULLRqKIiBRVzwa4mTFRXTtHeOeGnrkjBJbdTp9oThQRKaieDXCA8Wp5TTdKc/AHSYMBanMPaXk1ESm8ng7wwXK4dqm1IKI+eseaJdY0lFBEiuqCAW5mHzOzU2b2xKqyCTO738yeyR/Hr241L09gxvj6bpSRw1QXHoO0pUmtRKTQLqYF/gfAW9eVvR94wN0PAg/kr3el9Uut1UcPE6RNqgtPaE4UESm0Cwa4u38VOLuu+G3Affnz+4C3b3G9tsxQee1Sa/XRKQBqcw8RBrAUa3UeESmmy+0D3+/uJwDyx31bV6WtFQbGaDWilWQhHVevIy7vozZ3hNCMRjvlbL21w7UUEbl0V/0ippndY2ZHzOzI9PT01f64riaqZRJPVypEffQwtflsJEo1CvjefJ2m+sJFpGAuN8BPmtkBgPzx1GY7uvu97j7l7lOTk5OX+XFXZrgSsXqptfroFJWlpwnac4RBNunV83N1daWISKFcboB/Abg7f3438Pmtqc7VUQoChsvnllo7t0JPNj94JQxYaMa8tNTcsTqKiFyqixlG+EngG8BtZnbUzH4R+CDwFjN7BnhL/npXW73UWn3kToA1K9XXSgHHFhosa34UESmI6EI7uPs7N9n0pi2uy1WVrVifdZOkpTGaAwc7S6xBNmY8CoznZpZ5xd7hTteKiMhu1dN3Yq5WDgMGSuG5Vvjo4SzAV/V7l8OARpJybKG+U9UUEblofRPgAHtqpVX94FNErVNEzWNr9qlFAaeWmsw1NLRQRHa3vgrwbKm17KaezoXM2SNr9jEzSlHA83P1DetqiojsJn0V4JUwoBIGJO40h19FamUG5h7csF8pyPb53tyyhhaKyK7VVwG+stRaK0nxoMLi5E8y/v2PMDDzNxv2rYYBM402p3WXpojsUn0V4ACj1XMDb47f/iHatZdz3SPvpLz03TX7ZXdphnx/vq4ZC0VkV+q7AK9FYdZFkjppaZzv3/mnQMD133oHYevMmn3DwAiA52eXz80pLiKyS/RdgJsZe2rn5ghvD9zMi4c+San+Itc9+gtYuvZuzHIYsNiKeWlRd2mKyO7SdwEOMLZuqbX6+Gs5/qoPMzjzfznw5K+sGRue3aUZcnyxzmJLd2mKyO7RlwE+UAoJVy+1BswfeAenbvk3jJ34FHuf+601+2d3aQY8P7vcuRFIRGSn9WWAB2aM10obFjQ+ffO/ZPbAO9n37G8wcuLTa7aVw4BmknJ0XrMWisju0JcBDitLra0LYjNO3P6fWRp/Pdc88U+pzXxjzeZaFDBdbzLXbG9jTUVEuuvbAB8sRWtXrM95UOHFQ39Mu3YD1z/yTkrLz3a2mRmVMOD52fqG1ruIyHbr2wAPA2O0srEbBSAtTeTDC+GGh99B0D63JGgUBKTuvKC7NEVkh/VtgMPGFetXaw/ckg8v/D7XP/IuSM/dkVmNAuYabaaXdZemiOycvg7w4UqJUmCb3mlZH/9Rjr/qQwzOfI1rvv3POsMLV+7SfHG+Tl13aYrIDunrAI8C47Y9Q5SCgEa7exDPH/g5Tt3yrxk7/gn2Pv/bnfIwMAKD52d0l6aI7Iy+DnCAahRy254hqlFIvZ107dc+ffP7mT3wc+z77n9g5MRnOuWVKGQpjjmx2NjOKouIAApwIBvjfeueQYbKEfV2ujHEzThx+39laezHuObJf0Jt9twUtLUo5MRCg3kNLRSRbaYAz0VBwA+MDzJei1ju0hL3oMLRQx+nXb2O67/185SWnwPyuzTDgBdml4lTDS0Uke2jAF8lDIybxgbZN1hhuZ1s6NtOynt48Y4/BdJ8eOEMkLXgW6nzou7SFJFtpABfJzDjhpEa1wxXqXcJ8dbgD3D01Z+gXH9hzfDCWhRwernFTENdKSKyPa4owM3sBTN73MweMbMjF35HMZgZ1wxVuWG0Rr2dkKwbLL488TqO3/4hBme+yoFvvw/cs7s0o5AX5pZp6i5NEdkG0YV3uaA3uPvpLfg9u4qZsX+wSikIeG52iTIBUXDufDd3zc9TXn6Wyed+k9bALZy5+VeJAiNO4HuzyxycGMTMdvAIRKTXqQvlAiZqZQ6OD9JOfcMq9dO3/BpzL3sH+7/764y89DkAKlHAXKvNsYWGLmqKyFV1pQHuwF+a2UNmdk+3HczsHjM7YmZHpqenr/DjdsZotcxt44OkztruETOO3/4hlsd+lGue+CVqsw9mC0BEIS8tNXns1DzHFxobgl9EZCvYlYyaMLNr3P24me0D7gd+xd2/utn+U1NTfuRIcbvK63HC02cWSd2pRGGnPGyd4aYH30gQL/D8jzxAe+AmABJ3WnGKAfuHKkwOVCiH+qNHRC6NmT3k7lPry68oTdz9eP54Cvgz4DVX8vt2u1oU8oN7h7Nb7+NzY8WT8h6+f+dnMI+54VvvIGjPAhDmy7GVo4ATiw0ePzXPi/O6yCkiW+OyA9zMBs1seOU58JPAE1tVsd2qEgbctmeIWhTSiM/dtdkaPMiLhz5Befl5rn/0XWsWRw7MGChFVKKAU0tNnjg1z/fmljedREtE5GJcSQt8P/B1M3sU+Fvgf7v7n29NtXa3Uhhw68QQI5WI+qqW+PLE6zl++39h8OxXOPiVV7Dv6X+7ZkGIwIxaHuSnl1s8Mb3AC7PLmtFQRC7LFfWBX6qi94Gvl7rzvbllTtfbDERBZ9jgwJmvMPHivQxPfxHzhMWJn2D2unczv++nISh33u/uNOOUlGxu8pcNVRkohZt8moj0q836wLdiHHjfCsy4cXSAKKjz0lKTWhQSmLG858dZ3vPjRI0TjB3/Y8aO3sd1j72buDzJ7DW/wMx1d9MeuDmbV7wU4u7MNtucbbQYq5Y4MFRlIAo1jlxEzkst8C3g7ry02OToQp1qFBIG64LXEwbP/BXjR3+f4en/k7fK38DMde9mYd/f77TK3Z1mkpI6jJQjrhmuMlhSkIv0u81a4ArwLTS93OSFuWUqYUi0PsRzWav8jxg7eh/lxotZq/zadzFz7d2d4YfngtwZLkdcM1RjqKwgF+lXCvBtMlNv8ezsMlFglALbPHQ9Yej0A4wd/X2GT/951irf8wZmrvvHLEzeBUEJd6eVOLGnDJUirhmqMFIpKchF+owCfBvNN9scXWiwnC/TdqEwjxrHGTv2R4wfu49S4yhxed+qVvmNuDvt1IlTpxQYkwMVxqoRNfWTi/QFBfgOaMYp8602Z5ZbLLYTwAktoBxuEuaeMHT6fsaP/gFD038OOEudVvlPQVAiSZ1WkuJAOTT21iqMVUvUVo2CEZHeogDfYe0kZb7ZZqbRZq4Z40Bg2WIQQZfgjRrHGDv2h4wf/UNKzWO0y/uZu/YfsTD5U9RHp8BC4jzMIbvBaG+tzKjCXKTnKMB3kSR1FloxM/UWM82Y1B0jC/NuI1iGTv9l3ir/C4yUJBpjcc8bWNr7Zhb3vIm4eg1xmtJOUhyjEgZMDmRhXg0V5iJFpwDfpVJ3Flsxs402Zxtt4jQL81IYbBjJErTPMnTmrxk8/SWGzjxAqXkCgMbQ7SzueRNLe9/M0thria2ct8yNapS1zMeqJSoKc5FCUoAXgLuz3E6YbbY5U2/RShzwLMxtXb+5O5XFbzN0+ksMnnmAgZm/IfAWaTDA0sTfZTFvnddrN3e6WapRmLXMKwpzkSJRgBeMu1OPs37z0/VWPvGVEeYjWtb3m1u8yODM1zqBXll+DoBW7UYW976ZhT1vZn709TSDQcCpRRF7B0qMVUprpsYVkd1HAV5g2XjwlPlmzGyzzWIrIfGsdW6WBXq4roVeWn6WodMPZIE+8zWCZAm3EstjP8rC3jcxN/5GFgZuBzMGopDhSshAFFIthee9EUlEtp8CvIes3KlZj1MWmm0WWnE2tW22lSjI+s9XWumWNqnN/D+GznyJodMPUF3MZv1tV17G4p43sTD6YywN3ka9dhCPRnCcchgyUAoZKoXUopBKFKjbRWSHKMB7XJI69ThhqR0z34zP20qPGscZPPNXDJ3+EkNn/oownu38nnblAM3BW2kO3MrywK3UawdpDN5Ku/wyyJeLGyxn4V6LQir5xVYFu8jVowDvM+da6QkLzZj5VtzpR1/TSielvPwslaWnKS9+h8rS09nzpacJk4XO70uiEZoDB2kMHqReu5X6wK00Bm+lWb2RMCrnrfWIWimkGgZUou7j20Xk0mk62T5jZlSjkGoUMl7NZjuM81b68qpWeuqwXL4ZyrcQTtxFGGTT5AZA1HyJytJ3KC89nT8+w/DZrzDR/FTnc9xKNAdupjFwkPrArcwMHKQ5cBuNgR8gqoxSzbteqlFAKQwp5RdhS5vcwCQiF08B3keiwBguRwyXI/YPrm2lN9rZYz1OOlPaWriPhZF9+MjrCSzrggkDI4znqSw/s6a1Xlv8DqOns6lyV8SlCdrl/bTL+2iX99Es72exvJ+4so9WaT9e3Y9VX0ZU20u1FFEJs2AvBQGlwNQ1I3IBCvA+trqVTvVcubsTu9NOUlqJ00oSluOURjuhkaQ0GGR54A4YuAOf9KzFbkbkbSr156kuP0Nl6TtEjWNErVNEzZNU579J1HyJIG1sqEdqJeLyZCfsl8r7ifPQT6svI6i9jGDgAKWBA5Qq2aLSYZCdTCIzAkNBL31JAS4bmBklM0pBwEAJoLRme5I6rTSllaS04pRGnFBPUuqxMVc9yFz1IDZxFwCOYxhm2QKsYbJAuTVNqX2SUvMlSq1TnZCPmieptE4wuPAIUWsaI91QtyQcIi6NE0cTNEvjLJXGSaIx0vIEXp6A8gRWmSCo7CGoTBBU9xJWJwjDShb4XYZcihSVAlwuWRgYtSAbhUJl7bY0H7PeTrMWfJymxCm005R24sTpGO3SKHW/hTjNLqCvj1IH8JhS+yzl1knK7WlKrZOUWqeywG+fJWzPELVnqCweJWzPELZnugb+iiQcIo7GaJXGiaNxkvIEXhpfFfpjBNEAFlZh9WNQwcIqFg1AVMXCAYKwShCWscAI8pOTob8CZPspwGVLBSvdMhexr7uTOCTuJKmT5o+JezY5VzpEO72OOHGW05Q4zbp2suDPWvbnfllKkCwQtWcJ22eI4llKcRbyUTybhX48m71uz1Be+nbnJGAeX/JxOgFpUCUNq3hQJQ2qeFAhDWt4UMXDKqx5rEFYg7CKRdlzC6sQDuSvq1lZvi1YOYFENSysEYQ1LBogCEOdLKRDAS47xsyIDCIMLuFufncn9ay1n3ge/A5pOkziBzongXbqJGlKI81ODHF+gohTZ2XwrLkTpAuE7TmCtNH5saSZPa68XtmWNAm8TpA2CZJG9ugNLFn13rRB0F7A0ulzrzvb65d1wliRWkQa1EiDCr76J6xCUM4fK9kJIf/rgbCChavLanlZFes85s+DCLMIgggsXPUTQbDq+ept3fbdsD0CnXS23BUFuJm9FfhPZP/9/ru7f3BLaiVyHmZGaBBi63rnL166JvhHSPwa3LM++9Szbhx37zymnZNG9hdD7I4758rJ9lkpc4dk1Xs9/53Zh8cEaYMwbWBpfjJI6/mJIwv8MG0QJHUsbeb71LOTx+qTTNrC0gaWNgnSJpa2CNoNzOc727PyZv4ZTQJvbsVXcFk8D3e3CKyEd4I9xINS/jw/eeSv3c4975wIglJ2krEQLMhODBYCwaqy/IeNz22z7flrszD7zCDKTmhBedXnl1bVY/3r0ob6d8qDCCr7IKpt6b/pZQe4mYXAh4C3AEeBb5rZF9z921tVOZGrpTNyBi6p9X8lVk4Iqa9+vnKSyMN+ZT/n3HPWnkRih9TTzkkhu2aw8t6Vz8pORtm27ARD/hmkLUgbkDYJkiak2Y+lTUhj8AT37NHSJHv0GEggTbDO6zTflr/2NBtGmr82Vj33BDzOnqf548pneLuzz9rnMZa2sSTBvNl5z+ofAPMUSPLHNH/0rD6kXR6983pl//NdP9kqy6/7nwy8/Ke39HdeSQv8NcB33f05ADP7FPA2QAEu0oVZ1mufzRNWvO6E1Xdtr5x0Vp6z6mThq/bBfd3rC+3f2bJme+dEha/73LW/49y7N69vXq21nwvgKZ5mJy9LY1KPwduQxqRJjKct8DHW/gwAAARISURBVBhPY0jbuLchTfC0DWn2HG/nJ6H8hJW2Oyeq0aFXMHC+f+DLcCUBfi3w4qrXR4EfWb+Tmd0D3ANwww03XMHHichOWn3hdOM5qHgnpF4QXMF7u31jGyZWcfd73X3K3acmJyev4ONERGS1Kwnwo8D1q15fBxy/suqIiMjFupIA/yZw0MxuMrMy8PPAF7amWiIiciGX3Qfu7rGZvQf4C7Lr+B9z9ye3rGYiInJeVzQO3N2/CHxxi+oiIiKX4Eq6UEREZAcpwEVECkoBLiJSUNu6JqaZTQPf24aP2guc3obP2W69elzQu8em4yqe3XhsL3f3DTfSbGuAbxczO9JtAdCi69Xjgt49Nh1X8RTp2NSFIiJSUApwEZGC6tUAv3enK3CV9OpxQe8em46reApzbD3ZBy4i0g96tQUuItLzFOAiIgXVcwFuZi+Y2eNm9oiZHdnp+lwuM/uYmZ0ysydWlU2Y2f1m9kz+OL6TdbwcmxzXB8zsWP6dPWJmd+1kHS+XmV1vZl82s6fM7Ekze29eXujv7TzHVejvzcyqZva3ZvZofly/npffZGYP5t/Xn+Szre5KPdcHbmYvAFPuvtsG4l8SM/t7wCLwh+7+qrzst4Cz7v5BM3s/MO7u/2on63mpNjmuDwCL7v7bO1m3K2VmB4AD7v6wmQ0DDwFvB95Ngb+38xzXP6TA35tlSwwNuvuimZWArwPvBf4F8Dl3/5SZ/TfgUXf/8E7WdTM91wLvFe7+VeDsuuK3Afflz+8j+09UKJscV09w9xPu/nD+fAF4imzpwUJ/b+c5rkLzzGL+spT/OPBG4DN5+a7+vnoxwB34SzN7KF+Ps5fsd/cTkP2nAvbtcH220nvM7LG8i6VQXQzdmNmNwB3Ag/TQ97buuKDg35uZhWb2CHAKuB94Fph1z5e8z1Ye27Unq14M8Ne5+53ATwG/nP/JLrvbh4FbgEPACeB3drY6V8bMhoDPAu9z9/mdrs9W6XJchf/e3D1x90NkS0K+BnhFt922t1YXr+cC3N2P54+ngD8j+1J6xcm8P3KlX/LUDtdnS7j7yfw/Ugp8hAJ/Z3lf6meBj7v75/Liwn9v3Y6rl743d58F/hp4LTBmZiuL3ezqtX57KsDNbDC/yIKZDQI/CTxx/ncVyheAu/PndwOf38G6bJmVcMv9DAX9zvKLYh8FnnL33121qdDf22bHVfTvzcwmzWwsf14D3kzWv/9l4Gfz3Xb199VTo1DM7GayVjdky8V9wt1/YwerdNnM7JPAT5BNbXkS+HfA/wA+DdwAfB94h7sX6oLgJsf1E2R/hjvwAvBLK33GRWJmrwe+BjwOpHnxr5H1Fxf2ezvPcb2TAn9vZvbDZBcpQ7LG7Kfd/d/nOfIpYAL4FvAL7t7cuZpurqcCXESkn/RUF4qISD9RgIuIFJQCXESkoBTgIiIFpQAXESkoBbiISEEpwEVECur/A6dTH4kC2jr5AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(num_thetas, ee_mean, color = 'orange')\n",
    "plt.fill_between(num_thetas, \n",
    "                 np.array(ee_mean) + np.array(ee_std), \n",
    "                 np.array(ee_mean) - np.array(ee_std), \n",
    "                 color='lightblue', alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-29T01:16:53.380568Z",
     "start_time": "2020-08-29T01:16:53.327844Z"
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Test Linear Layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T23:08:27.316413Z",
     "start_time": "2020-08-26T23:08:27.310451Z"
    }
   },
   "outputs": [],
   "source": [
    "batch_size = 2\n",
    "num_part = 10\n",
    "feat_dim = 2\n",
    "rotate_angle = np.pi/7\n",
    "model = EquiLinear(feat_dim, 16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T23:08:27.550565Z",
     "start_time": "2020-08-26T23:08:27.540975Z"
    }
   },
   "outputs": [],
   "source": [
    "torch.manual_seed(2020)  #Testable\n",
    "\n",
    "\n",
    "field = torch.rand(batch_size, num_part, 2)\n",
    "\n",
    "center = torch.rand(batch_size, 3, 2)\n",
    "field_feat = torch.rand(batch_size, num_part, feat_dim, 2)\n",
    "field_mask = torch.ones(batch_size,num_part,1)\n",
    "unrotated_result = model(field_feat)\n",
    "# rotated_result = rotate_field(rotate_angle, center, unrotated_result)[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T23:08:27.791187Z",
     "start_time": "2020-08-26T23:08:27.779979Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(6.0482e-07, grad_fn=<NormBackward0>)"
      ]
     },
     "execution_count": 144,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rotated_field, rotated_feat = rotate_field(rotate_angle, field, field_feat)\n",
    "rotated_center = rotate_field(rotate_angle, center)\n",
    "result_rot_field = model(rotated_feat)\n",
    "unrot_result_rot_field = rotate_field(-rotate_angle, field, result_rot_field)[1]\n",
    "torch.norm(unrot_result_rot_field - unrotated_result)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Mesh Grid Idea"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "f_i w(x_i-x) \n",
    "\n",
    "Lambda(x_i - x) --> $(u,v) \\in [-1,1]\\times[-1,1]$\n",
    "\n",
    "w(x_i-x) = K(u,v) \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "kernel = torch.rand([3,3])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "interpolate_kernel(kernel,(0,0)) = 0.66\n",
    "interpolate_kernel(kernel,(-1,-1)) = 0.58\n",
    "interpolate_kernel(kernel,(0.5,1)) = 0.7\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "metadata": {},
   "outputs": [],
   "source": [
    "x = torch.tensor([1, 2, 3])\n",
    "y = torch.tensor([4, 5, 6])\n",
    "grid_x, grid_y = torch.meshgrid(x, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.7898, 0.5141, 0.8525],\n",
       "          [0.5273, 0.0228, 0.8944],\n",
       "          [0.1633, 0.8798, 0.7698]]]])"
      ]
     },
     "execution_count": 201,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kernel = torch.rand([3,3])\n",
    "kernel = kernel.unsqueeze(0).unsqueeze(0)\n",
    "kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 214,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.]]]])"
      ]
     },
     "execution_count": 214,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "grid = torch.tensor([0.0,-1.5]).unsqueeze(0).unsqueeze(0).unsqueeze(0)\n",
    "F.grid_sample(kernel,grid,padding_mode='zeros',mode='bilinear')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.1151, 0.8780, 0.0671],\n",
       "          [0.5173, 0.8126, 0.3861],\n",
       "          [0.4992, 0.5970, 0.0498]]]])"
      ]
     },
     "execution_count": 199,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kernel"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Check the mapping"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T06:24:56.714675Z",
     "start_time": "2020-06-09T06:24:56.573947Z"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T06:24:58.002357Z",
     "start_time": "2020-06-09T06:24:57.995620Z"
    }
   },
   "outputs": [],
   "source": [
    "rns = np.random.RandomState(202)\n",
    "r = rns.rand(10000)\n",
    "theta = rns.rand(10000) * 2 * np.pi\n",
    "x = r * np.cos(theta)\n",
    "y = r * np.sin(theta)\n",
    "xy = np.concatenate([x[:,np.newaxis], y[:,np.newaxis]], -1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T05:40:09.379015Z",
     "start_time": "2020-06-09T05:40:09.202466Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7efc49bfe630>"
      ]
     },
     "execution_count": 157,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(x, y, color='lightblue', alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T17:51:44.276347Z",
     "start_time": "2020-06-09T17:51:44.109614Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f8c91129b70>"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def stretch(theta):\n",
    "        return(1.0 + 0.414 * np.sin(2 * theta) ** 6)\n",
    "    \n",
    "r = np.sqrt(np.sum(xy ** 2, -1))\n",
    "theta = np.arctan2(xy[:,1], xy[:,0])\n",
    "# Stretch Radius\n",
    "r = r * stretch(theta)\n",
    "# Convert to Rectangular\n",
    "x = (r * np.cos(theta))[:,np.newaxis]\n",
    "y = (r * np.sin(theta))[:,np.newaxis]\n",
    "plt.scatter(x, y, color='lightblue', alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T17:50:46.343869Z",
     "start_time": "2020-06-09T17:50:46.295588Z"
    }
   },
   "outputs": [],
   "source": [
    "np.arctan2?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T06:33:39.457406Z",
     "start_time": "2020-06-09T06:33:39.444838Z"
    }
   },
   "outputs": [],
   "source": [
    "def map_polar_sqr(x, y):\n",
    "    r = np.linalg.norm([x, y])\n",
    "    if x == y == 0:\n",
    "        x_out = 0\n",
    "        y_out = 0\n",
    "    elif np.abs(y) <= np.abs(x):\n",
    "        x_out = np.sign(x) * r\n",
    "        y_out = 4 / np.pi * np.sign(x) * r * np.arctan(y / x)\n",
    "    else:\n",
    "        x_out = 4 / np.pi * np.sign(y) * r * np.arctan(x / y)\n",
    "        y_out = np.sign(y) * r\n",
    "    \n",
    "    return x_out, y_out\n",
    "\n",
    "def map_polar_sqr(x, y):\n",
    "\n",
    "    r = np.sqrt(x ** 2 + y ** 2)\n",
    "    \n",
    "    cond1 = (x == 0) & (y == 0)\n",
    "    cond2 = np.abs(y) <= np.abs(x)\n",
    "    cond3 = ~(cond1 | cond2)\n",
    "    \n",
    "    x_out = (cond1 * 0 + \n",
    "             cond2 * np.sign(x) * r + \n",
    "             cond3 * 4 / np.pi * np.sign(y) * r * np.arctan(x / y))\n",
    "    y_out = (cond1 * 0 + \n",
    "             cond2 * 4 / np.pi * np.sign(x) * r * np.arctan(y / x) + \n",
    "             cond3 * np.sign(y) * r)\n",
    "    return x_out, y_out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T06:29:44.309376Z",
     "start_time": "2020-06-09T06:29:44.298170Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000,)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "r = np.sqrt(x ** 2 + y ** 2)\n",
    "cond1 = (x == 0) & (y == 0)\n",
    "cond2 = np.abs(y) <= np.abs(x)\n",
    "cond3 = ~(cond1 & cond2)\n",
    "\n",
    "x_out = (cond1 * 0 + \n",
    "         cond2 * np.sign(x) * r + \n",
    "         cond3 * 4 / np.pi * np.sign(y) * r * np.arctan(x / y))\n",
    "# y_out = (cond1 * 0 + \n",
    "#          cond2 * 4 / np.pi * np.sign(xn) * r * np.arctan(yn / xn) + \n",
    "#          cond3 * np.sign(yn) * r)\n",
    "r.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T05:43:04.533349Z",
     "start_time": "2020-06-09T05:43:04.188815Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7efc48169a20>"
      ]
     },
     "execution_count": 165,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "xy_new = np.array([list(map_polar_sqr(v[0], v[1])) for v in xy])\n",
    "plt.scatter(xy_new[:,0], xy_new[:,1], color='lightblue', alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T06:33:44.713607Z",
     "start_time": "2020-06-09T06:33:44.497594Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f8c90af6550>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_new, y_new = map_polar_sqr(x, y)\n",
    "plt.scatter(x_new, y_new, color='lightblue', alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T05:51:54.916061Z",
     "start_time": "2020-06-09T05:51:54.903985Z"
    }
   },
   "outputs": [],
   "source": [
    "e = {('22', 24, 25): {'mean': 10.837532043457031, 'mse': 117.45210266113281, 'var': 0.0, 'min': 10.837532043457031, 'max': 10.837532043457031, 'median': 10.837532043457031, 'num_particles': 1}, ('22', 25, 26): {'mean': 11.433690071105957, 'mse': 130.72926330566406, 'var': 0.0, 'min': 11.433690071105957, 'max': 11.433690071105957, 'median': 11.433690071105957, 'num_particles': 1}, ('22', 26, 27): {'mean': 11.850491523742676, 'mse': 140.43414306640625, 'var': 0.0, 'min': 11.850491523742676, 'max': 11.850491523742676, 'median': 11.850491523742676, 'num_particles': 1}, ('22', 27, 28): {'mean': 12.232429504394531, 'mse': 149.63232421875, 'var': 0.0, 'min': 12.232429504394531, 'max': 12.232429504394531, 'median': 12.232429504394531, 'num_particles': 1}, ('22', 28, 29): {'mean': 12.717761993408203, 'mse': 161.74147033691406, 'var': 0.0, 'min': 12.717761993408203, 'max': 12.717761993408203, 'median': 12.717761993408203, 'num_particles': 1}}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T05:55:51.001338Z",
     "start_time": "2020-06-09T05:55:50.994819Z"
    }
   },
   "outputs": [],
   "source": [
    "result = {}\n",
    "de = {}\n",
    "\n",
    "for k, v in e.items():\n",
    "    de[k[0]] = de.get(k[0], [])\n",
    "    de[k[0]].append(v['mean'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-06-09T05:55:52.817050Z",
     "start_time": "2020-06-09T05:55:52.800334Z"
    }
   },
   "outputs": [
    {
     "ename": "IndexError",
     "evalue": "list index out of range",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-179-8361eacdce64>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mde\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitems\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m     \u001b[0made\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 7\u001b[0;31m     \u001b[0mde1s\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m9\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      8\u001b[0m     \u001b[0mde2s\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m19\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m     \u001b[0mde3s\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mIndexError\u001b[0m: list index out of range"
     ]
    }
   ],
   "source": [
    "\n",
    "ade = []\n",
    "de1s = []\n",
    "de2s = []\n",
    "de3s = []\n",
    "for k, v in de.items():\n",
    "    ade.append(np.mean(v))\n",
    "    de1s.append(v[9])\n",
    "    de2s.append(v[19])\n",
    "    de3s.append(v[-1])\n",
    "\n",
    "result['ADE'] = np.mean(ade)\n",
    "result['ADE_std'] = np.std(ade)\n",
    "result['DE@1s'] = np.mean(de1s)\n",
    "result['DE@1s_std'] = np.std(de1s)\n",
    "result['DE@2s'] = np.mean(de2s)\n",
    "result['DE@2s_std'] = np.std(de2s)\n",
    "result['DE@3s'] = np.mean(de3s)\n",
    "result['DE@3s_std'] = np.std(de3s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-13T19:59:47.708019Z",
     "start_time": "2020-08-13T19:59:47.705301Z"
    }
   },
   "outputs": [],
   "source": [
    "t = torch.tensor([[1,1],[2,2]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-13T20:00:40.749561Z",
     "start_time": "2020-08-13T20:00:40.745299Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([3, 3])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.sum(t, dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test Equivaraint Activation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:33:55.154089Z",
     "start_time": "2020-08-26T21:33:55.151597Z"
    }
   },
   "outputs": [],
   "source": [
    "# B x N x C x 2\n",
    "output = torch.rand(1,1,1,2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:37:01.144238Z",
     "start_time": "2020-08-26T21:37:01.140183Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.8495, 0.2981]]]])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:38:52.444222Z",
     "start_time": "2020-08-26T21:38:52.430526Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[-0.2981,  0.8495]]]])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.einsum('ij,abcj->abci',EquiCtsConv2d.RotMat(torch.tensor(math.pi/2)),output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:35:27.814207Z",
     "start_time": "2020-08-26T21:35:27.809979Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-4.3711e-08, -1.0000e+00],\n",
       "        [ 1.0000e+00, -4.3711e-08]])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "EquiCtsConv2d.RotMat(torch.tensor(math.pi/2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T22:08:58.101437Z",
     "start_time": "2020-08-26T22:08:58.098841Z"
    }
   },
   "outputs": [],
   "source": [
    "eps = 1e-6\n",
    "sigma = torch.nn.ReLU()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T22:08:59.833538Z",
     "start_time": "2020-08-26T22:08:59.828375Z"
    }
   },
   "outputs": [],
   "source": [
    "def VecSigma(sigma,outputs):\n",
    "    mags = torch.sum(output**2,axis=-1) + eps\n",
    "    return outputs/mags * (sigma(mags - 0.2 ))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:45:05.229532Z",
     "start_time": "2020-08-26T21:45:05.223887Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.6399, 0.2246]]]])"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "VecSigma(sigma,output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:55:50.274372Z",
     "start_time": "2020-08-26T21:55:50.271352Z"
    }
   },
   "outputs": [],
   "source": [
    "xs = torch.tensor(np.arange(0.,1.,0.01))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T22:09:05.502913Z",
     "start_time": "2020-08-26T22:09:05.493940Z"
    }
   },
   "outputs": [],
   "source": [
    "def f(x):\n",
    "    return sigma(x - 0.2)\n",
    "def g(x):\n",
    "    return torch.nn.Softplus(beta = 1)(x)\n",
    "ys = torch.stack([f(x) for x in xs])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T22:09:06.197218Z",
     "start_time": "2020-08-26T22:09:05.989061Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6,6))\n",
    "plt.plot(xs,ys)\n",
    "plt.xlim(-2,2)\n",
    "plt.ylim(-2,2)\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-08-26T21:57:44.069459Z",
     "start_time": "2020-08-26T21:57:44.065706Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Softplus(beta=1, threshold=20)"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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.8.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
