{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Fully Steerable 3D Spherical Neurons"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "SEED = 239\n",
    "\n",
    "import numpy as np\n",
    "np.random.seed(SEED)\n",
    "np.set_printoptions(precision=4)\n",
    "\n",
    "import torch\n",
    "torch.manual_seed(SEED)\n",
    "if torch.cuda.is_available():\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F \n",
    "import torch.optim as optim\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.collections as mcol\n",
    "import matplotlib.transforms as mtransforms\n",
    "\n",
    "from matplotlib import cm\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "from scipy.spatial.transform import Rotation as R\n",
    "from scipy.special import softmax\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "from models import PointCMLP, SteerableModel\n",
    "\n",
    "from utils import (get_tetris_data, plot_shapes, score, build_mlgp, \n",
    "                   construct_filter_banks, unembed_points, \n",
    "                   transform_parameters, build_steerable_model,\n",
    "                   random_axis_angle, torch_rotation_matrix, entropy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "('1.8.1+cu102', device(type='cuda'))"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "torch.__version__, device"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Creating a steerable spherical classifer\n",
    "in the following steps:\n",
    "\n",
    "**Step 1**. Train the ancestor MLGP.\n",
    "\n",
    "**Step 2**. Transform the hidden unit parameters into filter banks.\n",
    "\n",
    "**Step 3**. Fix the learned parameters and add the interpolation coefficients $v^k$ as learnable parameters to fulfill the steerability constraint $\\rightarrow$ Steerable spherical classifier."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Step 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Create the 3D Tetris dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "chiral_shape_1 \n",
      " tensor([[0., 0., 0.],\n",
      "        [0., 0., 1.],\n",
      "        [1., 0., 0.],\n",
      "        [1., 1., 0.]]) \n",
      "\n",
      "\n",
      "chiral_shape_2 \n",
      " tensor([[ 0.,  0.,  0.],\n",
      "        [ 0.,  0.,  1.],\n",
      "        [ 1.,  0.,  0.],\n",
      "        [ 1., -1.,  0.]]) \n",
      "\n",
      "\n",
      "square \n",
      " tensor([[0., 0., 0.],\n",
      "        [1., 0., 0.],\n",
      "        [0., 1., 0.],\n",
      "        [1., 1., 0.]]) \n",
      "\n",
      "\n",
      "line \n",
      " tensor([[0., 0., 0.],\n",
      "        [0., 0., 1.],\n",
      "        [0., 0., 2.],\n",
      "        [0., 0., 3.]]) \n",
      "\n",
      "\n",
      "corner \n",
      " tensor([[0., 0., 0.],\n",
      "        [0., 0., 1.],\n",
      "        [0., 1., 0.],\n",
      "        [1., 0., 0.]]) \n",
      "\n",
      "\n",
      "L \n",
      " tensor([[0., 0., 0.],\n",
      "        [0., 0., 1.],\n",
      "        [0., 0., 2.],\n",
      "        [0., 1., 0.]]) \n",
      "\n",
      "\n",
      "T \n",
      " tensor([[0., 0., 0.],\n",
      "        [0., 0., 1.],\n",
      "        [0., 0., 2.],\n",
      "        [0., 1., 1.]]) \n",
      "\n",
      "\n",
      "zigzag \n",
      " tensor([[0., 0., 0.],\n",
      "        [1., 0., 0.],\n",
      "        [1., 1., 0.],\n",
      "        [2., 1., 0.]]) \n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "Xtrain, Ytrain, shape_names = get_tetris_data()\n",
    "\n",
    "for shape, name in zip(Xtrain, shape_names):\n",
    "    print(name, '\\n', shape, '\\n\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_shapes(Xtrain, shape_names, offset=1.5)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Train the MLGP on the shapes in the canonical orientation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_GEOMETRIC_NEURONS = 5\n",
    "OUTPUT_DIM = len(set(Ytrain.numpy()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "model: MLGP\n",
      "PointCMLP(\n",
      "  (hidden_layers): ModuleList(\n",
      "    (0): Linear(in_features=20, out_features=5, bias=False)\n",
      "  )\n",
      "  (out_layer): Linear(in_features=7, out_features=8, bias=False)\n",
      ")\n",
      "total number of trainable parameters: 156\n",
      "\n",
      "epoch: 0, loss: 2.064,  acc:  0.375\n",
      "epoch: 500, loss: 0.318,  acc:  1.000\n",
      "epoch: 1000, loss: 0.054,  acc:  1.000\n",
      "epoch: 1500, loss: 0.019,  acc:  1.000\n",
      "epoch: 1999, loss: 0.009,  acc:  1.000\n"
     ]
    }
   ],
   "source": [
    "# set the seed here:\n",
    "torch.manual_seed(SEED)\n",
    "\n",
    "# instantiate the model:\n",
    "model = build_mlgp(input_shape=Xtrain.shape[1:], output_dim=OUTPUT_DIM, hidden_layer_sizes=[N_GEOMETRIC_NEURONS], bias=False)\n",
    "\n",
    "print(model)\n",
    "print('total number of trainable parameters:', sum([np.prod(p.size()) for p in filter(lambda p: p.requires_grad, model.parameters())]))\n",
    "print()\n",
    "\n",
    "model = model.to(device)\n",
    "Xtrain, Ytrain = Xtrain.float().to(device), Ytrain.to(device)\n",
    "\n",
    "# define the loss and optimizer:\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model.parameters(), lr=1e-3)\n",
    "\n",
    "epochs = 2000\n",
    "\n",
    "# train the model:\n",
    "for i in range(epochs): \n",
    "        y_pred = model(Xtrain)\n",
    "        loss = criterion(y_pred, Ytrain)\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        acc = score(y_pred.detach(), Ytrain)\n",
    "\n",
    "        if i % 500 == 0:\n",
    "            print('epoch: %d, loss: %.3f,  acc:  %.3f' % (i, loss.item(), acc))\n",
    "\n",
    "print('epoch: %d, loss: %.3f,  acc:  %.3f' % (i, loss.item(), acc))"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Step 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The main function in this step is `construct_filter_banks`:\n",
    "- takes in *non-normalized* (raw) spheres $\\tilde{S}_k \\in \\mathbb{R}^5$, i.e., parameters, extracted from the trained ancestor MLGP model;\n",
    "- computes the initial rotations $R_O^k$, i.e., from the original sphere centers $c_k$ to (1,1,1);\n",
    "- computes the tetrahedron rotations $R_{Ti}$, i.e., rotations transforming (1, 1, 1) into the other three vertices;\n",
    "- constructs the filter banks for each sphere as discussed in Section 4.1.2 in the paper\n",
    "\n",
    "\\begin{equation*}\n",
    "\tB(\\tilde{S}_k) = \n",
    "\t\\begin{bmatrix}\n",
    "\t\tR_O^{k\\top} R_{T0} R_O^{k} \\tilde{S}_k \\\\\n",
    "\t\tR_O^{k\\top} R_{T1} R_O^{k} \\tilde{S}_k \\\\\n",
    "\t\tR_O^{k\\top} R_{T2} R_O^{k} \\tilde{S}_k \\\\ \n",
    "\t\tR_O^{k\\top} R_{T3} R_O^{k} \\tilde{S}_k \\\\\n",
    "\t\\end{bmatrix} ~;\n",
    "\\end{equation*}\n",
    "\n",
    "- returns an array of $R_O^k$ (optionally) and an array of the constructed $B(\\tilde{S}_k)$.\n",
    "\n",
    "To demonstrate how it works, we first extract the ancestor model hidden layer (i.e., geometric neurons) spheres, and then take one of them to form a filter bank:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hidden_spheres_numpy.shape: (5, 4, 5)\n",
      "\n",
      "S_tilde_k =  [-0.6873  0.6743 -0.2568 -0.4767 -0.417 ]\n",
      "\n",
      "R_O^k =\n",
      " [[[ 0.408  -0.6725 -0.6174]\n",
      "  [ 0.9052  0.2101  0.3693]\n",
      "  [-0.1187 -0.7096  0.6945]]] \n",
      "\n",
      "B(S_tilde_k) =\n",
      " [[-0.6873  0.6743 -0.2568 -0.4767 -0.417 ]\n",
      " [ 0.2178  0.0995  0.9673 -0.4767 -0.417 ]\n",
      " [-0.3543 -0.9161 -0.1682 -0.4767 -0.417 ]\n",
      " [ 0.8238  0.1422 -0.5423 -0.4767 -0.417 ]]\n"
     ]
    }
   ],
   "source": [
    "# extract the spheres from the ancestor model:\n",
    "original_state_dict = model.state_dict()\n",
    "\n",
    "# get the geometric neuron spheres:\n",
    "hidden_name = 'hidden_layers.0.weight' \n",
    "hidden_spheres = original_state_dict[hidden_name]            # (n_geometric_neurons x N_points*5)\n",
    "\n",
    "# each sphere is a parameter vector of length 5;\n",
    "# each geometric neuron contains a number of spheres corresponding to the number of input points\n",
    "# in the point set\n",
    "\n",
    "# reshape to (n_geometric_neurons x N_points x 5):\n",
    "hidden_spheres_numpy = hidden_spheres.detach().cpu().numpy().reshape(len(hidden_spheres), -1, 5)\n",
    "print('hidden_spheres_numpy.shape:', hidden_spheres_numpy.shape) \n",
    "\n",
    "\n",
    "# e.g., select the third sphere from the second geometric neuron:\n",
    "one_sphere = hidden_spheres_numpy[1,2,:]\n",
    "print('\\nS_tilde_k = ', one_sphere)\n",
    "\n",
    "# construct a filter bank for this sphere:\n",
    "init_rotation, filter_bank = construct_filter_banks(one_sphere, return_init_rotations=True)\n",
    "print('\\nR_O^k =\\n', init_rotation, '\\n\\nB(S_tilde_k) =\\n', filter_bank)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Visualize\n",
    "\n",
    "We normalize, i.e., *unembed*, the resulting spheres to get their Euclidean $\\mathbb{R}^3$ representation.\n",
    "\n",
    "By unembedding the 5-vectors, we will get the first three elements that represent the Euclidean coordinates of the sphere center:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "the four sphere centers:\n",
      " [[ 1.6482 -1.6171  0.6159]\n",
      " [-0.5223 -0.2387 -2.3197]\n",
      " [ 0.8498  2.1969  0.4033]\n",
      " [-1.9756 -0.3411  1.3006]]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# the centers of the filter bank spheres:\n",
    "centers = unembed_points(filter_bank)\n",
    "\n",
    "print('\\nthe four sphere centers:\\n', centers)\n",
    "fig = plt.figure(1, figsize=(7,7))\n",
    "ax = fig.add_subplot(111, projection='3d')         \n",
    "ax.scatter(centers[:, 0], centers[:, 1], centers[:, 2], s=100)\n",
    "plt.title('A regular tetrahedron formed by the centers of the $B(S_k)$ spheres')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Step 2** is wrapped into the function `transform_parameters`: \n",
    "- takes in the trained ancestor MLGP model;\n",
    "\n",
    "- transforms its parameters --- uses the hidden layer spheres to create the filter banks and keeps the output (classification) layer the same;\n",
    "\n",
    "- returns the initial rotations $R_O^k$, the filter banks $B(\\tilde{S}_k)$, and the ancestor model output layer parameters."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "transformed_parameters = transform_parameters(model) # used in the experiments further down"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Step 3\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Step 3** is wrapped into the `build_steerable_model` function: \n",
    "- creates a steerable model with learnable interpolation coefficients $v^k$ according to the constraint (13) in the paper;\n",
    "\n",
    "   - since $v^k$ depends on the (possibly unknown) rotation $R_B$ applied to the input (see (12) in the paper), we will learn the parameters of this rotation instead, i.e., three axis-angle parameters, if they are unknown (as discussed in the paper in Section 5.2);\n",
    "\n",
    "- the rest of the model parameters are set to be the ones obtained in Step 2 (the filter banks and the unchanged output layer) and are fixed (**not** updated)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SteerableModel(\n",
      "  (hidden_layers): ModuleList(\n",
      "    (0): Linear(in_features=80, out_features=5, bias=False)\n",
      "  )\n",
      "  (out_layer): Linear(in_features=7, out_features=8, bias=False)\n",
      ")\n",
      "total number of trainable parameters: 3\n",
      "\n",
      "init_axis_angle:\n",
      " [-0.9549 -0.4905  1.5045]\n",
      "\n",
      "steerable_model.axis_angle:\n",
      " Parameter containing:\n",
      "tensor([-0.9549, -0.4905,  1.5045], device='cuda:0', dtype=torch.float64,\n",
      "       requires_grad=True)\n"
     ]
    }
   ],
   "source": [
    "# choose initial model parameters:\n",
    "init_axis_angle = random_axis_angle()\n",
    "\n",
    "# use the initial parameters and the transformed ancestor model parameters obtained in Step 2\n",
    "# to build a steerable spherical classifier:\n",
    "steerable_model = build_steerable_model(input_shape=Xtrain.shape[1:], \n",
    "                                        output_dim=OUTPUT_DIM,\n",
    "                                        hidden_layer_sizes=[N_GEOMETRIC_NEURONS],\n",
    "                                        init_axis_angle=init_axis_angle,\n",
    "                                        transformed_parameters=transformed_parameters,\n",
    "                                        print_hidden_layer_output=False).to(device)\n",
    "print(steerable_model)\n",
    "print('total number of trainable parameters:', \\\n",
    "      sum([np.prod(p.size()) for p in filter(lambda p: p.requires_grad, steerable_model.parameters())]))\n",
    "\n",
    "print('\\ninit_axis_angle:\\n', init_axis_angle)\n",
    "print('\\nsteerable_model.axis_angle:\\n', steerable_model.axis_angle)"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Paper experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Get the ancestor MLGP activations\n",
    "(used in the experiments further down)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "activation = {}\n",
    "def get_activation(name):\n",
    "    def hook(model, input, output):\n",
    "        activation[name] = output.detach()\n",
    "    return hook\n",
    "\n",
    "model.hidden_layers[0].register_forward_hook(get_activation('hidden_layer'))\n",
    "output = model(Xtrain)\n",
    "\n",
    "# the ground truth hidden activations -- the ancestor MLGP hidden layer output:\n",
    "gt_hidden_activations = activation['hidden_layer'].detach().cpu().numpy()\n",
    "\n",
    "# the ground truth output activations -- the ancestor MLGP model output: \n",
    "gt_outs = output.detach().cpu().numpy()\n",
    "\n",
    "# gt_hidden_activations, gt_outs"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The known rotation experiment (Section 5.3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "distortion: 0.0\n",
      "\n",
      "ancestor_acc:     0.4728 +/- 0.3403\n",
      "acc:              1.0000 +/- 0.0000\n",
      "\n",
      "ancestor L1 dist: 8.1021 +/- 4.1254\n",
      "L1 dist:          0.0000 +/- 0.0000\n",
      "\n",
      "\n",
      "\n",
      "distortion: 0.05\n",
      "\n",
      "ancestor_acc:     0.4761 +/- 0.3424\n",
      "acc:              1.0000 +/- 0.0000\n",
      "\n",
      "ancestor L1 dist: 8.0639 +/- 4.0796\n",
      "L1 dist:          0.3319 +/- 0.0472\n",
      "\n",
      "\n",
      "\n",
      "distortion: 0.1\n",
      "\n",
      "ancestor_acc:     0.4928 +/- 0.3501\n",
      "acc:              1.0000 +/- 0.0000\n",
      "\n",
      "ancestor L1 dist: 7.9400 +/- 3.9921\n",
      "L1 dist:          0.6625 +/- 0.0953\n",
      "\n",
      "\n",
      "\n",
      "distortion: 0.2\n",
      "\n",
      "ancestor_acc:     0.4595 +/- 0.3439\n",
      "acc:              0.9999 +/- 0.0040\n",
      "\n",
      "ancestor L1 dist: 8.3054 +/- 3.8510\n",
      "L1 dist:          1.3219 +/- 0.1936\n",
      "\n",
      "\n",
      "\n",
      "distortion: 0.3\n",
      "\n",
      "ancestor_acc:     0.4756 +/- 0.3439\n",
      "acc:              0.9971 +/- 0.0187\n",
      "\n",
      "ancestor L1 dist: 8.2549 +/- 3.7809\n",
      "L1 dist:          2.0030 +/- 0.3098\n",
      "\n",
      "\n",
      "\n",
      "distortion: 0.5\n",
      "\n",
      "ancestor_acc:     0.4445 +/- 0.3193\n",
      "acc:              0.9491 +/- 0.0772\n",
      "\n",
      "ancestor L1 dist: 8.6461 +/- 3.4424\n",
      "L1 dist:          3.3332 +/- 0.4837\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "\n",
    "n_trials = 1000\n",
    "\n",
    "# the parameter of additive uniform noise to apply to the rotated shapes:\n",
    "distortions = [0.0, 0.05, 0.1, 0.2, 0.3, 0.5]\n",
    "\n",
    "\n",
    "init_axis_angles = []\n",
    "accs = dict()          # classification accuracies for the perturbed rotated shapes\n",
    "dists = dict()         # L1 distances to the ground truth hidden activations\n",
    "\n",
    "# the same for the ancestor:\n",
    "ancestor_accs = dict() \n",
    "ancestor_dists = dict()\n",
    "\n",
    "\n",
    "for distortion in distortions:\n",
    "    accs[distortion] = []  \n",
    "    dists[distortion] = [] \n",
    "    ancestor_accs[distortion] = [] \n",
    "    ancestor_dists[distortion] = [] \n",
    "    \n",
    "    print('\\ndistortion:', distortion)\n",
    "    \n",
    "    for n in range(n_trials):       \n",
    "        # construct a random ground truth rotation:\n",
    "        init_axis_angle = random_axis_angle()\n",
    "        init_axis_angles.append(init_axis_angle)\n",
    "        gt_rotation = torch_rotation_matrix(init_axis_angle).to(device).float()\n",
    "\n",
    "        # rotate the shapes with the ground truth:\n",
    "        test_data = Xtrain.reshape(-1, 3) @ gt_rotation.T\n",
    "        test_data = test_data.reshape(Xtrain.shape)\n",
    "        test_label = Ytrain\n",
    "\n",
    "        # add uniform noise to the transformed shapes:\n",
    "        noise = distortion * (2 * torch.rand(test_data.shape).to(device) - 1)\n",
    "        test_data += noise\n",
    "\n",
    "        # construct the steerable model with the initial axis-angle parameters:\n",
    "        steerable_model = build_steerable_model(input_shape=test_data.shape[1:], \n",
    "                                                output_dim=OUTPUT_DIM,\n",
    "                                                hidden_layer_sizes=[N_GEOMETRIC_NEURONS],\n",
    "                                                init_axis_angle=init_axis_angle,\n",
    "                                                transformed_parameters=transformed_parameters,\n",
    "                                                print_hidden_layer_output=False).to(device)\n",
    "\n",
    "        # get the model output:\n",
    "        output = steerable_model(test_data)\n",
    "        ancestor_output = model(test_data)\n",
    "        \n",
    "        # compute the model accuracy for the perturbed rotated shapes:\n",
    "        acc = score(output.detach(), test_label)\n",
    "        accs[distortion].append(acc)\n",
    "        \n",
    "        ancestor_acc = score(ancestor_output.detach(), test_label)\n",
    "        ancestor_accs[distortion].append(ancestor_acc)\n",
    "        \n",
    "        # compute the L1 distance between the hidden activations:\n",
    "        hidden_activations = steerable_model.hidden_layer_activations.cpu().numpy()\n",
    "        dist = np.linalg.norm(hidden_activations - gt_hidden_activations, ord=1, axis=1)\n",
    "        dist = np.mean(dist)\n",
    "        dists[distortion].append(dist)\n",
    "        \n",
    "        ancestor_hidden_activations = model.hidden_layer_activations.cpu().numpy()\n",
    "        ancestor_dist = np.linalg.norm(ancestor_hidden_activations - gt_hidden_activations, ord=1, axis=1)\n",
    "        ancestor_dist = np.mean(ancestor_dist)\n",
    "        ancestor_dists[distortion].append(ancestor_dist)\n",
    "\n",
    "        # if n % 10 == 0:\n",
    "            # print('\\nexperiment #%d/%d' % (n+1, n_trials))\n",
    "            # print('\\nadditive_uniform_noise:\\n', noise)\n",
    "            # print('\\ngt_rotation:\\n', gt_rotation)\n",
    "            # print('\\nacc:  %.3f' % acc)\n",
    "            \n",
    "    print()\n",
    "    print('ancestor_acc:     %.4f +/- %.4f' % (np.mean(ancestor_accs[distortion]), np.std(ancestor_accs[distortion])))\n",
    "    print('acc:              %.4f +/- %.4f' % (np.mean(accs[distortion]), np.std(accs[distortion])))\n",
    "    print()\n",
    "    print('ancestor L1 dist: %.4f +/- %.4f' % (np.mean(ancestor_dists[distortion]), np.std(ancestor_dists[distortion])))\n",
    "    print('L1 dist:          %.4f +/- %.4f' % (np.mean(dists[distortion]), np.std(dists[distortion])))\n",
    "    print(end='\\n\\n')"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The adaptive rotation experiment (Section 5.4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "distortion = 0 +/- 10 degrees\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [51:10<00:00,  3.07s/it]\n",
      "  0%|                                                                                                                                             | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "mean_init_acc: 0.9990, mean_final_acc: 0.9990\n",
      "\n",
      "mean_init_dist: 0.0072 +/- 0.0328, mean_final_dist: 0.0065 +/- 0.0313\n",
      "\n",
      "\n",
      "\n",
      "distortion = 5 +/- 10 degrees\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [1:04:02<00:00,  3.84s/it]\n",
      "  0%|                                                                                                                                             | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "mean_init_acc: 0.9980, mean_final_acc: 0.9990\n",
      "\n",
      "mean_init_dist: 0.0092 +/- 0.0376, mean_final_dist: 0.0066 +/- 0.0315\n",
      "\n",
      "\n",
      "\n",
      "distortion = 10 +/- 10 degrees\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [53:55<00:00,  3.24s/it]\n",
      "  0%|                                                                                                                                             | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "mean_init_acc: 0.9980, mean_final_acc: 0.9980\n",
      "\n",
      "mean_init_dist: 0.0133 +/- 0.0459, mean_final_dist: 0.0074 +/- 0.0441\n",
      "\n",
      "\n",
      "\n",
      "distortion = 15 +/- 10 degrees\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [59:23<00:00,  3.56s/it]\n",
      "  0%|                                                                                                                                             | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "mean_init_acc: 0.9920, mean_final_acc: 0.9930\n",
      "\n",
      "mean_init_dist: 0.0250 +/- 0.0808, mean_final_dist: 0.0123 +/- 0.0822\n",
      "\n",
      "\n",
      "\n",
      "distortion = 30 +/- 10 degrees\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [54:45<00:00,  3.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "mean_init_acc: 0.9360, mean_final_acc: 0.9410\n",
      "\n",
      "mean_init_dist: 0.1059 +/- 0.2049, mean_final_dist: 0.0635 +/- 0.2323\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "\n",
    "\n",
    "n_trials = 1000\n",
    "epochs = 300\n",
    "\n",
    "# print_period = 50 # for online optimization\n",
    "\n",
    "\n",
    "# distortion rotation angle parameters (in degrees): \n",
    "distortion_std = 10\n",
    "distortion_means = [0, 5, 10, 15, 30]\n",
    "\n",
    "\n",
    "all_results = dict()\n",
    "\n",
    "for distortion_mean in distortion_means:\n",
    "    print('\\n\\n\\ndistortion = %d +/- %d degrees' % (distortion_mean, distortion_std))\n",
    "    \n",
    "    gt_axis_angles = []\n",
    "    init_axis_angles = []\n",
    "    gt_labels = []\n",
    "    \n",
    "    init_outputs = []\n",
    "    init_predictions = []\n",
    "    init_losses = []\n",
    "    init_accs = []\n",
    "    init_dists = []\n",
    "\n",
    "    final_outputs = []\n",
    "    final_predictions = []\n",
    "    final_losses = []\n",
    "    final_accs = []\n",
    "    final_dists = []\n",
    "    \n",
    "    optimized_axis_angles = []\n",
    "    \n",
    "    \n",
    "    for n in tqdm(range(n_trials)):\n",
    "        \n",
    "        # 1) Randomly transform the train data:\n",
    "        gt_axis_angle = random_axis_angle()\n",
    "        gt_axis_angles.append(gt_axis_angle)\n",
    "        gt_rotation = torch_rotation_matrix(gt_axis_angle).to(device).float()\n",
    "        # print('\\ngt_rotation:\\n', gt_rotation)\n",
    "\n",
    "        # select a sample:\n",
    "        shape_label = np.random.choice(len(Xtrain))\n",
    "        # print('\\nshape_label:', shape_label)\n",
    "        gt_labels.append(shape_label)\n",
    "        test_data = Xtrain.reshape(-1, 3) @ gt_rotation.T \n",
    "        test_data = test_data.reshape(Xtrain.shape)[shape_label:shape_label+1]\n",
    "        test_label = Ytrain[shape_label:shape_label+1]   \n",
    "        \n",
    "\n",
    "        # 2) Initialize steerable model parameters with distorted ground truth axis-angle \n",
    "        # create a \"distortion\" axis-angle:\n",
    "        distortion_angle = np.radians(distortion_std)*np.random.randn() + np.radians(distortion_mean)\n",
    "        # print('\\ndistortion_angle:', np.degrees(distortion_angle))\n",
    "        distortion_axis_angle = random_axis_angle(angle=distortion_angle)\n",
    "        distortion_matrix = torch_rotation_matrix(distortion_axis_angle)\n",
    "\n",
    "        # by multiplying distortion_matrix with the gt_rotation matrix, \n",
    "        # we can control the rotation angle randomness:\n",
    "        distorted_rotation =  distortion_matrix @ gt_rotation.cpu()   \n",
    "        init_r = R.from_matrix(distorted_rotation.cpu().numpy())\n",
    "        init_axis_angle = init_r.as_rotvec()\n",
    "\n",
    "        init_axis_angles.append(init_axis_angle)\n",
    "\n",
    "        # construct the steerable model with init_axis_angle:\n",
    "        steerable_model = build_steerable_model(input_shape=test_data.shape[1:], \n",
    "                                                output_dim=OUTPUT_DIM,\n",
    "                                                hidden_layer_sizes=[N_GEOMETRIC_NEURONS],\n",
    "                                                init_axis_angle=init_axis_angle,\n",
    "                                                transformed_parameters=transformed_parameters,\n",
    "                                                print_hidden_layer_output=False).to(device)\n",
    "        \n",
    "        \n",
    "        # get initial model output, hidden_activations, acc and loss:\n",
    "        output = steerable_model(test_data)\n",
    "        init_output = output.detach().cpu().numpy()\n",
    "        init_outputs.append(init_output)\n",
    "    \n",
    "        init_dist = np.linalg.norm(softmax(init_output) - softmax(gt_outs[shape_label]), ord=1)\n",
    "        init_dists.append(init_dist)\n",
    "\n",
    "        init_acc = score(output.detach(), test_label)\n",
    "        init_accs.append(init_acc)\n",
    "        \n",
    "        init_loss = entropy(output, is_logits=True).item()\n",
    "        init_losses.append(init_loss)\n",
    "\n",
    "        # print('\\ninit_acc:  %.3f' % init_acc)\n",
    "\n",
    "        # collect the initial predictions:\n",
    "        init_prediction = torch.argmax(output.detach(), axis=1)\n",
    "        init_predictions.append(init_prediction.cpu().numpy())\n",
    "        # print('initial prediction:', init_prediction.cpu().numpy())\n",
    "        # print()\n",
    "\n",
    "\n",
    "        # 3) Otimize the entropy loss wrt the axis-angle parameters of the steerable model:\n",
    "        optimizer = optim.Adam(steerable_model.parameters(), lr=1e-2)\n",
    "\n",
    "        for i in range(epochs):          \n",
    "            # compute the entropy loss:\n",
    "            output = steerable_model(test_data)\n",
    "            loss = entropy(output, is_logits=True)\n",
    "\n",
    "            # backpropagate:\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()        \n",
    "\n",
    "            # if i % print_period == 0:\n",
    "            #    print('epoch: %d,  loss: %.3f' % (i, loss.item())) \n",
    "\n",
    "                \n",
    "        # store the final data:                \n",
    "        final_losses.append(loss.item())\n",
    "        final_output = output.detach().cpu().numpy()\n",
    "        final_outputs.append(final_output)\n",
    "        \n",
    "        final_dist = np.linalg.norm(softmax(final_output) - softmax(gt_outs[shape_label]), ord=1)\n",
    "        final_dists.append(final_dist)\n",
    "\n",
    "        final_acc = score(output.detach(), test_label)\n",
    "        final_accs.append(final_acc)\n",
    "\n",
    "        final_prediction = torch.argmax(output.detach(), axis=1)\n",
    "        final_predictions.append(final_prediction.cpu().numpy())\n",
    "        \n",
    "        optimized_axis_angle = steerable_model.axis_angle.detach().cpu().numpy()\n",
    "        optimized_axis_angles.append(optimized_axis_angle)\n",
    "\n",
    "        # print('epoch: %d,  loss: %.3f' % (i, loss.item()))  \n",
    "        # print('\\nfinal_acc: %.3f' % final_acc)\n",
    "        # print('final prediction:', final_prediction.cpu().numpy()) \n",
    "        # print('\\ngt_axis_angle:\\n', gt_axis_angle)\n",
    "        # print('\\ninit_axis_angle:\\n', init_axis_angle)\n",
    "        # print('optimized_axis_angle:\\n', optimized_axis_angle) \n",
    "        \n",
    "        \n",
    "        \n",
    "    all_results[distortion_mean] = {        \n",
    "        'gt_axis_angles': gt_axis_angles,\n",
    "        'gt_labels': gt_labels,\n",
    "\n",
    "        'init_axis_angles': init_axis_angles,\n",
    "        'init_outputs': init_outputs,\n",
    "        'init_predictions': init_predictions,\n",
    "        'init_losses': init_losses,\n",
    "        'init_accs': init_accs,\n",
    "        'init_dists': init_dists,\n",
    "        \n",
    "        'final_outputs': final_outputs,\n",
    "        'final_predictions': final_predictions,\n",
    "        'final_losses': final_losses,\n",
    "        'final_accs': final_accs,\n",
    "        'final_dists': final_dists,\n",
    "        \n",
    "        'optimized_axis_angles': optimized_axis_angles,\n",
    "    }\n",
    "    \n",
    "    \n",
    "    print('\\nmean_init_acc: %.4f, mean_final_acc: %.4f' \n",
    "          % (np.mean(all_results[distortion_mean]['init_accs']), np.mean(all_results[distortion_mean]['final_accs'])))\n",
    "    \n",
    "    print('\\nmean_init_dist: %.4f +/- %.4f, mean_final_dist: %.4f +/- %.4f'  \n",
    "          % (np.mean(all_results[distortion_mean]['init_dists']), np.std(all_results[distortion_mean]['init_dists']), \n",
    "             np.mean(all_results[distortion_mean]['final_dists']), np.std(all_results[distortion_mean]['final_dists'])))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
