{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import packages and train models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import scipy  # linear_sum_assignment not supported by jax.scipy yet\n",
    "import utils as vae_utils\n",
    "import train\n",
    "import models\n",
    "import input_pipeline\n",
    "import tensorflow_datasets as tfds\n",
    "from concurrent.futures import ThreadPoolExecutor\n",
    "from PIL import Image\n",
    "import numpy as np\n",
    "import ml_collections\n",
    "\n",
    "config = ml_collections.ConfigDict()\n",
    "config.act_fn = \"colu\"\n",
    "config.dataset_name = 'binarized_mnist'\n",
    "config.model_name = \"mnist\"\n",
    "config.learning_rate = 1e-3\n",
    "config.batch_size = 128\n",
    "config.variant = \"soft\"\n",
    "config.share_axis = True\n",
    "\n",
    "# key, latents, dataset, model\n",
    "rng = jax.random.PRNGKey(0)\n",
    "rng, z_key, eval_rng = jax.random.split(rng, 3)\n",
    "z = jax.random.normal(z_key, (64, 20))\n",
    "ds_builder = tfds.builder(config.dataset_name)\n",
    "ds_builder.download_and_prepare()\n",
    "test_ds = input_pipeline.build_test_set(ds_builder)\n",
    "\n",
    "# utils\n",
    "def copy_pytree(pytree):\n",
    "  return jax.tree_map(jnp.array, pytree)\n",
    "\n",
    "def mat2pil(mat):\n",
    "    arr = np.array(jnp.clip(mat * 255.0 + 0.5, 0, 255).astype(jnp.uint8))\n",
    "    return Image.fromarray(arr)\n",
    "\n",
    "def eval_f(params, raw_images, z, z_rng, model, config):\n",
    "  (recon_x, mean, logvar), intermediates = model.apply({'params': params}, raw_images, z_rng, mutable=[\"intermediates\"],capture_intermediates=True)\n",
    "  return recon_x, mean, logvar, intermediates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# config.latents = 2401\n",
    "# config.num_groups = 800\n",
    "# model = models.model(config.latents, config.dataset_name, config.act_fn,num_groups=config.num_groups,variant=config.variant,share_axis=config.share_axis)\n",
    "\n",
    "# # train and save\n",
    "# config.seed = 13579\n",
    "# loss = train.train_and_evaluate(config)\n",
    "# another run\n",
    "# config.seed = 0\n",
    "# config.num_epochs = 50\n",
    "# loss = train.train_and_evaluate(config)\n",
    "# log_dir = f'log/{config.act_fn}_shareaxis_{config.share_axis}_{config.variant}/C{config.latents}_group{config.num_groups}/'\n",
    "# ckpt_dir = log_dir+f'seed{config.seed}.msgpack'\n",
    "# print(f\"checkpoint saved at {ckpt_dir}\")\n",
    "# # let's first align a pointwise activation instead"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Pointwise alignment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "# train twice with different seeds\n",
    "# default net\n",
    "config.latents = 2401\n",
    "config.num_groups = 2400\n",
    "# narrow net\n",
    "# config.latents = 101\n",
    "# config.num_groups = 100\n",
    "# wider\n",
    "# config.latents = 24001\n",
    "# config.num_groups = 24000\n",
    "\n",
    "\n",
    "# config.seed = 0\n",
    "# loss = train.train_and_evaluate(config)\n",
    "# config.seed = 1\n",
    "# loss = train.train_and_evaluate(config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "base model:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/evergreen/.local/lib/python3.8/site-packages/jax/_src/ops/scatter.py:92: FutureWarning: scatter inputs have incompatible types: cannot safely cast value from dtype=float64 to dtype=float32. In future JAX releases this will result in an error.\n",
      "  warnings.warn(\"scatter inputs have incompatible types: cannot safely cast \"\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "alternative model:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'bce': Array(70.21439569, dtype=float64), 'kld': Array(28.7202, dtype=float32), 'loss': Array(98.93459528, dtype=float64)}\n"
     ]
    }
   ],
   "source": [
    "model2 = models.model(config.latents, config.dataset_name, config.act_fn,num_groups=config.num_groups,variant=config.variant,share_axis=config.share_axis)\n",
    "\n",
    "params2 = vae_utils.load_model('log/colu_shareaxis_True_soft/C2401_group2400/seed0.msgpack')\n",
    "params3 = vae_utils.load_model('log/colu_shareaxis_True_soft/C2401_group2400/seed1.msgpack')\n",
    "# try reducing widths\n",
    "# params2 = vae_utils.load_model('log/colu_shareaxis_True_soft/C101_group100/seed0.msgpack')\n",
    "# params3 = vae_utils.load_model('log/colu_shareaxis_True_soft/C101_group100/seed13579.msgpack')\n",
    "# try increasing width\n",
    "# params2 = vae_utils.load_model('log/colu_shareaxis_True_soft/C24001_group24000/seed0.msgpack')\n",
    "# params3 = vae_utils.load_model('log/colu_shareaxis_True_soft/C24001_group24000/seed13579.msgpack')\n",
    "\n",
    "print(\"base model:\")\n",
    "metrics, comparison0, sample = train.eval_f(params2, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison0, f'results/reconstruction.png', nrow=8))\n",
    "print(\"alternative model:\")\n",
    "metrics, comparison1, sample = train.eval_f(params3, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison1, f'results/reconstruction.png', nrow=8))\n",
    "print(metrics)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mixed model:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mixed aligned model (encoder only):\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mixed aligned model (generator only):\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPIAAAA+CAIAAACeINE8AAAQL0lEQVR4Ae2bdeht1RLHr2J3t2C3YqFgYqPY3d2t2I1d2IHdYreY2ImKXaiI2KIodr/3uXd03jhr7bXXXnuf3/U+9vnjMGvWd74ze87aq8+wYf2nz0CfgT4DfQb6DPQZ6DPQZ6DPQJ+BPgN9BvoM9BkYVAb+M+IzKPaet3kGxmhuMkALmgfso402Gt8iizPRDNBxC2obZwuaoTDVUP/N+UwngkfICX70NMtQ1mrSEVSWAFwxM6oRNMPfExUyDfNhZYFl8ncbtoaa0ywyIxwpMH2QhPfh/WKbj/pokywliUZSzBylLWaLxmZddMjcOa0ltA/SYcxCq446Z4ZfyZHT/OWTEOvDZqpAJkRls+GitMV8ZmULTYo5QyqrKYvTMoiciDwEZ2qqOCXt7SOP8ltlexfuSWsJG09CCFc+eKpld9FUFSGUKkfoilXmtfqueJwjDdvpi4tKKAHLtyqLaasMhbklf0vzqthCvTrK+TUb9NbKKy419U4fBpTWtDRPk0utc0ExJzVpZuVsTxV1BK24aMmvceJFOIXQ6qMBJJRNbcG3fIpEMNGq3GatT+LiU32UPUcpuc5BZmKqQrKOWia6ykVmhFGYcmqGbcBRkwKlJcdcneZThSbKKVVaFM4Qn+8rRDryECCa+mZtw3KktqrKQVrvGCg6F2nz2lrYLKcUa63SABuzJXS+0iQ5tdZRDj6NITwHUH6bIodxRTURveN0RTCCD/WOtrbo/NbiG8ytw+BCTa0/BwgZeAD5OGRmEVuLdMXMKgtLy5ZfZKtJ29patYomxCI7lNWXCmlyDVJgmVZpzpxa5zfHpKZZK2P0GaSWqmhtjnswaqtCpmEUZkmQ5WORaLSoT6eaWiHHJAcTdWRjAyBFp4waJpQtzaPMcA6CNupLlY2c1jRrJXUCv1zxj+eoKGrEKqAs4y+zCkNqqSkLw1lJUb9dbWaEaStpnWlMpiOFwaYfVRYLUBXYZjVreXhhl4jVk61SZUtBG3fBIw0iHn0cG486kmg1ZgXnC5Y236oTpLjWZ8nkxEoMBS9F0Vi9skWVWjsIoX7JiNdoWE1z0Sh69YjQyJEaJtxBmANzDNZEQnKBhQDHEC1aKwCuKCZRZZStQOmeIsHg8hZGFWoSbAOtqumt8595QFEONIB88tofzALyaaNJw1wY5BvMCMVfyqhJjtJGaPFVeotRWUNSjRM01FqkM4wWNbambFm9tXPZ1IczH2iR2DQXCUeZMGVweFyIhm8wOR6VygnC4JQUnccQkKlRntBRWdghT2YkQwmr6a0JhceQT/uwJI98q5DmxG8aEK1VK3UUwjIDCA1VowwiiF5dK6yN0AmbhqdCm5CG0lYDLshDfbOWJ2njw+ZCeRCi4aLn45xahhzZMitbjmEjjPWihlGl1jYSJPIOCdX78BT/nWRV/muFglDrm7Ul7TDFQmXJw7S2cWdt8SKORBA5dJfWWEJBCg96/aQZGtWWBRm6kNg04JAWQGjViaYNcxhno5DqH0kdtIlSY1I21YRCJ46ENu2uzJFyYo5cRhI+dagRR53wa8zWSyfMljCU1W9TX2oIZ1Pb4SZhKFaj7AXUlicqK7nU4kI03fpyXqyvbh1Fn7FYacPuJE5LSFSdcNY+nTpt6k4Mm1ppPCOzWWsQQyAU53cIYqty0fKnraIdMv1IzHmqWY/EsIYs9b2jgWZgVH8zB5qcnrzPQJ+BPgN9BvoM9BnoM9BnoM9An4E+A30G+gxUZeCBBx6oqur1HWZA97465OypRrEMjDPOOJtssglBjz56/R2EUezZ+nBHiQzQDx1zzDHdhgrn999/zzefCy+8sFvybtlOOOEEglxsscX4Xm655R599NE0/3zzzZcGDE3tFltsoY6mmmqq7bfffvHFF1fNkArLLrtsS38nnnjiJ5988sUXX/AbHHTQQWOPPfYuu+wCJ8VGzPPOO++0006LlXzuu+++m2++uRFDAjzxxBM/99xzwvzWW2+JYPHyA6C3ypElf/nllxKhfP/+++8SyVxzzRWGFD5LiBkyDXl++OGHv/76a6J66qmnqmLr7D2k81tmmWU6ebx55pnngAMOuPHGG88444zTTz/9jz/+kOjd9z777DPBBBPke3z//fctw0YbbZRvm4Ok86DbwwVdNZ8bbrhhvPHGE8PbbrtNXJ966qnrrLNODtvgMKTX5uH555+/6aab0u7ApwFDWXvooYeedtpp9hEG4l0dXH/99ZdddtmYY46Z72aKKaaw4JlmmslF/NVXXyl/KFjbtExU1vz+++9P45vWTjPNNCuttBIu3n333T///POFF14Yf/zxeS3hmXnmmXmFjj32WNq6NvRMfhuzypm2VTDlEYGeb+21164Cix5kGlBbu9dee9ViMgFrrrkm3cc111wj8R944IGZhg1gjF+aJrpY5F9//XWMMUr+PIZXJkyrrrqqEH777bfbbrvtNttsw4BC+/jtt9/UEcKbb755ySWX5Af6xhtvqHnYXx555JH5VFHkHHPMwVstA8I333wz2WSTAdtggw0++uij5ZdfPmpSq3SPrPE/+eSTwl/LEAUoDwKDYRRjlUsssYQtNpJ52++66y71eMcdd7SJ3LpeeOGFhXbGGWe0+g5kDRehA7oRFNNPP73SXnzxxUJLR/jEE0+sscYaG2+8MZo555yzqTveaXKqzM4c/SyzzOKUjYpTTjmlkt96661iy3CJsOWWWzaiEvBRRx2lhFZgnNl3330LCNXEsu2www6qR9h9990lw1aZls8555wQQDdkvaj8ww8/hOAyjXKWmVdaKe+PP/5YCWpYsdlmm9EmlJmxZoYZZoCDuSnD+vrrry980003XUPiYbqMg/zBBx9U85NOOkncHXzwwapsKjDF15gRzjzzTDrvCy64AHmSSSZpyiZ4S6gyo8HRRx9dRihW9m157733hPn2229/7LHH1MtEE03UxoXYrrfeekr44osvIku30p7ZdnzQLrXUUu05/2JgPaRBR0l//vnnqD6tpCl8/PHHyvz222+fddZZmFx99dW1y5oEs52BCDmzSdrioosu+vLLL4vm0ksvTTCkqz777DONWQQWCSKsvPLKadtoLQOrI5Q1Rvt5JCl1zGExf/NqlVVWicZvlXvvvTdFnVvaqjKZbtTGXEYSt9p///2Fml1Ph2BD4IMPPuDtd/raIi3Yhivy6quvTsuA8+67765lAMAwyg6gRWqoSn7PPfccf/zxTM7YS1ElgrXKl3fbbTdL4uR8HkXuvPPOloRhioXE008/ze6kYhBmn312W8yRmSmxnLXkIn/66ad0paxrWa8zIHS4oyUxMw3jrOqWW27BXU6caYyNP41sXLvQQgsJu7NkkRTVO1hYtHMPYWBAoE2ztXzyySeLpmxAF1v7LT0osw6rRA6jqtWwInQkrsgrVEviAI6BBS4NnUbs9mKfffZZ3mFnW1tUcnoKka+99lprxS/4+eefr7baalZZJtOUGXYYyuhBeC0ZwdirLaNSK44s9BEQVN+NwE74vffea1e1zHdfe+21ddddV7wusMAC+Z7gsbGKvNVW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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'bce': Array(219.35747, dtype=float32),\n",
       " 'kld': Array(28.7202, dtype=float32),\n",
       " 'loss': Array(248.07767, dtype=float32)}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"mixed model:\")\n",
    "params = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2,params3)\n",
    "metrics, comparison2, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison2, f'results/reconstruction.png', nrow=8))\n",
    "print(\"mixed aligned model (encoder only):\")\n",
    "params = copy_pytree(params3) # either params2 or params3, to ensure good decoder\n",
    "params['encoder'] = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2['encoder'],params3['encoder'])\n",
    "metrics, comparison3, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison3, f'results/reconstruction.png', nrow=8))\n",
    "print(\"mixed aligned model (generator only):\")\n",
    "params_gen = copy_pytree(params3) # either params2 or params3, to ensure good latent/encoder\n",
    "params_gen['decoder'] = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2['decoder'],params3['decoder'])\n",
    "metrics, comparison4, sample = train.eval_f(params_gen, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison4, f'results/reconstruction.png', nrow=8))\n",
    "\n",
    "vae_mix = comparison2[8:]\n",
    "decoder_mix = comparison4[8:]\n",
    "metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mix base and aligned models:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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wnHx999/R32LLbYwR0RN5KmmmmrRRRdNdFU87rjjTj/99C233DKprYl87LHHJoo4niWWWIKFJ4QrrrgiEShEnnrqqSVmN/nAAw8MN9xwia6Kjz32GCB77bVXUmtkXCaeVbUjjDCCiNlnn13Eu+++G50uK+G+++477LDDDjjgACHcfvvtZcjwhx9+eNV65WiOwizb5eabbz4hX3bZZRGZQbHN8EcfffRYW0HjbvQKwwwzzJtvvgnI4YcfnshH5KSqx6yzzirW7rvvLjmKEOecc474uBaICy+8kK4pA1p55ZUPPvhgah966CFp8VxuueVEW4vZAP3OO+/A33///aH77bdfns8884xlcGbSYvZAwH/11VdVKz7PXXfdlSf7srXuv/9+aE9BGrIw/Ndff/3WW281RwTb1DbbbEPtjz/+mFSpqN6ERgZ8iJ133vnXX3/Fq8GJv1VXXTUirLjiikL2jk/t888/P++88zI2VsTjQl933XXSJSYxiGXMEXHllVfmVW+99RZ9hW2uYlsQjZaZCcFbeLImYm70iSeeIAjZY489rLvGGmtAn3vuuZJhZUIceuihGn2JWX2VVVZhr7MuhKsigS9XFU8WHlXEHtBPPfUUz/ibYoopoqIcGeGxduBY1QdNKAZKH6wePdiYDjzwQBwec5daYriffvoJYskll9TMI1iMbSfqKjLFjax9n0jLWs899xw0LsQcmsC/2iOKX4gMk9qk6uGHH8ZJM5MIHC+99FJq6SncVRRjV7333nubRV5ttdW23nprglEW1ddff62FCgircf755wcf37nffvsRGOTII488MgLrr78+JuU2swaIgxUTKly59tprEcOjE4fI8jLPIv+6wQYbxEaZUkcddZQ48XnnnXeqePHFF2tmMMRYZZnYS6LxIy+99BICDrLF33HHHRdffPEZZpiBIj3Dk1WK2NNPP82kpJf4GRZCWvkzr7LWIYccAo3zFefll19WXDTxxBOPOuqodog5Zso58cQTYSXbDeYyyZgrTGJeAPQddtiBdcyxgH3HRkCkcL3L+IZ77rmH0E1xMyP3888/33XXXah8/vnnzz777NFHHx1xzj//fPx65PRGKviXSQZXg8TxK2rdfPPNBHb77LMP6yT6J8bDYgWIlSzWJPupznksb2JQzlJzzz03Ssyw9957rxB53HHHjaiKVh1CcGAg6jjz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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mix base and aligned models (encoder only):\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mix base and aligned models (decoder only):\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPIAAAA+CAIAAACeINE8AAAPpElEQVR4Ae2cdcwfRRPHCynBKQ4JFAsuwQkQNMXdCe4Q3EtwKO4QCAlOgODBIbhbcAju7m3wBH3fTzt0mO7u7e3u3e95Hsj9/rjOzs5857tze3sr93TQoO7XZaDLQJeBLgNdBroMdBnoMtBloMtAl4EuA10Gugz0KgP/G/PrFXqHm5+BwfkuPfSge4A+3njjcRVZgommh4EbQFueDWD6wlWpDuR8xhNBE1LIjx9H6ctaTTqCykLAKSayGgMz+jlRIdEx3ayMWCJ+u7SVakq3SGTYL2bakEj00eNik5/GaJIsBQkyKUYOwhajBbnZEC0itw5rAW1DWuQssBqodWTwFRw5jl8+CbExbKYKZCgqmqWL0hbTkRXNdynG9KGspoynRRA5wtw3TtRUYUramzMP4ltl8xBOS2sBsych0JUfkWrRHTZVRQClygF0ilXutfq2cJxAStvRFxcVUAjLVZXFsFWOgtwQv6F7FTdfr4FS7mbGaK24ElJT7+h9QnFNQ/c4uNQ6ISimpCaOrJjNoYKBgJUQDfGVJ1EEUwCtPkggosz1xb5hKyJkglWp3Vpb4vBTfRA9RSm5TrFMtKmiZAM1THRViESGQTPF1AxbwkGXAqUFx12DpkP5LoopVVoUTN8+PZZv6YD7BqKp79aWlgNqq6oCxPUOAkUnRNy9thY0iynFWq+4geVsAZ1YcZCUWhsoxT5uAz3HQPFtihwbp6guoncwnSI2Yu/rHdjaohO31j5jbu2T8zW18RwDH4EGyM+xTCziay2dYmKVNYvLFl9kq4n72lr1CibEWrYoaywV4uBKUswSveKYKbVO3BSXmm6tiME2SC1VwdqU8NiorwqJjkEzC4IsP2uJRovaOtXUCikuKTbBQJYbBlJ0lEHHiLKhexAZzF7ABmOpMitoTbdWUEfgzhXfPAeKojJWAWUZfpmXT6mhpoyG4yVFvTq1iQzjXtI74zaJgdQMNP2pslgAqsA3qVtL4wVdGGskW6XKhoJ27oIm9YKPNsfy0UDCVjmrcbpgYdO9WrGU0NqWREy8xFHspSgaq1e0oFJreyHULxmJGqSVm4ss9hoRISuQOkbCAZhi5iBYF6HkEPMNHIRg0Xph4BTFJagMohUonVZEEJy8+ax8TQStp1U1o3V6m3vEsqcE0sFrb5g1SIcNJg13QZArNmMUfyuDLilKy9DaV+mtjcpKSTWOoFRrLR3HYFG55aIljdZOyNwYjntPi3DTXEQCJZopgmNPCNFwxSYlokI5giA4SopORN8gUaM4fqAy2j5OIpO+NKsZraFCM+TXnJbkkasKcUzixg2CteqlgXyzRAK+o2oUQQTRa2g1ayK0gqb0VGhCqS99lXBBHuq7tbSkSQybC8VBCNJFz88JahFSZIusaCmOWTY2ijoGlVqbJQjzFgE1+ugUj02yKgesUEC1vltb0BZTLFAW3E9rk3DWlygSSASR/XBxjQUUS8FBr784QlZtGUk/hHBTwj4sBr5XK5omyD7PLEr1TdIATVgqJ0VTjS+0Ekhg4+HKAikm7shlIH6rfY0EagVfOdsorSBbQF/WuLmx1BHMXN/RLj4Vq1H0AmiLE5QVXGoJIZp2YzlRbKx2AwXbWKy0tFvhaQFh1Qpmbes0aG44ccz1Uj792a2VRB8IxfntA25VIRre2irYPtP3Y85j3bofafVZ6rtAPc3Av/3J7GlyOvAuA10Gugx0Gegy0GWgy0CXgS4DXQa6DHQZ6DLQZeC/moHxx68/zy5o+4QTTvjRRx8VOHYuXQa6DHQZGKgZOOqoo6B25ZVXzjDDDE888cRApdnx6jKQnIEpp5zy1FNP5XBEf4ssssgRRxyRDDCADKUJDiGUjqa8OGTIEMeZuQ6aZZZZxtH3S3HPPff84YcfzjzzzDvuuKNfCAycoI8//rh2aBGOO+64xRZbbOAwTGRyww03wP+VV15x7AcPHrzwwgs7ypLiNddcs//++2+11VbDhg1jMABit912k5Slwx122GHictFFFyF88cUX6b4RS8H0r0OHDo14DYSqBx98kOfw5JNPhvxnn3325JNPNme14IIL+qlAc/fddzcHB8F5D4AchOVeB/WinHbaaQ8++OCIgVQR69JLL73wwgsdyx133HHuued2lKnF884775133vnxxx8PPfTQk046aeaZZ55mmmnOOOOM2267jcZ8+eWXXJ9++ulUuEGD9thjD1zsjzua7u5Y7rLLLm+99ZZFc+S//vprsskmc7yKiwK+7777Hn300cUg1vHFF190CFO0BmXy66+/bmG5g9ypb7755tdff918883LMNVLbr3FR7788st5lsTmkUceoUOvscYa6uIIkHE0kSIdetSoUV9//XXEJrvKsp944onXW2+9U045ZdVVV33ttdekaqqppsoGHfO3gBZ59tlnLwDBxYJUybvvvnsZuOPl4F9//fXHHHOMY5NVXGWVVRSTm6cywjnnnJMF5RgrFB360Ucfpcjzf//994veMa4tyjwTs0kmmUSRHYH3wGmnnaa0d9555y222KIWmQE7YrPAAgu8+eabBLr99ttXX331iGVG1U033WSpn3DCCThvu+22yy67LMLyyy9/5JFHfv/99xmIY03XWmstiywyo/jY+tR/DzjggGuvvfbnn39+6aWXfEDVtDWyKqAK/psxlfoYu6+++gooxv6ddtpJ+5yAH3/88VlQjrEy5K5ts802Unz77bdFmG222Rz7SHGppZZStCrhww8/lMneDjvswISKB/6nn3667rrrIrDxqjnmmMPGevnll5dccsm4S7iWPSBbMWLECIuLvNBCC2Ew+eSTs1XEc6nGzLZVThF48riLDjjF3LeMs9s/33zz8R5kM+vqq68W8DvvvBNhueWWS2GVYuNwnn/++VO8qmzoBwrIS1ZlBCZ7VV6JekGbYIIJsKd76TPD88+dTQQRM0usSmZsVkyG1RdeeAFLpn+qzBVWXHHFd999V8JdcMEFr7766mWXXbbCCivk4oxj77xrHnroIa0ePnw4/e+WW27hBTFy5Ej0GGttrcA0xs7MWCE988wzsP/jjz94PBh9axFSDMBhP4TlyMorr5xin2hzxRVXQJUuwtqcPl08cSLc9NNPL/dMr6RCZHpe8wX+SiutpHt53Kn40i3SfKXnCyy3UDJLZulvEVjeifFvv/1m9VkyGwka8cQTT2QFsvfee2chuMaHH364IoqgFqy9RPP777+zW8SgQlHTp2ZxAZftt9/+zz//FCjneskll8TdI7U6meNVuN1220Usc6vYS2IBJHs4LJqF8y+//MI8LRdK7O2sWjMgVWDqXLYMHK/vvvuOG7T11lszDPEqKMaBG3M8ZSjCueeeWwW4zjrrqDEvzyqzWj1zGMWpNa43mHrqqb/99ltB/Pjjj3nQrY8NplGZuukS2BpXyTx8+F511VVMe/Q5UTQEnqsq34ieDUc2bTCYddZZq8z22Wefsnm2pacyI8rZZ59NLLo73bQqaJVecXg87PAMlDMhrEKo0svOqeJPNNFEVZYp+oMOOogF1QMPPIDx888/X+Wy2mqrrbnmmhpUhCrjuH7TTTcVd/ZtIpYZRxMMvTzfPOg8o87L5Y033nBIy/zhrLPOSr+p+jTzHocxCxoHk2KkJZEqxWF3yZox0FLkxmywwQaRHm9dHJm+q+A85yKTcY5+sGRzEw0vrqxn2wmhRdmLZPmhmgLhgw8+UMKffvqpIjDVJg833nhjFj7dWhGCAjuGGs4Rgva1SgsS2SVM3ReedNJJ+YqA5eCMM8643377EZ7nhqtOtVkEMHmfa6656JSs4nnpsxlSy9IasM6DNItlnfXK8sK2xNqny4pw8803qxdLcmT27VVTIHz++ecbb7wxjX3//fdxX3vttTlAsenmbfvcc8+xsikAd1w222wzacixxx7rVKUXNRUI0im5ZXYn274camFl3embsSHGqZyNZeX47njkyIl3l8VBZlNo11139QmkagSOtcs999xDx51lllmcABZoiSWWYMQ6/fTTZTi0VQUyk3UdYwrcl156aaGqvnRo0XB4pMoygTyoI41l1Q+yahCmm266tnZVhfN9993HUa4NkSU/9dRTgqPHZLyvRSNXFpRZgEFjBguLaeXanRyMg5jsGlscZO5jMBVyyB0EcZWKyHsK2RlHHWu2QVgFczTj6IuLsuHFOroMgaF0yy23VF92+qQ5HL2qshUB2BZb7VASzg2/tuNMRHBkVGZYlaJenaDFRQVE4DMKcNgi4zXOy60VzHY+rGD3AH68c+F01113WdIOS+bTfPP07LPPFvdCB1CKRJRNw2BtXLnuuuvaYZXlAWjnn3++zKaY8wQf+jimXyurIiYhflUrGtlD5HOAJmgHHnig3DvZMKWr2Vv5ySefNAG3vuCzGJB1s9U3kS3VJjj/+MKPSQ9DEVvIdFkN8I9FzyRO4GVjsezYUnixxyICEyQOZZSsNgQBJSf/WpUrCBRbZjwwG264Ya57ij3bvcIzxThoo9+fXXzxxcya6Mf2xZt7fEaI3M8zq6bjQbZW6dwpW1Uuc6v4coAPGhkyN9lkE4kho105qPHkWGfOOeckitGNFlnQaHucqtwiozLHGZwUyJKFnRZWwAqO0GSqzSRHoZjN53JLtJcQicZVZmzLkG3Z2uNkW2kjlL0Pmc/wOVBVuFb0rE+UZ1uf8fxNTHB7NFSzHcv2JyHYGWTIJFMc5D722GPaGAT6fZMcLbrooorGlojKInD02ARc0TjIZT+EjaMmaL6vva9+bZlGOaswzzzz+FDBo2J/2ib7j767ahgWg1BqIAJkHA1FZUh6/Vpfs/jii/vKsIY1Muh6sMTIHbbztHyK7ekCCjbClL0vsGUe8MlUCSwHmT4+fx6SCTaOOYA8GHzQwoc441S0VLCEW4IcxErawiJnIafb87EQhx6sDcBPmefceuutFpx5C0XmwKxb0rfzGFySmvPee++BzorQhkzyTDYCOfjj+8lkjErDKaaYgqbKp5hOFE5P7r333krP/q5w2LZOZ/31108cBRND8xnmww8/zAxno402UheOqJFpC58lYSB61qxqoIJ/ejXTTDP16k/K+XJK8pv+xCjRLGHeeefNsk83hj+vJz7/lYboVT7NScfpS0slicB3qv7yoy/JxGPJHGavvfYSznx2Yu1tQ6zel+2X1rxS+P9/E/f+/T879MHDGvkAIFz3L9Tq1j1Hg/yND1+GDKhGcH7J363QIXr3qLfbXpZGfIbJ2bV/rm67NXK7cQXtkEMO6QXsOJitL5vGQe8Kvc9AcAXZMCzH3dK/G+IE3eXD5mBVp+wy0GWgy0CXgS4DXQa6DPR9Bv4P/1KVKg+6OiIAAAAASUVORK5CYII=",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'bce': Array(213.12357, dtype=float32),\n",
       " 'kld': Array(28.599962, dtype=float32),\n",
       " 'loss': Array(241.72353, dtype=float32)}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# align one layer. The whole algorithm shold align every layer\n",
    "intermediates = True # False for weight alignment\n",
    "C = config.latents\n",
    "\n",
    "def find_perm(corr):\n",
    "    \"\"\"pointwise alignment\"\"\"  \n",
    "    row_ind, col_ind = scipy.optimize.linear_sum_assignment(corr, maximize=True)\n",
    "    C = corr.shape[0]\n",
    "    assert any(row_ind == [i for i in range(C)]), \"just to make sure\"\n",
    "    return jnp.eye(C)[col_ind]\n",
    "\n",
    "\n",
    "def correlations_E(params2,params3,intermediates=True):\n",
    "    if intermediates:\n",
    "        # \"activation matching\"\n",
    "        recon_x, mean, logvar, intermediates = eval_f(params2, test_ds, z, eval_rng, model2, config)\n",
    "        xx2 = intermediates['intermediates']['encoder']['fc1']['__call__'][0]\n",
    "        recon_x, mean, logvar, intermediates = eval_f(params3, test_ds, z, eval_rng, model2, config)\n",
    "        xx3 = intermediates['intermediates']['encoder']['fc1']['__call__'][0]\n",
    "        return jnp.cov(xx2, xx3,rowvar=True)[-C:,:C]\n",
    "\n",
    "    else:\n",
    "        # weight matching\n",
    "        ww2 = params2['encoder']['fc1']['kernel']\n",
    "        ww3 = params3['encoder']['fc1']['kernel']\n",
    "        corr = 2*jnp.cov(ww2, ww3,rowvar=False)[-C:,:C]\n",
    "        # otherwise if data is assumed to be centered, corr = xx0.T.dot(xx1)\n",
    "        # also consider outgoing layers...\n",
    "        ww2 = params2['encoder']['fc2_mean']['kernel']\n",
    "        ww3 = params3['encoder']['fc2_mean']['kernel']\n",
    "        corr += jnp.cov(ww2, ww3,rowvar=True)[-C:,:C]\n",
    "        ww2 = params2['encoder']['fc2_logvar']['kernel']\n",
    "        ww3 = params3['encoder']['fc2_logvar']['kernel']\n",
    "        corr += jnp.cov(ww2, ww3,rowvar=True)[-C:,:C] \n",
    "        return corr\n",
    "\n",
    "corr = correlations_E(params2, params3, intermediates)\n",
    "p = find_perm(corr)\n",
    "\n",
    "def rotate_E(params0, p):\n",
    "    \"\"\"align params\"\"\"\n",
    "    params = copy_pytree(params0)\n",
    "    params['encoder']['fc1']['kernel'] = jnp.dot(params['encoder']['fc1']['kernel'],p)\n",
    "    params['encoder']['fc1']['bias'] = jnp.dot(params['encoder']['fc1']['bias'],p)\n",
    "    params['encoder']['fc2_logvar']['kernel'] = jnp.dot(p.T,params['encoder']['fc2_logvar']['kernel'])\n",
    "    params['encoder']['fc2_mean']['kernel'] = jnp.dot(p.T,params['encoder']['fc2_mean']['kernel'])\n",
    "    return params\n",
    "\n",
    "params31 = rotate_E(params3,p)\n",
    "\n",
    "print(\"mix base and aligned models:\")\n",
    "params = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2,params31)\n",
    "metrics, comparison, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))\n",
    "print(\"mixed aligned models (encoder only):\")\n",
    "params = copy_pytree(params2)\n",
    "params['encoder'] = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2['encoder'],params31['encoder'])\n",
    "metrics, comparison, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))\n",
    "print(\"mixed aligned models (decoder only):\")\n",
    "params = copy_pytree(params2)\n",
    "params['decoder'] = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2['decoder'],params31['decoder'])\n",
    "metrics, comparison, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))\n",
    "# not satisfying because latents are not rotated! it's a chain ⛓🔐\n",
    "metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mix base model and aligned model:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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T4XpXn/99fvvv/+SSy55wAEHPP3008Y84ogjLr74YqPfe++9HOR55pnH5P33ueeem6ObL7P88svvtNNO/Ja77rrr4Ycfzq+I21L3z5WYmcQee+xBXn7vvffefPPNl1566SmnnJKpWCbm46CHgZV7sMEGK1Mp5BsOXZQHRhtttE8++QTO22+/fdBBB5HyPfvss0w7mBzxr732Wib3JptsYjgLL7ywfChEzmSec8454Ky44oqZ8lliiy666LTTTutF2ZIww6Zw5ZVXUlVo5rppkf6ycQt8zjnnhL/++uuLM+ig1W+HmzAxlSee2HLLLYVWSSyyyCIJmfnmm48QM0UOPfRQNvcVVlhhxx135PFTtnP88cfLdAIn7pLWG2+8ccMNN9BkYWYHjyXzOcL0ucExxxxz4YUXMpAcHBAQ43vffffdc889GelUU00lWCNeffXVX3/9lUUKTGa5MdnKUGSpknCOuTIZnkPb1csEmvB//vnnzz777IknnjBljsz4ymDY2lZeeeUmiP06n3/+OTj8iv5M1gmgIgjBhDv99NPFYW9p7KdXfOaZZ4T51FNP2bYLx8vUpXFVmO+//z752BlnnMEGBbMyiUrbMtj777/fxEYaaSSeRmOyuKZ16eVwgjCEqfBNiqWji5hG8DzPPffcRl911VWUI7faaqu620KZS9tvv/1ll11W1tuE773nYSUZFWe44YZrgtivowkBGqvshBNOCJsHZv755x9zzDGbwcoxJt9kk0129NFHiwNRa82OHVhnnXU8WkBvuummsUoOh1TVQ11yySW77babODkIZTJsg4bDesQT/ttvvwkWIrNyT36oyerVK+nvvvtur732KvMtk8/Oyd5itnhUMrWqxZSqaxhkVEY/+OCDQw45ZDVEiYQAjQCWPOzss8+mrlKiUcEeccQRhckzs9FGG5FEimNEBUSy+8cffwzQ1CTijUMhEAhyD1ywsrfxkx5VdAqZ9OCVV15R04jMysYMM8yw1FJLBbqZzaAQTvZS4bHrJi/lULTLLrvIlussJf8nW73pppvKBGeddVZ1cU5aa6217rjjDuPMMccc/NLqrUuQw3gVzkkvvfTS66+/zs7u+fn0RRddJGEco2iw9tpri9M5McQQQ5SB3H777T4UHAaodudUo3zGRQGeMyKr/jjjjFNmKJ//wAMPSPiLL76wzVAcCB8uzw9o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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "only rotate encoder:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "only rotate decoder:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0aHBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA+APIDASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD5/oorvPCvgSxuPDUvi/xXqMmn+HY3eGOOAf6VeSgDasIZdpBORnnlGBAALKAcHRXv/wAJfEejS+Ib290zSNK8L6FY2h+2vcu88kryOoX/AEp8CNcouEJ5O7CsTuTwCgAq5pWlX2uapb6ZpltJc3lw+yKJOrH+QAGSSeAAScAVTr3z4F6esHg7xHqWn6vaQaxcoLWAyXTBbeVsrD5kRTbkuV2t8+clQAQwYA83T4S+PJLe7nHhq7CWjukgZkDMVGTsUtmQehQEN2zXF12njC68f6Gj+HfFep6lsu0juWtri++0B1VmCnIZsDcD8ueSqkjhSOLoAK0JdC1iCza8l0q+jtVijnaZ7dwgjkJEblsY2sQQD0OOK6D4XeHk8TfEXSLGZoPs6S/aJkmCsJEj+cpsYjfuxtIGcAk4IBr6D8VfFfw14HuLayhWS4Fu7Wn2LT5LcxxqhiyWAbdGUBdVQ7clXBAG1gAfJlFekfF7wKnhnXE1jSB53h7Vv39vPEq+TE7ZbylK8bcYZeBlTgZ2k15vQAV0lr4G1q58EX3i8xRw6TaOiB5SQ05Zwh8sY5CsQCTgdQMkECPwX4TvPGvii10WzfyvNy805QusMajLMQPwAzgFioyM5r3vxp8OvE134Ts/BvhNLS38O2bxBvtVywuLlyxZ3JXKmIGTeVIB3RnauAgIB8yUVc1XSr7Q9UuNM1O2ktry3fZLE/VT/IgjBBHBBBGQap0AFWLqwvLHyPtlpPb+fEs8PnRlPMjb7rrnqpwcEcGvTPCEGm+C/hvfeNdRitJdav3Nv4fjmVXaNkbDToDuGVbnLKMeWBn94M0/i1qlxry+FdYuzYyXF7pXmyS21wJDkyyHyyoxtVM7Rlc53qXkKE0Aeb0UUUAbGn+FtZ1TQ7/W7WzzplhgXF1JKkaKT/CCxG5uR8q5PzKMfMM49fSfjT4kw/Cuw0Pw34Vs7S7g/sxZoribBjZWcBJMxkBywWUtgDJdWB6g8J8W30nXfDnhfxjZwQWt7q/2n7RGJpZnk2uOrMoB2ElT0xlVXciggA8noor1jRvhn4b0zwMnibx7rM9l9siFxYWNjLH50seBjAYHczbk4GAoILEZO0A8nor3TSPjX4N8Opdto3gKOzniRYLOSJo1e4i3c+dJt3KcKp/5aZPU965/4k3eg6x4D8M69Y+GrTQru/uLkQw2ITY8MZCOZSEQ794G0DIALZOTgAHldFFFAFyw0q+1NLx7G2knFlbm6uNnJSIMql8dSAWGcdBkngEinXsFjdXHw0+DM80NxBbeI/EssTxeTdjz4bIqSkmznGcSAEYI80fMGXA8foAKKKKACvdPhfdaB4u8HWfhXxTo93NaaW91dRXYnaC0jiXa7vIwlXc6tLjhTtV16Asa8LrsNQ8ded8OrDwbpunfYbWKU3F7P5+57yTr8wVVG0Hs24/JHz8uSAanxE+JDeIDJoPh+KPTfC0DlY7O1VUjuCsjsJSAilQ2VbYeAQD15rzuiigDrPBPw81rx690ujvaKLV41ma4kKhA6uQ3AJIzHjjJyy8YyRz+pabNplwsMrRyBkDJLES0b8lW2NjDgMrIWXKkqcEjkmm6tqWjXDXGl6hd2M7IUaS1maJiuQcEqQcZAOPYV1g+MHj4WcNqPEc/lxbNpMUZc7CCNz7dzdBnJO7kHIJyAdh4/wBNuPDfwS8N6Tr9jv15ruQCS5uhM9rGpICx4kOFKCEbVBQdwGKmvF6sX99canqNzf3knmXV1K80z7QNzsSWOBwMknpVegDuPhP4s07wb45h1HVUn+ySRNbvJC7DytxHzso/1ijHKnPXcAWUCtD4k/D/AMQWvia71u2tf7S0zWbuS6tbrTg06Yll/dqxA4Y70x2bcApPOPN67jwd8WPFPgmz+w2E8FzYDcUtLyMukbMQSVIIYdDxnb8zHGTmgDrPHX/CTL8BfCcOt2sdskF6YGjnRkuMIrrBlCqhQEDg5ySBG2fmYDxutzxF4w1/xY8T67qUl4YnZ49yKoQsqK20KAACI14HGcnqSTh0AfRfwB03TbnwVrVxpjR2niRne1e9YrM8KlQY3WMgbU3ZO053GM5OAAtiwh1Lwvqn9q+O/iLJcRaXZBrbSobxraW7aPcG3RsUMo3qwVjnzflJOPlPzpY395pl5HeWF3PaXUedk0Ehjdcgg4YcjIJH40Xl/eahKJb27nuZBuw80hcjcxduT6szMfUsT1NAHSfEfxbN4z8a32otNHLaRO1vYlIyg+zqzbDg85OSxzzlj0GAOToooA9U1z4s6Hq3g628Nw+ArSGzs3V7WOTUJWjjYZBJEYRmJDPyW5LZOTXSfEXxtP4f8L+HtKg0aCyvrzRLm1ls7tJfMsbOUoiID5mC2IsZbLZjBKpuK14PXQeKPGGo+Lf7N/tCCxi/s+0W0i+yWyxZVe5x/wCgjCjnaoycgHP0UUUAe6fGvQ77xXqXhrXNGto79L23WyeewufPt1l83aq+ZsVQC8pUOzDceNq7eeb+Jmgy+D/Bfg7w9Je4umimu7+xQooWZiMOwXJZgGaIOSQRF8uPmzzegfEvxh4X0tdM0fWpILNXLrE0McoQnrt3qSBnnA4ySepNcvPPNdXEtxcSyTTyuXkkkYszsTkkk8kk85oAjr0yy+K1jceDrLw94q8I2mvJYoIba4Nx9nkjiG3aoKoSD8oBKkbgACDyT5nRQB6ovxd0jSnsrrwz8PtG0zULNDFHczSGY+WVAbO0IS5wPnZicFh/Ea6/4y6lD4j+DHhbxA62kl3cXEJaSAAiNnhcyopySBvXBGeqDPIr58rrNa8cTat4D0LwnFYx2lppjvJIUkLC4kJO18MCVI3PkBiCXPAAAAByddJ4D8KTeM/GNhoyCQQO++6kTP7uFeXOcEA4+UEjG5lB61zdamh+I9X8NXFzcaNfSWc9xbtbSSRgbvLYgkAkZU5UHcMEY4IoA7T456tcan8UL2G4tvIXT4o7WIHG5kx5m44YjkyEjp8pXIBzXm9STzzXVxLcXEsk08rl5JJGLM7E5JJPJJPOajoAKKKKACiivUPCvhvQfCvhZPGnja0a5Nwf+JPo8nym7I2sJTz/AKv13DbtOcNuUEA4JvDuspLawvptytxdYNvbshEsoIyGWP7zKcHDAYOMA1LqnhbW9EsIrzVbB7KOaQxolwypKWAyf3ZO8YGCSRgbl/vDPqmn3Vz4Oubj4oeNbKaXXNTkkXS7Ab42hch1YyK4yqBQqry3yt0PBHjN3d3F9dy3V3PJPcTMXklkYszMepJPWgCGus8D/D/VPH1xeQaVd2EMtoiuy3UjKWBJGV2q2cY56dRXJ16P8JvEnhfw6+ur4hmvLWXUbT7FDd2oYtDGwYyHjociPBwSCPTNAHRwfs9TPZ3KSeL9MXVrRA1zaRoWSEHJUu+4MoKjOSg79cZrxd0McjIxUlSQdrAj8CODXW+MvC9x4VubbUbDVxqWkatG7WmpQvtM4xiRHGSQwLYIPX65A5CgCW2tp7y6htbaJ5Z5nWOONBlnYnAAHckmvbT+zffpoEt02uLJqYtjIllHbDaZgMiPzC4GCfl3YHXPbFcT8GbSK8+LOhJPCssaPLLhlyFZYnZW/BgpHuBXafFT4ha1onxijj0/Urm2ttMSBJIFkYRS7gJGLJkhshwM4zwPQGgDw+ivS/jR4Di8G+KUu7EoNN1UyTQwqoXyHBG9ABxtG5SOBgHHbJ80oAK9Qi+HOgL8EP8AhNrvUL+PUX3CKJPLMRYTGNV2kAnIGSQ3AycHGDyfgbwZfeOvEsej2MkcICGa4nfkQxAgFsZyxywAA6kjJAyR9MeLtJ8M+JdDb4a2msWllqVvBAbS3Zy7xKgyowWBY7FORkkAhiOmQD5Doq7q+k32havdaXqVu0F5bOUkjYdD2I9QRgg9CCCOtUqANjw34X1jxbqqado1m9xMeXbokS/3nboo+vXoMkgUnibwzqvhLW5tJ1e3MNxH8ykHKSoejoe6nB/EEHBBA9UNhqHwr+CjXwS5sfEev3cSM4YxyWsS5dR35wpyPlP73B+7iofjnu1vTvCPi5dMuLb+0LALKzOHjTOJI0yO/wA8hBOMjsMEAA8aooq3pdpHf6vZWcs6W8dxOkTzSMFWMMwBYk8ADOcmgD0zwt8FRrXhbT9b1jxLb6INRlEdpBPb5aTP3OWdMs2CVUZyuCDzgcD4r8O3HhPxRqGh3TiSS0k2iQDG9SAytjJxlSDjPGcV678e/EE2l+N/DFpbxRrDpcK30SoSuWMmNvHQAQjGORk1W+Kml2vjPwJpnxO020+zSygQ38K4I2hmjDlsKWKuAmcHIK9AtAHiVFFfSPgjwB4d8E+B4vHuoQy6tfLYJqEaNGNsGUDgIvPzAkfOemM/LzQB4ZongnxP4jWN9J0O9uYZCQs4iKxEg4P7xsL196papoOsaGYxq2lX1h5u7y/tVu8W/GM7dwGcZHT1Fema9+0H4s1SRk0aC10mEMHUognmwF5DM42kZyeEBGBz1z3HxUu5pPgHpkniWCRtauWtSpZNhjuCCzFlwu07BICMcE4x3oA+aqKKKAO2+HXw8fx7NqbS6rHpljp0KyT3MkYcAtnAILLgYVyWzxj3ria9z1En4V/A6DTdnleIfE25pwykPFEVG4HKZBVCqFSQQ0jEHivDKACiiigAr2z4d/FXWtB8PyXuvXS3ug2SJp9rbRxKsscojLRDKpypVCuWOe/ODXidSGeZrdLdpXMKOzpGT8qswAYgepCrn6D0oA1fE/irV/F+sS6nq9yZZXJ2RrxHCvZUXsOB7nqSTk1jUUUAem/CHwJoPiy8u7vxFqEcVralRHZi5SN7hurbud4QAdQBndww2kVavPgR4kub3z9DuNKv9KuJn+z3EF18qxbvlLZ9j/CW+6evGfKKKAPVfHdrofg/4eW/gi01uPVNXXWGv7swD5IcRtFsJ7Nwvy5JBDZxxXlVFFAHQeCvFt54J8UW2tWaCXy8pNAzlVmjb7ykj8CDzggHBxivQNe0bRfjB4v/ALT8L+IIbXWL+MNPpeqxvEy+WoTKOqsrZVQ20EnGT6hfH6KAPe/jxot1Y+BvBn2y5E9zYJ9jmkyxMrmJMtk9eYj155+teCUrMzHLEk4AyT2HApKAPoj4G+JfBPh/whcJdavb2WryymS8+1sI8gEiMITjcoHOMkgs3bFZP/CT/CfwfqsniHR/7T8Sa7JPJcRvcPIgids53F1UEHceSrnIzx1rw2igDU8R6/feKfEF5rWpNGbu6cM/lrtVQAFVQPQKAOcnjkk81l0UUAdz41+KWueNLPTbWeWa2itbdEnSObC3MwwTKwUKASQCF5C9uprvfjxq2o3XhHwdBfzRwXdxD9qvbELtZZvLUbiDkgAtIo/Hrjjwmr2pazqOsG1Oo3clybWBbeEyHJWMEkLnv1PWgCpJLJNI0krs7sSSzHJJJyTn600EqwZSQQcgjtSUUAfQmveF0+OGm6B4h0bVdNh1WG1WDVYXkb91yTwg3Ffm83G7G4Ec8VzHxK8QaNoXgvTfhx4cvjepZuJdRvIWxHK/LFOCQ3zNuIyQu1RkkHHkVFABXvWkftA2Gi+B9M0yDRLmXU7Kzjtj5kiiElAEB3D5sFRnGODxz1rwWigDs9d+KfizX4Gtp79La1Nx9o8izhWJd24sMkDcw3Ethicnk5ODXrP7Ry3svhfw/cmKWK3+0MJ0M3CSsgKgqDhjgSfN25x96vnOuk1Hx74j1bw1beHr6+jn0u2SNIYWtYsoEGFIfbuBA4yDkjIOcnIBzdd78HNBTX/iZpayzeXHZN9uODhnMZBVRwR97bnOPlDYOcVwVFAHY/E7xgfGvji81GJ82MP+jWXH/LFScNyAfmJZsEZG7HauOqSQwlIhFG6uExKWcMGbceVGBtG3aMHPIJzzgR0AFFFFAH//2Q==",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# align the rest\n",
    "# rotate z\n",
    "def correlations_Z(params2,params3,intermediates=True):\n",
    "    if intermediates:\n",
    "        # \"activation matching\"\n",
    "        recon_x, mean, logvar, intermediates = eval_f(params2, test_ds, z, eval_rng, model2, config)\n",
    "        xx2 = intermediates['intermediates']['__call__'][0][1]\n",
    "        recon_x, mean, logvar, intermediates = eval_f(params3, test_ds, z, eval_rng, model2, config)\n",
    "        xx3 = intermediates['intermediates']['__call__'][0][1]\n",
    "        return jnp.cov(xx2, xx3, rowvar=False)[-20:,:20]\n",
    "\n",
    "    else:\n",
    "        ww2 = params2['encoder']['fc2_mean']['kernel']\n",
    "        ww3 = params3['encoder']['fc2_mean']['kernel']\n",
    "        corr = jnp.cov(ww2, ww3,rowvar=False)[-20:,:20]\n",
    "        ww2 = params2['encoder']['fc2_logvar']['kernel']\n",
    "        ww3 = params3['encoder']['fc2_logvar']['kernel']\n",
    "        corr += jnp.cov(ww2, ww3,rowvar=False)[-20:,:20]\n",
    "        # also consider outgoing layers...\n",
    "        ww2 = params2['decoder']['fc1']['kernel']\n",
    "        ww3 = params3['decoder']['fc1']['kernel']\n",
    "        corr += 2*jnp.cov(ww2, ww3,rowvar=True)[-20:,:20] \n",
    "    return corr\n",
    "\n",
    "corr = correlations_Z(params2, params31, intermediates)\n",
    "pz = find_perm(corr)\n",
    "\n",
    "def rotate_Z(params0, p):\n",
    "    \"\"\"align params\"\"\"\n",
    "    params = copy_pytree(params0)\n",
    "    params['encoder']['fc2_logvar']['kernel'] = jnp.dot(params['encoder']['fc2_logvar']['kernel'],p)\n",
    "    params['encoder']['fc2_logvar']['bias'] = jnp.dot(params['encoder']['fc2_logvar']['bias'],p)\n",
    "    params['encoder']['fc2_mean']['kernel'] = jnp.dot(params['encoder']['fc2_mean']['kernel'],p)\n",
    "    params['encoder']['fc2_mean']['bias'] = jnp.dot(params['encoder']['fc2_mean']['bias'],p)\n",
    "    params['decoder']['fc1']['kernel'] = jnp.dot(p.T,params['decoder']['fc1']['kernel'])\n",
    "    return params\n",
    "\n",
    "params32 = rotate_Z(params31,pz)\n",
    "\n",
    "# rotate decoder\n",
    "def correlations_D(params2,params3,intermediates=False):\n",
    "    if intermediates:\n",
    "        # \"activation matching\"\n",
    "        recon_x, mean, logvar, intermediates = eval_f(params2, test_ds, z, eval_rng, model2, config)\n",
    "        xx2 = intermediates['intermediates']['decoder']['fc1']['__call__'][0]\n",
    "        recon_x, mean, logvar, intermediates = eval_f(params3, test_ds, z, eval_rng, model2, config)\n",
    "        xx3 = intermediates['intermediates']['decoder']['fc1']['__call__'][0]\n",
    "        return jnp.cov(xx2.T, xx3.T)[-C:,:C]\n",
    "\n",
    "    else:\n",
    "        ww2 = params2['decoder']['fc1']['kernel']\n",
    "        ww3 = params3['decoder']['fc1']['kernel']\n",
    "        corr = jnp.cov(ww2, ww3,rowvar=False)[-C:,:C]\n",
    "        # also consider outgoing layers...\n",
    "        ww2 = params2['decoder']['fc2']['kernel']\n",
    "        ww3 = params3['decoder']['fc2']['kernel']\n",
    "        corr += jnp.cov(ww2, ww3,rowvar=True)[-C:,:C] \n",
    "    return corr\n",
    "\n",
    "corr = correlations_D(params2, params32, intermediates)\n",
    "p = find_perm(corr)\n",
    "\n",
    "def rotate_D(params0, p):\n",
    "    \"\"\"align params\"\"\"\n",
    "    params = copy_pytree(params0)\n",
    "    params['decoder']['fc1']['kernel'] = jnp.dot(params['decoder']['fc1']['kernel'],p)\n",
    "    params['decoder']['fc1']['bias'] = jnp.dot(params['decoder']['fc1']['bias'],p)\n",
    "    params['decoder']['fc2']['kernel'] = jnp.dot(p.T,params['decoder']['fc2']['kernel'])\n",
    "    return params\n",
    "\n",
    "params33 = rotate_D(params32,p)\n",
    "\n",
    "print(\"mix base model and aligned model:\")\n",
    "params = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2,params33)\n",
    "metrics, comparison2, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison2, f'results/reconstruction.png', nrow=8))\n",
    "print(\"only rotate encoder:\") # no Gaussianity\n",
    "params = copy_pytree(params2)\n",
    "params['encoder'] = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2['encoder'],params33['encoder'])\n",
    "metrics, comparison3, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison3, f'results/reconstruction.png', nrow=8))\n",
    "print(\"only rotate decoder:\") # it works\n",
    "params = copy_pytree(params2)\n",
    "params['decoder'] = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params2['decoder'],params33['decoder'])\n",
    "metrics, comparison4, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "display(vae_utils.save_image(comparison4, f'results/reconstruction.png', nrow=8))\n",
    "\n",
    "# comparisons = jnp.concatenate([comparison1,comparison2[8:],comparison3[8:],comparison4[8:]])\n",
    "# display(vae_utils.save_image(comparisons, f'results/samples_aligned.png', nrow=8))\n",
    "# metrics\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot Comparisons"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 56 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.sans-serif\": [\"Computer Modern Roman\"]})\n",
    "plt.rcParams['axes.spines.right'] = False\n",
    "plt.rcParams['axes.spines.top'] = False\n",
    "plt.rcParams['axes.spines.left'] = True\n",
    "plt.rcParams['axes.spines.bottom'] = True\n",
    "plt.rcParams['axes.grid'] = True\n",
    "plt.rcParams['grid.alpha'] = 0.5\n",
    "plt.rcParams['font.size'] = 17\n",
    "plt.rcParams['legend.framealpha'] = 0.7\n",
    "plt.rcParams['xtick.labelsize'] = 14\n",
    "plt.rcParams['ytick.labelsize'] = 14\n",
    "# plt.rcParams['xaxis.labellocation'] = 'center'\n",
    "# plt.rcParams['yaxis.labellocation'] = 'top'\n",
    "plt.rcParams['legend.fontsize'] = 'medium'\n",
    "\n",
    "images = jnp.concatenate([comparison0,comparison1[8:],vae_mix,comparison2[8:],decoder_mix,comparison4[8:],]).clip(0,1)\n",
    "\n",
    "labels = ['GT', 'Model 0', 'Model 1', 'Merge VAE', '+ Alignment', 'Merge Generator', '+ Alignment']  # Example labels\n",
    "\n",
    "def plot_images(images, labels):\n",
    "    num_images = images.shape[0]\n",
    "    rows = 7\n",
    "    cols = num_images // rows\n",
    "\n",
    "    fig, axes = plt.subplots(rows, cols, figsize=(3,3))\n",
    "    fig.subplots_adjust(hspace=0., wspace=0.)\n",
    "\n",
    "    for i in range(rows):\n",
    "        for j in range(cols):\n",
    "            index = i * cols + j\n",
    "            ax = axes[i, j]\n",
    "            ax.imshow(images[index, :, :, 0], cmap='gray')\n",
    "            ax.axis('off')\n",
    "\n",
    "            # Label on the left of each row\n",
    "            if j == 0:\n",
    "                ax.annotate(labels[i], xy=(-0.1, 0.5), xycoords='axes fraction', rotation=0, va='center', ha='right')\n",
    "\n",
    "    plt.savefig(\"results/mnist-comparison.pdf\",bbox_inches='tight')\n",
    "    plt.show()\n",
    "\n",
    "plot_images(images, labels)\n",
    "\n",
    "\n",
    "# display(vae_utils.save_image(comparisons, f'results/samples_aligned.png', nrow=8))\n",
    "# metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "permutation matrix:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0aHBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/wAALCAAUABQBAREA/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/9oACAEBAAA/APB7eG3lik8268iYcoHjJRgFYkFhkhiQigbcHdklQObFtDLbzrbNbeXfT7Fia6KJGI5UIywkGBkOjLJuAUfN3DLYs/FOt6XEYdI1S+0u3O0tBZXcsaM4UKXI3febaCf0AAAFdri3t9Rkj8qCazOyGU2wI81FK5eNpVZo2fZndtGNxG0KStRndaWCGO6kV7xGE0UbrtMQcbQ21ic70J2MoxtRhncMV54JrW4lt7iKSGeJykkcilWRgcEEHkEHjFal5Y26+EtK1KOPZcS3d1ay4YkOI1hdWIOcN++KnGBhV4zknLnnmuriW4uJZJp5XLySSMWZ2JySSeSSec0STNKkKMIwIk2LtjVSRuLfMQMscseTk4wOgAH/2Q==",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAAAAACo4kLRAAAAQ0lEQVR4AX2OWxIAIAgCuf+la3o4CaR+yQIW4DMEqQ5bOWkS0QAKfAPiiiyuWMpAUXw4/6tpr0Jjk0Uiv3T2bf8zRidaLBPtwvBVsQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<PIL.Image.Image image mode=L size=20x20>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# visualize barrier\n",
    "\n",
    "plt.rcParams['legend.fontsize'] = 'small'\n",
    "\n",
    "def barrier(params0,params1,grid):\n",
    "    bce = []\n",
    "    kld = []\n",
    "    loss = []\n",
    "    metrics, comparison, sample = train.eval_f(params0, test_ds, z, eval_rng, model2, config)\n",
    "    b0,k0,l0 = (metrics[i].item() for i in ['bce','kld','loss'])\n",
    "    metrics, comparison, sample = train.eval_f(params1, test_ds, z, eval_rng, model2, config)\n",
    "    b1,k1,l1 = (metrics[i].item() for i in ['bce','kld','loss'])\n",
    "    for t in grid:\n",
    "        def interp(x,y):\n",
    "            return (1-t)*x+t*y\n",
    "        params = jax.tree_util.tree_map(interp,params0,params1)\n",
    "        metrics, comparison, sample = train.eval_f(params, test_ds, z, eval_rng, model2, config)\n",
    "        b,k,l = (metrics[i].item() for i in ['bce','kld','loss'])\n",
    "        bb = interp(b0,b1)\n",
    "        kk = interp(k0,k1)\n",
    "        ll = interp(l0,l1)\n",
    "        bce.append(b/bb-1)\n",
    "        kld.append(k/kk-1)\n",
    "        loss.append(l/ll-1)\n",
    "    return bce, kld, loss\n",
    "\n",
    "grid = np.linspace(0,1,51)\n",
    "bce, kld, loss = barrier(params2,params3,grid)\n",
    "\n",
    "intermediates = True # State alignment\n",
    "\n",
    "corr = correlations_E(params2, params3, intermediates)\n",
    "p = find_perm(corr)\n",
    "params31 = rotate_E(params3,p)\n",
    "corr = correlations_Z(params2, params31, intermediates)\n",
    "p = find_perm(corr)\n",
    "params32 = rotate_Z(params31,p)\n",
    "corr = correlations_D(params2, params32, intermediates)\n",
    "p = find_perm(corr)\n",
    "params33 = rotate_D(params32,p)\n",
    "\n",
    "bce1, kld1, loss1 = barrier(params2,params33,grid)\n",
    "\n",
    "intermediates = False # Weight alignment\n",
    "\n",
    "corr = correlations_E(params2, params3, intermediates)\n",
    "p = find_perm(corr)\n",
    "params31 = rotate_E(params3,p)\n",
    "corr = correlations_Z(params2, params31, intermediates)\n",
    "p = find_perm(corr)\n",
    "params32 = rotate_Z(params31,p)\n",
    "corr = correlations_D(params2, params32, intermediates)\n",
    "p = find_perm(corr)\n",
    "params33 = rotate_D(params32,p)\n",
    "bce2, kld2, loss2 = barrier(params2,params33,grid)\n",
    "\n",
    "plt.figure(figsize=(3,2))\n",
    "plt.plot(grid,loss,label=\"No Alignment\")\n",
    "plt.plot(grid,loss1,label=\"State Matching\")\n",
    "plt.plot(grid,loss2,label=\"Weight Matching\")\n",
    "plt.xlabel(\"Model Interpolation\")\n",
    "plt.ylabel(\"Loss Barrier\")\n",
    "plt.legend(loc='upper center')\n",
    "plt.savefig(\"results/barriers.pdf\",bbox_inches='tight')\n",
    "plt.show() # \n",
    "plt.figure(figsize=(3,2))\n",
    "plt.plot(grid,kld,label=\"No Alignment\")\n",
    "plt.plot(grid,kld1,label=\"State Matching\")\n",
    "plt.plot(grid,kld2,label=\"Weight Matching\")\n",
    "plt.xlabel(\"Model Interpolation\")\n",
    "plt.ylabel(\"Latent Gaussianity\")\n",
    "plt.legend()\n",
    "plt.savefig(\"results/gaussianity.pdf\",bbox_inches='tight')\n",
    "plt.show() # Gaussianity is slightly better \n",
    "print(\"permutation matrix:\")\n",
    "display(mat2pil(pz))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Align Conic Activation Funcitons"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "# config.latents = 2401\n",
    "# config.num_groups = 1\n",
    "config.latents = 2401\n",
    "config.num_groups = 800\n",
    "model = models.model(config.latents, config.dataset_name, config.act_fn,num_groups=config.num_groups,variant=config.variant,share_axis=config.share_axis)\n",
    "# # train and save\n",
    "# config.num_epochs = 500\n",
    "# config.seed = 13579\n",
    "# loss = train.train_and_evaluate(config)\n",
    "# # another run\n",
    "# config.seed = 1\n",
    "# loss = train.train_and_evaluate(config)\n",
    "# log_dir = f'log/{config.act_fn}_shareaxis_{config.share_axis}_{config.variant}/C{config.latents}_group{config.num_groups}/'\n",
    "# ckpt_dir = log_dir+f'seed{config.seed}.msgpack'\n",
    "# print(f\"checkpoint saved at {ckpt_dir}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "PyTreeDef({'decoder': {'fc1': {'bias': *, 'kernel': *}, 'fc2': {'bias': *, 'kernel': *}}, 'encoder': {'fc1': {'bias': *, 'kernel': *}, 'fc2_logvar': {'bias': *, 'kernel': *}, 'fc2_mean': {'bias': *, 'kernel': *}}})"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "params0 = vae_utils.load_model('log/colu_shareaxis_True_hard/C2401_group800/seed105.msgpack')\n",
    "import flax\n",
    "import numpy as onp\n",
    "params0 = flax.core.unfreeze(params0)\n",
    "params0 = jax.tree_map(\n",
    "    lambda x, y: onp.reshape(x, y.shape) if hasattr(y, 'shape') else x,\n",
    "    params0,\n",
    "    flax.core.unfreeze(params0))\n",
    "loaded_paparams0rams = flax.core.freeze(params0)\n",
    "# params1 = vae_utils.load_model('log-archived/colu_shareaxis_True_soft/C2401_group800/seed13579.msgpack')\n",
    "tree,treedef = jax.tree_util.tree_flatten_with_path(params0)\n",
    "# [params0[key[0]] for key in tree]\n",
    "treedef"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "FrozenDict({\n",
       "    intermediates: {\n",
       "        __call__: (((10000, 784), (10000, 20), (10000, 20)),),\n",
       "        decoder: {\n",
       "            __call__: ((10000, 784),),\n",
       "            fc1: {\n",
       "                __call__: ((10000, 2401),),\n",
       "            },\n",
       "            fc2: {\n",
       "                __call__: ((10000, 784),),\n",
       "            },\n",
       "        },\n",
       "        encoder: {\n",
       "            __call__: (((10000, 20), (10000, 20)),),\n",
       "            fc1: {\n",
       "                __call__: ((10000, 2401),),\n",
       "            },\n",
       "            fc2_logvar: {\n",
       "                __call__: ((10000, 20),),\n",
       "            },\n",
       "            fc2_mean: {\n",
       "                __call__: ((10000, 20),),\n",
       "            },\n",
       "        },\n",
       "    },\n",
       "})"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# sow intermediates\n",
    "recon_x, mean, logvar, intermediates = eval_f(params0, test_ds, z, eval_rng, model, config)\n",
    "xx0 = intermediates['intermediates']['encoder']['fc1']['__call__'][0]\n",
    "# recon_x, mean, logvar, intermediates = eval_f(params1, test_ds, z, eval_rng, model, config)\n",
    "# xx1 = intermediates['intermediates']['encoder']['fc1']['__call__'][0]\n",
    "jax.tree_map(lambda x: x.shape,intermediates)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import functools\n",
    "from flax import linen as nn\n",
    "@functools.partial(jax.jit, static_argnames=['channel_axis','variant','eps','num_groups','project_axes','share_axis'])\n",
    "def group_colu(input, channel_axis = -1, variant = \"soft\", eps = 1e-7, num_groups = 100,project_axes = False, share_axis = True):\n",
    "    \"\"\"project the input x onto the axes dimension\"\"\"\n",
    "    \"\"\"output dimension = S = axes + cone sections = [len=(G or 1)] + G * [len=(S-1)]\"\"\"\n",
    "    if num_groups == 0: # trivial case\n",
    "        return input\n",
    "    num_channels = input.shape[channel_axis]\n",
    "    if (share_axis and num_groups == num_channels - 1) or (not share_axis and num_groups * 2 == num_channels): # pointwise case\n",
    "        return nn.silu(input) if variant == \"soft\" else nn.relu(input)\n",
    "    group_size = (num_channels - 1) // num_groups + 1 if share_axis else num_channels // num_groups\n",
    "        \n",
    "    # y = axes, x = cone sections\n",
    "    if share_axis:\n",
    "        assert (num_channels - 1) % num_groups == 0, \"Channel size must be a multiple of number of cones plus one\"\n",
    "        y, x = input.take(jnp.arange(1), axis=channel_axis), input.take(jnp.arange(1,num_channels), axis=channel_axis)\n",
    "    else:\n",
    "        assert num_channels % num_groups == 0, \"Channel size must be a multiple of number of cones\"\n",
    "        y, x = input.take(jnp.arange(num_groups), axis=channel_axis), input.take(jnp.arange(num_groups,num_channels), axis=channel_axis)\n",
    "        group_size = num_channels // num_groups # S = C / G\n",
    "\n",
    "    print(jnp.array(y))\n",
    "\n",
    "    assert channel_axis < 0, \"channel_axis must be negative\" # Comply with broadcasting on first dimensions\n",
    "    x_old_shape = x.shape\n",
    "    y_old_shape = y.shape\n",
    "    x_shape = x.shape[:channel_axis] + (num_groups, group_size - 1) # NG(S-1)\n",
    "    if share_axis:\n",
    "        y_shape = y.shape[:channel_axis] + (1, 1) # N11\n",
    "    else: \n",
    "        y_shape = y.shape[:channel_axis] + (num_groups, 1) # NG1\n",
    "    if channel_axis < -1:\n",
    "        x_shape += x.shape[(channel_axis+1):] # NGSHW if channel_axis = -3\n",
    "        y_shape += y.shape[(channel_axis+1):] # NG1HW\n",
    "    x = x.reshape(x_shape)\n",
    "    y = y.reshape(y_shape)\n",
    "    xn = jnp.linalg.norm(x,axis=channel_axis,keepdims=True) # NG1HW, norm\n",
    "\n",
    "    if project_axes:\n",
    "        assert not share_axis, \"shuffle_axes is not compatible with share_axis\"\n",
    "        y0, y1 = y.take(jnp.arange(1), axis=channel_axis-1), y.take(jnp.arange(1,num_groups), axis=channel_axis-1) # N11HW, N(G-1)1HW\n",
    "        yn = jnp.linalg.norm(y1,axis=channel_axis-1,keepdims=True) # N11HW\n",
    "        ymask = y0 / (yn + eps) # N11HW\n",
    "        ymask = nn.sigmoid(ymask-.5) if variant == \"soft\" else ymask.clip(0,1)\n",
    "        y1 = ymask * y1 # N(G-1)1HW\n",
    "        y = jnp.concatenate([y0,y1],axis=channel_axis-1)\n",
    "    \n",
    "    mask = y / (xn + eps) # NG1HW\n",
    "    if variant == \"softmax\":\n",
    "        mask = nn.softmax(mask, axis=channel_axis)\n",
    "    elif variant == \"softapprox\":\n",
    "        mask = nn.sigmoid(4 * mask - 2)\n",
    "    elif variant == \"soft\":\n",
    "        mask = nn.sigmoid(mask - .5)\n",
    "    elif variant == \"hard\":\n",
    "        mask = mask.clip(0,1)\n",
    "    else:\n",
    "        raise NotImplementedError(\"variant must be soft or hard.\")\n",
    "\n",
    "    x = mask * x # NGSHW\n",
    "    x = x.reshape(x_old_shape)\n",
    "    y = y.reshape(y_old_shape)\n",
    "    output = jnp.concatenate([y,x],axis=channel_axis)\n",
    "    \n",
    "    return output\n",
    "\n",
    "y = group_colu(xx0[1], num_groups=800)\n",
    "plt.hist(y)\n",
    "y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "after:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/evergreen/.local/lib/python3.8/site-packages/jax/_src/ops/scatter.py:92: FutureWarning: scatter inputs have incompatible types: cannot safely cast value from dtype=float64 to dtype=float32. In future JAX releases this will result in an error.\n",
      "  warnings.warn(\"scatter inputs have incompatible types: cannot safely cast \"\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAgGBgcGBQgHBwcJCQgKDBQNDAsLDBkSEw8UHRofHh0aHBwgJC4nICIsIxwcKDcpLDAxNDQ0Hyc5PTgyPC4zNDL/2wBDAQkJCQwLDBgNDRgyIRwhMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjL/wAARCAA+APIDASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD5/oorvPCvgSxuPDUvi/xXqMmn+HY3eGOOAf6VeSgDasIZdpBORnnlGBAALKAcHRXv/wAJfEejS+Ib290zSNK8L6FY2h+2vcu88kryOoX/AEp8CNcouEJ5O7CsTuTwCgAq5pWlX2uapb6ZpltJc3lw+yKJOrH+QAGSSeAAScAVTr3z4F6esHg7xHqWn6vaQaxcoLWAyXTBbeVsrD5kRTbkuV2t8+clQAQwYA83T4S+PJLe7nHhq7CWjukgZkDMVGTsUtmQehQEN2zXF12njC68f6Gj+HfFep6lsu0juWtri++0B1VmCnIZsDcD8ueSqkjhSOLoAK0JdC1iCza8l0q+jtVijnaZ7dwgjkJEblsY2sQQD0OOK6D4XeHk8TfEXSLGZoPs6S/aJkmCsJEj+cpsYjfuxtIGcAk4IBr6D8VfFfw14HuLayhWS4Fu7Wn2LT5LcxxqhiyWAbdGUBdVQ7clXBAG1gAfJlFekfF7wKnhnXE1jSB53h7Vv39vPEq+TE7ZbylK8bcYZeBlTgZ2k15vQAV0lr4G1q58EX3i8xRw6TaOiB5SQ05Zwh8sY5CsQCTgdQMkECPwX4TvPGvii10WzfyvNy805QusMajLMQPwAzgFioyM5r3vxp8OvE134Ts/BvhNLS38O2bxBvtVywuLlyxZ3JXKmIGTeVIB3RnauAgIB8yUVc1XSr7Q9UuNM1O2ktry3fZLE/VT/IgjBBHBBBGQap0AFWLqwvLHyPtlpPb+fEs8PnRlPMjb7rrnqpwcEcGvTPCEGm+C/hvfeNdRitJdav3Nv4fjmVXaNkbDToDuGVbnLKMeWBn94M0/i1qlxry+FdYuzYyXF7pXmyS21wJDkyyHyyoxtVM7Rlc53qXkKE0Aeb0UUUAbGn+FtZ1TQ7/W7WzzplhgXF1JKkaKT/CCxG5uR8q5PzKMfMM49fSfjT4kw/Cuw0Pw34Vs7S7g/sxZoribBjZWcBJMxkBywWUtgDJdWB6g8J8W30nXfDnhfxjZwQWt7q/2n7RGJpZnk2uOrMoB2ElT0xlVXciggA8noor1jRvhn4b0zwMnibx7rM9l9siFxYWNjLH50seBjAYHczbk4GAoILEZO0A8nor3TSPjX4N8Opdto3gKOzniRYLOSJo1e4i3c+dJt3KcKp/5aZPU965/4k3eg6x4D8M69Y+GrTQru/uLkQw2ITY8MZCOZSEQ794G0DIALZOTgAHldFFFAFyw0q+1NLx7G2knFlbm6uNnJSIMql8dSAWGcdBkngEinXsFjdXHw0+DM80NxBbeI/EssTxeTdjz4bIqSkmznGcSAEYI80fMGXA8foAKKKKACvdPhfdaB4u8HWfhXxTo93NaaW91dRXYnaC0jiXa7vIwlXc6tLjhTtV16Asa8LrsNQ8ded8OrDwbpunfYbWKU3F7P5+57yTr8wVVG0Hs24/JHz8uSAanxE+JDeIDJoPh+KPTfC0DlY7O1VUjuCsjsJSAilQ2VbYeAQD15rzuiigDrPBPw81rx690ujvaKLV41ma4kKhA6uQ3AJIzHjjJyy8YyRz+pabNplwsMrRyBkDJLES0b8lW2NjDgMrIWXKkqcEjkmm6tqWjXDXGl6hd2M7IUaS1maJiuQcEqQcZAOPYV1g+MHj4WcNqPEc/lxbNpMUZc7CCNz7dzdBnJO7kHIJyAdh4/wBNuPDfwS8N6Tr9jv15ruQCS5uhM9rGpICx4kOFKCEbVBQdwGKmvF6sX99canqNzf3knmXV1K80z7QNzsSWOBwMknpVegDuPhP4s07wb45h1HVUn+ySRNbvJC7DytxHzso/1ijHKnPXcAWUCtD4k/D/AMQWvia71u2tf7S0zWbuS6tbrTg06Yll/dqxA4Y70x2bcApPOPN67jwd8WPFPgmz+w2E8FzYDcUtLyMukbMQSVIIYdDxnb8zHGTmgDrPHX/CTL8BfCcOt2sdskF6YGjnRkuMIrrBlCqhQEDg5ySBG2fmYDxutzxF4w1/xY8T67qUl4YnZ49yKoQsqK20KAACI14HGcnqSTh0AfRfwB03TbnwVrVxpjR2niRne1e9YrM8KlQY3WMgbU3ZO053GM5OAAtiwh1Lwvqn9q+O/iLJcRaXZBrbSobxraW7aPcG3RsUMo3qwVjnzflJOPlPzpY395pl5HeWF3PaXUedk0Ehjdcgg4YcjIJH40Xl/eahKJb27nuZBuw80hcjcxduT6szMfUsT1NAHSfEfxbN4z8a32otNHLaRO1vYlIyg+zqzbDg85OSxzzlj0GAOToooA9U1z4s6Hq3g628Nw+ArSGzs3V7WOTUJWjjYZBJEYRmJDPyW5LZOTXSfEXxtP4f8L+HtKg0aCyvrzRLm1ls7tJfMsbOUoiID5mC2IsZbLZjBKpuK14PXQeKPGGo+Lf7N/tCCxi/s+0W0i+yWyxZVe5x/wCgjCjnaoycgHP0UUUAe6fGvQ77xXqXhrXNGto79L23WyeewufPt1l83aq+ZsVQC8pUOzDceNq7eeb+Jmgy+D/Bfg7w9Je4umimu7+xQooWZiMOwXJZgGaIOSQRF8uPmzzegfEvxh4X0tdM0fWpILNXLrE0McoQnrt3qSBnnA4ySepNcvPPNdXEtxcSyTTyuXkkkYszsTkkk8kk85oAjr0yy+K1jceDrLw94q8I2mvJYoIba4Nx9nkjiG3aoKoSD8oBKkbgACDyT5nRQB6ovxd0jSnsrrwz8PtG0zULNDFHczSGY+WVAbO0IS5wPnZicFh/Ea6/4y6lD4j+DHhbxA62kl3cXEJaSAAiNnhcyopySBvXBGeqDPIr58rrNa8cTat4D0LwnFYx2lppjvJIUkLC4kJO18MCVI3PkBiCXPAAAAByddJ4D8KTeM/GNhoyCQQO++6kTP7uFeXOcEA4+UEjG5lB61zdamh+I9X8NXFzcaNfSWc9xbtbSSRgbvLYgkAkZU5UHcMEY4IoA7T456tcan8UL2G4tvIXT4o7WIHG5kx5m44YjkyEjp8pXIBzXm9STzzXVxLcXEsk08rl5JJGLM7E5JJPJJPOajoAKKKKACiivS9G0nSPAvg618XeItPTU9U1VJF0bSrmEmBVHBnmBGGGGBVe4ZSOu5ADkfD/AIM8R+KnA0TR7q7TcUMyrtiVgMlTI2FBwRwT3HrWI6NHIyOCrKSCD2Ir3Hwlc65pWk3fxP8AG+pXMxgjlGiWd7K482eZeHRMgKjAkAKMbdzYAQE+GUAFdF4O8Ea3451R7HR4EPlLvmnmbbFCD03HB5PYAEnB4wCRztey/DLxb4K0/wCHOt+HtfvBpd5qLSRSXMNvK7yxMgCksob7pLgLwMduSSAcz4l8AaB4e0S4mTx3puoaxBCkj6faxblLF1R1WXfgldxOMBiFztA6cBXY+NvAh8MwWer6bfx6r4d1En7HfRKew+5JxhX+8MZ52twCCBx1ABXcr8HPH7WC3o8OzeW0fm7TNEJNuM8oW3Z/2cZzxjNS/BfSRq3xT0gSW7TQ2pe6kxkbNikoxI7CTZ14PA74rtfH/wAc/ENj4yn07QUis7TS7l4JhNGshumRyG3Z+6hxgBSG6nPIAAPDnRo3ZHUq6khlYYIPoabXqPxb0W0vLfR/H+lJttPEMYe6hj2tHbXIUbl3gDJJD5yM7kc98Dy6gAr0WH4cWtn8Jbvxjr15c2d1OyLpdqqKPNBPBYNgkMMkYxhV3fMDik+DvgZvGPjGOe4ijfSdMdJ7wOVO88mOPaQdwZl5GMbQ3IJGfXvih4b8MazrsD+LvGAsIUhWLTtOtlVZIy5wZGB3FgWXGQqgBQM8EkA+XaK3/GnhS78FeKbvRLuQTGLDRTqhVZY2GVYA/kRzggjJxmsCgDS0PQNV8S6omm6PZSXd24LCNMDAHUknAUe5IHIrR8aeC9T8C6xDpeqy2sk8tutwptnZl2lmXBJA5yprt7fTNS8I/DG0t9K0ee68ReLYXMs0Vo0zRWBAxEhGRlwQxwMgNggEIRS+IngXW9N0fwrPBpGoSWcGhRi5k8ot5E2+SWVX2j5ADLxuA+pINAHmVFFFAHpGifBHxbr/AIYh120Nikc8Rlhtp5XSaReduAV2jdgEEsBgg5Aridc0DVfDepNp+s2M1ndKN2yQfeXJG5SOGGQRkEjg16n8eNQuNL8S+GdO01nsbbTdMSazWJtrwMzleGBzwIkHXtWf488Sy+OfhV4d1zUTnVbK/msJWUBFlzGrl9oBGSBHnlcEthcEYAPKqKK99tdJ0X4ZfCjR/GVvoFtretXixP8AarkEpatIpkR9vzAbGCLkbST/ABDOKAPHNC8IeIvErL/Y2jXl4jSeV50cR8pWwDhpD8qnBHUjqPWovEHhrWfC2o/YNb0+WzuNoYB8FWBHVWBKsPoTg5HUV6FceOvi94vtXl0+HVV0+7b5DpdgyIuG6JMqlgMjB+f1B44p/wAW7HW7DwR4Ch8RXUtxqnk3ZnMshdgS8bAMxGSwVlU8kZXj1IB5LRRRQB0Phjwje+J4NYuoHENppNjJe3MzKT91SVQf7TYOMkcBj2weer1TxbEPAnwt0jwtHGkWq68q6hq+5MSrGCDFEwZcgA9sjDRt2Y15XQAUUUUAFe+/CjxZ4h0Twhd654pvpT4NsLU21lFJGrSzy7wFWLjcygBk5baM46KdvgVbWp+LNc1jRNP0a9v2fTdPGLa2SNI0XjGSFA3HGeWyeTzycgE3i3xrrnjbUUvNauhJ5W4QQRrtihUnJCr+XJySAMk4Fc/RRQBq+G9Lsta8Q2mnahqsWlWs5ZXvZl3JEdpIyMjgkAZyMZz2rtIPgX41urtEtodPmspArRajHeI0EiMAQy4+cjB/u/TtXm1FAHo/jO+0PQvAWm+BdKvYdUu47salqGoWsm6380oVEcZ53YVgCRgfKOMlgvnFFFAHQeC/Fl54K8UWutWaeb5WUmgLlFmjYYZSR+BGcgMFODjFeqaz8K7P4lyt4v8AA2rWqwajI0l3a3zMrQTnlxlQxBJOSp45ypKkV4XU1reXNjcC4s7ia3mAZRJC5RgCCCMjnkEg+xoA9W+J0kPhf4e+Gvh8uo2l/e2Usl1ftASfJkJYqn/kV+uCdoOBnFeR0UUAe1fCvxV4abwDqPg3VtZm0C6vLvzFvIWMfmIwTP7w5VDhCpztG0jGSTUk/iH4WeBpWv8ARI7zxV4hWRmhub5mZYXUqASxVVOMFlZVY5H3gCDXiNFAGlr+uX3iXXbzWNRcPd3Um99owBxgKB6AAAewrNoooA6Z/iH4wOn2VhH4i1C3trKIQwJbSmDagAABKYLYAGN2cV23xT8Xa2uk+CrCPUruNW8PwXc0qTuHneVCjGQ5+bhT15+dvWvI6nur67vTCbu6muPJiWGLzZC/lxr91Fz0UdgOBQBBRRRQB774k8K3vxt0jw54q0Oazjvfs7WWpxzS7EhdCW4VdxA3F+pJ2vGcdSOT+LOsaXp9vp/w+8OmQ6Xojs88zSrJ59wwyTkd13OD0+ZmG0bRXl1FABXUeG/iJ4q8I6dJYaHqv2S1klMzJ9niky5ABOXUnoo/KuXooA6/U/in451Zozc+Jr9DGCF+yuLbOfXygu7p3ziu5+It/JJ8C/BkGrakl7rE832gSAmRjFsY4Z8cMqywggnJPrjNeL1I08zW6W7SyGCN2dIyx2qzABiB0BIVcnvtHpQBHXb/AAl8OWXib4iafaahLALWDddSQzMB9o2ciMKQQ2Tgsv8AcD+lcRRQB03xB8QzeJ/HOrag9613b/aHitH52iBWIjCjsMc+5JJ5JrmaKKACiiigD//Z",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "before:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def orthogonal(rng, C, G=100):\n",
    "    \"\"\"w/ axis sharing, not group-wise, switch groups\"\"\"\n",
    "    p = jnp.eye(C)\n",
    "    # rotation within cones\n",
    "    S_1 = (C - 1) // G\n",
    "    for i in range(G):\n",
    "        rng, key = jax.random.split(rng, 2)\n",
    "        p = p.at[(1+S_1*i):(1+S_1*(i+1)),(1+S_1*i):(1+S_1*(i+1))].set(jax.random.orthogonal(key,S_1))\n",
    "    \n",
    "    # permutation across cones\n",
    "    rng, key = jax.random.split(rng, 2)\n",
    "    o = jax.random.permutation(key, G)\n",
    "    o = jnp.eye(G)[o]\n",
    "    e = jnp.eye(S_1)\n",
    "    p1 = jnp.eye(C).at[1:,1:].set(jnp.kron(o,e))\n",
    "    \n",
    "    return rng, p1.dot(p)\n",
    "\n",
    "def rotate_tree(params0, p):\n",
    "    \"\"\"align params\"\"\"\n",
    "    params = copy_pytree(params0)\n",
    "    params['encoder']['fc1']['kernel'] = jnp.dot(params['encoder']['fc1']['kernel'],p)\n",
    "    params['encoder']['fc1']['bias'] = jnp.dot(params['encoder']['fc1']['bias'],p)\n",
    "    params['encoder']['fc2_logvar']['kernel'] = jnp.dot(p.T,params['encoder']['fc2_logvar']['kernel'])\n",
    "    params['encoder']['fc2_mean']['kernel'] = jnp.dot(p.T,params['encoder']['fc2_mean']['kernel'])\n",
    "    return params\n",
    "\n",
    "# def rotate_tree_decoder(params0, p):\n",
    "#     \"\"\"align params\"\"\"\n",
    "#     params = copy_pytree(params0)\n",
    "#     params['decoder']['fc1']['kernel'] = jnp.dot(params['decoder']['fc1']['kernel'],p)\n",
    "#     params['decoder']['fc1']['bias'] = jnp.dot(params['decoder']['fc1']['bias'],p)\n",
    "#     params['decoder']['fc2']['kernel'] = jnp.dot(p.T,params['decoder']['fc2']['kernel'])\n",
    "#     return params\n",
    "\n",
    "rng = jax.random.PRNGKey(0)\n",
    "rng, p = orthogonal(rng,2401,800)\n",
    "\n",
    "params11 = rotate_tree(params1,p)\n",
    "print(\"after:\")\n",
    "# params = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params0,params11)\n",
    "metrics, comparison, sample = train.eval_f(params11, test_ds, z, eval_rng, model, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))\n",
    "\n",
    "print(\"before:\")\n",
    "# params = jax.tree_util.tree_map(lambda x,y: .5*x+.5*y,params0,params1)\n",
    "metrics, comparison, sample = train.eval_f(params1, test_ds, z, eval_rng, model, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))\n",
    "# what a chaos\n",
    "\n",
    "# pp = p.T.dot(p)\n",
    "# display(mat2pil(p).resize((1200,1200))) # watch the stars in the deep sky"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "OptimizerResult(point=array([[ 0.19716795, -0.22328332, -0.95460429],\n",
       "       [ 0.67502387, -0.67521962,  0.29735708],\n",
       "       [ 0.71096243,  0.70300997, -0.0175899 ]]), cost=Array(-38.24146177, dtype=float64), iterations=16, stopping_criterion='Terminated - min grad norm reached after 16 iterations, 0.14 seconds.', time=0.1382765769958496, cost_evaluations=16, step_size=2.4536782599269287e-05, gradient_norm=9.589014322025551e-05, log={'optimizer': 'ConjugateGradient', 'stopping_criteria': {'max_time': 1000, 'max_iterations': 1000, 'min_gradient_norm': 0.0001, 'min_step_size': 1e-10, 'max_cost_evaluations': 5000}, 'optimizer_parameters': {'beta_rule': 'HestenesStiefel', 'orth_value': inf, 'line_searcher': <pymanopt.optimizers.line_search.AdaptiveLineSearcher object at 0x7f9d003b9dc0>}, 'iterations': None})"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "import pymanopt\n",
    "def find_cone_rotation(w0, w1, tol = 1e-4):\n",
    "    \"\"\"tol: stopping rule on gradient norm\"\"\"\n",
    "    assert w0.shape == w1.shape, \"different network widths not supported yet\"\n",
    "    S_1 = w0.shape[-1]\n",
    "    # Define the manifold\n",
    "    manifold = pymanopt.manifolds.Stiefel(S_1,S_1)\n",
    "    # Define the objective function\n",
    "    @pymanopt.function.jax(manifold)\n",
    "    def objective(X):\n",
    "        return -jnp.trace(w0.dot(X).dot(w1.T)) # minus sign for maximizing\n",
    "    # Create the problem instance on the manifold with the objective function\n",
    "    problem = pymanopt.Problem(manifold=manifold, cost=objective)\n",
    "    # Select a solver\n",
    "    solver = pymanopt.optimizers.ConjugateGradient(verbosity=0,min_gradient_norm=tol) # faster than frist-order solver\n",
    "    # Solve the problem quietly\n",
    "    return solver.run(problem) # field .point is the array\n",
    "\n",
    "find_cone_rotation(xx0[:10,1:4],xx1[:10,1:4])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 800/800 [05:10<00:00,  2.58it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "def find_cone_permutation(xx0,xx1, C, G):\n",
    "    S_1 = (C - 1) // G\n",
    "    xx0 = jnp.array(xx0[:,1:].reshape((-1,G,S_1)).sum(axis=-1))\n",
    "    xx1 = jnp.array(xx1[:,1:].reshape((-1,G,S_1)).sum(axis=-1))\n",
    "    cov = xx0.T.dot(xx1)\n",
    "    row_ind, col_ind = scipy.optimize.linear_sum_assignment(cov, maximize=True)\n",
    "    assert any(row_ind == [i for i in range(G)]), \"just to let you know\"\n",
    "    return col_ind\n",
    "\n",
    "def align(xx0, xx1, C, G, parallel=True, num_MC=1000):\n",
    "    \"\"\"w/ axis sharing, not group-wise\"\"\"\n",
    "    \"\"\"num_MC: sample points to estimate covariance\"\"\"\n",
    "    p = jnp.eye(C)\n",
    "    S_1 = (C - 1) // G\n",
    "    # permute cones\n",
    "    permutation = find_cone_permutation(xx0, xx1, C, G)\n",
    "    perm_matrix = jnp.kron(jnp.eye(G)[permutation],jnp.eye(S_1))\n",
    "    p1 = jnp.eye(C).at[1:,1:].set(perm_matrix)\n",
    "    # split cones\n",
    "    def pi_G(A,i):\n",
    "        \"\"\"take each cone section's dimensions\"\"\"\n",
    "        return A[:num_MC,(1+S_1*i):(1+S_1*(i+1))]\n",
    "    blocks0 = [pi_G(xx0,i) for i in range(G)]\n",
    "    blocks1 = [pi_G(xx1,i) for i in permutation]\n",
    "    # align cones\n",
    "    if parallel:\n",
    "        with ThreadPoolExecutor(max_workers=G) as executor:\n",
    "            results = list(tqdm(executor.map(find_cone_rotation, blocks0,blocks1), total=len(blocks0)))\n",
    "        for i, result in enumerate(results):\n",
    "            p = p.at[(1+S_1*i):(1+S_1*(i+1)),(1+S_1*i):(1+S_1*(i+1))].set(jax.device_put(result.point))\n",
    "    else:\n",
    "        for i in tqdm(range(G)):\n",
    "            result = find_cone_rotation(blocks0[i],blocks1[i])\n",
    "            p = p.at[(1+S_1*i):(1+S_1*(i+1)),(1+S_1*i):(1+S_1*(i+1))].set(jax.device_put(result.point))\n",
    "    return p1.dot(p)\n",
    "\n",
    "p = align(xx0[:500],xx1[:500],C=config.latents, G=config.num_groups,parallel=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def rotation_matrix(theta, n1, n2):\n",
    "    dim = len(n1)\n",
    "    assert len(n1) == len(n2)\n",
    "    assert jnp.abs(jnp.dot(n1, n2)) < 1e-4\n",
    "    return (jnp.eye(dim) +\n",
    "            (jnp.outer(n2, n1) - jnp.outer(n1, n2)) * jnp.sin(theta) +\n",
    "            (jnp.outer(n1, n1) + jnp.outer(n2, n2)) * (jnp.cos(theta) - 1))\n",
    "\n",
    "def rotate_vector(theta, n1, n2, vec):\n",
    "    assert len(n1) == len(n2)\n",
    "    assert len(n1) == len(vec)\n",
    "    assert jnp.abs(jnp.dot(n1, n2)) < 1e-4\n",
    "\n",
    "    n1_dot_vec = jnp.dot(n1, vec)\n",
    "    n2_dot_vec = jnp.dot(n2, vec)\n",
    "\n",
    "    return (vec +\n",
    "            (n2 * n1_dot_vec - n1 * n2_dot_vec) * jnp.sin(theta) +\n",
    "            (n1 * n1_dot_vec + n2 * n2_dot_vec) * (jnp.cos(theta) - 1))\n",
    "\n",
    "n1 = jnp.zeros((500,)).at[1].set(1)\n",
    "n2 = jnp.zeros((500,)).at[2].set(1)\n",
    "theta = jnp.pi / 360\n",
    "p = rotation_matrix(theta, n1, n2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Optimal orthogonal matrices \n",
    "\n",
    "\\begin{split}\\begin{array}{ll}\n",
    "\\textrm{minimize}_{x\\in\\mathbb R^n}   & \\langle C, x\\rangle_F \\\\\n",
    "\\textrm{subject to} & x^\\top x=I,\n",
    "\\end{array}\\end{split}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0.1781394338607788±0.038357503358607686'"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import jax.numpy as jnp\n",
    "import pymanopt\n",
    "import jax\n",
    "\n",
    "key = jax.random.PRNGKey(0)\n",
    "S_1 = 3\n",
    "A = jax.random.normal(key,(S_1, S_1))\n",
    "\n",
    "def optimize(A):\n",
    "    # Define the manifold\n",
    "    manifold = pymanopt.manifolds.Stiefel(*A.shape)\n",
    "    # Define the objective function\n",
    "    @pymanopt.function.jax(manifold)\n",
    "    def objective(X):\n",
    "        return -jnp.linalg.norm(A * X,\"fro\")  # We use negative sign to demonstrate minimization\n",
    "    # Create the problem instance on the manifold with the objective function\n",
    "    problem = pymanopt.Problem(manifold=manifold, cost=objective)\n",
    "    # Select a solver\n",
    "    solver = pymanopt.optimizers.ConjugateGradient(verbosity=0,min_gradient_norm=1e-4)\n",
    "    # Solve the problem\n",
    "    return solver.run(problem)\n",
    "\n",
    "# test it \n",
    "data = []\n",
    "for i in range(100):\n",
    "    result = optimize(A)\n",
    "    data.append(result.time)\n",
    "data=jnp.array(data)\n",
    "f\"time per cone alignment: {jnp.mean(data):.4f}±{jnp.std(data):.4f}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from concurrent.futures import ThreadPoolExecutor\n",
    "from tqdm import tqdm\n",
    "def align(xx, C, G=100, parallel=True):\n",
    "    \"\"\"trivial alignment: test the method by aligning the model towards itself\"\"\"\n",
    "    \"\"\"w/ axis sharing, not group-wise\"\"\"\n",
    "    p = jnp.eye(C)\n",
    "    S_1 = (C - 1) // G\n",
    "    blocks = [xx[(1+S_1*i):(1+S_1*(i+1)),(1+S_1*i):(1+S_1*(i+1))] for i in range(G)]\n",
    "    if parallel:\n",
    "        with ThreadPoolExecutor(max_workers=G) as executor:\n",
    "            results = list(tqdm(executor.map(optimize, blocks), total=len(blocks)))\n",
    "        for i, result in enumerate(results):\n",
    "            p = p.at[(1+S_1*i):(1+S_1*(i+1)),(1+S_1*i):(1+S_1*(i+1))].set(jax.device_put(result.point))\n",
    "    else:\n",
    "        for i, block in tqdm(enumerate(blocks), total=len(blocks)):\n",
    "            result = optimize(block)\n",
    "            p = p.at[(1+S_1*i):(1+S_1*(i+1)),(1+S_1*i):(1+S_1*(i+1))].set(jax.device_put(result.point))\n",
    "    return p\n",
    "\n",
    "p = align(xx0,C=config.latents, G=config.num_groups,parallel=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "after:\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/evergreen/.local/lib/python3.8/site-packages/jax/_src/ops/scatter.py:92: FutureWarning: scatter inputs have incompatible types: cannot safely cast value from dtype=float64 to dtype=float32. In future JAX releases this will result in an error.\n",
      "  warnings.warn(\"scatter inputs have incompatible types: cannot safely cast \"\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "before:\n"
     ]
    },
    {
     "data": {
      "image/jpeg": "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",
      "image/png": "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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=242x62>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "params1 = prune(params,p)\n",
    "print(\"after:\")\n",
    "metrics, comparison, sample = train.eval_f(params1, test_ds, z, eval_rng, model, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))\n",
    "\n",
    "print(\"before:\")\n",
    "metrics, comparison, sample = train.eval_f(params, test_ds, z, eval_rng, model, config)\n",
    "display(vae_utils.save_image(comparison, f'results/reconstruction.png', nrow=8))"
   ]
  }
 ],
 "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
