{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "NvTXv8aJXzqQ"
   },
   "source": [
    "# Setup - Colab"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 26029,
     "status": "ok",
     "timestamp": 1719224341386,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "6mDwbxpStqHV",
    "outputId": "edd1588a-8381-401a-e6b4-d7a0f5bb1973"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mounted at /content/drive\n",
      "/content/drive/My Drive/multi_view_vae\n"
     ]
    }
   ],
   "source": [
    "from google.colab import drive\n",
    "drive.mount(\"/content/drive\")\n",
    "import sys\n",
    "# add the path of the virtual environmentsite-packages to colab system path\n",
    "sys.path.append(\"/content/drive/MyDrive/virtual_env/lib/python3.10/site-packages\")\n",
    "%cd '/content/drive/My Drive/multi_view_vae'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "_dXrx4KkZJcm"
   },
   "outputs": [],
   "source": [
    "# drive.mount(\"/content/drive\", force_remount=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "executionInfo": {
     "elapsed": 234,
     "status": "ok",
     "timestamp": 1719228339874,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "_oEYnYdPW3zI"
   },
   "outputs": [],
   "source": [
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import numpy as np\n",
    "from jax import random\n",
    "from flax import linen as nn\n",
    "import optax\n",
    "import ml_collections\n",
    "from ml_collections import config_flags\n",
    "import tensorflow_datasets as tfds\n",
    "from flax.training import train_state\n",
    "from absl import flags\n",
    "import utils as vae_utils\n",
    "from absl import logging\n",
    "import input_pipeline\n",
    "from clu import platform\n",
    "import tensorflow as tf\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sb\n",
    "import vae_model_both as vae\n",
    "import other\n",
    "import time\n",
    "import metrics as met"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "fx-dfms3W3zI"
   },
   "source": [
    "#Setup - Local"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "HWGYVLrEW3zJ",
    "outputId": "9291c1d1-8994-40bc-ec1d-5f34969d0749"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[Errno 2] No such file or directory: 'My Drive/multi_view_vae'\n",
      "/Users/ellaorme/Library/CloudStorage/GoogleDrive-ellaorme28@gmail.com/My Drive/multi_view_vae\n"
     ]
    }
   ],
   "source": [
    "%cd 'My Drive/multi_view_vae'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/lib/python3.10/pty.py:89: RuntimeWarning: os.fork() was called. os.fork() is incompatible with multithreaded code, and JAX is multithreaded, so this will likely lead to a deadlock.\n",
      "  pid, fd = os.forkpty()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Defaulting to user installation because normal site-packages is not writeable\n",
      "Collecting flax\n",
      "  Downloading flax-0.8.5-py3-none-any.whl.metadata (10 kB)\n",
      "Requirement already satisfied: numpy>=1.22 in /usr/local/lib/python3.10/dist-packages (from flax) (1.23.5)\n",
      "Collecting jax>=0.4.27 (from flax)\n",
      "  Downloading jax-0.4.30-py3-none-any.whl.metadata (22 kB)\n",
      "Collecting msgpack (from flax)\n",
      "  Downloading msgpack-1.0.8-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (9.1 kB)\n",
      "Collecting optax (from flax)\n",
      "  Downloading optax-0.2.2-py3-none-any.whl.metadata (8.1 kB)\n",
      "Collecting orbax-checkpoint (from flax)\n",
      "  Downloading orbax_checkpoint-0.5.20-py3-none-any.whl.metadata (1.8 kB)\n",
      "Collecting tensorstore (from flax)\n",
      "  Downloading tensorstore-0.1.63-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (3.0 kB)\n",
      "Collecting rich>=11.1 (from flax)\n",
      "  Downloading rich-13.7.1-py3-none-any.whl.metadata (18 kB)\n",
      "Requirement already satisfied: typing-extensions>=4.2 in /usr/local/lib/python3.10/dist-packages (from flax) (4.5.0)\n",
      "Requirement already satisfied: PyYAML>=5.4.1 in /usr/lib/python3/dist-packages (from flax) (5.4.1)\n",
      "Collecting jaxlib<=0.4.30,>=0.4.27 (from jax>=0.4.27->flax)\n",
      "  Downloading jaxlib-0.4.30-cp310-cp310-manylinux2014_x86_64.whl.metadata (1.0 kB)\n",
      "Requirement already satisfied: ml-dtypes>=0.2.0 in /usr/local/lib/python3.10/dist-packages (from jax>=0.4.27->flax) (0.2.0)\n",
      "Requirement already satisfied: opt-einsum in /usr/local/lib/python3.10/dist-packages (from jax>=0.4.27->flax) (3.3.0)\n",
      "Requirement already satisfied: scipy>=1.9 in /usr/local/lib/python3.10/dist-packages (from jax>=0.4.27->flax) (1.10.1)\n",
      "Collecting markdown-it-py>=2.2.0 (from rich>=11.1->flax)\n",
      "  Downloading markdown_it_py-3.0.0-py3-none-any.whl.metadata (6.9 kB)\n",
      "Requirement already satisfied: pygments<3.0.0,>=2.13.0 in /usr/local/lib/python3.10/dist-packages (from rich>=11.1->flax) (2.15.1)\n",
      "Requirement already satisfied: absl-py>=0.7.1 in /usr/local/lib/python3.10/dist-packages (from optax->flax) (1.4.0)\n",
      "Collecting chex>=0.1.86 (from optax->flax)\n",
      "  Downloading chex-0.1.86-py3-none-any.whl.metadata (17 kB)\n",
      "Collecting etils[epath,epy] (from orbax-checkpoint->flax)\n",
      "  Downloading etils-1.7.0-py3-none-any.whl.metadata (6.4 kB)\n",
      "Requirement already satisfied: nest_asyncio in /usr/local/lib/python3.10/dist-packages (from orbax-checkpoint->flax) (1.5.6)\n",
      "Requirement already satisfied: protobuf in /usr/local/lib/python3.10/dist-packages (from orbax-checkpoint->flax) (4.23.0)\n",
      "Collecting ml-dtypes>=0.2.0 (from jax>=0.4.27->flax)\n",
      "  Downloading ml_dtypes-0.4.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (20 kB)\n",
      "Collecting numpy>=1.22 (from flax)\n",
      "  Downloading numpy-2.0.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (60 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m60.9/60.9 kB\u001b[0m \u001b[31m952.3 kB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0ma \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hCollecting toolz>=0.9.0 (from chex>=0.1.86->optax->flax)\n",
      "  Downloading toolz-0.12.1-py3-none-any.whl.metadata (5.1 kB)\n",
      "Collecting mdurl~=0.1 (from markdown-it-py>=2.2.0->rich>=11.1->flax)\n",
      "  Downloading mdurl-0.1.2-py3-none-any.whl.metadata (1.6 kB)\n",
      "Collecting numpy>=1.22 (from flax)\n",
      "  Downloading numpy-1.26.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (61 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m61.0/61.0 kB\u001b[0m \u001b[31m1.8 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hCollecting fsspec (from etils[epath,epy]->orbax-checkpoint->flax)\n",
      "  Downloading fsspec-2024.6.1-py3-none-any.whl.metadata (11 kB)\n",
      "Collecting importlib_resources (from etils[epath,epy]->orbax-checkpoint->flax)\n",
      "  Downloading importlib_resources-6.4.0-py3-none-any.whl.metadata (3.9 kB)\n",
      "Requirement already satisfied: zipp in /usr/lib/python3/dist-packages (from etils[epath,epy]->orbax-checkpoint->flax) (1.0.0)\n",
      "Downloading flax-0.8.5-py3-none-any.whl (731 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m731.3/731.3 kB\u001b[0m \u001b[31m28.0 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hDownloading jax-0.4.30-py3-none-any.whl (2.0 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m2.0/2.0 MB\u001b[0m \u001b[31m20.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m:00:01\u001b[0m\n",
      "\u001b[?25hDownloading rich-13.7.1-py3-none-any.whl (240 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m240.7/240.7 kB\u001b[0m \u001b[31m3.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m:00:01\u001b[0m\n",
      "\u001b[?25hDownloading msgpack-1.0.8-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (385 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m385.1/385.1 kB\u001b[0m \u001b[31m4.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m:00:01\u001b[0m\n",
      "\u001b[?25hDownloading optax-0.2.2-py3-none-any.whl (223 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m223.7/223.7 kB\u001b[0m \u001b[31m5.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0mta \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hDownloading orbax_checkpoint-0.5.20-py3-none-any.whl (222 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m222.2/222.2 kB\u001b[0m \u001b[31m6.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hDownloading tensorstore-0.1.63-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (14.9 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m14.9/14.9 MB\u001b[0m \u001b[31m21.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m00:01\u001b[0m00:01\u001b[0m\n",
      "\u001b[?25hDownloading chex-0.1.86-py3-none-any.whl (98 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m98.2/98.2 kB\u001b[0m \u001b[31m1.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0mta \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hDownloading jaxlib-0.4.30-cp310-cp310-manylinux2014_x86_64.whl (79.6 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m79.6/79.6 MB\u001b[0m \u001b[31m16.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m00:01\u001b[0m00:01\u001b[0m\n",
      "\u001b[?25hDownloading markdown_it_py-3.0.0-py3-none-any.whl (87 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m87.5/87.5 kB\u001b[0m \u001b[31m1.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0mta \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hDownloading ml_dtypes-0.4.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (2.2 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m2.2/2.2 MB\u001b[0m \u001b[31m12.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m00:01\u001b[0m00:01\u001b[0m\n",
      "\u001b[?25hDownloading numpy-1.26.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (18.2 MB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m18.2/18.2 MB\u001b[0m \u001b[31m21.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m00:01\u001b[0m00:01\u001b[0m\n",
      "\u001b[?25hDownloading mdurl-0.1.2-py3-none-any.whl (10.0 kB)\n",
      "Downloading toolz-0.12.1-py3-none-any.whl (56 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m56.1/56.1 kB\u001b[0m \u001b[31m1.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0mta \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hDownloading etils-1.7.0-py3-none-any.whl (152 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m152.4/152.4 kB\u001b[0m \u001b[31m6.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hDownloading fsspec-2024.6.1-py3-none-any.whl (177 kB)\n",
      "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m177.6/177.6 kB\u001b[0m \u001b[31m5.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hDownloading importlib_resources-6.4.0-py3-none-any.whl (38 kB)\n",
      "Installing collected packages: toolz, numpy, msgpack, mdurl, importlib_resources, fsspec, etils, ml-dtypes, markdown-it-py, tensorstore, rich, jaxlib, jax, orbax-checkpoint, chex, optax, flax\n",
      "\u001b[33m  WARNING: The script f2py is installed in '/home/eso18/.local/bin' which is not on PATH.\n",
      "  Consider adding this directory to PATH or, if you prefer to suppress this warning, use --no-warn-script-location.\u001b[0m\u001b[33m\n",
      "\u001b[0m\u001b[33m  WARNING: The script markdown-it is installed in '/home/eso18/.local/bin' which is not on PATH.\n",
      "  Consider adding this directory to PATH or, if you prefer to suppress this warning, use --no-warn-script-location.\u001b[0m\u001b[33m\n",
      "\u001b[0m\u001b[31mERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts.\n",
      "tensorflow 2.12.0 requires numpy<1.24,>=1.22, but you have numpy 1.26.4 which is incompatible.\n",
      "fenics-ffcx 0.7.0 requires fenics-ufl<2023.3.0,>=2023.2.0, but you have fenics-ufl 2019.1.0 which is incompatible.\u001b[0m\u001b[31m\n",
      "\u001b[0mSuccessfully installed chex-0.1.86 etils-1.7.0 flax-0.8.5 fsspec-2024.6.1 importlib_resources-6.4.0 jax-0.4.30 jaxlib-0.4.30 markdown-it-py-3.0.0 mdurl-0.1.2 ml-dtypes-0.4.0 msgpack-1.0.8 numpy-1.26.4 optax-0.2.2 orbax-checkpoint-0.5.20 rich-13.7.1 tensorstore-0.1.63 toolz-0.12.1\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Note: you may need to restart the kernel to use updated packages.\n"
     ]
    }
   ],
   "source": [
    "%pip install flax"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "xTRPb7cEtxTu"
   },
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'flax'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[4], line 6\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mnumpy\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mnp\u001b[39;00m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mjax\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m random\n\u001b[0;32m----> 6\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mflax\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m linen \u001b[38;5;28;01mas\u001b[39;00m nn\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01moptax\u001b[39;00m\n\u001b[1;32m      8\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mml_collections\u001b[39;00m\n",
      "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'flax'"
     ]
    }
   ],
   "source": [
    "# %cd 'My Drive/multi_view_vae'\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import numpy as np\n",
    "from jax import random\n",
    "from flax import linen as nn\n",
    "import optax\n",
    "import ml_collections\n",
    "from ml_collections import config_flags\n",
    "import tensorflow_datasets as tfds\n",
    "from flax.training import train_state\n",
    "from absl import flags\n",
    "import utils as vae_utils\n",
    "from absl import logging\n",
    "import input_pipeline\n",
    "from clu import platform\n",
    "import tensorflow as tf\n",
    "import matplotlib.pyplot as plt\n",
    "# import seaborn as sb\n",
    "import vae_model_both as vae\n",
    "import other\n",
    "import time\n",
    "import metrics\n",
    "from scipy.stats import normaltest"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "LT2Sg4zaXVvZ"
   },
   "source": [
    "#Implementation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "executionInfo": {
     "elapsed": 246,
     "status": "ok",
     "timestamp": 1719228354513,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "8SVf6nNoIC9p"
   },
   "outputs": [],
   "source": [
    "#actual training step\n",
    "def training_step(state, batch, z_rng, latents, beta, matrices):\n",
    "  #define the loss function\n",
    "  @jax.jit\n",
    "  def loss_fn(params):\n",
    "    # this is all the params for the neural nets!! they are updated elsewhere\n",
    "   logits1, mean1, logvar1, _, logits2, mean2, logvar2, _ = vae.model(latents).apply({'params': params}, batch, z_rng)\n",
    "\n",
    "    # calculate the entropy loss between the reconstructed x and the original (batch)\n",
    "   bce_loss1 = jnp.mean(met.bce_with_logits(logits1, batch))\n",
    "   bce_loss2 = jnp.mean(met.bce_with_logits(logits2, batch[:,::-1]))\n",
    "   kld_loss = jnp.mean(met.kl_div(mean1,logvar1, mean2, logvar2, matrices))\n",
    "   loss = bce_loss1 + bce_loss2 + beta * kld_loss\n",
    "\n",
    "   return loss\n",
    "  grads = jax.grad(loss_fn)(state.params)\n",
    "  return state.apply_gradients(grads=grads)\n",
    "\n",
    "train_step = jax.jit(training_step, static_argnums=(3,4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "executionInfo": {
     "elapsed": 258,
     "status": "ok",
     "timestamp": 1719228369943,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "Grqq9i_DcRjE"
   },
   "outputs": [],
   "source": [
    "def eval(params, images, z_1, z_2, z_rng, latents, matrices):\n",
    "  rngs = random.split(z_rng, 50)\n",
    "  def eval_model(vae):\n",
    "    loss = []\n",
    "    for i in range(50):\n",
    "      recon_images1, mean1, logvar1, z1, recon_images2, mean2, logvar2, z2 = vae(images, rngs[i])\n",
    "      metrics = met.compute_metrics(recon_images1, recon_images2, images,\n",
    "                                  mean1, logvar1, mean2, logvar2, matrices, False)\n",
    "      loss.append(metrics['loss'])\n",
    "\n",
    "    ll = jnp.mean(nn.activation.logsumexp(-jnp.asarray(loss),axis=0) - jnp.ones(10000)*jnp.log(500))\n",
    "    recon_images1, mean1, logvar1, z1, recon_images2, mean2, logvar2, z2 = vae(images, rngs[0])\n",
    "    metrics = met.compute_metrics(recon_images1, recon_images2, images, mean1, logvar1, mean2, logvar2, matrices)\n",
    "\n",
    "    comparison = jnp.concatenate([\n",
    "        images[:8].reshape(-1, 28, 28, 1),\n",
    "        recon_images1[:8].reshape(-1, 28, 28, 1),\n",
    "        recon_images2[:8].reshape(-1, 28, 28, 1)\n",
    "    ])\n",
    "    # print(\n",
    "    #     'no mean components greater than 0.01 : {}, mean : {}, sd : {}'.format(\n",
    "    #         (abs(mean1[0])>0.5).sum(), abs(mean1[0]).mean(),\n",
    "    #         jnp.std(mean1[0])\n",
    "    #     )\n",
    "    # )\n",
    "    generate_images1, generate_images2 = vae.generate(z_1, z_2)\n",
    "    generate_images1 = generate_images1.reshape(-1, 28, 28, 1)\n",
    "    generate_images2 = generate_images2.reshape(-1, 28, 28, 1)\n",
    "    return metrics, comparison, generate_images1, generate_images2, ll, z1, z2\n",
    "\n",
    "  return nn.apply(eval_model, vae.model(latents))({'params': params})\n",
    "eval_f = jax.jit(eval, static_argnums=(5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 306,
     "status": "ok",
     "timestamp": 1719224430336,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "tw4fj1_IxrIP"
   },
   "outputs": [],
   "source": [
    "def get_z(params, images, z_rng, latents, flip):\n",
    "  def eval_model(vae):\n",
    "    recon_images1, _, _, z1, recon_images2, _, _, z2= vae(images, z_rng)\n",
    "    return z1, recon_images1, z2, recon_images2\n",
    "\n",
    "  if flip:\n",
    "    images = images[:,::-1]\n",
    "  return nn.apply(eval_model, vae.model(latents))({'params': params})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "executionInfo": {
     "elapsed": 259,
     "status": "ok",
     "timestamp": 1719229424423,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "xNFIfx59dwPq"
   },
   "outputs": [],
   "source": [
    "def train_and_evaluate(config: ml_collections.ConfigDict, key_val,seed, matrix, flip=False):\n",
    "  \"\"\"Train and evaulate pipeline.\"\"\"\n",
    "  rng = random.key(key_val)\n",
    "  rng, key = random.split(rng)\n",
    "\n",
    "  ds_builder = tfds.builder('binarized_mnist')\n",
    "  ds_builder.download_and_prepare()\n",
    "\n",
    "  logging.info('Initializing dataset.')\n",
    "  train_ds = input_pipeline.build_train_set(config.batch_size, ds_builder,seed)\n",
    "  test_ds = input_pipeline.build_test_set(ds_builder)\n",
    "  logging.info('Initializing model.')\n",
    "  init_data = jnp.ones((config.batch_size, 784), jnp.float32)\n",
    "  params = vae.model(config.latents).init(key, init_data, rng)['params']\n",
    "\n",
    "  state = train_state.TrainState.create(\n",
    "      apply_fn=vae.model(config.latents).apply,\n",
    "      params=params,\n",
    "      tx=optax.adam(config.learning_rate),\n",
    "  )\n",
    "\n",
    "  rng, z_key, eval_rng = random.split(rng, 3)\n",
    "  z_1 = random.normal(z_key, (64, config.latents[0]))\n",
    "  z_2 = random.normal(z_key, (64, config.latents[1]))\n",
    "\n",
    "  steps_per_epoch = (\n",
    "      ds_builder.info.splits['train'].num_examples // config.batch_size\n",
    "    )\n",
    "\n",
    "  beta_vec = other.make_beta(steps_per_epoch,config.num_epochs, 5)\n",
    "  matrices = other.make_matrices(config.latents, C)\n",
    "\n",
    "  if flip:\n",
    "    test_ds = test_ds[:,::-1]\n",
    "\n",
    "  for epoch in range(config.num_epochs):\n",
    "    for i in range(steps_per_epoch):\n",
    "      batch = next(train_ds)\n",
    "      if flip:\n",
    "          batch = batch[:,::-1]\n",
    "      rng, key = random.split(rng)\n",
    "      # beta = int(beta_vec[epoch*config.num_epochs + i])\n",
    "      beta = 1\n",
    "      state = train_step(state, batch, key, config.latents, beta, matrices)\n",
    "\n",
    "    metrics, comparison, sample1, sample2, ll, z1, z2= eval_f(\n",
    "        state.params, test_ds, z_1,z_2, eval_rng, config.latents, matrices\n",
    "    )\n",
    "    # return z1, z2\n",
    "    vae_utils.save_image(\n",
    "        comparison, f'results/reconstruction_{epoch}.png', nrow=8\n",
    "    )\n",
    "    vae_utils.save_image(sample1, f'results/sample1_{epoch}.png', nrow=8)\n",
    "    vae_utils.save_image(sample2, f'results/sample2_{epoch}.png', nrow=8)\n",
    "    if epoch % 5 == 0:\n",
    "      print(\n",
    "          'eval epoch: {}, loss: {:.4f}, BCE: {:.4f}, KLD: {:.4f}, LL: {:.4f}'.format(\n",
    "              epoch + 1, metrics['loss'], metrics['bce'], metrics['kld'], ll)\n",
    "      )\n",
    "\n",
    "  # rng, key = random.split(rng)\n",
    "  rng = random.key(20) # fix this !\n",
    "  train_ds = input_pipeline.build_train_set(50000, ds_builder, seed)\n",
    "  zs1, recons1, zs2, recons2 = get_z(state.params, next(train_ds), rng, config.latents, flip)\n",
    "  return zs1, recons1, zs2, recons2, state.params"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "hdNd27ASXmqQ"
   },
   "source": [
    "# Investigation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "TB5HXgzdYlDv"
   },
   "source": [
    "Base investigation with same number of latent variables in each view"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "executionInfo": {
     "elapsed": 242,
     "status": "ok",
     "timestamp": 1719228423757,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "XkLqbKiZjB9W"
   },
   "outputs": [],
   "source": [
    "C = 0.6*jnp.eye(20)\n",
    "no_latents1 = 20\n",
    "no_latents2 = 20\n",
    "\n",
    "c_flags = other.get_config(no_latents1, no_latents2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 275620,
     "status": "ok",
     "timestamp": 1719228701339,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "-ZzWItXmD_1K",
    "outputId": "2ea8fa1d-12bd-4ceb-eba3-8c342fdcb270"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "eval epoch: 1, loss: 226.0773, BCE: 187.7381, KLD: 38.3392, LL: -215.4170\n",
      "eval epoch: 6, loss: 198.1090, BCE: 157.1241, KLD: 40.9849, LL: -186.9416\n",
      "eval epoch: 11, loss: 193.8318, BCE: 151.5573, KLD: 42.2745, LL: -183.3986\n",
      "eval epoch: 16, loss: 192.4468, BCE: 149.5638, KLD: 42.8830, LL: -182.1643\n",
      "eval epoch: 21, loss: 191.2322, BCE: 148.0418, KLD: 43.1903, LL: -181.2273\n",
      "eval epoch: 26, loss: 190.6862, BCE: 147.1901, KLD: 43.4961, LL: -180.4987\n"
     ]
    }
   ],
   "source": [
    "test=train_and_evaluate(c_flags, key_val=15,seed=20, matrix=C)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 128202,
     "status": "ok",
     "timestamp": 1719229563849,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "l_3ePaK11P2P",
    "outputId": "39f24efd-adcb-4efd-9a60-e52026f62cd5"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "eval epoch: 1, loss: 224.8975, BCE: 185.5122, KLD: 39.3853, LL: -214.4776\n",
      "eval epoch: 6, loss: 196.8661, BCE: 155.0118, KLD: 41.8543, LL: -185.6221\n",
      "eval epoch: 11, loss: 194.6128, BCE: 151.6335, KLD: 42.9793, LL: -183.1453\n",
      "eval epoch: 16, loss: 191.4119, BCE: 148.1048, KLD: 43.3071, LL: -180.8812\n",
      "eval epoch: 21, loss: 190.5906, BCE: 147.4112, KLD: 43.1794, LL: -179.9134\n",
      "eval epoch: 26, loss: 189.7921, BCE: 146.2554, KLD: 43.5367, LL: -179.3612\n"
     ]
    }
   ],
   "source": [
    "z1, recon1, z2, recon2, params = train_and_evaluate(config_flags, key_val=10,seed=21, matrix=C)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 1167,
     "status": "ok",
     "timestamp": 1719229390263,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -60
    },
    "id": "LxQEKRr046ZX",
    "outputId": "1f5a4d1b-eecc-4a75-bd74-657f7fa16fc3"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "no_z = 20\n",
    "all_zs = jnp.concatenate((test[0], test[2]),axis=1)#latent variables stacked\n",
    "mean_z = jnp.asarray([all_zs[:,j].mean().item() for j in range(2*no_z)]) #mean of each latent variable\n",
    "norm = all_zs - mean_z\n",
    "cov = jnp.matmul(norm.transpose(),norm)/50000\n",
    "sb.heatmap(cov)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 1739,
     "status": "ok",
     "timestamp": 1718371274858,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "4u6ZE6lFMhmm",
    "outputId": "4326b48f-f7f1-484e-ab85-2cf912ce69f2"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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tNDUqVOVmppa7QIBAED95q3uG4YNG6Zhw4ZVuX2HDh00b948SdJf/vKX6u4OAADUc9UOI5FQWFiowsLC0ud5eXkGqwEAAOFUKyewzpo1S36/v/SRkpJiuiQAABAmtTKMpKenKxAIlD52795tuiQAABAmtXKYxufzyefzmS4DAABEQK3sGQEAANGj2j0jhw8fVlZWVunzHTt2KDMzU02bNlW7du2Unp6u7OxsLV68uLRNZmZm6Xv37dunzMxMxcbGqlu3bqf/DQAAQJ1mua7rVucN69at08CBA0/YPm7cOC1atEg333yzvvrqK61bt+77nVjWCe3bt2+vr776qkr7zMvLk9/vVyAQUGJiYnXKBQAAhlT1/F3tMGICYQQAgLqnqudv5owAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjCCMAAMAowggAADCKMAIAAIwijAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMQJIULA4q78AhBYuDpksBAEQZr+kCYFbuzn164YFX9faSDBUXFCvG59Vl11+ssfeNUZuOrUyXBwCIApbruq7pIk4mLy9Pfr9fgUBAiYmJpsupN3Z/lq27L5iqI3lHFAo6pds9XlvxDeM1d8Pv1L5bisEKAQB1WVXP39UepsnIyNDIkSOVlJQky7K0YsWKk75n3bp16tOnj3w+n7p06aJFixZVd7cIg8cmPKn8QNkgIkmhoKMjh45q9i1/NFQZACCaVDuM5OfnKzU1VQsWLKhS+x07dmjEiBEaOHCgMjMzdc8992jChAlavXp1tYtFzdn5ydf66L3P5ISccl93Qo4+3ZKlL/+5M8KVAQCiTbXnjAwbNkzDhg2rcvuFCxeq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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "total_cov =[abs(cov[0:no_z,0:no_z])[:,j].sum() for j in range(no_z)]\n",
    "total_cov2 =[abs(cov[no_z:2*no_z,no_z:2*no_z])[:,j].sum() for j in range(no_z)]\n",
    "\n",
    "\n",
    "# total_cross = [abs(cov[0:no_z,no_z:2*no_z])[j,:].sum() for j in range(no_z)]\n",
    "total_cross1 = [abs(cov[0:no_z,no_z:2*no_z])[j,:].sum()/(total_cov[j]*total_cov2[j]) for j in range(no_z)]\n",
    "total_cross2 = [abs(cov[0:no_z,no_z:2*no_z])[:,j].sum()/(total_cov[j]*total_cov2[j]) for j in range(no_z)]\n",
    "\n",
    "v1 = jnp.asarray([jnp.square(all_zs[:,j]).mean().item() for j in range(no_z)])\n",
    "v2 = jnp.asarray([jnp.square(all_zs[:,j+no_z]).mean().item() for j in range(no_z)])\n",
    "\n",
    "\n",
    "col_vec = (normaltest(all_zs[:,0:(no_z)],axis=0).pvalue<(0.05/20))|(normaltest(all_zs[:,no_z:(2*no_z)],axis=0).pvalue<(0.05/20))\n",
    "col_vec = 1 - col_vec\n",
    "# col_vec = (normaltest(all_zs,axis=0).pvalue<(0.05/20))\n",
    "fig, ax = plt.subplots()\n",
    "scatter = ax.scatter(v1, v2, c=col_vec) # plotting by columns\n",
    "legend1 = ax.legend(*scatter.legend_elements(),\n",
    "                    loc=\"upper right\", title=\"Normal\")\n",
    "ax.add_artist(legend1)\n",
    "# ax.legend()\n",
    "# ax.grid(True)\n",
    "plt.show()\n",
    "# plt.plot(total_cov,total_cross,\".\")\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "x__vu_ycICAy"
   },
   "outputs": [],
   "source": [
    "C = 0.3*jnp.concatenate((0.3*jnp.eye(20),jnp.zeros((20,20))))\n",
    "\n",
    "config_flags2 = get_config(num_latents1=20, num_latents2 = 40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ceZxlFfqd4-L"
   },
   "outputs": [],
   "source": [
    "C = 0.3*jnp.eye(20)\n",
    "D = jnp.linalg.inv(jnp.eye(max(config.latents1,config.latents2)) - jnp.matmul(C, jnp.transpose(C)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "V_s3eOeGW4eQ"
   },
   "outputs": [],
   "source": [
    "sb.heatmap(C)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "collapsed": true,
    "executionInfo": {
     "elapsed": 697655,
     "status": "ok",
     "timestamp": 1718370413192,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "kKvT9BMFQwMa",
    "outputId": "1cfce424-1126-4fd7-e864-ec73a890b962"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "no mean components greater than 0.01 : 6, mean : 0.6263822913169861, sd : 0.9364571571350098\n",
      "eval\n",
      "76.97210597991943\n",
      "eval epoch: 1, loss: 249.6293, BCE: 201.5808, KLD: 48.0485, LL: -240.0952\n",
      "no mean components greater than 0.01 : 6, mean : 0.692435622215271, sd : 1.00324547290802\n",
      "eval\n",
      "73.6747899055481\n",
      "no mean components greater than 0.01 : 9, mean : 0.7109705805778503, sd : 0.9928213953971863\n",
      "eval\n",
      "72.53964328765869\n",
      "no mean components greater than 0.01 : 8, mean : 0.6673903465270996, sd : 0.9697781801223755\n",
      "eval\n",
      "79.13631081581116\n",
      "no mean components greater than 0.01 : 7, mean : 0.5902196764945984, sd : 0.8734252452850342\n",
      "eval\n",
      "73.79425692558289\n",
      "no mean components greater than 0.01 : 8, mean : 0.6282925009727478, sd : 0.9530402421951294\n",
      "eval\n",
      "73.28196954727173\n",
      "eval epoch: 6, loss: 218.9585, BCE: 163.9852, KLD: 54.9732, LL: -211.0591\n",
      "no mean components greater than 0.01 : 7, mean : 0.6576220393180847, sd : 0.9377078413963318\n",
      "eval\n",
      "73.98633337020874\n",
      "no mean components greater than 0.01 : 8, mean : 0.634891927242279, sd : 0.9266260862350464\n",
      "eval\n",
      "74.28574872016907\n",
      "no mean components greater than 0.01 : 7, mean : 0.632366955280304, sd : 0.9480294585227966\n",
      "eval\n",
      "73.8206889629364\n",
      "no mean components greater than 0.01 : 7, mean : 0.6317101120948792, sd : 0.9168297648429871\n",
      "eval\n",
      "73.75759506225586\n",
      "no mean components greater than 0.01 : 9, mean : 0.6694588661193848, sd : 0.9312186241149902\n",
      "eval\n",
      "73.6739559173584\n",
      "eval epoch: 11, loss: 213.9280, BCE: 158.8787, KLD: 55.0493, LL: -205.6411\n",
      "no mean components greater than 0.01 : 7, mean : 0.6142326593399048, sd : 0.9240360856056213\n",
      "eval\n",
      "75.2600634098053\n",
      "no mean components greater than 0.01 : 8, mean : 0.6702856421470642, sd : 0.9222508668899536\n",
      "eval\n",
      "73.07793164253235\n",
      "no mean components greater than 0.01 : 7, mean : 0.637170672416687, sd : 0.9615494608879089\n",
      "eval\n",
      "77.50260210037231\n",
      "no mean components greater than 0.01 : 7, mean : 0.6405726075172424, sd : 0.9624583721160889\n",
      "eval\n",
      "72.66812539100647\n",
      "no mean components greater than 0.01 : 9, mean : 0.7279790639877319, sd : 0.9833398461341858\n",
      "eval\n",
      "76.89101672172546\n",
      "eval epoch: 16, loss: 212.5904, BCE: 156.8411, KLD: 55.7493, LL: -204.1405\n",
      "no mean components greater than 0.01 : 9, mean : 0.6206873059272766, sd : 0.942402184009552\n",
      "eval\n",
      "73.80674862861633\n",
      "no mean components greater than 0.01 : 6, mean : 0.6283323168754578, sd : 0.9250999093055725\n",
      "eval\n",
      "75.25370669364929\n",
      "no mean components greater than 0.01 : 7, mean : 0.6231257319450378, sd : 0.8830966353416443\n",
      "eval\n",
      "72.27119779586792\n",
      "no mean components greater than 0.01 : 8, mean : 0.6556993126869202, sd : 0.9421969056129456\n",
      "eval\n",
      "75.71754693984985\n",
      "no mean components greater than 0.01 : 7, mean : 0.6514347195625305, sd : 1.001503586769104\n",
      "eval\n",
      "71.56708884239197\n",
      "eval epoch: 21, loss: 212.1058, BCE: 155.4119, KLD: 56.6939, LL: -203.8765\n",
      "no mean components greater than 0.01 : 8, mean : 0.6467903256416321, sd : 0.9510869979858398\n",
      "eval\n",
      "73.80941653251648\n",
      "no mean components greater than 0.01 : 7, mean : 0.6273987293243408, sd : 0.9245078563690186\n",
      "eval\n",
      "72.44886064529419\n",
      "no mean components greater than 0.01 : 8, mean : 0.6358987092971802, sd : 0.9430950880050659\n",
      "eval\n",
      "71.21905827522278\n",
      "no mean components greater than 0.01 : 8, mean : 0.6531015038490295, sd : 0.9802690148353577\n",
      "eval\n",
      "71.92323136329651\n",
      "no mean components greater than 0.01 : 8, mean : 0.6631945371627808, sd : 0.9853647947311401\n",
      "eval\n",
      "71.40093636512756\n",
      "eval epoch: 26, loss: 210.9112, BCE: 154.3202, KLD: 56.5910, LL: -202.4631\n",
      "no mean components greater than 0.01 : 8, mean : 0.647988498210907, sd : 0.9490954875946045\n",
      "eval\n",
      "71.01180791854858\n",
      "no mean components greater than 0.01 : 7, mean : 0.5858054161071777, sd : 0.8927105665206909\n",
      "eval\n",
      "72.01559233665466\n",
      "no mean components greater than 0.01 : 7, mean : 0.6043118834495544, sd : 0.9502145051956177\n",
      "eval\n",
      "76.5133261680603\n",
      "no mean components greater than 0.01 : 7, mean : 0.5952978134155273, sd : 0.9563853144645691\n",
      "eval\n",
      "71.95044350624084\n"
     ]
    }
   ],
   "source": [
    "test2 = train_and_evaluate(config_flags2, key_val=10,seed=5, matrix=C)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "zIrrTyZJ3n9d"
   },
   "outputs": [],
   "source": [
    "z1_2, recon1_2, z2_2, recon2_2, params_2 = test2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "nfytptNitNRI"
   },
   "outputs": [],
   "source": [
    "test = train_and_evaluate(config_flags, key_val=5, alpha = 0.6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 1234,
     "status": "ok",
     "timestamp": 1718182426167,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "73lylang3rLr",
    "outputId": "83c57499-25ee-4387-f2f8-55458f150f81"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "alpha = 0.9\n",
    "id = jnp.eye(20)\n",
    "W  = jnp.block([\n",
    "    [(1+jnp.square(alpha))*id, 2*alpha*id],\n",
    "    [2*alpha*id, (1+jnp.square(alpha))*id]\n",
    "])\n",
    "W_inv = jnp.linalg.inv(W)\n",
    "sb.heatmap(W)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 216
    },
    "executionInfo": {
     "elapsed": 895,
     "status": "error",
     "timestamp": 1718274827060,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "4oM_m9Ib5_se",
    "outputId": "73969597-a93b-40a4-e4ce-e1304f9665f7"
   },
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'W_inv' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-12-71c9245a9bef>\u001b[0m in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mog_z\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mjnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmatmul\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mW_inv\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mjnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtranspose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mjnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconcatenate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mz1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mz2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0maxis\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0mog_z2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mjnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtranspose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mog_z\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mmean_z\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mjnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0masarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mog_z2\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mj\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0;36m20\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;31m#mean of each latent variable\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mnorm\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mog_z2\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mmean_z\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mcov\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mjnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmatmul\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnorm\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtranspose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mnorm\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0;36m50000\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'W_inv' is not defined"
     ]
    }
   ],
   "source": [
    "og_z = jnp.matmul(W_inv,jnp.transpose(jnp.concatenate((z1,z2),axis=1)))\n",
    "og_z2 = jnp.transpose(og_z)\n",
    "mean_z = jnp.asarray([og_z2[:,j].mean().item() for j in range(2*20)]) #mean of each latent variable\n",
    "norm = og_z2 - mean_z\n",
    "cov = jnp.matmul(norm.transpose(),norm)/50000\n",
    "sb.heatmap(cov)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 689,
     "status": "ok",
     "timestamp": 1718373060842,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "_IN6YuACVPSP",
    "outputId": "b5828fcb-34ba-47ab-e102-3e5bb07924e4"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Array(0.21471378, dtype=float32)"
      ]
     },
     "execution_count": 127,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abs(params['decoder1']['fc1']['bias']-params['decoder2']['fc1']['bias']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 431
    },
    "executionInfo": {
     "elapsed": 3042,
     "status": "ok",
     "timestamp": 1718371386183,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "Pz17BbHChivc",
    "outputId": "4a5c6eca-fddb-49d6-a0ea-ffa85c901b82"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "no_z1 = 20\n",
    "no_z2 = 40\n",
    "no_z = no_z1 + no_z2\n",
    "all_zs = jnp.concatenate((z1_2, z2_2),axis=1)#latent variables stacked\n",
    "mean_z = jnp.asarray([all_zs[:,j].mean().item() for j in range(no_z)]) #mean of each latent variable\n",
    "norm = all_zs - mean_z\n",
    "cov = jnp.matmul(norm.transpose(),norm)/50000\n",
    "sb.heatmap(cov)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 1223,
     "status": "ok",
     "timestamp": 1718374030997,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "bVHZqwauEaW9",
    "outputId": "3e1ddc6a-bca9-4724-8893-52e5be397995"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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VatWYe3atYiLi8Px48fh4OCA0NBQ3Llzx6h4arUaQ4cOxcqVK03KraysDJmZmVi8eDEyMzOxd+9eZGdn4/HHHzf6ud5///1Yv349zpw5g6NHj6Jr164YMWIErl+/blS8u/bt24djx47B09OzzusaEi8sLMzg/fjJJ58YHe+3337D0KFD0atXL6SmpuL06dNYvHgxbG1tjYr317zy8vKwdetWKBQKPPXUU7JjRUVFITExER999BGysrIwb948zJkzBwkJCbJzkyQJ4eHhOH/+PD777DP88MMP8PLyQkhIiNG/U6mZNOO+Jg02ePBgafbs2fqvtVqt5OnpKalUKpNjA5D27dtncpy7rl27JgGQjhw5Iixmu3btpA8//NDox9+6dUvq0aOHlJSUJAUHB0tz5841OlZsbKzUv39/ox//VwsXLpSGDh0qJFZN5s6dK3Xv3l3S6XRGPX706NHStGnTDI49+eSTUkREhFHxysrKJEtLS+nAgQMGxwcOHCi9+uqrsmJVfd/qdDrJ3d1devvtt/XHbt68KSmVSumTTz6RHe+vcnNzJQDSDz/8YFRuNUlPT5cASBcuXBASr7i4WAIgHTp0yOh4ly9fljp16iSdPXtW8vLykt577716Y9UWb/LkydLYsWMb9PiGxBs/frz0zDPPCItX1dixY6XHHnvMqFi9e/eWXn/9dYNjDX1PV42XnZ0tAZDOnj2rP6bVaqWOHTtKmzdvrjcemQ+z77koLy9HRkYGQkJC9McsLCwQEhKCtLS0ZsysZsXFxQCA9u3bmxxLq9Vi165dUKvVCAoKMjrO7NmzMXr0aIPX0BTnzp2Dp6cnvL29ERERUWvXbH0SEhIwaNAgPP3003B1dcWAAQOwefNmITmWl5fjo48+wrRp06BQKIyKMWTIECQnJ+PXX38FAPz44484evQoRo4caVS8yspKaLXaan9t2tnZGd37c1dubi7y8/MNfsZOTk4IDAw028+JQqGAs7OzybHKy8uxadMmODk5oX///kbF0Ol0ePbZZxEdHY3evXubnBMApKamwtXVFT179sSsWbNQWFhodG5ffPEF7r//foSGhsLV1RWBgYEmDef+VUFBAb744gtMnz7dqMcPGTIECQkJuHLlCiRJQkpKCn799VeMGDFCdiyNRgMABp8RCwsLKJVKkz8j1LTMvri4ceMGtFot3NzcDI67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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sb.heatmap(cov[0:no_z1,no_z1:2*no_z1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 416,
     "status": "ok",
     "timestamp": 1718374131318,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "0P-68bMMEzpV",
    "outputId": "8e240575-914f-4d1c-fde4-61d8cd1c5b5d"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Array(29.956388, dtype=float32)"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# abs(cov[0:no_z1,no_z1:2*no_z1]).sum()\n",
    "abs(cov[0:no_z1,0:no_z1]-jnp.diag(cov[0:no_z1,0:no_z1])).sum()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 1679,
     "status": "ok",
     "timestamp": 1718376904426,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "09XqguRZ6j1R",
    "outputId": "f815ec79-a2e6-4d01-9b02-cdddfd730d63"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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yWTyas2VVZm+/vOf/8SoUaMwfvx4AED79u2Rk5ODhx56CNOnT4ei+Mf/T9WtW7fEn4vFYvHbqyurVq3C+PHj8cknn1SJK7+VkZWVhX379uHAgQN49NFHATh+N0kpYTQasW3bNvTp08fHVXpOvXr1UL9+fYSHhzu3tWnTBlJKnDlzBi1atPB6Df7xG6EKM5lM6NKlC3bs2OHcpqoqduzYgbi4uFKPmz9/Pl544QVs2bIF119/vRaleoS7/W3dujV++eUXJCYmOl+33367846LmJgYLct3S2X+2d500004duyYM5QBwO+//4569erpNqwAletrbm5usVByOahJP3rEWVxcnMvPBQC2b99e5n/fVdnHH3+MsWPH4uOPP8agQYN8XY7XWCyWYr+bHn74YbRq1QqJiYno1q2br0v0qJtuugl//vknsrOzndt+//13KIqCBg0aaFOEz6b7ktOqVatkYGCgXL58uTx06JB86KGHZI0aNWRKSoqUUspRo0bJqVOnOtvPmzdPmkwm+emnn8rk5GTnKysry1ddcIu7/S2qKt0l5G5fT506JcPCwuSjjz4qjxw5Iv/73//KyMhI+a9//ctXXagwd/s6c+ZMGRYWJj/++GOZlJQkt23bJps1aybvueceX3WhQrKysuSBAwfkgQMHJAD5yiuvyAMHDsiTJ09KKaWcOnWqHDVqlLN9UlKSDA4Olk8//bQ8fPiwXLx4sTQYDHLLli2+6kKFudvXDz/8UBqNRrl48WKX303p6em+6oJb3O1vUVXpLiF3+5qVlSUbNGgghw0bJg8ePCi/+eYb2aJFCzl+/HjNamZg0YnXX39dNmzYUJpMJtm1a1f5/fffO/f16tVLjhkzxvm+UaNGEkCx18yZM7UvvJLc6W9RVSmwSOl+X/fs2SO7desmAwMDZdOmTeW///1vabPZNK66ctzpa2FhoZw1a5Zs1qyZNJvNMiYmRk6YMEFevHhR+8Ld8PXXX5f439/lvo0ZM0b26tWr2DEdO3aUJpNJNm3aVL733nua110Z7va1V69eZbbXu8r8s71aVQoslenr4cOHZd++fWVQUJBs0KCBnDRpkszNzdWsZiGlH117JSIiIr/EOSxERESkewwsREREpHsMLERERKR7DCxERESkewwsREREpHsMLERERKR7DCxERESkewwsREREpHsMLERERKR7DCxERESkewwsREREpHsMLERERKR7/w/D11j3lPGPAQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "total_cov =[abs(cov[0:no_z1,0:no_z1])[:,j].sum() for j in range(no_z1)]\n",
    "total_cov2 =[abs(cov[no_z1:no_z,no_z1:no_z])[:,j].sum() for j in range(no_z2)]\n",
    "\n",
    "\n",
    "# total_cross = [abs(cov[0:no_z,no_z:2*no_z])[j,:].sum() for j in range(no_z)]\n",
    "total_cross1 = [abs(cov[0:no_z1,no_z1:no_z])[j,:].sum()/(total_cov[j]) for j in range(no_z1)]\n",
    "total_cross2 = [abs(cov[0:no_z1,no_z1:no_z])[:,j].sum()/(total_cov2[j]) for j in range(no_z2)]\n",
    "\n",
    "v1 = jnp.asarray([jnp.square(all_zs[:,j]).mean().item() for j in range(no_z1)])\n",
    "v2 = jnp.asarray([jnp.square(all_zs[:,j+no_z1]).mean().item() for j in range(no_z2)])\n",
    "\n",
    "\n",
    "# col_vec = (normaltest(all_zs[:,0:(no_z1)],axis=0).pvalue<(0.05/10))|(normaltest(all_zs[:,no_z1:(2*no_z1)],axis=0).pvalue<(0.05/10))\n",
    "# col_vec = (normaltest(all_zs[:,0:(no_z1)],axis=0).pvalue<(0.05/20))\n",
    "# col_vec = (normaltest(all_zs[:,0:(no_z1)],axis=0).pvalue)\n",
    "\n",
    "col_vec = (normaltest(all_zs[:,no_z1:(no_z)],axis=0).pvalue<(0.05/40))\n",
    "\n",
    "col_vec = 1 - col_vec\n",
    "# col_vec = (normaltest(all_zs,axis=0).pvalue<(0.05/20))\n",
    "fig, ax = plt.subplots()\n",
    "scatter = ax.scatter(total_cross2, v2, c=col_vec) # plotting by columns\n",
    "legend1 = ax.legend(*scatter.legend_elements(),\n",
    "                    loc=\"upper right\", title=\"Normal\")\n",
    "ax.add_artist(legend1)\n",
    "# ax.legend()\n",
    "# ax.grid(True)\n",
    "plt.show()\n",
    "# plt.plot(total_cov,total_cross,\".\")\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 424,
     "status": "ok",
     "timestamp": 1718370873973,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "oSOmzVe4OLcG",
    "outputId": "27245ce5-9e6d-4a8a-f8d5-22d9a8b85cd2"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Array(0.23056905, dtype=float32)"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abs(cov[0:no_z,no_z:2*no_z])\n",
    "# [abs(cov[0:no_z1,no_z1:no_z])[j,:].sum() for j in range(no_z)]\n",
    "[(cov[0:no_z1,no_z1:2*no_z1])[j,j] for j in range(no_z1)]\n",
    "jnp.diag(cov[0:no_z1,no_z1:2*no_z1]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 999,
     "status": "ok",
     "timestamp": 1718276494374,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "TWjpclmPN9iP",
    "outputId": "b54bd714-b236-405b-f5ef-db109997b54f"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAllElEQVR4nO3df3RU9Z3/8ddkIJMEyYAdmAScmGhF6xKChTCNVvqD1GgtK5vdc7LVUyht9WDRg6bdlVAl/clQrZa20NLSn39USfUE3VaXXRqFHtZUIJgVWqUFQ8PWJDDd4wxNQmIzn+8ffDPuSAK5SYbPzOT5OOeeA5987p33J58r8/Jz79xxGWOMAAAALMmyXQAAAJjYCCMAAMAqwggAALCKMAIAAKwijAAAAKsIIwAAwCrCCAAAsIowAgAArJpku4CRiMVieuONNzR16lS5XC7b5QAAgBEwxuj06dOaNWuWsrKGX/9IizDyxhtvKBAI2C4DAACMwokTJ3TZZZcN+3PHYeQ3v/mNHnnkEbW0tKijo0M7duzQsmXLzrvP7t27VVtbq9/97ncKBAJ68MEH9clPfnLErzl16lRJZweTn5/vtGQAAGBBNBpVIBCIv48Px3EY6e7uVllZmT71qU+purr6gv3b2tp06623atWqVfr5z3+upqYmfeYzn1FhYaGqqqpG9JqDl2by8/MJIwAApJkL3WLhOIzccsstuuWWW0bcf+vWrSopKdGjjz4qSXrPe96jvXv36pvf/OaIwwgAAMhcSf80TXNzsyorKxPaqqqq1NzcPOw+fX19ikajCRsAAMhMSQ8jnZ2d8vv9CW1+v1/RaFS9vb1D7hMKheT1euMbN68CAJC5UvI5I3V1dYpEIvHtxIkTtksCAABJkvSP9hYUFKirqyuhraurS/n5+crNzR1yH4/HI4/Hk+zSAABACkj6ykhFRYWampoS2nbt2qWKiopkvzQAAEgDjsPIX//6V7W2tqq1tVXS2Y/utra2qr29XdLZSyzLly+P91+1apVef/11/eu//qtee+01ffe739UvfvEL3X///eMzAgAAkNYch5EDBw7ouuuu03XXXSdJqq2t1XXXXaf169dLkjo6OuLBRJJKSkr07LPPateuXSorK9Ojjz6qH/7wh3ysFwAASJJcxhhju4gLiUaj8nq9ikQiPPQMAIA0MdL375T8NA0AAJg4CCNpqiPSqxePhdURGfpZLQAApIu0+NZeJGrY3666xkOKGSnLJYWqS1VTXmS7LAAARoWVkTTTEemNBxFJihlpXeNhVkgAAGmLMJJm2sLd8SAyaMAYHQ/32CkIAIAxIoykmRLfFGW945uY3S6Xin15dgoCAGCMCCNpptCbq1B1qdyus4nE7XJpQ/VcFXqHfrQ+AACpjhtY01BNeZEWz5mh4+EeFfvyCCIAgLRGGElThd5cQggAICNwmQYAAFhFGAEAAFYRRgAAgFWEEQAAYBVhBAAAWEUYAQAAVhFGAACAVYQRAABgFWEEAABYRRgBAABWEUYAAIBVhBEAAGAVYQQAAFhFGAEAAFYRRgAAgFWEEQAAYBVhBAAAWEUYAQAAVhFGAACAVYQRAABgFWEEAABYRRgBAABWEUYAAIBVhBEAAGAVYQQAAFhFGAEAAFYRRgAAgFWEEQAAYBVhBAAAWEUYAQAAVhFGAACAVYQRAABgFWEEAABYRRgBAABWEUYAAIBVhBEAAGAVYQQAAFhFGAEAAFYRRgAAgFWEEQAAYBVhBAAAWEUYAQAAVhFGAACAVYQRAABgFWEEAABYRRgBAABWEUYAAIBVhBEAAGAVYQQAAFhFGAEAAFaNKoxs2bJFxcXFysnJUTAY1L59+87bf9OmTbr66quVm5urQCCg+++/X2fOnBlVwQAAILM4DiMNDQ2qra1VfX29Dh48qLKyMlVVVenkyZND9n/88ce1du1a1dfX69VXX9WPfvQjNTQ0aN26dWMuHgAApD+XMcY42SEYDKq8vFybN2+WJMViMQUCAd17771au3btOf3vuecevfrqq2pqaoq3fe5zn9NLL72kvXv3DvkafX196uvri/89Go0qEAgoEokoPz/fSbkAAMCSaDQqr9d7wfdvRysj/f39amlpUWVl5dsHyMpSZWWlmpubh9zn+uuvV0tLS/xSzuuvv67nnntOH/3oR4d9nVAoJK/XG98CgYCTMgEAQBqZ5KRzOBzWwMCA/H5/Qrvf79drr7025D633367wuGw3v/+98sYo7/97W9atWrVeS/T1NXVqba2Nv73wZURAACQeZL+aZrdu3drw4YN+u53v6uDBw+qsbFRzz77rL7yla8Mu4/H41F+fn7CBgAAMpOjlRGfzye3262urq6E9q6uLhUUFAy5z0MPPaRPfOIT+sxnPiNJKi0tVXd3t+666y594QtfUFYWny4GAGAic5QEsrOztWDBgoSbUWOxmJqamlRRUTHkPj09PecEDrfbLUlyeO8sAADIQI5WRiSptrZWK1as0MKFC7Vo0SJt2rRJ3d3dWrlypSRp+fLlmj17tkKhkCRp6dKleuyxx3TdddcpGAzq6NGjeuihh7R06dJ4KAEAABOX4zBSU1OjU6dOaf369ers7NT8+fO1c+fO+E2t7e3tCSshDz74oFwulx588EH9+c9/1owZM7R06VJ97WtfG79RAACAtOX4OSM2jPRzygAAIHUk5TkjAAAA440wAgAArCKMAAAAqwgjAADAKsIIAACwijACAACsIowAAACrCCMAAMAqwggAALCKMAIAAKwijAAAAKsIIwAAwCrCCAAAsIowAgAArCKMAAAAqwgjAADAKsIIAACwijACAACsIowAAACrCCMAAMAqwggAALCKMAIAAKwijAAAAKsIIwAAwCrCCAAAsIowAgAArCKMAAAAqwgjAADAKsIIAACwijACAACsIowAAACrCCMAAMAqwggAALCKMAIAAKwijAAAAKsIIwAAwCrCCAAAsIowAgAArCKMAAAAqwgjAADAKsIIAACwijACAACsIowAAACrCCMAAMAqwggAALCKMAIAAKwijAAAAKsIIwAAwCrCCAAAsIowAgAArCKMAAAAqwgjAADAKsIIAACwijACAACsIowAAACrCCMAAMAqwggAALCKMAIAAKwaVRjZsmWLiouLlZOTo2AwqH379p23/5tvvqnVq1ersLBQHo9Hc+bM0XPPPTeqggEAQGaZ5HSHhoYG1dbWauvWrQoGg9q0aZOqqqp05MgRzZw585z+/f39+shHPqKZM2fqqaee0uzZs/WnP/1J06ZNG4/6AQBAmnMZY4yTHYLBoMrLy7V582ZJUiwWUyAQ0L333qu1a9ee03/r1q165JFH9Nprr2ny5MmjKjIajcrr9SoSiSg/P39UxwAAABfXSN+/HV2m6e/vV0tLiyorK98+QFaWKisr1dzcPOQ+//Zv/6aKigqtXr1afr9fc+fO1YYNGzQwMDDs6/T19SkajSZsAAAgMzkKI+FwWAMDA/L7/Qntfr9fnZ2dQ+7z+uuv66mnntLAwICee+45PfTQQ3r00Uf11a9+ddjXCYVC8nq98S0QCDgpEwAApJGkf5omFotp5syZ+sEP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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(normaltest(all_zs,axis=0).pvalue,\".\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 176
    },
    "executionInfo": {
     "elapsed": 14,
     "status": "error",
     "timestamp": 1718300540784,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "QVZ3QVNyijvD",
    "outputId": "31287d2d-affb-4474-c1b2-f1e157dfc5b4"
   },
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'sb' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-1-52f82b1ab3f2>\u001b[0m in \u001b[0;36m<cell line: 2>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;31m# sb.heatmap(cov[0:no_z,0:no_z]-jnp.eye(no_z))\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0msb\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mheatmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcov\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mno_z\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mno_z\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshow\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'sb' is not defined"
     ]
    }
   ],
   "source": [
    "# sb.heatmap(cov[0:no_z,0:no_z]-jnp.eye(no_z))\n",
    "sb.heatmap(cov[0:no_z,0:no_z])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 993,
     "status": "ok",
     "timestamp": 1718182550244,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "EeEYe2Y5iw4P",
    "outputId": "6ada47b7-6ae7-470b-e259-d5cc0c6f717f"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sb.heatmap((cov[0:no_z,no_z:2*no_z]))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 430
    },
    "executionInfo": {
     "elapsed": 2008,
     "status": "ok",
     "timestamp": 1718182601640,
     "user": {
      "displayName": "Ella Orme",
      "userId": "06151406938212358295"
     },
     "user_tz": -120
    },
    "id": "wdRBl4P8xdb4",
    "outputId": "04ab9b41-605d-427e-b213-9ba487af8e08"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cross_var_vec = jnp.asarray([cov[i,i+no_z].item()/cov[i,i].item() for i in range(no_z)])\n",
    "# cross_var_vec = jnp.asarray([cov[i,i].item() for i in range(no_z)])\n",
    "plt.plot(cross_var_vec,'.') # plotting by columns\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "riHPXRcKoHe8"
   },
   "outputs": [],
   "source": [
    "#means from each model\n",
    "mean_vec1 = jnp.asarray([z1[:,j].mean().item() for j in range(no_z)])\n",
    "mean_vec2 = jnp.asarray([z2[:,j].mean().item() for j in range(no_z)])\n",
    "#subcovariance matrices\n",
    "cov_11 = cov[0:no_z,0:no_z]\n",
    "cov_12 = cov[0:no_z,no_z:(2*no_z)]\n",
    "cov_22 = cov[no_z:(2*no_z), no_z:(2*no_z)]\n",
    "cov_term = jnp.matmul(cov_12.transpose(),jnp.linalg.inv(cov_11))\n",
    "#latent variables from model 1\n",
    "obs_z = z1\n",
    "#mean of conditional dist\n",
    "mean_cond = mean_vec2 + jnp.matmul(cov_12.transpose(),jnp.matmul(jnp.linalg.inv(cov_11),(obs_z- mean_vec1).transpose())).transpose()\n",
    "#covariance mat of conditonal dist\n",
    "cov_mat = cov_22-jnp.matmul(cov_term, cov_12)\n",
    "rng = random.key(60)\n",
    "#generate latent variables from the conditional dist\n",
    "cond_z =  random.multivariate_normal(rng,mean=mean_cond, cov=cov_mat)\n",
    "# cond_z =  random.multivariate_normal(rng,mean=mean_cond, cov=jnp.eye(100))"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [
    "XBFJdVbrsrxX",
    "LT2Sg4zaXVvZ"
   ],
   "gpuType": "T4",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
