{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch import nn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<numpy.lib.npyio.NpzFile object at 0x7fc1842e3af0>\n"
     ]
    }
   ],
   "source": [
    "f = np.load('/local/data/<user>/disentanglement_multitask/mpi3d_real.npz')\n",
    "print(f)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['images']\n"
     ]
    }
   ],
   "source": [
    "print(list(f.keys()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7fbd33086a90>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPsAAAD7CAYAAACscuKmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8+yak3AAAACXBIWXMAAAsTAAALEwEAmpwYAAA2vElEQVR4nO19a6wlx3HeVzPnPnbv3eU+SK5WJE3SFkVZcGzKYCQ5EhxaimRGNqw/hvxKwAQE+McJ5MSBJcVJYCcxIP2wbCGIDRCRbAZQLMkPhQTh2JYZKYgThxJlUhYpkuZDpLjkPsjl3n3fxznT+XHmnv6qerrvIXf3XJpTH7DYntM93T2PvlPVVfWVhBDgcDhe/6i2ewIOh2M28MXucPQEvtgdjp7AF7vD0RP4Ync4egJf7A5HT3BBi11EbhWRx0XkSRH56MWalMPhuPiQV2tnF5EawN8AeB+AQwC+BuBnQgjfunjTczgcFwuDCzj37QCeDCE8DQAi8jkAHwSQXewiEkQEAJD+kZHO4hghU6WPQnJedx98XumUwgxfVbukcuoTTQXfO3tO6CyWmqXDZuZo769kxpqyuy0x7f2eGq96klOeeLEd1Krim9SNJiCE7pVwIYv9KgDP0fEhAO8onSAiGMzNAQCGG0NdVw+orLWLEDYm5Vr9UdDtmjo/dqibeBo1rJMHGftsjJIj9HYLPdjGaEOV+rvVqLqG5izJYo8/BPUHyfTf0NiV7p+fc8BoUq5NHyNqZ98pflXUdYpuWI3i2E2Vv49c1SR/dWIf9hWtAs254aK+Zkh+wakuzWlqGnzNZpKBTkweGbVtRiNkQSdW5j6OGno36WHIwpxqVxUvZnyvhufXs1O4kMU+FUTkDgB3XOpxHA5HGRey2J8HcA0dX93+phBCuBPAnQAgVRXC5p95+yUI/KU30+KvS0V/7U0X6ksp+i9fRZ9p/uIFseJArJNEbOUf6Attx6Ky/ZIJfcnSLzv3SX2Yr1XDFy72K0TzIAmmSQbjc8zXUN1HljDsDScpoqCS8N0p7RFJ4cPIEkZlr4WeS/Lxph9ESU55BHtPQ15yCOp5Uv9GTJGqNDZfG984c0OqTBlKQMriQnbjvwbgBhG5XkTmAfw0gHsuoD+Hw3EJ8aq/7CGEoYj8MwB/CqAG8JkQwiMXbWYOh+Oi4oJ09hDCHwP444s0F4fDcQlxyTfoGCK022j1ItrZrazmpbeHucKO0FFqMSKNhfUno//VtAM8MvMIdB7viEvQ2pDetTe78SHecjt2Bdb5qD9znXyeVYHVTjJvbyR2M9q3SPToqOtXIX+/uaqydZlnUZlNjFFd2EtgS0PD+wPWAEv3W7p3qcdzor6LVrK8Apw8C9bTlfkubxVoGlPHWwJVXrPme1qN7J5A9rR4ztZNHA7H6wG+2B2OnmCmYvxYEBmLSGLE+Kbkd5ZxJghWfOZWQZvU2PShxUorIpO4aMUtEm/t7PNH+b+nVuJU5jGhR5PYVUpeKgSy3CTmKrqCkRGLm4yjS5U8o6aj1PbO4i39blUXpXZYsxaJqmqKBYfC2l7LtPeKp2HnWBD5lbpVscpgVEB+r0wdLwW1LIy3kzaRmrpNx5zCXP3L7nD0BL7YHY6ewBe7w9ETzFhnl6i72CATpVsZnaZiswuZv6yCwt6FA6MzgU17EcPUJ7aznR27CRl9Evpakj54z8HsCSgVjUxjicstm5qsjqbUOt6n0A1HSj8umA67rV/tWGx7K/hvFtxNWacuBDsqk5rd32FT7cjs1ejbQa6tdiw27dn3aspnrf2CTRdqU8D20W1aFhOJJWSmtHO0+1dd8C+7w9ET+GJ3OHqCGYvxJKVYOYrEaethVNUkmrHnmjXfNbkDY5bTwcW6HceK22gwcB3Hx5u/mWTms9FmQc1fn8aiWIkYIigx3qor3Ad7d9nB+MBEV4Vur7MiK4e538okxRK9FT+rbpVhDJqHUt9sVFrpmxUy7Ur6j/UGpPLIvhPS2U6s2ayx4xGqTB9mHhU9pmGyftrKgp3Qv+wOR0/gi93h6AlmLsZvChm14YxoqrwYb2Tw2FdhR19MZICKpaF2A/P3rqkpgMPu7LIXVGGnW6p4WysbtDHgOVrvPRafY9l6hakjw/jAO9VMtmGleBa7G3uvSGTmOxAS6ineiTa77HxtigZMy+pq9gkdFO8+E0WT2dGvMuoVoDlSCjE9SsSvrCfftGR7rMokkSmk9iUPg4OG+B2znplMJZZ7d/K6ln/ZHY6ewBe7w9ET+GJ3OHqCmevs0cxglB/+s2MsQYpscC5OuV6c1+2oj7rSl8a6XK3I/7ReXlWsuxmiBe4f3fo7AFRMo2z0s6HyBlRVWKCmIyafLIR5WVMW63Ic+WfpohtEgs9RIXqwIr1xZO9Vo+nA1RSZYIOJL83DHfD+gLkhG6yjFk2FXByaqvgeNEzZbEyFI3pOlmBDX0vepLuxGinPmYwFAJoheXBajtMqsydQ2Heyr0RCBtoB/7I7HD2BL3aHoyeYvQddK24kDkUkslQmy8n8jsVJud4RRffaiJXDsBoPjChWSbf3lPV0YoIKa9qr2XxH4m1iGiMu+oTjrsrLYprbPiLlnqdzCtYwnqNtp8w/iZcfH7HJKDtUYk7SwR2xXFt1gs2DxtQ5rzwAeTT92rL0b7Pz8CTn2LxbyGBTykxTDeyNjCZBmad5DfU7vDEX1YuwrlWNxvjNpTNq2xXcGTdV0wL1vn/ZHY6+wBe7w9ET+GJ3OHqC2ZveWlXGZsqsKHPr/PJOVTeYZ651joTSetGA9O2h1beJr125mBrdjSPYrF6nTWDdPPTjGs76acxJDbnS2hxxZJOZr3fE8kDrsnN1vD+DWt+rhbl4LOSTLNbFlLLmjswGykhlzY1z3DAK4Wh0vrMMAKujmE10uBH3UprGtCNTVmjyuixzxQ9szgHh+21cnEO3WcvuD8zRu2Tfnabko60iEOndqY2JcQeNN2fMsWvxuhuKqguWvEK5RttnVnX8qrHll11EPiMix0TkYfptn4h8SUSeaP/fu1U/DodjezGNGP+7AG41v30UwH0hhBsA3NceOxyO1zCklEJ30kjkOgD3hhC+rz1+HMAtIYTDInIQwFdCCDdu1U9VSxjsGIuPg1onmp9jb7haaxeiTHEkmiaRXGyq0X/HWNJm0dSm2+GsOk3QYuUciZKVxPnODRZUu92Ly5Py0uIVqm7nzisn5eXFfbpuftekPD8f+6gr3b9UZH40noJV1W3yKsl3iRVUybvUzkaDKRFc1w1JFRgN1+LvQy3Gn1s/Mymvrp1QdafOvzwpnzn/0qS8vvayanduI/YxNM9sxLxzimfOivvkUVgg8xAxXoOczovGSqLvSDwfFdJohfU49sa6nodKK1Abpo/2fR+ubqAZdRPkv9oNugMhhMNt+QiAA6+yH4fDMSNc8AZdCCGIDcwmiMgdAO4YH1zoaA6H49Xi1S72oyJykMT4Y7mGIYQ7AdwJAPWgDgvz413met6kZ1JBIPng/rpAyMCSe7CkFExFrHZltVi2OIi72bt3XKXq9i/H4727rp6Ul0g0B4CFhd2T8qA2wTpqksbrjOQ5UeoENPi0hNu4++9uKaVRkZ5ODWt2wTloyPQxB7YsRA/IsHCZare8pFhFdP8sFo+iWrCxcU61O7saxfrTZ/WrePzMoUl55dyRSfn8xknVrhnm+fp4HhJMgBU9TmXxaMzSIgI5G4TDz6ZaiOcNavMO0659Sr6h/+/CqxXj7wFwW1u+DcDdr7Ifh8MxI0xjevs9AH8J4EYROSQitwP4OID3icgTAP5Be+xwOF7D2FKMDyH8TKbqvRd5Lg6H4xJiKtPbxcJgfhB2XTHW2WzqJkWUaP4GDZiHnfREm5YZSv/WZosF8jTbv/zGSfkNe96k2u3Zfe2kvHNR+wrVg2guZL2utO8YTK0KNrNRb0qPZjNRvo8OFgMqMsnFK9kd7Y7CSqnWS1zr3Z5r9nXTEV/WJMXeaXyOhrpO2z/px2vDaKI7dfaIanf81Ldj+fR3VN2589EkuN6sqTq1n0L7J8OEECS+jyFY0x5dp8qaZQg2OJX2eV03bMkyRmsbCM3FNb05HI6/ZfDF7nD0BDMX4/dcsQdAmomzJtl0ZEi6OLCExbKBaHF/71L07Tm4/82qbj+J6zvno+eaGE++jPPY+Jg8+RTphfXWUyJ+nkfMctyp85iDznKQF/jplFWu6haDAS3WFwX8gvyskpYa+yCboZrM8xvPIx80pINYQvfvuqqjrpuvz14zi8wb61pUP3kmivwvnnhM1R07/fSkfHb97KTcDLWoztx4I3MjG8Wrz/M3OQHofbG5FUbteBtnVtEMRy7GOxx9hi92h6Mn8MXucPQEM9bZ58KeA3sAAI0xTbCusmF0mkVyOT1IuvcbL/9+1W7PrujOWptINM2i2K0bb85kE9YFlAOlKqVT58ktK7ERfCqMTNU1RN6wTmQQ5zd0pNgGmZA2SE8EgHNNdCWth9HFVIzJaIP54M3ewUC4HPc0GnNPd9bxuJpbVnU7yO14bm4p9lctqnaV1J1lAGALEkel2f0B5VZrU1hn9g6SPhRBhc05l0k2CGBtNbrdHjv51KR8+OXHVbuVs89PysPhuqobqlTdvGlkot6UKm459sdYXTmDZsN1doej1/DF7nD0BDMX4y87MDZ7NURuAAA7qyjqXX3596q6gySuLy0RGUQhLW5l6iQrdpvouypvNuMoJOZws0QFq0SmwKQLAHDqTIzKOnX2sKo7vx6jt1bXozg+HGkRPIzynoKKE43nb7yxOJ2z5VrniMEBe35ZC2DImx9rIogfkLg/P9CceXMk/u/eqck89ix916S8vPPySXmx3g0N8mxM+PSI340814wFUKl51gQ44ntn0z8pU228BxvDVdXupZPRK++Fl7+h6o6einWjJp4XjDSu03Hr5755tPqyi/EOR+/hi93h6AlmKsbPLcyF/W8Yi2pv3PtWVXfdgR+clHcuaparRslKTPBg8/TQzi7sbn/3DnxVazG+rqJIOIJWNU6vRpH8pVPPTsrHT35btTtz9uikPCSRHgBGnOKpMhx3vHNPAT8DIz83zMNXGU8t5smj0xojmlY5Wmxosb5CtxUDACp6d6zgqLLXKhHZ7pbTuGYnHXQ/5il777IJUNq3fM2kvJcCmQBgeSG+SwOJ9NxDm8WVLCGWolxncc3v4jMlt6XuZk/HoaHMfvHkM5Pyc8cempRXTEDOWojqnNHKJk/33PEzGG0MXYx3OPoMX+wOR0/gi93h6AlmqrPv2X0g/P13/hQAYGnxoJkJh4NZuwhzxRP5ZGVtQczrbsxmpItzH2fWTql27AV19OVHVd1JMps15OFmyXU1UaAlMSACSqNvs3Od0putGZH08mC9rOg8yeremnzDEluoY1IOxewdVGT+sTz9uj86x6aHpj6DjfLie8c6to1so4gy+04sLu6ZlK+47LpJ+co9Os3BEun2liwyZ74bH9N+BHvrWdse6fNNQgpKEZ/k9Xjs5SdVq+eOfW1SXlk1HK8tecXp46cwdJ3d4eg3fLE7HD3BTLO41tUASzvG4pL1UhJF3GC45Vh0L5A61JaIgnD87AuT8jPHogfTysrfqHZrGzGwxAbCBAoKUWMlNHA8R9OHJonT59H11KS6JJzvKsOTIQHh4BHFaW5UASa8KwR+8Jwsn3oV8nOE4oXLBw0pJzzTBZsHA6W5ElhiCArWMdLzqXMrk/KZc1+flJ879rBqt2/5DZPygf3aLLxv13dPygPoQJ4heTMqs6LJ7Kuu01DEsQcmqyFXXf4WPY/dMVfBsy8+qOoOH/8mAOBMpU29DP+yOxw9gS92h6Mn8MXucPQEM9XZxxjrK1Z3Uy6s1qLGUVisuxmd/Si5Fz59+K9U3cmVSAzYNKSXGz1/wOmRE7MWzzdTAU3EYXPOKcJJ636qdOXucwDtElsHmzOve09AzB4J1yW59agpu73a+bKenvSvriVPulCpvYS8Pq9h8wXE5zQyZtuKcrPVirBRP9ujKzEn3BEqA8Ce5eiee83lf0fVXX5Z1KslRHfckdk7YJJJa6VU6j275kK71W7mSQSAG6/6e6ruQEvq8pcnPo8cpkn/dI2IfFlEviUij4jIh9vf94nIl0Tkifb/vVv15XA4tg/TiPFDAL8YQngrgHcC+HkReSuAjwK4L4RwA4D72mOHw/EaxTS53g4DONyWT4vIowCuAvBBALe0ze4C8BUAHyn3JlH0LvC21Va8HcRprpw7Pik/+cL/U+1eJI+3xkQW1ST+10SmIEZnUAKnVTXAZij2TjNccpyC15JGkAhaGxOj8qArcM9rET+Tu9c0TCR1nr+Vl9lkJ+whZu9VXgRX6as4vZFpx1YoMdFmI+anU2mW9LMNylPQfr8y98Py7tFpQ3NPV85QSujT96m6y5a/OSlfe/DvTsp7l3Tegoq44YcjM382b3JG74Trn82Z+l5dtnNM6sLvucUr2qATkesAvA3A/QAOtH8IAOAIgAO58xwOx/Zj6sUuIssA/hDAL4QQlEN5GP/p7nSyF5E7ROQBEXlg1TChOhyO2WGqxS4icxgv9M+GEP6o/fmoiBxs6w8CONZ1bgjhzhDCzSGEmxfnl7qaOByOGWBLnV3GytenATwaQvgkVd0D4DYAH2//v3vL0YRyuhlf1JoYYzYazav95AtfnZSffZ5MakPtGliR/s2MM+PriGWVCte6ojJho1V0Sd/U08/bUirrHqoi1hI/Wxq76vzdHlodWKWSVnq/dbllPnVjylLtMnMCjFJp9ze62YUqq4eq0wxrkNojib83JhcgRvl5KHOmOiW/z5L0QeSiNt/dypm4h3Tiyf8xKV+57xHV7voD0VS2Y6AjPodsYmMmHBtl2LBZTsO6n3dhGjv7uwD8YwDfFJGH2t/+NcaL/AsicjuAZwF8aIq+HA7HNmGa3fi/QPJtmeC9F3c6DofjUmGmHnSCaGKznmtHzz43KT/27FdU3ZnT0aOposizOUMWybzaSYQWie5sbUv8vthrzqZu0nI2VygM2GRk+m9ocEsWqcU2NkVasgbpaNXWKXJOjjaz3oD5+TMqFq2TdrF/y52vu2cdyt5xJtuwBBucFokiw4x4G6o8sYXmWmfiEzMLqhvZt4JNh0aVGdWsX8TikZeeUe1OnIpRl9cfeJuqO7g/muxA7/fI5FbgZ2sJMKSbKl7BfeMdjp7AF7vD0RPMOBBGJumVHj96v6p5+rm/nJQ5UAXQRBEsvDQJyUUUe2r7d4xFQvrZElRw1lW7w8k9NkpOzbez/HQqDVWyQ949L7vjjuLYrMrw76WAHA3l8caecIV0W1a8VZx3LHYb1YVF6/Q6VUuah77mWvFw6HdCBesovjjbe7fKYIZO5qg4QCoeS5NcbGzEHffHDv1fVffSmaim3vDGH5mUdwyuVO1GDWXltZpGq8qU7qF/2R2OnsAXu8PRE/hidzh6gpnq7GfXVvDVp+4FABw78biZCJmTqnlVx+qg1id19JAoU1nB7Yy92KxLV9ZLznin0ZxsLjbtJmYi20hPt2QQuXTRaWRb9zw2z+zqw7p+8bWNrB6a8bxr7C1VxBbWE7H7O1KMerNtlS7O3mPWa7AQKpa5HwnhKR3bqEvt9VjYx+G8dYZEgwk/Kxiz84mos585/4eT8luuuUW127czct0PTc65SfRm0YzqcDh6AV/sDkdPMFMxfjhaxcstwcScDWYgubKyvGokmtVMppDIsCWyhtDVLDEZKVHd9F4ps1khUEUd20o+z4jWGQ+9RCRW5Bj5AAjF/57MIy8WNyS2DqiqTsg88sQWKrU2utUCwBBn2KAh5V1H3m+Jh1uch018pMXnQoASeRg2TWKMpHloNJlrsyogc8WPzPMc0Ot+/nwMAvvmU3+m2r356kii8ca979TzaDZNb3n4l93h6Al8sTscPYEvdoejJ5h51NtEZU30VSbdsySNEU2B1IH7tOYN5SJLpjEbHcc3xOp1yvTE+edsrjTl9low7dkLyETjJfpf7iQDdZ6ZxmA+nrd7zx5Vt7Ea7+P6uXOxC2vuYR72RJ+noQsk+8qd2JI1MBFjw3s1lniCzrF7B5xnDvx+2EjCfHSfep7JFgmbJumdaOxeEI+tB+Aou3oQy6OR7uOxZ6OL+fpoVdVdd8W7O+fO8C+7w9ET+GJ3OHqC2ad/akUzKz43BTORKJE/n7LZhCcpVOq8vAlGebwl3lKcohhZaDb1vHhr3d8qZQ7rNjsBaSSd7p/MRCTHb4x0tNnu3bsm5R1LO1Td/ELs4+zp03F+xjuNeQOT7FKKo10pJWa+SklTdUq8pWtJPP5IVLfPZajC0qgiEffZM1NX6dud/z7yvU854fLq20gtQ3o3a0PmQWrUU8zFCGAtvAQAWN1Yyc7Pv+wOR0/gi93h6AlmTl5RtUOOjMjG3lmpd1N3naXdGqhgBjt0dxqgyrZUlgDr0aVmHFtZ64HajbfqCqsTRkzLqBqpKlDQITIBP6vrevf25WNRrF84o6m75+Yi8cKLx09MyvuWF1S7wc6oCiRWB0VK0fnz5pmxnelC37v8bjbfD5sWqVbeb3GsYYE4pETLbNNGqfMKqsCId+OtOkTX1pB60STptmgsowJ+5/kxh+P6hn6WDP+yOxw9gS92h6Mn8MXucPQEMze9TbyYjCsSRyclzOKkn7DOa/9Ssf5dinpT5yXeafnIOeWpJXnyQp1yyJrXaKzEPMiV+XTI6loSk1c8b20j6uVHXjis2i0sxEffiNbF2Uy5vnZ+Ut6943LVbo3SYlfGu25uQB6MhTRUOsW0rtJ888Sjb/Y6NId6PmKtCvF+pCZXJou03m/dXPzjSiLdVL1ZP0d+vzXpCgIvw/wc1btk9iZiSqz8fs6WX3YRWRSRr4rIN0TkERH51fb360XkfhF5UkQ+LyLzW/XlcDi2D9OI8WsA3hNC+AEANwG4VUTeCeATAH4jhPAmACcA3H7JZulwOC4Y0+R6CwA206XOtf8CgPcA+Nn297sA/AqA3y52JtGrKxlY8ZNbswgTF+S95AKTKRhyDBYJtRifHysNOelWIRJxS6WGMgEXShUwppVMSikrEipVw8jxPJd14irfv/8y1W7X3mg2W1vXfbz4YjS3DdcjV/n5NZ2OCIMo4tv0Q4u7ohjPZBipeFt47ty2pHsFVtGsiE/NSIcKTf7ZWk8+Hf+UT6MV1Pthnrty5DNpyzIenYkBkFSlhL++HfuCyStEpG4zuB4D8CUATwFYCSFsvk2HAFw1TV8Oh2N7MNViDyGMQgg3AbgawNsBvGXaAUTkDhF5QEQeaEbN1ic4HI5LgldkegshrAD4MoAfArBHInfz1QCez5xzZwjh5hDCzZVNnelwOGaGLXV2EbkCwEYIYUVEdgB4H8abc18G8JMAPgfgNgB3b9kXoq4xMvqZ4l5PdPHuKqvTDBSxhc09lnFTTUKcMvsDMGY/pV4nicOy/WuznL2C7hxr1vU3dz8AvSewuBgNJPVgyTSMj35xXvdy3bXfFc9j900z1nAY9dcNIrkAzP4DTdj+uR8xV35ilWOTF5FEmD5k2htCaBrrqkx6c2XNa6wr21xy3UMHu3egnq3uXpGAqJPMu0OHJtl3mp+uA9PY2Q8CuEtEaoyf1RdCCPeKyLcAfE5E/iOABwF8eoq+HA7HNmGa3fi/BvC2jt+fxlh/dzgcfwswUw+6gCjOWM+yEUWOJemWuQ/2xkq8oKhdEoRFYiCJTXXitcXn2Lo8d51qp0Q7y6fePZY9T6WoKngDJuZBdW2x3TMvHDGdRLOc8nYDMLcYRf6dO6N33dy89rQTImlfXtIpiqsBe3uxyUtPo2ryaoJ+GBz1plFK/8RqU9OsTco3vUPvMb9wKNYd+c5Tqm4w100uMR6OTWUh206pjoafrqE65pdPNBDOgm1Nup2javiOmcPRE/hidzh6gm3goBsLGqkYEnc5rWitRfcRtbN/qzgQxnpBde+kN0YM1jfE7rJngjaSzXiW1fPzSFnK+Drz6Zk0n5mpyYj4jRFvN2gn/fxZ7RknL56dlE8vxhEOXHVQtWMR+YwNzDi1Minz86sThoqailqdGFRRNahr3s22lpa8hx7PKiCK6j/1j35UtTtwzfsn5f/wb/6tqnviwUjhvDBvbCOKCpt/N16PnNKs0nvpTGbBXngjs+cuKvjKel92DqvHyVc5HI7XE3yxOxw9gS92h6MnmHn6p4l3klEuasXJbj2HyDRRTGVcSKNMZU1gWTCNJSmESTcMrDcXBiuRRZaivJQHmvXC45PyxInsCKa1YV05NB50TLo5mI+vyOX7r9DN6lgXEo+0iNEomvmGQ02IuEqRdOfPa1LM9Y24dwCJ5w1E681zg+gpuLDDmADpFV9aiuWrr32Tave91143Kf/mb/0nVffrn/j1Sfl/3fP7qo757JUFsOk2jXWB942YuNN6cLIXqK0rj7B5vsPh6AV8sTscPcHsTW8tkuAOyXunaYKDvOkKBRGZnL0w300hn4yVRGZkOeI0VPxGlRfnEv53Nq0oXvrSPIyqwdI/m2cGmjVsYY5EwqE28WysEg/agER1821gAohQcPeKwZHA3JzuY26OA3T0dY5IFG5GUdwfGm709fVoUjtz7qyqGxKBx669y7FiYadqd3T1hUn5st3Lqu5Xfu2XJ+X/euObVd1nf+tTcR7nKVWWeT+Ub13Qb39N5mSVBs3cU06HBZOrIHFN7IB/2R2OnsAXu8PRE/hidzh6gtnq7IKJrjEKxjGVdE9rJlJEgUoXshFOUfdJI+IyqZgT85qdcPexKJ1Ut0o5ybv7r8TW5dI0l/R+i26SxlGj9fJmNeqyYvRodlsV0psrM+FAfdooQ8XfwUSgpl2jdE2bM4/cbCk99KDW5rXFxZhy2va/thb1+xu/L9IkHn/5tGr30vHHYv9z+t3csRD7/9Ef01Hdizv/xaT8O5+M+vvq2ZOqnZC50BJbaPAF2Lx1THJhokYndfl3z7/sDkdP4Ivd4egJtiH9U8tvnTidacFPgyLWOBVwIYVUIsxkONFS0TE/DZ1SOd+wlIyoUt57VmkgU5MiubAT4XY2uioeD5W3oTb3DIfRXNUMjey7EY9XyRy4el6LvnuujFFw507qupykmlgzC1ApkNXv9q5SymOj8gyIRGNuce+k/L///P+odqdfXpmUz5zU5rvTJ05T3YqqW1+NJsGGPAUhemnxs7XPPaj3lm+cfmYj0TF8jHqK++pfdoejJ/DF7nD0BDMW4wVSbe702p1GFtn036ABi7eawznpf1Iy4q3OwNpN2Tw+Jg+9YnyLdP8Oq6IU2ARskEz3RrrhNjNjV9ozjoNfrty3e1I+9Jx+1Iq0w6Ru4qSu1SieJ8YLb24h7tov7tql6tZWzsQDZf2w6ZM4eMncK/WKdNNKj/vgDKzmWsgD8PGHDk3KD/7F03q+66zWGCIOpU7o+XNwFBuKLB21qDxUJv2Tapg9MKK6UQVaK1dKT05zytY4HI7XFXyxOxw9gS92h6MnmL3prVVDKqtbKc84y6vdbYIRM30daJSPnIMiytDz0+SWNg1QxtxWSPucmM2KxPHklYe8p6DU7A2oO9l7eYzm2rk/mppGiecadWHegrAWx96zJ3qrXXmtTtR7+nj0ElvapSPF1s/HTkcUpWafu0p5lZBFsi7efQ5goiQLnA4r5DWXROlxFwOtU7OF1+Y0YA9AxSGf5C0g706rV4fu9yVJc0VDN8b8uGmmTMlJI6b+srdpmx8UkXvb4+tF5H4ReVJEPi8i81v14XA4tg+vRIz/MIBH6fgTAH4jhPAmACcA3H4xJ+ZwOC4uphLjReRqAD8G4NcA/EsZy6nvAfCzbZO7APwKgN8u9gMKVkk8jJhXW5/HRABNSQouiciZVKJWVC+J4ErySwgluA+eRp5nTqw7GQVLKIXB8qSTGL9B5AwAsGuZgljmY7mxpk5FEqevc0htz56k7KyGGGKdPO2WRtoktbAY7XejjWjWSsVsmoiRW/leBVJxqiQwiMylwd5vKnNAVaK/kYdb4hFJ6lXy2HNid/65W1Fb5TEI+XbcZTD5CDbnXDL0Tvtl/00Av4R4PfsBrIQwSRh2CMBVHec5HI7XCLZc7CLy4wCOhRC+/moGEJE7ROQBEXlgNLJZpR0Ox6wwjRj/LgA/ISIfALAIYDeATwHYIyKD9ut+NYDnu04OIdwJ4E4AWNyx8ArCIBwOx8XENPnZPwbgYwAgIrcA+FchhJ8Tkd8H8JMAPgfgNgB3TzViS1phI9a0HqZNHypiiM8xChRrMYOE8I+izRR3Rd5EZ/PRMW+3cpN8BS6xldowMHqXsL7GEXYmwokiuRroNMpnT0Y31eWlaHpb3KkJH9YlRmsZD1ZUTTSV7dq3b1KeW9IusauHo/tp2KX7V9sbah/EPLPAOq/VxZWS2lVMkMbDdefnS+IqyZTVFPRyqysrF20et7B3YN2flSs3m+HEuu1SO2sCxKbpLY8Lcar5CMabdU9irMN/+gL6cjgclxivyKkmhPAVAF9py08DeHupvcPheO1gG1I2JwUAWjSrbGSUdHuMJZ5IyuZlIoa6J9ERHcckA1YVYHWiVjUMDniy4mJDUVOWg66Yb1e1i8Xly7Tn2pFjUbTeRzx/zKMGAKGhVEuNHneJRP433xjTJB17aUW1ayg9Uz24UtWdPxdNdiVev5Cv0vz71DIRVafcCVK8gYYDUVQkpPVwyw8V2INO8u+VcORcwcuvUSmgbWpqJunQ2Exz7imbHQ6HL3aHoy+YqRgfEMX1ZIeZZLih+RvE4pcSn62oVKBfVjIibcfbnV1FA51oCSyfs1hmvZlYxLfqCpNj5DOwai88o2qsR1VgbkmPfdkV0bfpO89+O85puKHaLVRRVD+3oT3jqjqmZPrOtw9PyqtBp1160/d8z6S8sabnMSIyCCXShoIFwsimmqeEvSitrxqpRvZ+E1GElMRx5cWWf/8ssQrX5VTF8Zzz1hvVI1snkncTWdjAmy74l93h6Al8sTscPYEvdoejJ5ipzi6QiW5uI3pYHbbpnxgcgVSL1ZKIXz5J69Rtsivq7Ekf3TY1a6IrkVGy51OF7sil8Vh5Ak6O7Dpz6qSq20EkEvv3RXPYUfJ2A4DzZ4kQ0sQsrFZRN9+9K+rv1195vWo3XI/zP0emNkCnigpN/n4rVdOkIU754cdIdd6CGVTti7BpzHRKE7PvjoqETJTjbs87u4/DpBfWU7BSZkXOkVAgGjX3ZpOwteTN6V92h6Mn8MXucPQEs8/iuil6J8QNKnQiPa8LRiZUXN0Jt3j3UV3IR5RmguW6ci7VzBSh+c+tuMhlzvppxb7YcDTS4uLpEyuT8pCk8x07tQfdBqK4PzJmueXlPZPyzqXIPX/+3HnVrmkoE6xVqTKqTLDPNmTKsOoWi9kwDamd5TbMmGOTcBa+90Z8Vlx49lmzxyXZyhLiCTWN5AK6ywV+fItScNBkfls3cTgcrwf4Ync4egJf7A5HTzDzqLdNU0hIzFoRqUbDJhMmkLCpb0n3rPKXlnPDHNe98sizdEcg7xqpSCkSJZXdMvN9KNJN41PZ0HFDJBSW6GPHfCS9aOY0AQbfg421GB3XDLRRdFDlTV4qlxznQLM+oMpNVev9OsqwO3fAuF0+2ozNd5Vye81OIzHLcR91QivJxBZMfGnn2P1s7eBssrPmNe1Ka69ga8o3/7I7HD2BL3aHoyeYuRg/ifSykgyJQHUiSdf2h/E5lRXZusW+cWNKPaxEKtN3JtXU+DjHQZfYjGKxwHFnRWsmK7ARcXnkedtYXNQiNxDmYgKfxpCu1cRLL3yeuSGNErPtdbKZK3/NSn2z+QJCt8qTxDOqofORhPxtS6jksrPSHpLJc8mFmyXWY/buNGmf2W4W8lGdiv/ODNt0/1yaksPheL3CF7vD0RNsQxbXzUAYSwIQYXcalVivRDsNlUbH7JqK4n4redrlCeTUjqrk56HE/URe5Dp7Xs4SkGwP05ymEyuTlENFTy19ZlcR0Pc7HbXqKAFieauZXMLuMGeIRNKUWow8Dbnmu7MWlDivxr6byssvz0tY8qrUAS7Qdeoy896A/MysUaNu25ZsSf5ldzh6Al/sDkdP4Ivd4egJZkxewapSXj9LSf1Ij1EKjzHjUORVwvme0XNttJb2YrN/C1kPLZje1BwLaaiSaLYINlcFG6PFanSJOVGRYupmOsIupdjoHCxJ3cQc+9absZtPvU5tUp2jAvoeaIdFu4dBYyWmSDqN34FkvrmzYN5N2z8/T/7dEnFQuUCcMW3ugNruCWy+74XTp83P/gyA0xj75A1DCDeLyD4AnwdwHYBnAHwohHBiqpk6HI6Z45WI8T8SQrgphHBze/xRAPeFEG4AcF977HA4XqO4EDH+gwBuact3YZwD7iPlUwTSDmnFPg6+aKyXEonFkjHpAB2EAar/eKkhMM+49bgqBKqohtmDjmOeR75LJYKqgAh90qgi85WNf2DRnc1E1gRI6osU1ASdSDUfbGHNRHwLuDubIVXz7tl0RypiqavYzisfgKK85hLKCupT8nK25pPLG/pG6n6XSDTs4N3mtsQLVN3U7v4vBgddAPBnIvJ1Ebmj/e1ACGEzg8ARAAem7MvhcGwDpv2yvzuE8LyIXAngSyLyGFeGEIIk2fDGaP843AEAg7nZ55F0OBxjTPVlDyE83/5/DMAXMU7VfFREDgJA+/+xzLl3hhBuDiHcPBj4Ync4tgtbrj4RWQJQhRBOt+X3A/j3AO4BcBuAj7f/373laBJVGUtekdeKtJ5eInVQXRrTG9cxdzvr7+M+OeoobwJkbc26xKr0v5Z4okReSFD7D9adlYkNE1282wxlTZEV7YNY0ohhpo/Q2HvKzyLPga8jC41JiudV0PsLKrXa0yiZALP7GWYsC2Ves+8tDafchxPyCrof1uWW5sUmtRJZack9OYdpPrUHAHyxfbADAP8thPAnIvI1AF8QkdsBPAvgQ1P05XA4tglbLvYQwtMAfqDj9+MA3nspJuVwOC4+Zh/11v5vxXgWTCobuZQlcjBRQUqML5gt+Nda34KGxL7KpgaWbs41S60hmbI+K63UMVMkzqVuclSyKkQss7daSFIr0f02YuVAeXRxumzdjlWSgZE5lfifjQzT80hNnRmVzdyPEn9hd2+ldyrthM1hJfNdqQ9R6ptVh3JKbMIWkqtJvSw74L7xDkdP4Ivd4egJfLE7HD3BjHX2MEnLW4nmILfOf9kjNqEl0U/crGTGKaT4Zb75MFR1UNFbmYgsgyQ1dSFaTuueRQUtzjfh389dm40ClEw76+nJer+eRpXTqTuOu0cquyRrTva8cVar33mzltL1C2SfJS9pW8X3f8R6eWofjMUC007CPKQGi8XaulCHblLWzOkOh+P1DF/sDkdPMGMxXibeVDYtrjLFJWJrN5d2yh/OolI69qRE3mOpCZDaiTXLRbG+qSLvuo1OqgtzZKQifuYo8ZJjs1wpmioWK9uOIueSwLkmFymWJwlNxU+uzac0CiXDmRK78xFfirCxQOaY69rOMUkrrcyIeZ1KG81Kz8WmkKIqdX8KKk6Sj6BrFsi0cTgcr2v4Ync4eoLZc9C1InQq5rDYasW0bq4zsYEqoaAK8O4rE1QkJAMlTyQifOAAGpuGKsNLliIv+updZHOWuszCVj03rLSwzl5zjZFp9W1lkouSUpK/UiVyBivCEm9ggfuNr8vmFVDn2aCkzAZ8URwv5IaqEu+9jGdm4aFZEVw9w6JpJ88HGLvMPyP/sjscPYEvdoejJ/DF7nD0BDPV2QOijpPmemNzVUEnU+eYY8nr/TptWMnTqXtO43l054FLA/jy18KwxJqVMvF0c9QD2owWjOEsF1VXJiK03lfd3l7pc4m6rc2PpqfB+nB2qLRSqexsEs1H8FmEDOtFyXuxRIqZ9K/mUfJKLJBdqne/QG6iTK66qino6pvwL7vD0RP4Ync4eoLZmt4kcqFZjyslslRW5GERjvub3sNIi4EqYibXrCNgoXs8a7oqccOPQrzllgwi541l70YpWEKbEumaE0tQITAjyzdvTYx8Tl71YpXEcuaV7nfWCy9JqVV4DzLXkrx/SsQvie3WPNhNSpGQiiiTqOk0l6bLqpjTeEsWmviX3eHoCXyxOxw9gS92h6MnmG3UW5CoGyUusRwZpaeldfN4XpOYggpRb5wvTiubhbE0tPqqbHm6nZ6UgiZiLLnmssutHqApuNJmCSuSG8L3qjY13SYka4JSXOiWSLJk3iTokUo6aeF+FPrgI56/Na+Vnmej3k1zntr+yUfw6Tx+2S70vbL2NbXnUIqY7IZ/2R2OnsAXu8PRE8xWjJdoPUiNLHmRMzDZBLWri+Y1U6UGYzNLxyQ3z0nEz8x5iUoSy4n3W0URdyNL4NE948ZOI8PpMK7jiL5MBBy0eS0Rn7PmJI2qYZNaXpdRUYCGvKLJXPO4i25zWOpZlk8lrd6rwOY7DaUSJp6N0wjJutfUqEqqko0yZM84FXJoI/gKzyyhIEkx1ZddRPaIyB+IyGMi8qiI/JCI7BORL4nIE+3/e6fpy+FwbA+mFeM/BeBPQghvwTgV1KMAPgrgvhDCDQDua48dDsdrFNNkcb0MwA8D+CcAEEJYB7AuIh8EcEvb7C4AXwHwkWkHtru37E1mBRJOY6S9u0pkB6Yqc5SqE3kRPxGnJ9PIz8Pu+jKPHXPhAUCtxOJ8UEUp4CLH6WZ3sEcFHjudqoitHxr6NBusw+1YDTNglcpkic15142mFPcBG2xEqpFpV9PVjUpBQ+ada7Ked3ndK7H4ZCwB1gtU2VmSZyadozKm+bJfD+BFAL8jIg+KyH9pUzcfCCEcbtscwTjbq8PheI1imsU+APCDAH47hPA2AGdhRPYwjjHsNFCLyB0i8oCIPDDcGHY1cTgcM8A0i/0QgEMhhPvb4z/AePEfFZGDAND+f6zr5BDCnSGEm0MINw/mZp401uFwtJgmP/sREXlORG4MITyOcU72b7X/bgPw8fb/u7ceLkz0lZI+khBJMqc3KYO10VCUjpeGeVFlnrivQk5vtlsE3J+NcCp4rhWc3xQ9vurS/E1WnlR5aE/B6XTqFPmUzdqEZJ9FxiMt8bSL7WpzrxSxpNKNLQpejzkPwKQTNg/mPQUtWQinf9JvlX0n8kNLhrM+jf2k/ZPiM+vGtJ/afw7gsyIyD+BpAP8U4zfwCyJyO4BnAXzoFY/ucDhmhqkWewjhIQA3d1S996LOxuFwXDLMPP1T5KBLazZRl4RTJR1aAgL2OrNeViQuZogVbJ+JBJ6RxVKJKu+5pkTyxqZ14nnl+1ABKEld971LvQEzY5k6TRSR97RLvMK4N+bpLwT/WNOmFNQtqJp8EIueB/1uTaJ8T6u8upIQZ0wtTbOXnDGD0sSqTNAXYJ91Tk0tmA2nmabD4fjbD1/sDkdP4Ivd4egJZm74juYDY15jfTVxJ2T9suASmyFbLKEqRawlXo3Mkx7tZCmRQMEUpPQ/o7+GzHUGa3qjqgJJY1PYf9jCaNd5XlMwJ5XJGvLkD+rKEr2fo7xKJBo8R5i6zLVY0pJM2f6gcvwh/z5aM6UazeS7023ZNVz3qcYyw25y55eeqn/ZHY6ewBe7w9ETSCl1zkUfTORFjB1wLgfw0swG7sZrYQ6Az8PC56HxSudxbQjhiq6KmS72yaAiD4QQupx0ejUHn4fPY5bzcDHe4egJfLE7HD3Bdi32O7dpXMZrYQ6Az8PC56Fx0eaxLTq7w+GYPVyMdzh6gpkudhG5VUQeF5EnRWRmbLQi8hkROSYiD9NvM6fCFpFrROTLIvItEXlERD68HXMRkUUR+aqIfKOdx6+2v18vIve3z+fzLX/BJYeI1C2/4b3bNQ8ReUZEvikiD4nIA+1v2/GOXDLa9pktdhGpAfxnAP8QwFsB/IyIvHVGw/8ugFvNb9tBhT0E8IshhLcCeCeAn2/vwaznsgbgPSGEHwBwE4BbReSdAD4B4DdCCG8CcALA7Zd4Hpv4MMb05JvYrnn8SAjhJjJ1bcc7culo20MIM/kH4IcA/CkdfwzAx2Y4/nUAHqbjxwEcbMsHATw+q7nQHO4G8L7tnAuAnQD+CsA7MHbeGHQ9r0s4/tXtC/weAPdi7PW9HfN4BsDl5reZPhcAlwH4Ntq9tIs9j1mK8VcBeI6OD7W/bRe2lQpbRK4D8DYA92/HXFrR+SGMiUK/BOApACshTIjtZ/V8fhPALyHGsOzfpnkEAH8mIl8XkTva32b9XC4pbbtv0KFMhX0pICLLAP4QwC+EEE5tx1xCCKMQwk0Yf1nfDuAtl3pMCxH5cQDHQghfn/XYHXh3COEHMVYzf15EfpgrZ/RcLoi2fSvMcrE/D+AaOr66/W27MBUV9sWGiMxhvNA/G0L4o+2cCwCEEFYAfBljcXmPiGyGPc/i+bwLwE+IyDMAPoexKP+pbZgHQgjPt/8fA/BFjP8Azvq5XBBt+1aY5WL/GoAb2p3WeQA/DeCeGY5vcQ/GFNjA1FTYFwYZB9x/GsCjIYRPbtdcROQKEdnTlndgvG/wKMaL/idnNY8QwsdCCFeHEK7D+H34nyGEn5v1PERkSUR2bZYBvB/Aw5jxcwkhHAHwnIjc2P60Sdt+ceZxqTc+zEbDBwD8Dcb64S/PcNzfA3AYwAbGfz1vx1g3vA/AEwD+HMC+Gczj3RiLYH8N4KH23wdmPRcA3w/gwXYeDwP4d+3v3w3gqwCeBPD7ABZm+IxuAXDvdsyjHe8b7b9HNt/NbXpHbgLwQPts/juAvRdrHu5B53D0BL5B53D0BL7YHY6ewBe7w9ET+GJ3OHoCX+wOR0/gi93h6Al8sTscPYEvdoejJ/j/BueHPqoKGzwAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "images = f['images'].reshape([-1,64,64,3])\n",
    "plt.imshow(images[0])\n",
    "# images.reshape([6,6,2,3,3,40,40,64,64,3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "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": [
    "images.shape\n",
    "\n",
    "\n",
    "def process_index(idx):\n",
    "    dimensions = [6,6,2,3,3,40,40]\n",
    "    label = []\n",
    "\n",
    "    for d in reversed(dimensions):\n",
    "        label += [idx % d]\n",
    "        idx = idx // d\n",
    "    return list(reversed(label))\n",
    "\n",
    "labels = process_index(np.arange(len(images)))\n",
    "labels = np.array(labels).transpose(1, 0)\n",
    "\n",
    "idx = 655458\n",
    "plt.imshow(images[idx])\n",
    "plt.title(str(labels[idx]))\n",
    "plt.show()\n",
    "\n",
    "\n",
    "dataset_x = torch.tensor(labels).cuda().float()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.manual_seed(658)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False\n",
    "\n",
    "networks = []\n",
    "multitask_targets = []\n",
    "for network in range(50):\n",
    "    network = nn.Sequential(\n",
    "        nn.Linear(7, 300),\n",
    "        nn.Tanh(),\n",
    "        nn.Linear(300, 300),\n",
    "        nn.Tanh(),\n",
    "        nn.Linear(300, 300),\n",
    "        nn.Tanh(),\n",
    "        nn.Linear(300, 300),\n",
    "        nn.Tanh(),\n",
    "        nn.Linear(300, 1),\n",
    "    )\n",
    "    \n",
    "    for module in network.children():\n",
    "        if isinstance(module, nn.Linear):\n",
    "            torch.nn.init.normal_(module.weight.data, 0, 1.)\n",
    "            \n",
    "    network = network.cuda()\n",
    "    targets = network(dataset_x)\n",
    "    targets = targets.detach().cpu().numpy()\n",
    "    multitask_targets += [targets]\n",
    "\n",
    "multitask_targets = np.concatenate(multitask_targets, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "mpi3d = {'images': images, 'labels': labels, 'multitask_targets': multitask_targets}\n",
    "np.savez_compressed(\"mpi3d_multitask.npz\", **mpi3d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-11.780248    -0.21679541  -0.39157826  51.10386     11.741002\n",
      " -20.40133    -10.99998     35.743584   -21.485134    -0.10833603\n",
      "  -6.3265314    5.3337183    0.45183036 -44.748135     1.0263846\n",
      " -16.234142    10.764619   -17.793833   -11.27251     -7.739171\n",
      "  16.869694     3.9488254   -5.576894    -8.402218     0.6171662\n",
      "  27.24728      1.9098554  -14.695993     0.27298242  -6.4692616\n",
      "   5.4376836   26.029087    -2.8916068   24.56573      0.5793803\n",
      "  26.435556    12.672287    18.62973      9.656433    13.737272\n",
      " -15.70365     -4.396952     6.569562    -6.1971693  -21.064194\n",
      " -12.520681    -9.120901    -3.5052545  -31.046425     8.920781  ]\n"
     ]
    }
   ],
   "source": [
    "A = np.load('mpi3d_multitask.npz')\n",
    "print(A['multitask_targets'][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "images = A['images']\n",
    "labels = A['labels']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1036800 1036800\n"
     ]
    },
    {
     "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": [
    "idx = 250555\n",
    "print(len(images), len(labels))\n",
    "plt.imshow(images[idx])\n",
    "plt.title(labels[idx])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Custom Splits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks=50\n",
    "num_true = 7\n",
    "\n",
    "\n",
    "#[1,1,0,0,0,0],\n",
    "#[1,1,1,0,0,0],\n",
    "#[1,1,1,1,0,0],etc\n",
    "grow_splits = []\n",
    "for i in range(num_tasks):\n",
    "    temp = np.zeros(num_true)\n",
    "    temp[:((i%(num_true-1))+2)] = 1.0\n",
    "    grow_splits.append(temp)\n",
    "\n",
    "\n",
    "#[1,1,0,0,0,0],\n",
    "#[0,0,1,1,0,0],\n",
    "#[0,0,0,0,1,1],etc.\n",
    "independent_splits_v1 = []\n",
    "div_size=2\n",
    "for i in range(num_tasks):\n",
    "    k = num_true//div_size\n",
    "    temp = np.zeros(num_true)\n",
    "    j = i%k\n",
    "    if num_true-div_size*(j+1)<div_size:\n",
    "        end = num_true\n",
    "    else:\n",
    "        end = div_size*(j+1)\n",
    "    temp[div_size*j:end] = 1.0\n",
    "    independent_splits_v1.append(temp)\n",
    "    \n",
    "    \n",
    "independent_splits_v2 = []\n",
    "div_size=3\n",
    "for i in range(num_tasks):\n",
    "    k = num_true//div_size\n",
    "    temp = np.zeros(num_true)\n",
    "    j = i%k\n",
    "    if num_true-div_size*(j+1)<div_size:\n",
    "        end = num_true\n",
    "    else:\n",
    "        end = div_size*(j+1)\n",
    "    temp[div_size*j:end] = 1.0\n",
    "    independent_splits_v2.append(temp)    \n",
    "\n",
    "#random\n",
    "#[1,0,1,1,0,0]\n",
    "#[0,0,1,0,1,1], etc. \n",
    "rs = np.random.RandomState(11)\n",
    "random_splits = []\n",
    "for i in range(num_tasks):\n",
    "    temp = np.zeros(num_true)\n",
    "    temp[rs.rand(len(temp))>0.5]=1.0\n",
    "    if(sum(temp)==0):\n",
    "        i = rs.randint(num_true)\n",
    "        temp[i]=1.0\n",
    "    random_splits.append(temp)\n",
    "    \n",
    "\n",
    "\n",
    "torch.manual_seed(658)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False\n",
    "\n",
    "\n",
    "class Masked(nn.Module):\n",
    "    def __init__(self, split, input_shape):\n",
    "        super(Masked, self).__init__()\n",
    "        self.split = split\n",
    "        self.input_shape = input_shape\n",
    "        self.mask = torch.zeros(self.input_shape, dtype=torch.float32).cuda()\n",
    "        self.mask[self.split] = 1\n",
    "    \n",
    "    def forward(self, input):\n",
    "        return self.mask*input\n",
    "        \n",
    "    \n",
    "SPLITS={\n",
    "    \"grow\":grow_splits,\n",
    "    \"independent_v1\":independent_splits_v1,\n",
    "    \"independent_v2\":independent_splits_v2,\n",
    "    \"random\":random_splits\n",
    "}\n",
    "    \n",
    "    \n",
    "    \n",
    "def save_splitted_dataset(split_type):\n",
    "    networks = []\n",
    "    multitask_targets = []\n",
    "    split_array = SPLITS[split_type]\n",
    "    for network in range(50):\n",
    "        network = nn.Sequential(\n",
    "            Masked(split_array[network], 7),\n",
    "            nn.Linear(7, 300),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(300, 300),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(300, 300),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(300, 300),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(300, 1),\n",
    "        )\n",
    "\n",
    "        for module in network.children():\n",
    "            if isinstance(module, nn.Linear):\n",
    "                torch.nn.init.normal_(module.weight.data, 0, 1.)\n",
    "\n",
    "        network = network.cuda()\n",
    "    \n",
    "        \n",
    "        targets = network(dataset_x)\n",
    "        targets = targets.detach().cpu().numpy()\n",
    "        multitask_targets += [targets]\n",
    "\n",
    "    multitask_targets = np.concatenate(multitask_targets, 1)\n",
    "\n",
    "    mpi3d = {'images': images, 'labels': labels, 'multitask_targets': multitask_targets}\n",
    "    np.savez_compressed(\"mpi3d_multitask_{}_splits.npz\".format(split_type), **mpi3d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.]),\n",
       " array([0., 0., 0., 0., 1., 1., 1.]),\n",
       " array([1., 1., 0., 0., 0., 0., 0.]),\n",
       " array([0., 0., 1., 1., 0., 0., 0.])]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "independent_splits_v1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.]),\n",
       " array([1., 1., 1., 0., 0., 0., 0.]),\n",
       " array([0., 0., 0., 1., 1., 1., 1.])]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "independent_splits_v2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "grow\n",
      "independent_v1\n",
      "independent_v2\n",
      "random\n"
     ]
    }
   ],
   "source": [
    "print(\"grow\")\n",
    "save_splitted_dataset(\"grow\")\n",
    "print(\"independent_v1\")\n",
    "save_splitted_dataset(\"independent_v1\")\n",
    "print(\"independent_v2\")\n",
    "save_splitted_dataset(\"independent_v2\")\n",
    "print(\"random\")\n",
    "save_splitted_dataset(\"random\")"
   ]
  },
  {
   "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.5"
  },
  "pycharm": {
   "stem_cell": {
    "cell_type": "raw",
    "source": [],
    "metadata": {
     "collapsed": false
    }
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}