{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "gpuType": "T4"
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "accelerator": "GPU"
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wbWseRahVTNS",
        "outputId": "79e30dc7-7fe2-4642-8b40-1485a2d2e51f"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting pot\n",
            "  Downloading POT-0.9.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (789 kB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m790.0/790.0 kB\u001b[0m \u001b[31m6.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hRequirement already satisfied: numpy>=1.16 in /usr/local/lib/python3.10/dist-packages (from pot) (1.23.5)\n",
            "Requirement already satisfied: scipy>=1.0 in /usr/local/lib/python3.10/dist-packages (from pot) (1.11.3)\n",
            "Installing collected packages: pot\n",
            "Successfully installed pot-0.9.1\n"
          ]
        }
      ],
      "source": [
        "!pip install pot"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import tensorflow.keras as keras\n",
        "from tensorflow.keras.datasets import mnist\n",
        "from tensorflow.keras.layers import Dense, Input, Flatten,\\\n",
        "                                    Reshape, LeakyReLU as LR,\\\n",
        "                                    Activation, Dropout\n",
        "from tensorflow.keras.models import Model, Sequential\n",
        "import tensorflow as tf\n",
        "\n",
        "import numpy as np\n",
        "from matplotlib import pyplot as plt\n",
        "from matplotlib.colors import LinearSegmentedColormap\n",
        "import seaborn as sns\n",
        "\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.optim as optim\n",
        "from torch.nn import functional as F\n",
        "from torch.autograd import Variable\n",
        "\n",
        "import ot\n",
        "\n",
        "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")"
      ],
      "metadata": {
        "id": "RKN1UewKXk3W",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "2c6386f8-62ed-427e-9216-176750546c4f"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.10/dist-packages/ot/backend.py:1368: UserWarning: Explicitly requested dtype <class 'jax.numpy.float64'> requested in array is not available, and will be truncated to dtype float32. To enable more dtypes, set the jax_enable_x64 configuration option or the JAX_ENABLE_X64 shell environment variable. See https://github.com/google/jax#current-gotchas for more.\n",
            "  jax.device_put(jnp.array(1, dtype=jnp.float64), d)\n",
            "/usr/local/lib/python3.10/dist-packages/ot/backend.py:2998: UserWarning: To use TensorflowBackend, you need to activate the tensorflow numpy API. You can activate it by running: \n",
            "from tensorflow.python.ops.numpy_ops import np_config\n",
            "np_config.enable_numpy_behavior()\n",
            "  register_backend(TensorflowBackend())\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Load in MNIST data\n",
        "(x_train, y_train), (x_test, y_test) = mnist.load_data()\n",
        "\n",
        "# Normalize data\n",
        "x_train = x_train/255.0\n",
        "x_test = x_test/255.0"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "auwJ_c1OWfTk",
        "outputId": "3d0ab319-35d5-486e-8746-214059c2051a"
      },
      "execution_count": 4,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Downloading data from https://storage.googleapis.com/tensorflow/tf-keras-datasets/mnist.npz\n",
            "11490434/11490434 [==============================] - 0s 0us/step\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Construct encoder and decoder networks\n",
        "latent_length = 32\n",
        "\n",
        "encoder = Sequential([\n",
        "    Flatten(input_shape = (28, 28)),\n",
        "    Dense(512),\n",
        "    Dense(256),\n",
        "    Dense(128),\n",
        "    Dense(64),\n",
        "    Dense(latent_length),\n",
        "    LR()\n",
        "])\n",
        "\n",
        "decoder = Sequential([\n",
        "    Dense(64, input_shape = (latent_length,)),\n",
        "    Dense(128),\n",
        "    Dense(256),\n",
        "    Dense(512),\n",
        "    Dense(784),\n",
        "    Activation(\"sigmoid\"),\n",
        "    Reshape((28, 28))\n",
        "])"
      ],
      "metadata": {
        "id": "0p0gzyRTWfYE"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Load in pre-trained encoder-decoder networks\n",
        "File = \"encoder.pth\"\n",
        "encoder = torch.load(File)\n",
        "\n",
        "File = \"decoder.pth\"\n",
        "decoder = torch.load(File)"
      ],
      "metadata": {
        "id": "BQ5s3Iw4WfcK"
      },
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Define branch and trunk networks to learn geodesics in encoded space\n",
        "# Enhanced architecture\n",
        "\n",
        "# Define network widths\n",
        "m_b = 150 # branch width\n",
        "m_t = 100 # trunk width\n",
        "\n",
        "class Branch_enh(nn.Module):\n",
        "    def __init__(self):\n",
        "        super(Branch_enh, self).__init__()\n",
        "        self.hidden_U = nn.Linear(32,m_b, bias=True)\n",
        "        self.hidden_V = nn.Linear(32,m_b, bias=True)\n",
        "        self.hidden_H_1 = nn.Linear(32,m_b, bias=True); self.hidden_Z_1 = nn.Linear(m_b,m_b, bias=True)\n",
        "        self.hidden_Z_2 = nn.Linear(m_b,m_b, bias=True); self.hidden_Z_3 = nn.Linear(m_b,m_b, bias=True)\n",
        "        self.hidden_Z_4 = nn.Linear(m_b,m_b, bias=True); self.hidden_Z_5 = nn.Linear(m_b,m_b, bias=True)\n",
        "        self.hidden_Z_6 = nn.Linear(m_b,m_b, bias=True); self.hidden_Z_7 = nn.Linear(m_b,200, bias=True)\n",
        "\n",
        "\n",
        "    def forward(self, u):\n",
        "        U = F.tanh(self.hidden_U(u)); V = F.tanh(self.hidden_V(u)); H_1 = F.tanh(self.hidden_H_1(u));\n",
        "        Z_1 = F.tanh(self.hidden_Z_1(H_1)); H_2 = (1 - Z_1)*U + Z_1*V\n",
        "        Z_2 = F.tanh(self.hidden_Z_2(H_2)); H_3 = (1 - Z_2)*U + Z_2*V\n",
        "        Z_3 = F.tanh(self.hidden_Z_3(H_3)); H_4 = (1 - Z_3)*U + Z_3*V\n",
        "        Z_4 = F.tanh(self.hidden_Z_4(H_4)); H_5 = (1 - Z_4)*U + Z_4*V\n",
        "        Z_5 = F.tanh(self.hidden_Z_5(H_5)); H_6 = (1 - Z_5)*U + Z_5*V\n",
        "        Z_6 = F.tanh(self.hidden_Z_6(H_6)); H_7 = (1 - Z_6)*U + Z_6*V\n",
        "        Z_7 = self.hidden_Z_7(H_7)\n",
        "        output = Z_7\n",
        "        return output\n",
        "\n",
        "class Trunk_enh(nn.Module):\n",
        "    def __init__(self):\n",
        "        super(Trunk_enh, self).__init__()\n",
        "        self.hidden_U = nn.Linear(2,m_t, bias=True)\n",
        "        self.hidden_V = nn.Linear(2,m_t, bias=True)\n",
        "        self.hidden_H_1 = nn.Linear(2,m_t, bias=True); self.hidden_Z_1 = nn.Linear(m_t,m_t, bias=True)\n",
        "        self.hidden_Z_2 = nn.Linear(m_t,m_t, bias=True); self.hidden_Z_3 = nn.Linear(m_t,m_t, bias=True)\n",
        "        self.hidden_Z_4 = nn.Linear(m_t,m_t, bias=True); self.hidden_Z_5 = nn.Linear(m_t,m_t, bias=True)\n",
        "        self.hidden_Z_6 = nn.Linear(m_t,m_t, bias=True); self.hidden_Z_7 = nn.Linear(m_t,200, bias=True)\n",
        "\n",
        "\n",
        "    def forward(self, x,t):\n",
        "        z = torch.cat((x,t),1)\n",
        "        U = F.tanh(self.hidden_U(z)); V = F.tanh(self.hidden_V(z)); H_1 = F.tanh(self.hidden_H_1(z));\n",
        "        Z_1 = F.tanh(self.hidden_Z_1(H_1)); H_2 = (1 - Z_1)*U + Z_1*V\n",
        "        Z_2 = F.tanh(self.hidden_Z_2(H_2)); H_3 = (1 - Z_2)*U + Z_2*V\n",
        "        Z_3 = F.tanh(self.hidden_Z_3(H_3)); H_4 = (1 - Z_3)*U + Z_3*V\n",
        "        Z_4 = F.tanh(self.hidden_Z_4(H_4)); H_5 = (1 - Z_4)*U + Z_4*V\n",
        "        Z_5 = F.tanh(self.hidden_Z_5(H_5)); H_6 = (1 - Z_5)*U + Z_5*V\n",
        "        Z_6 = F.tanh(self.hidden_Z_6(H_6)); H_7 = (1 - Z_6)*U + Z_6*V\n",
        "        Z_7 = self.hidden_Z_7(H_7)\n",
        "        output = Z_7\n",
        "        return output"
      ],
      "metadata": {
        "id": "Q1mbwA7gXW-J"
      },
      "execution_count": 8,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Construct networks\n",
        "cty_branch0 = Branch_enh().to(device)\n",
        "cty_branch1 = Branch_enh().to(device)\n",
        "cty_trunk = Trunk_enh().to(device)\n",
        "\n",
        "HJ_branch0 = Branch_enh().to(device)\n",
        "HJ_branch1 = Branch_enh().to(device)\n",
        "HJ_trunk = Trunk_enh().to(device)"
      ],
      "metadata": {
        "id": "9Px2hE5CXXCO"
      },
      "execution_count": 9,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Load in the models\n",
        "File = \"Cty_branch0.pth\"\n",
        "cty_branch0.load_state_dict(torch.load(File))\n",
        "\n",
        "File = \"Cty_branch1.pth\"\n",
        "cty_branch1.load_state_dict(torch.load(File))\n",
        "\n",
        "File = \"Cty_trunk.pth\"\n",
        "cty_trunk.load_state_dict(torch.load(File))\n",
        "\n",
        "File = \"HJ_branch0.pth\"\n",
        "HJ_branch0.load_state_dict(torch.load(File))\n",
        "\n",
        "File = \"HJ_branch1.pth\"\n",
        "HJ_branch1.load_state_dict(torch.load(File))\n",
        "\n",
        "File = \"HJ_trunk.pth\"\n",
        "HJ_trunk.load_state_dict(torch.load(File))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hUuvbpVse2FL",
        "outputId": "2b6f82c1-6845-453b-f31a-17df3db74c83"
      },
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<All keys matched successfully>"
            ]
          },
          "metadata": {},
          "execution_count": 10
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Define loss functions\n",
        "mse_cost_function = torch.nn.MSELoss()\n",
        "l1_cost_function = torch.nn.L1Loss()\n",
        "\n",
        "# Define optimizer (Adam)\n",
        "optimizer = optim.Adam([\n",
        "    {'params': cty_branch0.parameters()},\n",
        "    {'params': cty_branch1.parameters()},\n",
        "    {'params': cty_trunk.parameters()},\n",
        "    {'params': HJ_branch0.parameters()},\n",
        "    {'params': HJ_branch1.parameters()},\n",
        "    {'params': HJ_trunk.parameters()},\n",
        "], lr=2e-4)"
      ],
      "metadata": {
        "id": "QsmHtbtdXXFc"
      },
      "execution_count": 11,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Construct training data from MNIST data\n",
        "\n",
        "# Define parameters for training\n",
        "N = 30000  # Number of initial conditions (total MNIST size / 2)\n",
        "n = latent_length\n",
        "\n",
        "# Initialize training data as numpy arrays\n",
        "u0 = np.zeros(shape=(N,n))\n",
        "u1 = np.zeros(shape=(N,n))\n",
        "\n",
        "# Encode the MNIST data\n",
        "encoded_train = encoder(x_train)\n",
        "\n",
        "# Place the encoded data into the numpy arrays. Shift upwards by 10 to ensure nonnegativity for densities\n",
        "for i in range(N):\n",
        "  u0[i,:] = encoded_train[i,:].numpy() + 10\n",
        "  u1[i,:] = encoded_train[i+N,:].numpy() + 10\n",
        "\n",
        "# Store normalization coefficients to convert back from densities to encoded representations\n",
        "normalization_constants = np.zeros(shape=(N,2))\n",
        "\n",
        "x_min = 0 # Domain beginning\n",
        "x_max = 5 # Domain endpoint\n",
        "for i in range(N):\n",
        "\n",
        "  # Collect normalization constant\n",
        "  normalization_constants[i,0] = ((x_max-x_min)/n)*np.sum(u0[i,:])\n",
        "  normalization_constants[i,1] = ((x_max-x_min)/n)*np.sum(u1[i,:])\n",
        "\n",
        "  # Normalize the data to be made densities\n",
        "  u0[i,:] /= ((x_max/n)*np.sum(u0[i,:]))\n",
        "  u1[i,:] /= ((x_max/n)*np.sum(u1[i,:]))\n",
        "\n",
        "# Convert training data to PyTorch tensors\n",
        "u0 = Variable(torch.from_numpy(u0)).to(device)\n",
        "u1 = Variable(torch.from_numpy(u1)).to(device)\n",
        "u0 = u0.to(torch.float32)\n",
        "u1 = u1.to(torch.float32)"
      ],
      "metadata": {
        "id": "1xw4PLAhXu4R"
      },
      "execution_count": 12,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Define additional tensors used as input, notably space and time\n",
        "X = torch.arange(x_min, x_max, (x_max-x_min)/n).to(device)\n",
        "X_vec = torch.unsqueeze(X,1).to(device)\n",
        "t0 = torch.zeros(size=(n,1)).to(device)\n",
        "t1 = torch.ones(size=(n,1)).to(device)"
      ],
      "metadata": {
        "id": "5ouJnkixXu8c"
      },
      "execution_count": 13,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def physics_informed_loss(x, t, u0, u1, cty_branch0, cty_branch1, cty_trunk, HJ_branch0, HJ_branch1, HJ_trunk):\n",
        "\n",
        "  # Define continuity outputs\n",
        "  cty_branch0_output = cty_branch0(u0)\n",
        "  cty_branch1_output = cty_branch1(u1)\n",
        "  cty_trunk_output = cty_trunk(x, t)\n",
        "\n",
        "  # Take continuity derivatives\n",
        "  cty = torch.sum( (cty_branch0_output * cty_branch1_output) * cty_trunk_output, dim=1)\n",
        "  cty_x = torch.autograd.grad(cty.sum(), x, create_graph=True)[0]\n",
        "  cty_t = torch.autograd.grad(cty.sum(), t, create_graph=True)[0]\n",
        "  cty = torch.unsqueeze(cty,1)\n",
        "\n",
        "  # Define HJ outputs\n",
        "  HJ_branch0_output = HJ_branch0(u0)\n",
        "  HJ_branch1_output = HJ_branch1(u1)\n",
        "  HJ_trunk_output = HJ_trunk(x, t)\n",
        "\n",
        "  # Take HJ derivatives\n",
        "  HJ = torch.sum( (HJ_branch0_output * HJ_branch1_output) * HJ_trunk_output, dim=1)\n",
        "  HJ_x = torch.autograd.grad(HJ.sum(), x, create_graph=True)[0]\n",
        "  HJ_xx = torch.autograd.grad(HJ_x.sum(), x, create_graph=True)[0]\n",
        "  HJ_t = torch.autograd.grad(HJ.sum(), t, create_graph=True)[0]\n",
        "  HJ = torch.unsqueeze(HJ,1)\n",
        "\n",
        "  # Construct physics-informed loss\n",
        "  cty_loss = (cty_t + cty_x*HJ_x + cty*HJ_xx)**2\n",
        "  HJ_loss = (HJ_t + (1/2)*(HJ_x**2))**2\n",
        "\n",
        "  return(cty_loss + HJ_loss)"
      ],
      "metadata": {
        "id": "CnYvbqAuXvAn"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Training hyperparameters\n",
        "num_iter = 300000\n",
        "batch_size = 1000\n",
        "\n",
        "# Initialize zero vector for physics-informed loss\n",
        "T0 = torch.zeros(size=(batch_size,1)).to(device)\n",
        "\n",
        "# Training algorithm\n",
        "for i in range(num_iter):\n",
        "\n",
        "  # Define random indices for input\n",
        "  I =  np.random.randint(0,N,batch_size)\n",
        "  J = np.random.randint(0,n,batch_size)\n",
        "\n",
        "  # Collocation procedure : randomly sample x and t\n",
        "  x_unif = Variable(torch.from_numpy(np.random.uniform(x_min,x_max,size=(batch_size,1))).float(), requires_grad=True).to(device)\n",
        "  t_unif = Variable(torch.from_numpy(np.random.uniform(0,1,size=(batch_size,1))).float(), requires_grad=True).to(device)\n",
        "\n",
        "  # Define continuity outputs for boundary conditions\n",
        "  cty_branch0_output = cty_branch0(u0[I,:])\n",
        "  cty_branch1_output = cty_branch1(u1[I,:])\n",
        "  cty_trunk_output_0 = cty_trunk(X_vec[J], t0[J])\n",
        "  cty_trunk_output_1 = cty_trunk(X_vec[J], t1[J])\n",
        "\n",
        "  # Evaluate continuity DeepONets\n",
        "  inner_prod_0 = torch.sum( (cty_branch0_output * cty_branch1_output) * cty_trunk_output_0, dim=1)\n",
        "  inner_prod_1 = torch.sum( (cty_branch0_output * cty_branch1_output) * cty_trunk_output_1, dim=1)\n",
        "\n",
        "  # Take boundary loss\n",
        "  boundary_loss_0 = mse_cost_function(inner_prod_0, u0[I,J])\n",
        "  boundary_loss_1 = mse_cost_function(inner_prod_1, u1[I,J])\n",
        "\n",
        "  # Compute physics-informed loss\n",
        "  physics_term = physics_informed_loss(x_unif, t_unif, u0[I,:], u1[I,:], cty_branch0, cty_branch1, cty_trunk, HJ_branch0, HJ_branch1, HJ_trunk)\n",
        "  physics_loss = l1_cost_function(physics_term, T0)\n",
        "\n",
        "  # Compute loss\n",
        "  loss = boundary_loss_0  + boundary_loss_1 + 1*physics_loss\n",
        "\n",
        "  # Update parameter\n",
        "  optimizer.zero_grad()\n",
        "  loss.backward()\n",
        "  optimizer.step()\n",
        "\n",
        "  if i % 100 == 0:\n",
        "    print(\"Training loss:\", '{:.4e}'.format(loss.data), \"- PINN loss:\", '{:.4e}'.format(physics_loss))"
      ],
      "metadata": {
        "id": "kKlpre_XXvDr"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "qvrMj2ZFXvHu"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Save the models to current directory\n",
        "File = \"Cty_branch0.pth\"\n",
        "torch.save(cty_branch0.state_dict(), File)\n",
        "\n",
        "File = \"Cty_branch1.pth\"\n",
        "torch.save(cty_branch1.state_dict(), File)\n",
        "\n",
        "File = \"Cty_trunk.pth\"\n",
        "torch.save(cty_trunk.state_dict(), File)\n",
        "\n",
        "File = \"HJ_branch0.pth\"\n",
        "torch.save(HJ_branch0.state_dict(), File)\n",
        "\n",
        "File = \"HJ_branch1.pth\"\n",
        "torch.save(HJ_branch1.state_dict(), File)\n",
        "\n",
        "File = \"HJ_trunk.pth\"\n",
        "torch.save(HJ_trunk.state_dict(), File)"
      ],
      "metadata": {
        "id": "LpR5z2L-eyyz"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "FsptLMYZey2H"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Define a heat map plot\n",
        "def heatmap2d(data: np.ndarray):\n",
        "  cmap = LinearSegmentedColormap.from_list('Colormap', [ 'orangered', 'darkorange', 'aquamarine', 'dodgerblue', 'blue'])\n",
        "  fig, (ax) = plt.subplots(1,1, figsize=(6,4))\n",
        "  ax = sns.heatmap(data, ax=ax, cmap=cmap, square=True, cbar=False)\n",
        "\n",
        "  ax.set(xticklabels=[]); ax.set(yticklabels=[]); ax.tick_params(left=False, bottom=False)\n",
        "  plt.savefig(\"heatmap.png\", dpi=300)\n",
        "  plt.show()"
      ],
      "metadata": {
        "id": "rBSCSZ6He7Mc"
      },
      "execution_count": 14,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Get sample test results\n",
        "u_test = torch.zeros(size=(n,n))\n",
        "I = np.random.randint(0,N,1)\n",
        "J = np.random.randint(0,N,1)\n",
        "for i in range(n):\n",
        "  cty_branch0_output_test = cty_branch0(u0[I,:])\n",
        "  cty_branch1_output_test = cty_branch1(u1[J,:])\n",
        "  T_test = 1*(i/(n-1))*torch.ones(size=(n,1)).to(device)\n",
        "  cty_trunk_output_test = cty_trunk(X_vec, T_test)\n",
        "  u_test[:,i] = torch.sum( (cty_branch0_output_test * cty_branch1_output_test) * cty_trunk_output_test, dim=1)\n",
        "\n",
        "heatmap2d(u_test.detach().numpy())"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 345
        },
        "id": "4U915k1We7QJ",
        "outputId": "f244ffe3-0c71-458a-b7a6-26d63500a4e2"
      },
      "execution_count": 42,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 600x400 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Plot mu_0 initial condition\n",
        "plt.plot(torch.squeeze(u0[I,:].cpu()), linewidth=2, color='dodgerblue')\n",
        "plt.plot(u_test[:,0].cpu().detach().numpy(), linewidth=2, linestyle='dashed', color='orangered')\n",
        "plt.legend(['true', 'predicted'], loc='upper right')\n",
        "#plt.savefig(\"initial_condition.png\", dpi=300)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 447
        },
        "id": "qGnaEcC0e7Tz",
        "outputId": "d0eb8c1a-89c4-4edb-c81f-fa7a9526befd"
      },
      "execution_count": 43,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7f379658f3d0>"
            ]
          },
          "metadata": {},
          "execution_count": 43
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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5OTk8OSTT+Lv709jY2Obxy1fvpyysrKWR15eXqc+35tkxttnEd00HH7Q157EiIiISAe7hCwWC6NHj2bTpk3MmjULgKamJjZt2sTSpUs7FcDUqVP54osvWm1btGgRgwcP5p577sHPz6/N46xW63kH8fZUYVb4zys8HYWIiIh36fAyqsuWLWPhwoWMGTOGcePGsWrVKqqqqli0aBEAN998M3379iU7OxuwD9Tdu3dvy/Njx46xa9cuQkJCGDBgAKGhoQwbNqzVZwQHBxMdHf297SIiIuKbOpywzJs3j+PHj3P//fdTWFjIxRdfzNtvv90yEPfIkSOYzY6epvz8fEaOHNny+rHHHuOxxx5jypQpbNmypet/AhEREen1TIZhGJ4OwhXKy8sJDw+nrKyMsDAVDBQREekJLvT/b4/PEhIRERFpjxIWERER8XpKWERERMTrKWERERERr6eERURERLyeEhYRERHxekpYRERExOspYRERERGvp4RFREREvJ4SFhEREfF6Ha4l5K3OVBgoLy/3cCQiIiJyoc78v91epaBek7BUVFQAkJyc7OFIREREpKMqKioIDw8/5/u9pvhhU1MT+fn5hIaGYjKZXHbe8vJykpOTycvLU1HFc9A1ap+u0fnp+rRP16h9ukbt88ZrZBgGFRUVJCYmYjafe6RKr2lhMZvNJCUlue38YWFhXvOX6610jdqna3R+uj7t0zVqn65R+7ztGp2vZeUMDboVERERr6eERURERLyeEpZ2WK1WVqxYgdVq9XQoXkvXqH26Ruen69M+XaP26Rq1rydfo14z6FZERER6L7WwiIiIiNdTwiIiIiJeTwmLiIiIeD0lLCIiIuL1lLC0Y/Xq1aSmpmKz2Rg/fjxbt271dEhe44EHHsBkMrV6DB482NNhecw///lPrrvuOhITEzGZTLz++uut3jcMg/vvv5+EhAQCAwPJysrim2++8UywHtLeNfrJT37yvXtqxowZngnWA7Kzsxk7diyhoaH06dOHWbNmsX///lb71NbWsmTJEqKjowkJCWHu3LkUFRV5KOLudyHX6LLLLvvefXTbbbd5KOLu99RTTzFixIiWxeEmTJjAhg0bWt7vqfeQEpbzWLduHcuWLWPFihXs2LGDzMxMpk+fTnFxsadD8xpDhw6loKCg5fHhhx96OiSPqaqqIjMzk9WrV7f5/iOPPMKTTz7JmjVr+PTTTwkODmb69OnU1tZ2c6Se0941ApgxY0are+rFF1/sxgg9KycnhyVLlvDJJ5/w7rvv0tDQwLRp06iqqmrZ56677uLvf/87L7/8Mjk5OeTn5zNnzhwPRt29LuQaASxevLjVffTII494KOLul5SUxMqVK9m+fTvbtm3jiiuuYObMmezZswfowfeQIec0btw4Y8mSJS2vGxsbjcTERCM7O9uDUXmPFStWGJmZmZ4OwysBxvr161teNzU1GfHx8cajjz7asq20tNSwWq3Giy++6IEIPe/sa2QYhrFw4UJj5syZHonHGxUXFxuAkZOTYxiG/Z4JCAgwXn755ZZ9vvrqKwMwcnNzPRWmR519jQzDMKZMmWLccccdngvKC0VGRhp/+tOfevQ9pBaWc6ivr2f79u1kZWW1bDObzWRlZZGbm+vByLzLN998Q2JiIunp6SxYsIAjR454OiSvdOjQIQoLC1vdT+Hh4YwfP17301m2bNlCnz59GDRoELfffjsnT570dEgeU1ZWBkBUVBQA27dvp6GhodV9NHjwYPr16+ez99HZ1+iMF154gZiYGIYNG8by5cuprq72RHge19jYyNq1a6mqqmLChAk9+h7qNcUPXe3EiRM0NjYSFxfXantcXBz79u3zUFTeZfz48Tz33HMMGjSIgoICfvOb33DppZfy5ZdfEhoa6unwvEphYSFAm/fTmffE3h00Z84c0tLSOHjwIL/61a+46qqryM3Nxc/Pz9PhdaumpibuvPNOJk2axLBhwwD7fWSxWIiIiGi1r6/eR21dI4Abb7yRlJQUEhMT2b17N/fccw/79+/ntdde82C03euLL75gwoQJ1NbWEhISwvr168nIyGDXrl099h5SwiKddtVVV7U8HzFiBOPHjyclJYWXXnqJn/70px6MTHqq+fPntzwfPnw4I0aMoH///mzZsoWpU6d6MLLut2TJEr788kufHhfWnnNdo1tvvbXl+fDhw0lISGDq1KkcPHiQ/v37d3eYHjFo0CB27dpFWVkZr7zyCgsXLiQnJ8fTYXWJuoTOISYmBj8/v++NnC4qKiI+Pt5DUXm3iIgILrroIg4cOODpULzOmXtG91PHpKenExMT43P31NKlS3nzzTd5//33SUpKatkeHx9PfX09paWlrfb3xfvoXNeoLePHjwfwqfvIYrEwYMAARo8eTXZ2NpmZmTzxxBM9+h5SwnIOFouF0aNHs2nTppZtTU1NbNq0iQkTJngwMu9VWVnJwYMHSUhI8HQoXictLY34+PhW91N5eTmffvqp7qfzOHr0KCdPnvSZe8owDJYuXcr69evZvHkzaWlprd4fPXo0AQEBre6j/fv3c+TIEZ+5j9q7Rm3ZtWsXgM/cR21pamqirq6uZ99Dnh71683Wrl1rWK1W47nnnjP27t1r3HrrrUZERIRRWFjo6dC8wi9+8Qtjy5YtxqFDh4yPPvrIyMrKMmJiYozi4mJPh+YRFRUVxs6dO42dO3cagPH4448bO3fuNA4fPmwYhmGsXLnSiIiIMN544w1j9+7dxsyZM420tDSjpqbGw5F3n/Ndo4qKCuOXv/ylkZubaxw6dMh47733jFGjRhkDBw40amtrPR16t7j99tuN8PBwY8uWLUZBQUHLo7q6umWf2267zejXr5+xefNmY9u2bcaECROMCRMmeDDq7tXeNTpw4IDx4IMPGtu2bTMOHTpkvPHGG0Z6eroxefJkD0fefe69914jJyfHOHTokLF7927j3nvvNUwmk/HOO+8YhtFz7yElLO34/e9/b/Tr18+wWCzGuHHjjE8++cTTIXmNefPmGQkJCYbFYjH69u1rzJs3zzhw4ICnw/KY999/3wC+91i4cKFhGPapzffdd58RFxdnWK1WY+rUqcb+/fs9G3Q3O981qq6uNqZNm2bExsYaAQEBRkpKirF48WKf+oHQ1rUBjGeffbZln5qaGuNnP/uZERkZaQQFBRmzZ882CgoKPBd0N2vvGh05csSYPHmyERUVZVitVmPAgAHG3XffbZSVlXk28G50yy23GCkpKYbFYjFiY2ONqVOntiQrhtFz7yGTYRhG97XniIiIiHScxrCIiIiI11PCIiIiIl5PCYuIiIh4PSUsIiIi4vWUsIiIiIjXU8IiIiIiXk8Ji4iIiHg9JSwiIiLi9ZSwiIiIiNdTwiIiIiJeTwmLiIiIeD0lLCIiIuL1/j8xFQFAmaVODQAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Plot mu_1 initial condition\n",
        "plt.plot(torch.squeeze(u1[J,:].cpu()), linewidth=2, color='dodgerblue')\n",
        "plt.plot(u_test[:,n-1].cpu().detach().numpy(), linewidth=2, linestyle='dashed', color='orangered')\n",
        "plt.legend(['true', 'predicted'], loc='upper right')\n",
        "plt.savefig(\"initial_condition.png\", dpi=300)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 430
        },
        "id": "6S91gRBCe7W9",
        "outputId": "1c40982f-29e5-4863-8a01-4efaddd7e1b1"
      },
      "execution_count": 44,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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337LwYMHeffdd9mwYQMgVSsdOnSIbdu2UV9fj91uZ9GiRcyfP59zzz2X1atXU1xczHfffcfvfvc7fvzxRwBuueUWXnrpJV5++WX27dvHfffdx65du0L42+seIViGMXvrYWLrjiPWZ1jLRTWAICI42uQPmkdrxJUkJ962VldHY0gCQFNfwtyGr5nYsh1tnJyArzOJZOi+sHTpUqxWK3PnzuWXv/wlt9xyi698uSumTZvGunXr2LdvH8cddxwzZ87k3nvvJTtb/j68/PLLZGdns3DhQs4//3yuvfZa0tPTuz2mRqNh9erVpKenc/rppzN16lQefvhhX5Tnggsu4NRTT+XEE08kLS2NN998E4VCwSeffMLxxx/PsmXLGD9+PJdccgklJSVkZGQAcPHFF3PPPfdw5513MmvWLEpKSrjhhhtC9JvrBW8QPPPMM95Ro0Z5tVqtd+7cud6NGzd2u+3f//5374IFC7yJiYnexMRE78knn9zj9tddd50X8D755JMBjclkMnkBr8lkCmi/4cwj673etZcu9npPodO/zy8707ulKtqjEwwHNn670/e5++muq7zf/1DkPfZPRd5xj1u8j34b7dENX1773SO+v4vr+d/4ll9ZfpPX5Y7MGKxWq3f37t1eq9UamROGiIULF3pvueWWaA9jwNHT37Ov9++AIyxvvfUWt912G/fddx9btmxh+vTpLFmypNt68LVr13LppZeyZs0aNmzYQE5ODosXL6ai4shM7ffff5/vv/++k6oUhI+9DTCxVZoScscm41ZKKU2Ztgphzy+ICE4/Yyyv1kj8qHzKDPnYVXrRADGKqK1yWbNqlFw6m26rpNEajREJBEFMCT3xxBMsX76cZcuWMWnSJJ5//nkMBgMvvfRSl9u//vrr3HjjjcyYMYOCggJefPFFPB4PX375ZaftKioquPnmm3n99deJiYkJ7qcRBERteQ3p9hoAlGNnYkuQhGKmrVwIFkFEcFv8Pmg6Ixmx8staIViiRozNr1NzjtwyId1WJdxuBVEjoCohh8PB5s2bufvuu33rlEolixYt8iXy9IbFYsHpdHbKWvZ4PFx++eXccccdTJ48uU/Hsdvt2O1yZlhLS//q5ocbrXbY6UjjhIWFnKHazh0nxeJ++SFoKpUSHpvtwNDtSSEYGLgtsipR6GNJ0kGMEpweIViiidZfsCSkYTGk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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Perform POT to find reference geodesic in encoded space\n",
        "T = n\n",
        "\n",
        "y = np.arange(n, dtype=np.float64)\n",
        "OT = np.zeros(shape=(n,T))\n",
        "\n",
        "a1 = u0[I,:].cpu()\n",
        "a2 = u1[J,:].cpu()\n",
        "\n",
        "A = np.vstack((a1, a2)).T\n",
        "n_distributions = A.shape[1]\n",
        "\n",
        "K = ot.utils.dist0(n)\n",
        "K /= K.max()\n",
        "\n",
        "for t in range(T):\n",
        "  alpha = t/(T-1)  # 0<=alpha<=1\n",
        "  weights = np.array([1 - alpha, alpha])\n",
        "\n",
        "  reg = 0.0003\n",
        "  bary_wass = ot.bregman.barycenter(A, K, reg, weights)\n",
        "\n",
        "  OT[:,t] = bary_wass"
      ],
      "metadata": {
        "id": "kSAXsccTe7aW"
      },
      "execution_count": 45,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "heatmap2d(OT)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 345
        },
        "id": "CDEzeIwGfePw",
        "outputId": "2b286825-a10b-47eb-ba1c-693d1c8dbbd3"
      },
      "execution_count": 46,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 600x400 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Compute L1 error between GeONet and POT\n",
        "time_steps = 5\n",
        "errors_encoded = np.zeros(shape=(1,time_steps))\n",
        "for step in range(time_steps):\n",
        "  i = max(step*8-1,0)\n",
        "  errors_encoded[0,step] = np.sum( np.abs(u_test[:,i].detach().numpy() - OT[:,i]) ) / np.sum( OT[:,i])\n",
        "\n",
        "  print(\"Time:\", step/4, \"- L1 error:\", errors_encoded[0,step])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "iOfOpz9koKW8",
        "outputId": "7330ddf3-f8e8-4bca-932c-6396a612b451"
      },
      "execution_count": 47,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Time: 0.0 - L1 error: 0.01335374273812795\n",
            "Time: 0.25 - L1 error: 0.013824257360718552\n",
            "Time: 0.5 - L1 error: 0.016684805622832338\n",
            "Time: 0.75 - L1 error: 0.016572366607701533\n",
            "Time: 1.0 - L1 error: 0.014879891143763379\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "aeTyQhiGfeTg"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Define heatmap grid\n",
        "def heatmap2d_grid(u: np.ndarray):\n",
        "  cmap = 'gray'\n",
        "\n",
        "# Plot the geodesics at the five times\n",
        "  fig, (ax1, ax2, ax3, ax4, ax5) = plt.subplots(1,5, figsize=(12,6))\n",
        "\n",
        "  ax1 = sns.heatmap(u[0,:,:], ax=ax1, cmap=cmap, square=True, cbar=False)\n",
        "  ax1.set(xticklabels=[]); ax1.set(yticklabels=[]); ax1.tick_params(left=False, bottom=False)\n",
        "\n",
        "  ax2 = sns.heatmap(u[1,:,:], ax=ax2, cmap=cmap, square=True, cbar=False)\n",
        "  ax2.set(xticklabels=[]); ax2.set(yticklabels=[]); ax2.tick_params(left=False, bottom=False)\n",
        "\n",
        "  ax3 = sns.heatmap(u[2,:,:], ax=ax3, cmap=cmap, square=True, cbar=False)\n",
        "  ax3.set(xticklabels=[]); ax3.set(yticklabels=[]); ax3.tick_params(left=False, bottom=False)\n",
        "\n",
        "  ax4 = sns.heatmap(u[3,:,:], ax=ax4, cmap=cmap, square=True, cbar=False)\n",
        "  ax4.set(xticklabels=[]); ax4.set(yticklabels=[]); ax4.tick_params(left=False, bottom=False)\n",
        "\n",
        "  ax5 = sns.heatmap(u[4,:,:], ax=ax5, cmap=cmap, square=True, cbar=False)\n",
        "  ax5.set(xticklabels=[]); ax5.set(yticklabels=[]); ax5.tick_params(left=False, bottom=False)\n",
        "\n",
        "  plt.savefig('Pred_geodesic.png', dpi=350)\n",
        "\n",
        "  plt.xticks([])\n",
        "  plt.yticks([])\n",
        "  plt.show()"
      ],
      "metadata": {
        "id": "LwCD6kfvfeWU"
      },
      "execution_count": 48,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Decode solution\n",
        "time_steps = 5\n",
        "u_test_decoded = np.zeros(shape=(5,28,28))\n",
        "for step in range(time_steps):\n",
        "  i = max(step*8-1,0)\n",
        "  u_encoded_section = u_test[:,i].cpu().detach().numpy().squeeze() * (normalization_constants[I,0]*(1 - step/4) + normalization_constants[J,1]*(step/4)) -10\n",
        "  u_encoded_tf = tf.convert_to_tensor(u_encoded_section)\n",
        "  u_test_decoded[step,:,:] = decoder(tf.expand_dims(u_encoded_tf,0))[0,:,:].numpy()"
      ],
      "metadata": {
        "id": "iw3DT1RbfvYh"
      },
      "execution_count": 52,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "heatmap2d_grid(u_test_decoded)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 197
        },
        "id": "pbyIakdzfvcZ",
        "outputId": "c64063bf-7543-440f-9242-07cafcf6cce5"
      },
      "execution_count": 53,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1200x600 with 5 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Produce exact (non-GeONet output) decoded boundary mu_0\n",
        "u_encoded_section = u0[I,:].cpu().detach().numpy().squeeze() * normalization_constants[I,0] - 10\n",
        "u_encoded_tf1 = tf.convert_to_tensor(u_encoded_section)\n",
        "plt.imshow(decoder(tf.expand_dims(u_encoded_tf1,0))[0,:,:], cmap=\"gray\")\n",
        "#plt.savefig(\"boundary_MNIST.png\", dpi=300)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 447
        },
        "id": "RkogoY9wfvf-",
        "outputId": "556549ba-bd43-4aff-bc5e-9edf11a0b230"
      },
      "execution_count": 54,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.image.AxesImage at 0x7f379711b430>"
            ]
          },
          "metadata": {},
          "execution_count": 54
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaAAAAGdCAYAAABU0qcqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAdB0lEQVR4nO3de3BU9f3/8dcGkgU02TRALiu3ACqtXDqlkmZUiiUF0o4jSlu1/gGt1UGDrVK1k1ZFqzNpccZa21Q70wLe8DZTYHQ6WI0m9AJYUIpOW4bQKEFIEMbshkBCTD6/P/i5X1dufo6bvDfL8zHzmSF7zjv7zuGwr5zd5b0h55wTAAD9LMu6AQDAmYkAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAAgInB1g18Um9vr/bu3avc3FyFQiHrdgAAnpxzam9vVzQaVVbWya9z0i6A9u7dq9GjR1u3AQD4jJqbmzVq1KiTbk+7p+Byc3OtWwAApMDpHs/7LIBqa2s1btw4DRkyRGVlZXr99dc/VR1PuwFAZjjd43mfBNCzzz6rpUuXatmyZXrjjTc0bdo0zZ07V/v37++LuwMADESuD8yYMcNVVVUlvu7p6XHRaNTV1NSctjYWizlJLBaLxRrgKxaLnfLxPuVXQEePHtXWrVtVUVGRuC0rK0sVFRXauHHjcft3dXUpHo8nLQBA5kt5AB04cEA9PT0qKipKur2oqEgtLS3H7V9TU6NIJJJYvAMOAM4M5u+Cq66uViwWS6zm5mbrlgAA/SDl/w9oxIgRGjRokFpbW5Nub21tVXFx8XH7h8NhhcPhVLcBAEhzKb8CysnJ0fTp01VXV5e4rbe3V3V1dSovL0/13QEABqg+mYSwdOlSLVy4UF/+8pc1Y8YMPfTQQ+ro6ND3vve9vrg7AMAA1CcBdNVVV+n999/X3XffrZaWFn3xi1/U+vXrj3tjAgDgzBVyzjnrJj4uHo8rEolYtwH0qSATP4LUZGdne9dIx/47ha80eyhBGojFYsrLyzvpdvN3wQEAzkwEEADABAEEADBBAAEATBBAAAATBBAAwAQBBAAwQQABAEwQQAAAEwQQAMAEAQQAMEEAAQBM9Mk0bGCgCjLwc8iQId41X//6171rgnycyUsvveRdI0krVqzwrgkywBRnNq6AAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmmIYNfEyQydZlZWXeNYsWLfKumT17tnfNV7/6Ve8aSZo4caJ3zW9/+1vvmvfee8+7pru727sG6YkrIACACQIIAGCCAAIAmCCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYYRgp8TFdXl3dNW1ubd02QYZ9BBqU657xrJGnBggXeNfX19d417777rncNMgdXQAAAEwQQAMAEAQQAMEEAAQBMEEAAABMEEADABAEEADBBAAEATBBAAAATBBAAwAQBBAAwQQABAEwwjBT4mCDDO5uamrxrfv3rX3vX/PCHP/SuGTlypHeNJL311lveNf/617+8a4IOS0Vm4AoIAGCCAAIAmEh5AN1zzz0KhUJJa9KkSam+GwDAANcnrwFdcMEFeuWVV/7vTgbzUhMAIFmfJMPgwYNVXFzcF98aAJAh+uQ1oJ07dyoajWr8+PG69tprtXv37pPu29XVpXg8nrQAAJkv5QFUVlamVatWaf369XrkkUfU1NSkSy65RO3t7Sfcv6amRpFIJLFGjx6d6pYAAGko5QFUWVmpb3/725o6darmzp2rP//5z2pra9Nzzz13wv2rq6sVi8USq7m5OdUtAQDSUJ+/OyA/P1/nnXeeGhsbT7g9HA4rHA73dRsAgDTT5/8P6NChQ9q1a5dKSkr6+q4AAANIygPotttuU0NDg9555x394x//0BVXXKFBgwbpmmuuSfVdAQAGsJQ/Bbdnzx5dc801OnjwoEaOHKmLL75YmzZtCjyTCgCQmUIuzaYBxuNxRSIR6zaATy0UCnnX5OTkeNeMGzfOu+b73/++d4107KlzXytWrPCuee+997xrMHDEYjHl5eWddDuz4AAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAAgAkCCABgggACAJjo8w+kAzJdkHm+XV1d3jW7du3yrnnttde8ayTpZz/7mXdNVpb/77P333+/d01PT493DdITV0AAABMEEADABAEEADBBAAEATBBAAAATBBAAwAQBBAAwQQABAEwQQAAAEwQQAMAEAQQAMEEAAQBMEEAAABNMw0baC4VC3jVBJlRnovnz5weqKysr86654IILvGsefPBB75r29nbvGqQnroAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYYBgp+tXgwf6nXJDBor29vd41Qe+rv+Tl5XnXXH755YHuK8jf07Bhw7xrOjs7vWtwTJAhvVJ6neNcAQEATBBAAAATBBAAwAQBBAAwQQABAEwQQAAAEwQQAMAEAQQAMEEAAQBMEEAAABMEEADABAEEADDBMFIElpXl//tLfw1CzIRBjZ8U5Gc6cuRIoPvq6enxrtm6dat3TXd3t3cNMgdXQAAAEwQQAMCEdwBt2LBBl112maLRqEKhkNauXZu03Tmnu+++WyUlJRo6dKgqKiq0c+fOVPULAMgQ3gHU0dGhadOmqba29oTbly9frocffliPPvqoNm/erLPOOktz587lg6cAAEm834RQWVmpysrKE25zzumhhx7SnXfemfgkxscff1xFRUVau3atrr766s/WLQAgY6T0NaCmpia1tLSooqIicVskElFZWZk2btx4wpquri7F4/GkBQDIfCkNoJaWFklSUVFR0u1FRUWJbZ9UU1OjSCSSWKNHj05lSwCANGX+Lrjq6mrFYrHEam5utm4JANAPUhpAxcXFkqTW1tak21tbWxPbPikcDisvLy9pAQAyX0oDqLS0VMXFxaqrq0vcFo/HtXnzZpWXl6fyrgAAA5z3u+AOHTqkxsbGxNdNTU3atm2bCgoKNGbMGN1yyy26//77de6556q0tFR33XWXotGo5s+fn8q+AQADnHcAbdmyRZdeemni66VLl0qSFi5cqFWrVumOO+5QR0eHbrjhBrW1teniiy/W+vXrNWTIkNR1DQAY8EIuzaYvxuNxRSIR6zbwKQQd+JnO0uyfQ5KcnBzvmgceeCDQfX38l8xP64477vCuWb9+vXdNJgrybymdz9WPxGKxU76ub/4uOADAmYkAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYML74xiAjwyEabyZJDs727tm/Pjxge4rPz/fu6a0tNS7ZvBg/4egDz/80Lsm3WXqNOzT4QoIAGCCAAIAmCCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACYaRAgaCDJ/8wx/+4F1TWVnpXSMF6++mm27yrvnrX//qXbNz507vmp6eHu8aSert7Q1Uh0+HKyAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmQs45Z93Ex8XjcUUiEes2kEaCDMYMKsg/h6ws/9/jvvWtb3nXPP300941QXoLqqury7vm9ddf965ZsWKFd822bdu8ayRp37593jXt7e3eNUGOXdABq/0pFospLy/vpNu5AgIAmCCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCYaQILMigy9zcXO+a4cOHe9dEo1HvGknq7e31rrnzzju9ay699FLvmiFDhnjX9KfOzk7vmg8++MC7ZufOnd41b7zxhneNJP3lL3/xrnnrrbe8a1paWrxrPvzwQ++a/sYwUgBAWiKAAAAmvANow4YNuuyyyxSNRhUKhbR27dqk7YsWLVIoFEpa8+bNS1W/AIAM4R1AHR0dmjZtmmpra0+6z7x587Rv377ECvJBWgCAzDbYt6CyslKVlZWn3CccDqu4uDhwUwCAzNcnrwHV19ersLBQ559/vm688UYdPHjwpPt2dXUpHo8nLQBA5kt5AM2bN0+PP/646urq9Mtf/lINDQ2qrKw86eeX19TUKBKJJNbo0aNT3RIAIA15PwV3OldffXXiz1OmTNHUqVM1YcIE1dfXa/bs2cftX11draVLlya+jsfjhBAAnAH6/G3Y48eP14gRI9TY2HjC7eFwWHl5eUkLAJD5+jyA9uzZo4MHD6qkpKSv7woAMIB4PwV36NChpKuZpqYmbdu2TQUFBSooKNC9996rBQsWqLi4WLt27dIdd9yhiRMnau7cuSltHAAwsHkH0JYtW5LmWH30+s3ChQv1yCOPaPv27XrsscfU1tamaDSqOXPm6L777lM4HE5d1wCAAc87gGbNmqVTzS996aWXPlND6H+DBwd7L8q0adO8a1atWuVdM3bsWO+anJwc7xpJGjRoUL/UBJkBHGTY5/vvv+9dI0n//Oc/vWveeecd75ogw2nz8/O9a7q6urxrpGADYIMMtA0y2DcUCnnXSMHOvb7CLDgAgAkCCABgggACAJgggAAAJgggAIAJAggAYIIAAgCYIIAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAA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i4vdAw88kLitra3NhcNh9/TTTxt02D8+eRycc27hwoXu8ssvN+nHyv79+50k19DQ4Jw79nefnZ3tnn/++cQ+//nPf5wkt3HjRqs2+9wnj4Nzzn31q191P/rRj+ya+hTS/gro6NGj2rp1qyoqKhK3ZWVlqaKiQhs3bjTszMbOnTsVjUY1fvx4XXvttdq9e7d1S6aamprU0tKSdH5EIhGVlZWdkedHfX29CgsLdf755+vGG2/UwYMHrVvqU7FYTJJUUFAgSdq6dau6u7uTzodJkyZpzJgxGX0+fPI4fOSpp57SiBEjNHnyZFVXV+vw4cMW7Z1U2g0j/aQDBw6op6dHRUVFSbcXFRXpv//9r1FXNsrKyrRq1Sqdf/752rdvn+69915dcsklevvtt5Wbm2vdnomWlhZJOuH58dG2M8W8efN05ZVXqrS0VLt27dJPf/pTVVZWauPGjRo0aJB1eynX29urW265RRdddJEmT54s6dj5kJOTo/z8/KR9M/l8ONFxkKTvfve7Gjt2rKLRqLZv366f/OQn2rFjh/70pz8Zdpss7QMI/6eysjLx56lTp6qsrExjx47Vc889p+uuu86wM6SDq6++OvHnKVOmaOrUqZowYYLq6+s1e/Zsw876RlVVld5+++0z4nXQUznZcbjhhhsSf54yZYpKSko0e/Zs7dq1SxMmTOjvNk8o7Z+CGzFihAYNGnTcu1haW1tVXFxs1FV6yM/P13nnnafGxkbrVsx8dA5wfhxv/PjxGjFiREaeH0uWLNGLL76o1157LenjW4qLi3X06FG1tbUl7Z+p58PJjsOJlJWVSVJanQ9pH0A5OTmaPn266urqErf19vaqrq5O5eXlhp3ZO3TokHbt2qWSkhLrVsyUlpaquLg46fyIx+PavHnzGX9+7NmzRwcPHsyo88M5pyVLlmjNmjV69dVXVVpamrR9+vTpys7OTjofduzYod27d2fU+XC643Ai27Ztk6T0Oh+s3wXxaTzzzDMuHA67VatWuX//+9/uhhtucPn5+a6lpcW6tX714x//2NXX17umpib397//3VVUVLgRI0a4/fv3W7fWp9rb292bb77p3nzzTSfJPfjgg+7NN9907777rnPOuV/84hcuPz/frVu3zm3fvt1dfvnlrrS01B05csS489Q61XFob293t912m9u4caNrampyr7zyivvSl77kzj33XNfZ2WndesrceOONLhKJuPr6erdv377EOnz4cGKfxYsXuzFjxrhXX33VbdmyxZWXl7vy8nLDrlPvdMehsbHR/fznP3dbtmxxTU1Nbt26dW78+PFu5syZxp0nGxAB5Jxzv/nNb9yYMWNcTk6OmzFjhtu0aZN1S/3uqquuciUlJS4nJ8edc8457qqrrnKNjY3WbfW51157zUk6bi1cuNA5d+yt2HfddZcrKipy4XDYzZ492+3YscO26T5wquNw+PBhN2fOHDdy5EiXnZ3txo4d666//vqM+yXtRD+/JLdy5crEPkeOHHE33XST+9znPueGDRvmrrjiCrdv3z67pvvA6Y7D7t273cyZM11BQYELh8Nu4sSJ7vbbb3exWMy28U/g4xgAACbS/jUgAEBmIoAAACYIIACACQIIAGCCAAIAmCCAAAAmCCAAgAkCCABgggACAJgggAAAJgggAIAJAggAYOL/ARd2d0Im346XAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Produce exact (non-GeONet output) decoded boundary mu_1\n",
        "u_encoded_section = u1[J,:].cpu().detach().numpy().squeeze() * normalization_constants[J,1] - 10\n",
        "u_encoded_tf2 = tf.convert_to_tensor(u_encoded_section)\n",
        "plt.imshow(decoder(tf.expand_dims(u_encoded_tf2,0))[0,:,:], cmap=\"gray\")\n",
        "#plt.savefig(\"boundary_MNIST.png\", dpi=300)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 447
        },
        "id": "RR9P0xr1fvi6",
        "outputId": "850fce41-3adf-43b6-aede-aa9f18a6db26"
      },
      "execution_count": 55,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.image.AxesImage at 0x7f37969b4250>"
            ]
          },
          "metadata": {},
          "execution_count": 55
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "fYqHBHLJf6_K"
      },
      "execution_count": null,
      "outputs": []
    }
  ]
}