{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Compare Different Coverage Distributions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "ROOT_DIR = \"../..\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "from numba import cuda\n",
    "cuda.select_device(0)\n",
    "cuda.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning: To use the exr data format, please install the OpenEXR package following the instructions detailed in the README at github.com/tensorflow/graphics.\n",
      "Warning: To use the threejs_vizualization, please install the colabtools package following the instructions detailed in the README at github.com/tensorflow/graphics.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import h5py\n",
    "import numpy as np   \n",
    "\n",
    "import sys\n",
    "sys.path.append(ROOT_DIR) \n",
    "from cryoem.projections import RotationMatrix\n",
    "from cryoem.conversions import euler2quaternion, d_q\n",
    "from cryoem.plots import plot_angles_histogram, plot_quaternions_histogram, plot_distances_histogram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[name: \"/device:CPU:0\"\n",
      "device_type: \"CPU\"\n",
      "memory_limit: 268435456\n",
      "locality {\n",
      "}\n",
      "incarnation: 15225816626165151517\n",
      ", name: \"/device:XLA_CPU:0\"\n",
      "device_type: \"XLA_CPU\"\n",
      "memory_limit: 17179869184\n",
      "locality {\n",
      "}\n",
      "incarnation: 2488608247863660383\n",
      "physical_device_desc: \"device: XLA_CPU device\"\n",
      ", name: \"/device:XLA_GPU:0\"\n",
      "device_type: \"XLA_GPU\"\n",
      "memory_limit: 17179869184\n",
      "locality {\n",
      "}\n",
      "incarnation: 10355243206640403887\n",
      "physical_device_desc: \"device: XLA_GPU device\"\n",
      ", name: \"/device:GPU:0\"\n",
      "device_type: \"GPU\"\n",
      "memory_limit: 3427794944\n",
      "locality {\n",
      "  bus_id: 1\n",
      "  links {\n",
      "  }\n",
      "}\n",
      "incarnation: 11322707187662172196\n",
      "physical_device_desc: \"device: 0, name: GeForce GTX 1050 Ti with Max-Q Design, pci bus id: 0000:01:00.0, compute capability: 6.1\"\n",
      "]\n"
     ]
    }
   ],
   "source": [
    "import tensorflow as tf\n",
    "from tensorflow.python.client import device_lib \n",
    "print(device_lib.list_local_devices())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Read data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Read data that we previously generated, covering different coverages:\n",
    "- full sphere coverage with uniform distribution on euler angles (non-uniform)\n",
    "- full sphere coverage with uniform distribution on $\\mathbb{S}^2$-sphere (uniform)\n",
    "- half sphere coverage with uniform distribution on euler angles\n",
    "- quarter sphere coverage with uniform distribution on $\\mathbb{S}^2$-sphere"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5000 projections of images with dimension (275, 275) pixels\n",
      "5000 sets of 3 ground truth angles of corresponding projection images\n"
     ]
    }
   ],
   "source": [
    "# full sphere coverage with non-uniform distribution\n",
    "projections_filename = \"../../data/5a1a_full.h5\"\n",
    "\n",
    "# load structures\n",
    "data_full_5k = h5py.File(projections_filename, 'r')\n",
    "angles1 = np.array(data_full_5k['Angles'], dtype=np.float32)\n",
    "projections1 = np.array(data_full_5k['Projections'], dtype=np.float32)\n",
    "label1 = \"Full-coverage, Euler uniform\"\n",
    "\n",
    "\n",
    "print(f\"{angles1.shape[0]} projections of images with dimension {projections1.shape[1:]} pixels\")\n",
    "print(f\"{angles1.shape[0]} sets of {angles1.shape[1]} ground truth angles of corresponding projection images\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5000 projections of images with dimension (116, 116) pixels\n",
      "5000 sets of 3 ground truth angles of corresponding projection images\n"
     ]
    }
   ],
   "source": [
    "# full sphere coverage with uniform distribution\n",
    "projections_filename = \"../../data/5j0n_full_uniformS2.h5\"\n",
    "\n",
    "# load structures\n",
    "data_full_5k_uniform = h5py.File(projections_filename, 'r')\n",
    "angles2 = np.array(data_full_5k_uniform['Angles'], dtype=np.float32)\n",
    "projections2 = np.array(data_full_5k_uniform['Projections'], dtype=np.float32)\n",
    "label2 = r\"Full-coverage, $\\mathbf{SO}(3)$ uniform\"\n",
    "\n",
    "print(f\"{angles2.shape[0]} projections of images with dimension {projections2.shape[1:]} pixels\")\n",
    "print(f\"{angles2.shape[0]} sets of {angles2.shape[1]} ground truth angles of corresponding projection images\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5000 projections of images with dimension (116, 116) pixels\n",
      "5000 sets of 3 ground truth angles of corresponding projection images\n"
     ]
    }
   ],
   "source": [
    "# half sphere coverage with non-uniform distribution\n",
    "projections_filename = \"../../data/5j0n_half.h5\"\n",
    "\n",
    "# load structures\n",
    "data_half_5k = h5py.File(projections_filename, 'r')\n",
    "angles3 = np.array(data_half_5k['Angles'], dtype=np.float32)\n",
    "projections3 = np.array(data_half_5k['Projections'], dtype=np.float32)\n",
    "label3 = \"Half-sphere, Euler uniform\"\n",
    "\n",
    "print(f\"{angles3.shape[0]} projections of images with dimension {projections3.shape[1:]} pixels\")\n",
    "print(f\"{angles3.shape[0]} sets of {angles3.shape[1]} ground truth angles of corresponding projection images\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5000 projections of images with dimension (275, 275) pixels\n",
      "5000 sets of 3 ground truth angles of corresponding projection images\n"
     ]
    }
   ],
   "source": [
    "# quarter sphere coverage with uniform distribution\n",
    "projections_filename = \"../../data/5a1a_quarter.h5\"\n",
    "\n",
    "# load structures\n",
    "data_quarter_5k = h5py.File(projections_filename, 'r')\n",
    "angles4 = np.array(data_quarter_5k['Angles'], dtype=np.float32)\n",
    "projections4 = np.array(data_quarter_5k['Projections'], dtype=np.float32)\n",
    "label4 = r\"Quarter-sphere, $\\mathbf{SO}(3)$ uniform\"\n",
    "\n",
    "print(f\"{angles4.shape[0]} projections of images with dimension {projections4.shape[1:]} pixels\")\n",
    "print(f\"{angles4.shape[0]} sets of {angles4.shape[1]} ground truth angles of corresponding projection images\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Angle coverage histogram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA5MAAAEfCAYAAADcApIDAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nOzdd3hUZfr/8ffMpBJCNxgIvYQmRZpBRYEASg11dSNlAQtVF11FV3FFFwuw64+msDaklwChilJtCBFByQKLAguEEpAE0jOTmfP7I19mCaRMyAkE+Lyui4ucM8/c586ZnEzuecqxGIZhICIiIiIiIlII1pudgIiIiIiIiNx6VEyKiIiIiIhIoamYFBERERERkUJTMSkiIiIiIiKFpmJSRERERERECk3FpIiIiIiIiBSaikkREREREREptCIXkw6HgwMHDnD06FEz8hEREREREZFbgMfF5IYNG3j22We5ePGie9+JEyfo0aMH/fr1o3v37owZM4asrKxiSVRERERERERKDo+LyaioKI4ePUq5cuXc+9555x2OHz9O27ZtCQ0NZcuWLaxcubJYEhUREREREZGSw+Ni8siRI9xzzz3u7ZSUFL7++mseffRRPvvsM5YvX07t2rVVTIqIiIiIiNwBPC4mExISuOuuu9zbe/fuJSsri+7duwPg7e1Nu3btOHHihPlZioiIiIiISInicTEZEBBASkqKezsmJgaLxcK9997r3ufr60tqaqq5GYqIiIiIiEiJ4+Vpwxo1avD1119jt9sB+OKLLwgNDaVChQruNqdPn6ZixYrmZykiIiIiIiIlisc9k3/4wx84efIkXbp0oVu3bpw8eZJ+/frlaPPzzz9Tt25d05MUERERERGRksXjYrJPnz489dRTpKenk5ycTGRkJE888YT78Z07d3Lq1Cnatm1bLImKiIiIiIhIyWExDMMwI5DdbiczMxN/f3+8vDwePSsiIiIiIiK3INOKSREREREREblzXFcXYlpaGsnJyTidzlwfr1KlSpGSEhERERERkZKtUMXk6tWr+eijjzhy5EiebSwWCwcOHChyYiWJy+UiNTUVb29vLBbLzU5H5IYzDAOHw0FAQABWq8dTrQtF15nc6XSdiRS/G3GdidxJPC4mV65cySuvvILNZqNVq1bcfffdd8zcyNTUVA4fPnyz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zyO8Um77LuvatSubNm3i999/p3v37u72ffr04fnnn8/RNi4uzl0AXbZr1y6+//57li5dir+/P4MGDco357xi58fhcFCzZk0mTZoEwPTp05k1axa//vor99xzDwD79u1zt7/8df369fHz88Nut+cat0yZMrRt25ZvvvkmxyJIdrsdX1/fHG3ze118fHzcX9tstgJfs/xej6vP75WxrVare9tiseB0OvM9zvXKd5hrx44d6dSpE506dQKyVxa6vH3lvy5dujBkyBBOnDjBgAEDiiVRERERERH5n4oVK3LhwgUSExOx2+1s37493/aRkZFER0cTHR1N5cqVCQsL44svviAxMRGAixcv0rp1azZv3kx6ejppaWls3ryZVq1aAdC9e3c2bNjApk2b6Nq1KwBhYWFs2rSJCxcuuGPk1QuWnJxM2bJl8ff358iRI+5C7t5772Xbtm1kZmaSmprq/j7yiz1kyBDi4+OvOcZvv/1G9+7dmTlzJqtWrSImJgbILhbbtm1L69at+emnn3j11VdZuHAhr732GgCjRo2ibNmyOJ1Od4GXkJDgnuaXkZHB999/T+3atd3HSkxMpEKFCteMzCzs65Kf/F6PkiDfnsmIiAgsFguGYbB69WpCQ0Pd3bJXslqt7hWQHnjggWJLVkTkdpCcaictM8u97V/mLuIT0q4rln/eH1iKiMhtztvbm9GjRzNw4EBCQkJyFDqeqFevHs888wyDBg3CarXSqFEj3nnnHfr27evuIOrfvz+NGjVyt09NTSUoKMg9bLRu3bo899xzDBs2DJfLhbe3NxMnTqRSpUrXHK99+/YsWbKEnj17UqtWLfcQzaZNm9KxY0d69epF1apVadKkCYGBgXnGDg4O5sSJE5QtW/aaY1SqVInatWuzZMkSLl68SMWKFRk7dizt27cHshcOeu+99/jqq69YvXo1tWvX5v333ycsLAyA+++/nz179tCuXTvOnTvHhAkTcDqdGIbBI4884h6CC9k9rQ899JDpr8uVGjdunOvrUdQhzmaxGPn1nV6hQYMGjBkzhjFjxhR3TiVOZmYmsbGxNGnS5JpubMnbnj17aNmy5c1O45ZSUs/ZjbgG7qTrLD4hjS0xJ9zbp0+fpkqVKtcVq0eoHz/PnmFKXi2eHsXeObNNidXsqZEcX/ypacNcS1WrbkpeN1NB17eus5KrpP5uLslK6jm73mvg4MGDOTpUbtatQW5nqampBAQEkJ6eTmRkJG+++SaNGzfOte3hw4eJiori5ZdfNj2PAwcO8OmnnzJlypQC244ZM4bx48cXqVi8FVz9838ljxfgOXTokGkJiYiIiIjcqmz+gXd88We2iRMn8ttvv5GZmUmfPn3yLCQhe8hqcRSSAI0aNaJt27Y4nc58b0Fit9sJDw+/7QvJgpi6mquIiIiIiEhhTZs27Wan4HZ59dj8+Pj4EBERcQOyKdkKXUz+8ssvfPvtt8THx+e62pHFYnHfBFRERO5kBnaHK9dHbDafPB+7mtPlIjnVTmCAT8GNRURE5IbxuJg0DIMJEyawZs0aDMNwL8xz2eVtFZMiIvnzzcqgedD/hs6Elq6If6m8h9Lkx2JWUsXA5YKk1IxcH7Nn2vHx9WyZ8vSMLIzMLBWTIiIiJYzHxeSCBQuIjo4mIiKCQYMG0a9fP4YMGcKjjz7K7t27mTt3Lg899BDjx48vznxFRG55RmYGx9Z96d4uzGI0V6v2x0fNSktERESkUDwuJletWkWtWrV455133PsCAwNp3rw5zZs354EHHmDgwIG0a9eOfv36FUuyIiIiIiIiUjLkvmZ7Lo4dO8Z9992XY5/T+b8hSo0aNaJDhw4sWrTIvOxERERERESkRPK4mARyDMPy9/fn0qVLOR6vUaMGR48eNSczERERERERKbE8LiaDgoKIj493b1erVo1///vfOdocP36cUqVKmZediIiIiIjQokWLHNsrV65k0qRJ+T7nyjYJCQkMGDCAiIgIfvzxxyLl0rFjRxISEooUo7AGDRpE165d6d27N71792bcuHH5to+Li6NHjx43KLts8fHxOfIaP348PXv25LPPPruhedxIHs+ZbNq0aY7isX379nz88cfMmjWLLl26sHv3brZs2cLDDz9cHHmKiIiIiJQIyZmppGflvlr19fD38iPQN8C0eLnZuXMntWvX5t133y3W4xQkKysLL6/ru9X91KlTueeee0zOKJvT6cRmu76V1S+rXLky06dPB+D8+fPs3buXbdu2efz8opybm8XjbLt27UpsbCwnT56kWrVqjBgxgo0bNzJjxgxmzpyJYRiULVuW559/vjjzFRERERG5qdKzMth+bKdp8R6uFVakYnLr1q188MEHOBwOypUrx9SpU6lUqZL78YMHDzJlyhQyMjLo3bs3S5cuxc/Pz/34r7/+yssvv4zD4cDlcjFjxgy8vLwYMWIEzZo148CBA9SqVYt3330Xf39/IPtOD9u2bSMrK4v333+fOnXqkJaWxptvvsnhw4dxOp2MGTOG8PBwVq5cyfbt27Hb7aSlpfH555/z0UcfsXHjRux2O507dy6wpzEvEyZM4OGHH+aRRx4Bsntw9+7dm6ON0+lk6tSp7N69G7vdTmRkJI899hi7du1i5syZBAUFcfDgQTZs2JDjeVfG+uKLL9i+fTvvvPMOEyZMoHTp0sTGxnL+/Hn+8pe/8MgjjxAXF8czzzzDunXrGDZsGBcuXKB379689tprBAQE8Prrr5Oenk716tWZPHkyZcuWZdCgQbRo0YKffvqJjh07cvjwYXx9fTl69CinT5/m7bffZtWqVezbt49mzZrlWAy1JPC4mAwPDyc8PNy9Xa5cOVavXs2yZcs4ceIEVatWJSIigqCgoGJJVETkdmHDSZUy/7tDpKOUP95e13fHSAtGwY1EROSWd7kQvOzSpUt07NgRgJYtW7Js2TIsFgvLly/no48+YsKECe62DRs2ZNy4ccTGxjJx4sRrYi9ZsoTBgwfTq1cv7HY7LpeL33//nWPHjvH3v/+dli1b8vLLL7No0SKGDx8OQPny5Vm1ahULFy7kk08+4e9//zsffvgh9913H2+//TZJSUkMGDCAdu3aAbBv3z7WrFlDuXLl+Pbbbzl+/DgrVqzAMAxGjhxJTEwMrVu3zvccvPDCC+4iuF27drz00ksenbsVK1YQGBhIVFQUdrudxx57jPvvvx+A/fv3s3btWqpVq+ZRrMvOnTvHokWLOHr0KCNHjnQXs5d98MEHPPPMM0RHRwPQs2dPXnvtNdq0acP/+3//j5kzZ/LXv/4VgKSkJBYsWABkF8dJSUl8/vnnbNmyhWeeeYbFixdTr149+vfvz8GDB2nYsGGhci1ORepHDQwMdP9AiYiIZywuJymnjri37Zl2fHx9bmJGIiJS0vn5+bkLE8ieDxkbGwvA2bNn+fOf/8z58+ex2+2EhIQUKnbz5s358MMPOXv2LF26dKFmzZoABAcH07JlSwB69erF/Pnz3X/7d+nSBYAmTZrw1VdfAfDtt9+ydetWPvnkEwAyMzM5c+YMAPfffz/lypUD4LvvvuO7774jIiICgLS0NP773/8WWExe7zDX7777jv/85z9s2rQJyL6/8/Hjx/H29uaee+4pdCEJ2R1tVquVunXr8vvvv+fbNjk5meTkZNq0aQNAnz59ePbZZ92Pd+vWLUf7Dh06YLFYCA0NpVKlSoSGhgJQt25dTp06dWsWky+//DLh4eF06tQpzzbbtm3jyy+/5O233zYlORERERERyd9bb73F0KFD6dSpk3voZn6++uord5u33nqLnj170qxZM7Zv387w4cN56623qFatGhZLzlEzV257e3sDYLVac9wucPr06dSuXTvH837++Wf38FgAwzB46qmneOyxx67vG76CzWbD5XK54zocjryIbP8AACAASURBVGvaGIbBq6++yoMPPphj/65duzxePDQzMzPHto+PeR8CX3luroxtsVhyHMdqtZKVlWXacc3g8Wquq1at4uDBg/m2OXToEKtXry5yUiIiIiIi4pnk5GQqV64M4NHf4p07dyY6Opro6Gjuuece95oogwcPpmPHjvznP/8B4PTp0+45g+vXr3f3UublgQceYMGCBRhG9hSMAwcO5NkuKiqK1NRUIHsV1AsXLgAwZMiQHHeQKEjVqlXdi4Ru2bIl12LygQceYPHixe7Hjh07RlpaWoGxK1WqxJEjR3C5XGzevNnjnK4WGBhImTJl3KvoRkdHF9gLe6swdbkgu91e5FWQRERERETEc2PGjOHZZ5+lcuXKNGvWjLi4uEI9f8OGDaxZswYvLy8qVarE6NGjSUlJoU6dOqxatYqJEydSs2ZNHn/88XzjjBo1ismTJ9OrVy8Mw6Bq1arMmTPnmnYPPPAAR44ccfdMlipViilTplC+fHlOnDhB2bJlc41/5ZzJ8uXL89lnnzFw4EBGjRpF//79CQsLy7WnccCAAZw6dYq+fftiGAbly5dn9uzZBZ6X559/nqeffprg4GDq1avnUQGal3fffde9AE+1atVum5GcFuPyRwcFaNCgAWPHjmX06NG5Pm632xk+fDgnT55k+/btZuZ402VmZhIbG0uTJk3w9fW92encMvbs2VPgJ1iSU0k9ZzfiGriTrrPk4/9l36wZ7u2izJls8fQo9s4p+A3xRsdq9tRIji38hKTUzFwfL8z3HDp8JMZdVahc4da+j3FB17eus5KrpP5uLslK6jm73mvg6kVPbsVbgxTWlSuT3iiHDx8mKiqKl19++YYdUwqW36I/+fZMXj0/ct68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woULWbZsGQBz586lVq1arFy5kh07djBt2jTuv/9+IiIirimEL2/7+Pi499lsNndunh4/r3Z5cTgc1KxZk0mTJgEwffp0Zs2axa+//spDDz1E/fr1Adi3b5/7OZe/rl+/Pn5+fnkuelSmTBnatm3LN998445jt9vx9fXN0c7LyyvP1wvyPie5KejDhKtf4ytjW61W97bFYimwhzs3Hg9zjYiIICIigj59+ri/zu1f7969C52EiIiIiIjkLSwsjPT0dFavXg1kD6185513iIyMpFKlSly4cIHExETsdjvbt293Py85OZmyZcvi7+/PkSNHchRJVwoICCA1NTXH8TZt2uReM+XixYu59lxFRkYSHR1NdHQ0lStXJj4+Hn9/f3r37s3w4cPdnUynT59m7969AKxfv97dS5nf9+vJ8fNrN2TIkGum6P322290796dmTNnsmrVKmJiYgDcxV/btm1p3bo1P/30E6+++ioLFy7ktddeA7LnnpYtW9a9iitkL+iTlJQEZPeKfv/999SuXRvI7sWsUKEC3t7eOXKoWLFinq9XYbVu3ZrNmzeTnp5OWloamzdvplWrVtcdr7A87pl85513ijMPERERERHJg8ViYdasWbzxxhvMnj2bhIQEunXrxsiRIwEYPXo0AwcOJCQkxF3MQPZUtSVLltCzZ09q1aqV5/DU8uXLc++999KjRw8efPBBXnrpJZ577jmGDRuGy+XC29ubiRMnUqlSpXzzPHz4MO+99x5WqxUvLy/+9re/AVCnTh1WrVrFxIkTqVmzJo8//ni+i3vWrVvXo+Pn1S44OJgTJ05QtmzZHO0rVapE7dq1WbJkCRcvXqRixYqMHTuW9u3bu9vMmDGD9957j6+++orVq1dTu3Zt3n//fcLCwgC4//772bNnD+3atePcuXNMmDABp9OJYRg88sgjdOjQAcjuFc5t6Ky3t3eer1dhNW7cmL59+zJgwAAgewGey0NcbwSL4clA6ztcZmYmsbGxNGnS5Jpuasnbnj17CvzUSXIqqefsRlwDJf06c6Yn48o0Zxn4zEup7J01071tz7Tj4+uTzzPy1uLpUeydM9uUvMyM1eypkRxb+AlJqbkPzSnM9xw6fCTGXVWoXCHv4Vi3goKub11nJVdJ/d1ckpXUc3a918DBgwfdc9jg5twa5Go//fQTzz//PDNmzKBJkyam5VIc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RERKJo+LycjISBISEujfvz/Lly/n5MmTZGRkcPLkSaKiohg4cCAJCQlERkYWZ74iIiIiIiJSAng8JrVbt24cOnSIuXPnMnHixGseNwyDESNG0K1bN1MTFBERERERkZKnUBMcx48fT8eOHVmxYgUHDhwgJSWF0qVL06hRI/r160eLFi2KK08REREREREpQQq9Wk7z5s1p3rx5ceQiIiIiIiIitwiP50yKiIiIiIiIXKZiUkRERERERApNxaSIiIiIiIgUmopJERERERERKTQVkyIiIiIiIlJoKiZFRERERESk0PIsJtu0acO//vUv9/bMmTOJiYm5IUmJiIiIiIhIyZbnfSaTkpLIzMx0b8+cOROA1q1bF39WIiIixcQA4hPSTIlVyteLwAAfU2KJiIjcavIsJitVqkR8fPyNzEVERKTYOV0GW2JOmBKrU+vqKiZFROSOlWcxQx17wQAAIABJREFU2axZM6Kjo7Fardx1110A7N69291DmReLxcLo0aPNzVJERMQk3jYLrUJspsTyIwMoZUosERGRW02exeSLL77If//7X5YuXeret3v3bnbv3p1vQBWTIiJSklmcds7u+tKUWMHd+5gSR0RE5FaUZzFZo0YN1q5dS1xcHPHx8QwaNIg+ffrQp4/eOEVERERERO50eRaTAFarlerVq1O9enUAqlatSps2bW5IYiIiIiIiIlJy5VtMXunQoUPFmYeIiEixCyhfESPTRY3Qe0yJZ3WZEkZEROSW5HExeaWzZ89y4MABkpKSCAwMpHHjxtx9991m5yYict1C/asQkOygqXdwvu08aQPgZVjMSk1uJqeLs19+xZnfDpsSrsLosabEERERuRUVqpg8ffo0r732Gt9///01j7Vr14433niDkJAQ05ITEblevnYnp3Z8SVziyXzb2ctXK7ANQHCfoSZlJiIiInJ78LiYPH/+PI8//jjx8fFUrVqV1q1bc9ddd3H+/Hn27NnDd999xx//+EeioqLctxIREblZDMOFkeXAmXIx/3aBdxfYRkRERESu5XExOXv2bOLj43nhhRf405/+hM32v3t0OZ1OPvvsM6ZMmcIHH3zAxIkTiyVZERERERERKRmsnjbcsWMH999/PyNGjMhRSALYbDaGDx/O/fffz/bt283OUUREREREREoYj4vJ8+fP06RJk3zbNGnShPPnzxc5KRER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\n",
      "text/plain": [
       "<Figure size 720x288 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_angles_histogram([angles1, angles2, angles3, angles4], \n",
    "                      [label1, label2, label3, label4], \n",
    "                      plot_settings=dict(legend_size=10, alpha=0.5))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Quaternion coverage histogram"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x288 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_quaternions_histogram([euler2quaternion(angles1), euler2quaternion(angles2), euler2quaternion(angles3), euler2quaternion(angles4)], \n",
    "                           [label1, label2, label3, label4], \n",
    "                           plot_settings=dict(legend_size=9, alpha=0.5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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DH366adatGiRAgMDNW7cOMsCAwAAALXh8h3gVq1aKTExUf7+/lqyZIlGjRolm82mTz75RPfff78SExPl6+urd955R82bN7cyMwAAAFBj1XoT3N13362PP/5YcXFxuvPOO9WoUSM1bNhQ7dq109ixY7Vp0yb17dvXqqwAAABArVV7u4aWLVtqxowZmjFjhhV5AAAAAEtV6w4wAAAAcLOr0Ya9WVlZ2rt3r3744QfZbDYFBwerT58+atWqldn5AAAAAFNVqwCfO3dOL774ov7xj3/I4XBUOGez2RQTE6MXXniBh+AAAABQb7lcgPPz8/XII4/oxIkT8vLyUs+ePdWmTRtJUmZmpr799ltt3rxZ6enpWrNmjQIDAy0LDQAAANSUywU4MTFR33//vX7+859rzpw5ld72durUKf3hD3/QV199pcTERP3+9783PSwAAABQWy4/BLdlyxY1a9ZMf/7zn6t81fHtt9+u+fPnKygoSFu2bDE1JAAAAGAWlwtwXl6e+vTpI39/f6dj/P391adPH507d86UcNeTn5+vV155RTExMerevbvuvvtujRs3Tl9//XWFcceOHdNTTz2lPn36KDIyUo888oh27txZ5TUdDoeWL1+uIUOGqHv37oqOjta8efNUUFBg+ecBAABA3XB5CURISIhKSkpuOK6kpETBwcG1CnUjmZmZGjdunAoKCjRq1Ch16NBBly5d0qFDh5SVlVU+7uTJk3r44Yfl7e2tiRMnqnHjxlq3bp0mTpyoJUuW6J577qlw3ZdeeknJycmKiYlRXFycMjIylJycrLS0NC1fvlxeXuwaBwAAcLNzuQAPGTJE7733nnJyctSyZcsqx+Tk5GjXrl0aM2aMaQGrMmPGDJWWlmrjxo3XLduvv/66Lly4oPXr16tr166SpOHDh+v+++/XnDlz9Nlnn8lms0mSjhw5opUrV2rw4MGaP39++TXatm2ruXPn6uOPP9awYcMs/VwAAACwnsu3NJ9++ml16tRJsbGx+uKLLyqd3759ux577DF16tRJ8fHxpoa82t69e/Wvf/1LEydOVHBwsEpKSlRYWFhpXEFBgbZt26a+ffuWl19JCggI0KhRo/T9998rNTW1/PimTZtkGIbGjx9f4TqjR4+Wn5+fNm7caNlnAgAAQN1xegc4Nja20jEvLy8dP35cTz75pJo0aVJhG7QLFy5I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ycur+r8dDcPQ3Llz1bhxY02aNMmChO7j5+enJ598UgcOHNCGDRvcHQcAcAuhAANutH//fklSREREjb5/06ZNSk1N1bhx49S0aVMzo9ULo0ePVsuWLfXGG2+ouLjY3XEAALcICjDgRrUtwElJSbLZbBo5cqSZseoNHx8fDRs2TNnZ2frss8/cHQcAcIugAAMWO3bsmH73u99pwIAB6tGjh0aMGKHNmzdLklJTUyXVrADv379fqamp6tOnj9q2bet0XEZGhmbOnKkBAwaoe/fu+uUvf6klS5bIMAz169dPXbt21U8//VSzD3cDZsw9YsQISdJ7771nSUYAgOdp4O4AwK3sk08+0axZs2S329WtWzdFRUUpIyND8fHxeu6555SZmanbbrtN7du3r/a1t27dKkm65557rjv/c889p+Li4grzJyQk6MyZM8rPz1fHjh0VEBBQ489o9dydO3dWixYttG/fPp07d07NmjUzPSsAwLNQgAGLfP3115o5c6YCAgK0ePFi3X333ZKuPLj26quv6tVXX5UkdevWTTabrdrX3717tyQpMjKyyvMpKSnl8y9dulT9+vWrMP+yZcsk1Xz5xfWYPXdkZKS2bNmiXbt2aejQoabnBQB4FpZAABa4fPmynn/+eZWUlOjNN98sL7+SZLPZNHXqVPn6+kqqeQFNT0+XJHXs2LHSudLS0vL533777fICWjZ/fHy8GjS48vffbt26VfjezZs3q2vXrsrPz69RrtrMvXPnToWFhSkzM7PC8TvvvFOS9N1339UoEwAAV6MAAxbYtGmTTpw4oV/84hdVLlHw9fVV69atJdWsABcUFKiwsFCSFBgYWOn8p59+qmPHjmngwIEVyncZPz8/hYSEVDl/ZGSkPvjggyqv64razN2pUyetW7dObdq0qXC8bIeL3NzcGmUCAOBqLIEALPDPf/5TkvTAAw84HXPp0iVJNSvAFy9elHRllwQfH59K5//xj39Ikn796187vUZRUZG8vLzUtWvXCsdDQkLKC2pN1GbuFi1aqEWLFpXGN27cWNK/PzcAALXBHWDAAmlpaZKk7t27V3n+zJkzysnJUWBgoG6//fby40VFRZo3b5769++vyMhITZkyRZ999pnCwsIq3P1s0qSJJKm4uLjK/XEPHDggyXm5zs7OVl5enjp27Ch/f/8K5/r3768FCxZU49OaN/egQYP01ltvVfqesr8slH1uAABqgzvAgAXOnTsnSeXrfK9V9mazq0uiw+HQU089pRMnTmjGjBlq0aKFli9frrlz56ply5YV7oz6+fnJ399fBQUFys/PV3BwcIXr5+XllY+rysaNGyVVXoObl5en3NxcdenSpTof15S5L126pNOnT1c5d9l65ObNm9c4FwAAZbgDDFig7M5mRkZGpXNZWVlV7oKwcuVKpaSkaNWqVRo+fLgGDBighIQE5eXlVVkKw8PDnc5RNv/JkycrnTt79qwWLVpUaX7p3w/W1aYA12ZuwzAqLYuQpKNHj0r692cGAKA2KMCABXr16iVJSkxMrPCih1OnTmnSpEnla1mvLoHLli3TyJEj1apVq/JjgYGBatKkSZWlsGx3hZSUFKfzL168uMISiYyMDE2YMEEXLlyQVPkubHp6upo2bVr+gF6Z9evXKywsTPfee6/Ln726c3/33XcKCAhQu3btKl3z22+/lc1mq7CjBAAANUUBBizw29/+Vg0bNtTXX3+tIUOGKD4+XhMmTNB9992nkpKS8h0WygpwRkaGzp49qwEDBlS4TlFRkc6fP19lAR40aJCkK1uHXWvy5Mlq2LChPv/8cw0ZMkRTpkxRbGyshg0bpp49e6px48by9vaudN1Dhw4pLCys0vUcDocklW9fdj01nfu7775TWFhYpT2RDx06pNzcXEVGRvISDACAKSjAgAUiIiK0fPlyRUVF6fz589q+fbtyc3M1ceJELV68WPn5+WrevHn5ndYffvhBkhQaGlrhOl9++aUMw3C6BCIyMlJ79+7V6dOnK5zr0aOHli1bpl69eik3N1c7duyQYRhKSEjQ5MmTdenSJXXs2LHSOt309PQq5yp7qG/UqFE3/Oy1mbuqol+2XvqRRx654dwAALiCh+AAi0RFRWnVqlVVnjt06FCFr8vuCJ88eVKdO3eWdGWHh/nz58vPz08dOnSo8jqxsbGaNm2aPvjgA02ZMqXCub59++r999+v9D2bNm2SVHkNbklJiY4dO6bx48dX+p4vv/xSISEhio2NrTLHtao79+XLl3XkyBE9/PDDFY4XFxfr73//u4KDgzVkyBCX5gYA4Ea4AwzUA506dVKbNm302muvacuWLdqyZYsee+wx5eXlKSwsTF5eVf9WHTp0qHr06KGVK1fq/PnzLs2VmpoqqfIa3IyMDJWUlFS6A3z27Fl9//33+u///m81atSoBp/OtbmLi4srzb127Vrl5ORo2rRpVe53DABATVCAgXrAx8dH77zzjgICAjRt2jS9/fbbio2NVevWra+7I4PNZtPvf/97Xbx4UUuWLHFpLmf79Kanp6tBgwbq1KlTheOtW7fWoUOH9Jvf/Kaan6p6c3t7e5ff/ZakwsJCLVy4UBERERo+fHit5wYAoIzNMAzD3SEAVFZaWqrevXtr1qxZGjNmjCnXdDgc6t27t+x2u7755pta39E1a+4XXnhBqamp+vDDD+ssDwDAc7EGGKinjh8/rsLCwiofDKspLy+vKrdNqwtVzX3mzBmlpKRo06ZNevzxx92SCwDgeSjAQD2VlpYmLy+vCssCbjWvv/66duzYoWHDhmnSpEnujgMA8BAsgQAAAIBH4SE4AAAAeBQKMAAAADwKBRgAAAAehQIMAAAAj0IBBgAAgEehAAMAAMCjUIABAADgUSjAAAAA8Cj/D7XIZBd1a7SWAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_distances_histogram([angles1, angles2, angles3, angles4], \n",
    "                         [label1, label2, label3, label4], \n",
    "                         plot_settings=dict(legend_size=13, alpha=0.7))"
   ]
  }
 ],
 "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
