{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "/home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/torchvision/io/image.py:13: UserWarning: Failed to load image Python extension: '/home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/torchvision/image.so: undefined symbol: _ZN3c104warnERKNS_7WarningE'If you don't plan on using image functionality from `torchvision.io`, you can ignore this warning. Otherwise, there might be something wrong with your environment. Did you have `libjpeg` or `libpng` installed before building `torchvision` from source?\n",
      "  warn(\n"
     ]
    }
   ],
   "source": [
    "import copy\n",
    "import itertools\n",
    "import logging\n",
    "import math\n",
    "from functools import partial\n",
    "from pathlib import Path\n",
    "from typing import Dict\n",
    "import json\n",
    "\n",
    "import hydra\n",
    "import matplotlib\n",
    "import matplotlib.colors as colors\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import omegaconf\n",
    "import pytorch_lightning\n",
    "import seaborn as sns\n",
    "import torch  # noqa\n",
    "import wandb\n",
    "from hydra.utils import instantiate\n",
    "from matplotlib import tri\n",
    "from matplotlib.offsetbox import AnnotationBbox, OffsetImage\n",
    "from omegaconf import DictConfig\n",
    "from pytorch_lightning import LightningModule\n",
    "from scipy.stats import qmc\n",
    "from torch.utils.data import DataLoader, Subset, SubsetRandomSampler\n",
    "from tqdm import tqdm\n",
    "\n",
    "from nn_core.callbacks import NNTemplateCore\n",
    "from nn_core.common import PROJECT_ROOT\n",
    "from nn_core.common.utils import seed_index_everything\n",
    "from nn_core.model_logging import NNLogger\n",
    "\n",
    "import ccmm  # noqa\n",
    "from ccmm.matching.utils import (\n",
    "    apply_permutation_to_statedict,\n",
    "    get_all_symbols_combinations,\n",
    "    load_permutations,\n",
    "    perm_indices_to_perm_matrix,\n",
    "    plot_permutation_history_animation,\n",
    "    restore_original_weights,\n",
    ")\n",
    "from ccmm.utils.utils import (\n",
    "    fuse_batch_norm_into_conv,\n",
    "    get_interpolated_loss_acc_curves,\n",
    "    l2_norm_models,\n",
    "    linear_interpolate,\n",
    "    load_model_from_info,\n",
    "    map_model_seed_to_symbol,\n",
    "    normalize_unit_norm,\n",
    "    project_onto,\n",
    "    save_factored_permutations,\n",
    "    vector_to_state_dict,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'light red': '#c05761',\n",
       " 'green': '#2a9d8f',\n",
       " 'yellow': '#e9c46a',\n",
       " 'dark blue': '#264653',\n",
       " 'red': '#941c2f',\n",
       " 'orange': '#e76f51',\n",
       " 'violet': '#734f5a',\n",
       " 'light orange': '#f4a261'}"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plt.rcParams.update(\n",
    "    {\n",
    "        \"text.usetex\": True,\n",
    "        \"font.family\": \"serif\",\n",
    "    }\n",
    ")\n",
    "sns.set_context(\"talk\")\n",
    "\n",
    "cmap_name = \"coolwarm_r\"\n",
    "\n",
    "from ccmm.utils.plot import Palette\n",
    "\n",
    "palette = Palette(f\"{PROJECT_ROOT}/misc/palette2.json\")\n",
    "palette"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "logging.getLogger(\"lightning.pytorch\").setLevel(logging.WARNING)\n",
    "logging.getLogger(\"torch\").setLevel(logging.WARNING)\n",
    "logging.getLogger(\"pytorch_lightning.accelerators.cuda\").setLevel(logging.WARNING)\n",
    "pylogger = logging.getLogger(__name__)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Configuration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "hydra.initialize()"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import hydra\n",
    "from hydra import initialize, compose\n",
    "from typing import Dict, List\n",
    "\n",
    "hydra.core.global_hydra.GlobalHydra.instance().clear()\n",
    "initialize(version_base=None, config_path=str(\"../conf\"), job_name=\"matching\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "cfg = compose(config_name=\"matching\", overrides=[\"model=cnn\", \"dataset=emnist\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:49:55 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Global seed set to <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1273642419</span>                      <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/utilities/seed.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.seed</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/utilities/seed.py#71\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">71</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:49:55\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Global seed set to \u001b[1;36m1273642419\u001b[0m                      \u001b]8;id=839211;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/utilities/seed.py\u001b\\\u001b[2mpytorch_lightning.utilities.seed\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=368085;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/utilities/seed.py#71\u001b\\\u001b[2m71\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Setting seed <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1273642419</span> from seeds<span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span><span style=\"font-weight: bold\">]</span>                         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/nn_core/common/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">nn_core.common.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/nn_core/common/utils.py#107\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">107</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Setting seed \u001b[1;36m1273642419\u001b[0m from seeds\u001b[1m[\u001b[0m\u001b[1;36m1\u001b[0m\u001b[1m]\u001b[0m                         \u001b]8;id=904482;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/nn_core/common/utils.py\u001b\\\u001b[2mnn_core.common.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=488394;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/nn_core/common/utils.py#107\u001b\\\u001b[2m107\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "1273642419"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "core_cfg = cfg  # NOQA\n",
    "cfg = cfg.matching\n",
    "\n",
    "seed_index_everything(cfg)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_test_samples = 5000\n",
    "num_train_samples = 5000"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/data/EMNIST/raw/emnist-letters-train-images-idx3-ubyte /media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/data/EMNIST/raw/emnist-letters-train-labels-idx1-ubyte\n",
      "/media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/data/EMNIST/raw/emnist-letters-test-images-idx3-ubyte /media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/data/EMNIST/raw/emnist-letters-test-labels-idx1-ubyte\n"
     ]
    }
   ],
   "source": [
    "transform = instantiate(core_cfg.dataset.test.transform)\n",
    "\n",
    "train_dataset = instantiate(core_cfg.dataset.train, transform=transform)\n",
    "test_dataset = instantiate(core_cfg.dataset.test, transform=transform)\n",
    "\n",
    "train_subset = Subset(train_dataset, list(range(num_train_samples)))\n",
    "train_loader = DataLoader(train_subset, batch_size=5000, num_workers=cfg.num_workers)\n",
    "\n",
    "test_subset = Subset(test_dataset, list(range(num_test_samples)))\n",
    "\n",
    "test_loader = DataLoader(test_subset, batch_size=1000, num_workers=cfg.num_workers)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/connectors/accelerator_connector.py:447: LightningDeprecationWarning: Setting `Trainer(gpus=1)` is deprecated in v1.7 and will be removed in v2.0. Please use `Trainer(accelerator='gpu', devices=1)` instead.\n",
      "  rank_zero_deprecation(\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:49:56 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> GPU available: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span> <span style=\"font-weight: bold\">(</span>cuda<span style=\"font-weight: bold\">)</span>, used: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>      <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1751\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1751</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:49:56\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m GPU available: \u001b[3;92mTrue\u001b[0m \u001b[1m(\u001b[0mcuda\u001b[1m)\u001b[0m, used: \u001b[3;92mTrue\u001b[0m      \u001b]8;id=118512;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=499288;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1751\u001b\\\u001b[2m1751\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> TPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> TPU cores    <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1754\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1754</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m TPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m TPU cores    \u001b]8;id=215118;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=143249;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1754\u001b\\\u001b[2m1754\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> IPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> IPUs         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1757\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1757</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m IPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m IPUs         \u001b]8;id=768303;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=365854;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1757\u001b\\\u001b[2m1757\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> HPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> HPUs         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1760\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1760</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m HPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m HPUs         \u001b]8;id=464800;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=343238;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1760\u001b\\\u001b[2m1760\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "trainer = instantiate(cfg.trainer, enable_progress_bar=False, enable_model_summary=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #800000; text-decoration-color: #800000; font-weight: bold\">ERROR   </span> Failed to detect the name of this notebook, you can set it manually  <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/wandb/jupyter.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">wandb.jupyter</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/wandb/jupyter.py#224\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">224</span></a>\n",
       "<span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span>         with the WANDB_NOTEBOOK_NAME environment variable to enable code     <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">                 </span>\n",
       "<span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span>         saving.                                                              <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">                 </span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[1;31mERROR   \u001b[0m Failed to detect the name of this notebook, you can set it manually  \u001b]8;id=700264;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/wandb/jupyter.py\u001b\\\u001b[2mwandb.jupyter\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=645850;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/wandb/jupyter.py#224\u001b\\\u001b[2m224\u001b[0m\u001b]8;;\u001b\\\n",
       "\u001b[2;36m                    \u001b[0m         with the WANDB_NOTEBOOK_NAME environment variable to enable code     \u001b[2m                 \u001b[0m\n",
       "\u001b[2;36m                    \u001b[0m         saving.                                                              \u001b[2m                 \u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: Currently logged in as: \u001b[33m\u001b[0m (\u001b[33mANONYMIZED\u001b[0m). Use \u001b[1m`wandb login --relogin`\u001b[0m to force relogin\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "wandb version 0.17.0 is available!  To upgrade, please run:\n",
       " $ pip install wandb --upgrade"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Tracking run with wandb version 0.16.6"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Run data is saved locally in <code>/media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/notebooks/wandb/run-20240522_074956-ctqtcrzw</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Syncing run <strong><a href='https://wandb.ai/ANONYMIZED/cycle-consistent-model-merging/runs/ctqtcrzw' target=\"_blank\">polar-yogurt-3022</a></strong> to <a href='https://wandb.ai/ANONYMIZED/cycle-consistent-model-merging' target=\"_blank\">Weights & Biases</a> (<a href='https://wandb.me/run' target=\"_blank\">docs</a>)<br/>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View project at <a href='https://wandb.ai/ANONYMIZED/cycle-consistent-model-merging' target=\"_blank\">https://wandb.ai/ANONYMIZED/cycle-consistent-model-merging</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View run at <a href='https://wandb.ai/ANONYMIZED/cycle-consistent-model-merging/runs/ctqtcrzw' target=\"_blank\">https://wandb.ai/ANONYMIZED/cycle-consistent-model-merging/runs/ctqtcrzw</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:50:02 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Trying to load                                                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.utils.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#255\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">255</span></a>\n",
       "<span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span>         ANONYMIZED/cycle-consistent-model-merging/EMNIST_CNN_1:latest         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">                    </span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:50:02\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Trying to load                                                    \u001b]8;id=260230;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\u001b\\\u001b[2mccmm.utils.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=131413;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#255\u001b\\\u001b[2m255\u001b[0m\u001b]8;;\u001b\\\n",
       "\u001b[2;36m                    \u001b[0m         ANONYMIZED/cycle-consistent-model-merging/EMNIST_CNN_1:latest         \u001b[2m                    \u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m:   1 of 1 files downloaded.  \n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:50:04 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Trying to load                                                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.utils.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#255\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">255</span></a>\n",
       "<span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span>         ANONYMIZED/cycle-consistent-model-merging/EMNIST_CNN_2:latest         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">                    </span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:50:04\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Trying to load                                                    \u001b]8;id=682161;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\u001b\\\u001b[2mccmm.utils.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=77612;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#255\u001b\\\u001b[2m255\u001b[0m\u001b]8;;\u001b\\\n",
       "\u001b[2;36m                    \u001b[0m         ANONYMIZED/cycle-consistent-model-merging/EMNIST_CNN_2:latest         \u001b[2m                    \u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m:   1 of 1 files downloaded.  \n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:50:06 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Using <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span> models with architecture CNN                                       <a href=\"file:///tmp/ipykernel_2371794/4100191972.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">__main__</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///tmp/ipykernel_2371794/4100191972.py#20\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">20</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:50:06\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Using \u001b[1;36m2\u001b[0m models with architecture CNN                                       \u001b]8;id=679197;file:///tmp/ipykernel_2371794/4100191972.py\u001b\\\u001b[2m__main__\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=551854;file:///tmp/ipykernel_2371794/4100191972.py#20\u001b\\\u001b[2m20\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from ccmm.utils.utils import load_model_from_artifact\n",
    "\n",
    "run = wandb.init(project=core_cfg.core.project_name, entity=core_cfg.core.entity, job_type=\"matching\")\n",
    "\n",
    "# {a: 1, b: 2, c: 3, ..}\n",
    "symbols_to_seed: Dict[int, str] = {map_model_seed_to_symbol(seed): seed for seed in cfg.model_seeds}\n",
    "\n",
    "artifact_path = (\n",
    "    lambda seed: f\"{core_cfg.core.entity}/{core_cfg.core.project_name}/{core_cfg.dataset.name}_{core_cfg.model.model_identifier}_{seed}:latest\"\n",
    ")\n",
    "\n",
    "# {a: model_a, b: model_b, c: model_c, ..}\n",
    "models: Dict[str, LightningModule] = {\n",
    "    map_model_seed_to_symbol(seed): load_model_from_artifact(run, artifact_path(seed)) for seed in cfg.model_seeds\n",
    "}\n",
    "model_orig_weights = {symbol: copy.deepcopy(model.model.state_dict()) for symbol, model in models.items()}\n",
    "\n",
    "num_models = len(models)\n",
    "\n",
    "pylogger.info(f\"Using {num_models} models with architecture {core_cfg.model.model_identifier}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load permutation specification"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def conv_axes(name, p_rows, p_cols, bias=False):\n",
    "    axes = {\n",
    "        f\"{name}.weight\": (\n",
    "            p_rows,\n",
    "            p_cols,\n",
    "            None,\n",
    "            None,\n",
    "        )\n",
    "    }\n",
    "    if bias:\n",
    "        axes[f\"{name}.bias\"] = (p_rows,)\n",
    "\n",
    "    return axes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ccmm.matching.permutation_spec import PermutationSpec, PermutationSpecBuilder, conv_axes, dense_layer_axes\n",
    "\n",
    "\n",
    "class CNNPermutationSpecBuilder(PermutationSpecBuilder):\n",
    "\n",
    "    def __init__(self) -> None:\n",
    "        super().__init__()\n",
    "\n",
    "    def create_permutation_spec(self) -> PermutationSpec:\n",
    "        axes_to_perm = {\n",
    "            **conv_axes(\"conv1\", p_rows=\"P_conv1\", p_cols=None, bias=True),\n",
    "            **conv_axes(\"conv2\", p_rows=\"P_conv2\", p_cols=\"P_conv1\", bias=True),\n",
    "            'shortcut.identity': (None, 'P_conv2'),\n",
    "            **dense_layer_axes(\"fc1\", p_rows=\"P_fc1\", p_cols=None),\n",
    "            **dense_layer_axes(\"fc2\", p_rows=None, p_cols=\"P_fc1\"),\n",
    "        }\n",
    "\n",
    "        return self.permutation_spec_from_axes_to_perm(axes_to_perm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "permutation_spec_builder = CNNPermutationSpecBuilder()\n",
    "permutation_spec = permutation_spec_builder.create_permutation_spec()\n",
    "\n",
    "ref_model = list(models.values())[0]\n",
    "assert set(permutation_spec.layer_and_axes_to_perm.keys()) == set(ref_model.model.state_dict().keys())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Git Re-Basin"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# always permute the model having larger character order, i.e. c -> b, b -> a and so on ...\n",
    "from ccmm.matching.matcher import GitRebasinMatcher\n",
    "from ccmm.matching.utils import get_inverse_permutations\n",
    "\n",
    "symbols = set(symbols_to_seed.keys())\n",
    "sorted_symbols = sorted(symbols, reverse=False)\n",
    "fixed_symbol, permutee_symbol = \"a\", \"b\"\n",
    "fixed_model, permutee_model = models[fixed_symbol].cpu(), models[permutee_symbol].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   3%|▎         | 3/100 [00:00<00:25,  3.79it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Function __call__ Took 0.7953 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# dicts for permutations and permuted params, D[a][b] refers to the permutation/params to map b -> a\n",
    "gitrebasin_permutations = {symb: {other_symb: None for other_symb in symbols.difference(symb)} for symb in symbols}\n",
    "\n",
    "matcher = GitRebasinMatcher(name=\"git_rebasin\", permutation_spec=permutation_spec)\n",
    "gitrebasin_permutations[fixed_symbol][permutee_symbol], perm_history = matcher(\n",
    "    fixed=fixed_model.model, permutee=permutee_model.model\n",
    ")\n",
    "\n",
    "gitrebasin_permutations[permutee_symbol][fixed_symbol] = get_inverse_permutations(\n",
    "    gitrebasin_permutations[fixed_symbol][permutee_symbol]\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:50:07 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Permuting model b into a.                                                   <a href=\"file:///tmp/ipykernel_2371794/3759520715.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">__main__</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///tmp/ipykernel_2371794/3759520715.py#7\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">7</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:50:07\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Permuting model b into a.                                                   \u001b]8;id=556350;file:///tmp/ipykernel_2371794/3759520715.py\u001b\\\u001b[2m__main__\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=630242;file:///tmp/ipykernel_2371794/3759520715.py#7\u001b\\\u001b[2m7\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/connectors/accelerator_connector.py:447: LightningDeprecationWarning: Setting `Trainer(gpus=1)` is deprecated in v1.7 and will be removed in v2.0. Please use `Trainer(accelerator='gpu', devices=1)` instead.\n",
      "  rank_zero_deprecation(\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> GPU available: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span> <span style=\"font-weight: bold\">(</span>cuda<span style=\"font-weight: bold\">)</span>, used: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>      <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1751\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1751</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m GPU available: \u001b[3;92mTrue\u001b[0m \u001b[1m(\u001b[0mcuda\u001b[1m)\u001b[0m, used: \u001b[3;92mTrue\u001b[0m      \u001b]8;id=695568;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=388715;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1751\u001b\\\u001b[2m1751\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> TPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> TPU cores    <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1754\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1754</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m TPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m TPU cores    \u001b]8;id=648379;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=721919;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1754\u001b\\\u001b[2m1754\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> IPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> IPUs         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1757\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1757</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m IPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m IPUs         \u001b]8;id=643718;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=66844;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1757\u001b\\\u001b[2m1757\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> HPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> HPUs         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1760\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1760</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m HPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m HPUs         \u001b]8;id=296678;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=508184;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1760\u001b\\\u001b[2m1760\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/2 [00:00<?, ?it/s]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Evaluating interpolated model with lambda: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.5</span>                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.utils.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">167</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Evaluating interpolated model with lambda: \u001b[1;36m0.5\u001b[0m                    \u001b]8;id=454140;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\u001b\\\u001b[2mccmm.utils.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=876104;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\u001b\\\u001b[2m167\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 1/1 [00:01<00:00,  1.41s/it]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.5460000038146973     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">     2.790825366973877     </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.5460000038146973    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m    2.790825366973877    \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 5/5 [00:00<00:00, 85.00it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.5511999726295471     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    2.8371200561523438     </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.5511999726295471    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   2.8371200561523438    \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 1/2 [00:05<00:05,  5.66s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:50:13 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Evaluating interpolated model with lambda: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span>                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.utils.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">167</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:50:13\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Evaluating interpolated model with lambda: \u001b[1;36m1.0\u001b[0m                    \u001b]8;id=393881;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\u001b\\\u001b[2mccmm.utils.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=553091;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\u001b\\\u001b[2m167\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 1/1 [00:00<00:00, 23.68it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.9909999966621399     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">   0.025072705000638962    </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.9909999966621399    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m  0.025072705000638962   \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 5/5 [00:00<00:00, 77.93it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.9602000117301941     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.22009170055389404    </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.9602000117301941    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.22009170055389404   \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2/2 [00:09<00:00,  4.89s/it]\n"
     ]
    }
   ],
   "source": [
    "from scripts.evaluate_matched_models import evaluate_pair_of_models\n",
    "\n",
    "restore_original_weights(models, model_orig_weights)\n",
    "\n",
    "updated_params = {fixed_symbol: {permutee_symbol: None}}\n",
    "\n",
    "pylogger.info(f\"Permuting model {permutee_symbol} into {fixed_symbol}.\")\n",
    "\n",
    "# perms[a, b] maps b -> a\n",
    "updated_params[fixed_symbol][permutee_symbol] = apply_permutation_to_statedict(\n",
    "    permutation_spec, gitrebasin_permutations[fixed_symbol][permutee_symbol], models[permutee_symbol].model.state_dict()\n",
    ")\n",
    "restore_original_weights(models, model_orig_weights)\n",
    "\n",
    "lambdas = [0.5, 1.0]\n",
    "\n",
    "gitrebasin_results = evaluate_pair_of_models(\n",
    "    models,\n",
    "    fixed_symbol,\n",
    "    permutee_symbol,\n",
    "    updated_params,\n",
    "    train_loader,\n",
    "    test_loader,\n",
    "    lambdas,\n",
    "    core_cfg,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.3085141777992249"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gitrebasin_results[\"test_loss_barrier\"]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Frank-Wolfe"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "restore_original_weights(models, model_orig_weights)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ccmm.matching.frank_wolfe_matching import collect_perm_sizes, frank_wolfe_weight_matching_trial\n",
    "from ccmm.matching.matcher import FrankWolfeMatcher\n",
    "\n",
    "params_a = fixed_model.model.state_dict()\n",
    "params_b = permutee_model.model.state_dict()\n",
    "perm_sizes = collect_perm_sizes(permutation_spec, params_a)\n",
    "\n",
    "initialization_method = \"identity\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   0%|          | 0/200 [00:00<?, ?it/s]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:50:44 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:50:44\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m0\u001b[0m                                     \u001b]8;id=34891;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=739053;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:02 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.9999940391390134</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:02\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.9999940391390134\u001b[0m                   \u001b]8;id=594330;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=631409;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1457.060537</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1457.060537\u001b[0m                          \u001b]8;id=894051;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=433994;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   0%|          | 1/200 [00:17<59:16, 17.87s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m1\u001b[0m                                     \u001b]8;id=468854;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=342732;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:19 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.9999911898889463</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:19\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.9999911898889463\u001b[0m                   \u001b]8;id=481603;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=580561;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:20 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1462.263511</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:20\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1462.263511\u001b[0m                          \u001b]8;id=330865;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=377127;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   1%|          | 2/200 [00:35<58:55, 17.86s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m2\u001b[0m                                     \u001b]8;id=910306;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=686864;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:31 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.37500657928966796</span>                  <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:31\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.37500657928966796\u001b[0m                  \u001b]8;id=192700;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=941767;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:32 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1462.690717</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:32\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1462.690717\u001b[0m                          \u001b]8;id=300116;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=70434;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   2%|▏         | 3/200 [00:47<49:23, 15.04s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m3\u001b[0m                                     \u001b]8;id=254310;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=606959;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:49 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.9999937032899088</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:49\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.9999937032899088\u001b[0m                   \u001b]8;id=874871;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=168233;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:51:50 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1463.965094</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:51:50\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1463.965094\u001b[0m                          \u001b]8;id=249044;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=349189;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   2%|▏         | 4/200 [01:05<52:46, 16.15s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m4\u001b[0m                                     \u001b]8;id=623555;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=377560;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:52:05 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.26189883344769677</span>                  <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:52:05\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.26189883344769677\u001b[0m                  \u001b]8;id=914094;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=144772;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.013983</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.013983\u001b[0m                          \u001b]8;id=181129;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=943707;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   2%|▎         | 5/200 [01:21<52:06, 16.03s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m5\u001b[0m                                     \u001b]8;id=433382;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=44526;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:52:23 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.9998995930256014</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:52:23\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.9998995930256014\u001b[0m                   \u001b]8;id=14430;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=617693;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.206624</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.206624\u001b[0m                          \u001b]8;id=922037;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=729913;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   3%|▎         | 6/200 [01:38<53:48, 16.64s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m6\u001b[0m                                     \u001b]8;id=906475;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=871223;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:52:36 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.2605590452383321</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:52:36\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.2605590452383321\u001b[0m                   \u001b]8;id=406136;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=946905;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:52:37 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.221874</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:52:37\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.221874\u001b[0m                          \u001b]8;id=925328;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=116437;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   4%|▎         | 7/200 [01:52<50:32, 15.71s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m7\u001b[0m                                     \u001b]8;id=748973;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=872299;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:52:54 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.9999764286583908</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:52:54\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.9999764286583908\u001b[0m                   \u001b]8;id=528071;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=345316;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:52:55 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.303944</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:52:55\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.303944\u001b[0m                          \u001b]8;id=108575;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=896729;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   4%|▍         | 8/200 [02:10<52:28, 16.40s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m8\u001b[0m                                     \u001b]8;id=136659;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=888473;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:53:13 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.48027103616674166</span>                  <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:53:13\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.48027103616674166\u001b[0m                  \u001b]8;id=581322;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=101438;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:53:14 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.30394</span>                           <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:53:14\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.30394\u001b[0m                           \u001b]8;id=194571;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=232950;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   4%|▍         | 9/200 [02:29<55:01, 17.29s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9</span>                                     <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m9\u001b[0m                                     \u001b]8;id=525856;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=540961;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:53:30 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.6711608308937381</span>                   <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:53:30\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.6711608308937381\u001b[0m                   \u001b]8;id=317490;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=368317;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:53:31 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.303936</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:53:31\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.303936\u001b[0m                          \u001b]8;id=152058;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=408780;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   5%|▌         | 10/200 [02:46<54:01, 17.06s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10</span>                                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m10\u001b[0m                                    \u001b]8;id=596502;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=999640;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:53:47 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.07701879464562578</span>                  <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:53:47\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.07701879464562578\u001b[0m                  \u001b]8;id=997389;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=713589;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:53:48 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.303936</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:53:48\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.303936\u001b[0m                          \u001b]8;id=471270;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=498584;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   6%|▌         | 11/200 [03:03<53:51, 17.10s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">11</span>                                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m11\u001b[0m                                    \u001b]8;id=408842;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=345948;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:54:04 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.24379855535816686</span>                  <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:54:04\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.24379855535816686\u001b[0m                  \u001b]8;id=377596;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=834082;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.303936</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.303936\u001b[0m                          \u001b]8;id=809542;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=390032;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   6%|▌         | 12/200 [03:20<53:01, 16.92s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Iteration <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">12</span>                                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">131</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Iteration \u001b[1;36m12\u001b[0m                                    \u001b]8;id=477238;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=471191;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#131\u001b\\\u001b[2m131\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:54:20 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Step size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.16064341616915345</span>                  <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">256</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:54:20\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Step size: \u001b[1;36m0.16064341616915345\u001b[0m                  \u001b]8;id=51191;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=217385;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#256\u001b\\\u001b[2m256\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Objective: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1464.303936</span>                          <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.matching.frank_wolfe_matching</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">145</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Objective: \u001b[1;36m1464.303936\u001b[0m                          \u001b]8;id=272942;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py\u001b\\\u001b[2mccmm.matching.frank_wolfe_matching\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=646065;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/matching/frank_wolfe_matching.py#145\u001b\\\u001b[2m145\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Weight matching:   6%|▌         | 12/200 [03:35<56:22, 17.99s/it]\n"
     ]
    }
   ],
   "source": [
    "perm_matrices, perm_matrices_history, new_obj, all_step_sizes = frank_wolfe_weight_matching_trial(\n",
    "    params_a,\n",
    "    params_b,\n",
    "    perm_sizes,\n",
    "    initialization_method,\n",
    "    permutation_spec,\n",
    "    200,\n",
    "    device=\"cuda\",\n",
    "    return_step_sizes=True,\n",
    "    global_step_size=True,\n",
    ")\n",
    "\n",
    "restore_original_weights(models, model_orig_weights)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk0AAAHgCAYAAAC4kFn1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB4AklEQVR4nO39a3Rb6Xkn+P5xI3EjCZISKepGEShVuZI4SUFSEufEWYkLijs9Gac7RUoeu53YsUW6MnM+nRRpZT6cddZZbZlMZebTJCarch8nLpFV6STdTlxkVdKrM9PplMiKnU7kcokgdaVEiQB4A0jisucDhY13AyC4AWxg7w38f2t5mXvj9nIXxf3wfZ/3eSySJEkgIiIiopKseg+AiIiIyAwYNBERERGpwKCJiIiISAUGTUREREQqMGgiIiIiUoFBExEREZEKDJqIiIiIVGDQRERERKQCgyYiIiIiFex6D4CIaGpqCrOzs+jq6gIA+Hw+jIyMwO/3Y2JiAqOjozqPkIgIsLCNChHpaWhoCBcuXCgIjEZGRnDu3DmMj49jcXGx4HULCwsIBoP1GqamAoEAQqEQJicn9R4KEZWBy3NEpJuZmRnEYrGiM0mTk5OYnp4+8LVmDzh8Pp/eQyCiMnF5joh088Ybb2BoaOjAxycnJ3Hx4sWij4XD4VoNq+aKzZwRkfFxpomIdLOwsIBYLHbg436/H36/v+D8zMxMDUdFRFQcgyYi0k0wGDx0mW1kZERxHA6HceXKlVoOi4ioKCaCE5FuFhYWcO7cOQSDQUxPTxedVRJld9ktLCwgEokgFArJj42Pjxe8fmJiQs4dWlxcRCAQwPDwMID94GtoaAjhcBjnz5/H9PQ0pqamAABra2uIxWIYGxs7dEyicDiMmZkZ+P1+RCIRxGIx+P1+vPfeexgfHwcAXLx4EeFwGD6fD/Pz8/JrLRYL/H4/BgcHEQgE5POTk5MIh8OIRqOqvzciqhGJiEhH4+PjEgAJgOT3+6Xh4WFpenq65GuGh4elUChU8jnBYLDgfQYHB6XR0VHFuVAoJAWDQWlyclJxfn5+XvL5fIeOJSsajUqDg4MF5ycnJwvODw8PS8FgUHHO7/cXvHZ+fl4CUDAGtd8bEWmLy3NEpKvR0VEsLi7KO+impqYwNDQEi8WCsbGxit5zYmICADA4OKg4Pz4+jomJCUUSeTAYRDgcLpilCQaDuHr1Kq5cuVIy7yprbm5OrjMlGh4eLjgvziQBQCwWK1iGBPbLMQwPDyu+j3K+NyLSFoMmItKd3++X6zFFo1FMT08jFAphYmKiaDBxmLGxMVy+fLno5/h8PszNzRWcL2Z4eBixWExetjvse7h+/ToWFhYKHiu1QxAAIpFIQc2psbExRCKRgpyvcr83ItIOSw4QkaH4fD4MDg5icHAQY2NjmJiYKCu3KDvTsri4eOAuO7Vb/n0+H3w+H957771DnxsMBhEKhXDu3Dn4/X6EQiFcvHgRg4ODityrYvJ3Cc7NzWFiYkKR8wRo+70RUfkYNBGRbmZmZgqWmUTj4+OYmprC3Nyc6iTnbGAxNDRUNFgp9XnF+P1+1Ute09PTmJubk/9/amoKfr8f09PTZVUvHxoawujoaMFrtP7eiKg8XJ4jIt288cYbhz7n/PnzqnKKsjMv2RkbNa9RIxwOq5rlygY02fYo2aXGYDCIF198UfXnDQ0NoaurS95tl31vcRxafW9EVB4GTUSkm8OKWwLF832y50XZoCWb21NqSU1t0BGLxRCLxXDhwoVDnzs3N1eQT+Tz+TA9PY2uri5Vs1UzMzOYmZkpaB+TzZPS8nsjovIxaCIiXZVKkg6Hw4jFYgVLUYFAoGRwkF3WK2ZhYQE3btxQnDvova5duwafz1e0N14xB/XKU7M0F4vFcOXKFYyPjxc8/7333pN34JX7vRGRdhg0EZGuhoaGMDIyUjATky0+WaxieCgUkgMqYD9YEAON4eFhhEKhgp13sVgMc3NzRfOB8hOrFxYWMDU1hXfeeUf191Js91x2jPlLfPmB2tDQEPx+f0GAlt29ly1kWcn3RkTaYEVwItLN2NgYxsfHEYvFcO3aNcRiMcWyW7Eq31kzMzOYnZ3FuXPnAKBoovjU1BTm5+cRCATkKt35zxsbG8Pc3BzeeecdXL9+XV5KW1xcxPj4uBysHCZbCTwb/GW/j1gsJgdC2dmkubk5eQZtfHxcDhCHh4fl7ycWi2FxcRHXr18HgIKK4Gq+NyLSFoMmImpq2aApf3s/EVE+Ls8RERERqcCgiYiIiEgFBk1E1NS4RZ+I1GLQRERNKZt8nd3xNjQ0xL5tRFQSE8GJiIiIVOBMExEREZEKbNiroTNnzmB1dRVOpxMDAwN6D4eIiIhUWFpaws7ODnp6erC8vHzg87g8pyG3241EIqH3MIiIiKgCLpcL8Xj8wMc506Qhp9OJRCIBl8uF559/Xu/hEBERkQo3b95EIpGA0+ks+TwGTRoaGBhANBrF888/z+rCREREJnHu3DksLCwcmlrDRHAiIiIiFRg0EREREanAoImIiIhIBQZNRERERCowaCIiIiJSgUETERERkQoMmoiIiIhUMEWdprGxMQDA+Ph42a+dmprC/Pw8AoEAFhcXEQgEMDo6qvUQiYiIqMEZNmgaGRlBJBKB3+/HxMRERYHO2NgYYrEYJicnFeeGhoYwPT2t5XCJiIiowRk2aBIDnYmJibJfHw6HMTExgWg0qjg/Pj4Oi8WCubk5hEKhqsdJREREzaFhc5omJyfh8/ng8/kKHgsGg5xpIiIiorI0bNA0MzOD8+fPF33M7/fj+vXrdR4RERERmZlhl+eqFQ6HEQwGiz7W1dWFWCxW3wFVaO397+L+X8/pPQxVnEePoP+lT6G106f3UExJkiTc/YtvYXctiv5f+h/R4uvQe0imJEkS7n9rFnuxdZz61M/D0ebVe0imJGUyuPPn/wnJjU30/9KneB2J0MBBUynZJbtYLFZ0+U40OTmJqakpVe978+bNKkdWaC8SRfQ7/13z962VTDKJj7z8Rb2HYUpP3lvA0p++CQCQ0mk8e+VXdB6ROa3deB+Lf/xNAPs/j898/jM6j8icHv/9e1h+488AAFJGwtkvfFbnERHpryGDpsNmkbKPRyKRQ4OmlZUVLCwsaDOwJrB+8/t6D8G01m9+IH+98f1bOo7E3Na/l/sZXP/gQx1HYm7iz2D0u+b5w42olhoyaDosECpHX1/fgct8+W7evIlEIqHZZwNA+3PP4Oyvfk7T99RaKhGXZ0h2Vh8jlUjA7nLpPCrz2bp9T/46/vARpEwGFmvDph3WTPzBQ/nrxMpDSJIEi8Wi44jMSXkdHyG5tQWHl0t01NwaMmjKOmjGKRKJANjPbTrMyMgIRkZGVH3euXPnNJ+V8pw8Ac/JE5q+p9akTAZ3/uw/Ir2zCwDYvnMfHc89o/OozEWSJGzfuZs7Tqaw82QNrp6jOo7KnBIruZt9emcXe9EYWrs6dRyROYlBEwBs3lpC149+VKfREBlDw/4Z6/f75eAoXzaXScsZqWZmsVrhOXVSPhZv/qTOXjSG1Na24lwi76ZFh8ukUkisPlGcy7/50+HSe3vYXVP+/ty4FdZpNETG0bBB0+DgIMLh4v/II5EILl26VOcRNTZP/yn56+0790o8k4rZul0YaPJmX77Eo1Ugk1Ge43UsW2LlESBJinMbHy7qNBoi42iYoCl/Ke7y5cuIxWIFgVMsFsPCwgKGhobqOLrG5zmdm2na4kxT2YoFmuIyE6mTuL9ScC6+UniOSiv2s7d5awlSXiBF1GwMHzRlg6FSO+ICgQAGBgYU54LBIIaHh+Vmv1nXrl3D6OgoW6hozHtaXJ67x1+uZSoWNHGmqXzxIjd7XsfyFbtmqe3t/RkooiZm2ETwsbExhMNhObF6amoK4XAYPp8PV69eVexoCwaDRZfisjWWRkZGEAgEsLa2hu7u7oqa/1Jp4kxTOrGD3cdrcPYc0XFE5lIsD6xYAEClFbvZc8aufAcFmpu3wnAfP1bn0RAZh2GDpvHxcdXPLdVHbnh4WIvh0CHsbjdaj3Rj98kagP0lOgZN6mSSyaI3qb1IFOmdHdicTh1GZU7F8pd2Hq8hs5eEtcWhw4jMSQw0bc5WeWfsxq1F9P70T+o1LCLdGX55jszDy2TwisTvr0BKpwEAFrsdVkfu5h7nckhZis7OSRISj3gd1ZIkSRHEH/nxXA9P7qCjZsegiTTjOc2yA5UQE+c9J4/D1dcrHyceMIlZreTGpqJsg6O9Tf6aeU3qJdc3kBaK9IozS9u37yG9t6fHsIgMgUETaUacaSq2hZ6K2xYqgXtOn1TkjPBmr544y2T3uNH+bK7AKq+jeuK1crR54fvIs7C2tgDY74m4tXRbr6ER6Y5BE2lGnGlKPFxFendXx9GYh7iU6Tl9Eq4+IWhiErNq4s3e1XcMbuE6Mhlcvbgwu+k6fgwWmw1t/tzuZNZrombGoIk04zrWm8vHkSRs33ug74BMQrE8d/oU3Mf75GMWZlRPvFbu48fg4oxdRcQAMxt4tj/jl89tMq+JmhiDJtLMfjuVXJ+8bS7RHWovto7k+oZ87D19UnmzX3nEmlcqibNyrr5jimXObONeOpxixu5pAN9+Nhc0bdxaqvuYiIyCQRNpypNX5JJK276bu0aOjna0+DoUy0qZ3V3sRaJ6DM108meaxOuY2o4jubGpx7BMRzHT9DTwbBNmmnafrGE3Gqv3sIgMgUETacpzWkgGZ9B0qK28fCYAsLtdaPF1yOfj3EF3KCmd3u8795T7+DE42ttg93rkc1yiO1x+w+Ns4Nna1YnWrk75PJfoqFkxaCJNKWs13eWSyCHEnXNiKxpFMjhv9odKrD6Ra13BYoGrd79sA5PBy6NoeGy1wtl7VH6s7WxA/prJ4NSsGDSRpsTludTWNvY4jV+SWM/KIwSc7hNCMjhv9ocS61k5j3bL1b+ZDF4ecYnT1XMUVnuuaYSYDM68JmpWDJpIU442L1qEaXzWazpYJpVS7DD0Ckubbs40lSU/CTwrPxmcSlMmgSt7zInJ4JuLS5CyM1JETYRBE2nOy8rgqiRWHkFKpfYPrFbF7BJnSMqTnwQuf60IPpkbdphi5QayvAP9gHX/lpHZ3cX23ft1HRuRETBoIs0pdtDdZjL4QcSA0n28T9FzTrxh7a5F2LriEHHFzb548Lmz+gSZbJBKRcUPCD4BwNbaqshZZF4TNSMGTaQ57qBTR7w24uwcADh7jsCSzSeRJCTYuLckxbLSidzN3tXbA1gsAPZ32O2sPq772MxEscyZFzQBLHJJxKCJNOftzwUA8QcryCSTOo7GuBTtU/qVQZPFaoXrWI98zHycg6W244oCoeIsndXhgLMntwOMS50HS25uIbW5JR/nL88BQJuiyCWDJmo+DJpIc66+Y7lZkkwG8fvMJSlGrJguzs5lMRlcHTFXyeZsRUunT/E4k8HVEX/GbG4XHB3tBc8RZ5ri91eQisfrMjYio2DQRJqz2u3wnDwuH28xGbxAcmsLu0Kl7/zlOYDJ4GrlLylZni7HyecYfKqSWMkFn+6+wusI7PeXtHueFgyVJGwusvQANRcGTVQTTAYvTbwmdq9HUaYhi4UZ1VHsnBOSwOVzDD5VKZUEnmWxWtH2zIB8zCU6ajYMmqgmxKCJM02FxGviOX2q+F/1eTd7VlcvrlRtIYDBp1qHJYFnKYpcfsigiZoLgyaqCTFHh417C22X2DmXJf61n04kFMnOlFOqthCgDACSG5tIbm3XZVxmc9iMXVZb3g46BvPUTBg0UU2IgUByfQN7sXUdR2M820Ua9eZzeL1wtHnlYy4tFZIyGcQf5soxFFtWavF1wOZyysecbSokpdNIPMw1PFY705Tc2GQZB2oqDJqoJlp8HYrdN6zXlCNlMopqymLPuXzKJTruQsy382QNUjJXsNJ1rLfgORaLhTsRD7HzOK/hsVDuIp+jzau4zqzXRM2EQRPVjIftVIpKPFxFJlvh22JR7DTMx3yc0sQlpdbuLticrUWfx52IpYnXxHmkG7aWlpLPb3uG9ZqoOTFooppR9qDjTFOWeC1cx3pgay1+owcA1/Fcbglv9oUOSwLPYvBZmtok8CyxeS+TwamZMGiimhGXnRg05eTvnCuFhRlLOywJPIszTaUpk8BVBE3CTNPW8h1W/aemwaCJasYr7qC794DNUp8SK4F7S+QzAXkzJI8e8+aUR01tISD/Oj6ClMnUdFxmo3bGLsvTf0puMC2lUthavlOzsREZCYMmqhn3iT7Auv8jJqVSnCl5Ss3OuSxn71H5GkKSkHi0WvL5zUaxrFRqpklIXJaSKew8flLTcZmN2hm7LKvdDu9Av3zMvCZqFgyaqGasDgfcQk7OFiuDIxWPK27Y3kOW56x2O1y9uYazCS4tydI7O9gTWtGUmmmyOVvR2t0lH3OJLicVTyhKgpS6jiIxr2mTeU3UJBg0UU15uYNOQSw1YHM50Xq0+9DXiIFnnLN1svhKrj6TtaVFERQV42J+WFHiz5S1tbVoS59iuIOOmhGDJqopTz930InEnnOe0yeLtk/Jx4azxSWEulWuYz2wWEv/OmOtpuKUSeC9qn4mAaD9bED+emf1MfY2WLGeGh+DJqopcXcYC1wqd84dtjSXpdhBx5u9TJkEfnDbj9xzONNUjFg0VU0SeFZrdxdafB3yMZfoqBkwaKKaEpfn9iJRJDe3dByN/spJAs9SzDTxZi8rd8cXZ+yKKzcJPMtisaDtLJfoqLkwaKKaaunqhN3rkY+beYluv32KGDSVP9OU2tpGcmNT87GZkeJmryJoEp+zF40hlUjUZFxmo7ZsQzHtzGuiJsOgiWrKYrHkLdE1bzL4zuMnSCd25GPP6ROqXudob4Pd45aPOdv0tFFvmTMkrd1dsArtQRJCInmzkjKZvEa9hy9zitqfyeU1bd5aYv0rangMmqjmFDvobjdv0CTOsjl7jsLucql6ncVi4dJSnt1IDJndPfm4VI2mLIvVqmhEy+sI7K5Fcn0QsZ8IXo62wBngaeJ4OpFgU2lqeAyaqOY87EEHQJkIL+4qVIPJ4EqJldzNuaWzA3a3ugCUyeBKYuDY0tUJm9NZ1uttTic8p3IzpuxDR42OQRPVnKIH3d37TTuFr2ifojKfKYvJ4EqKJPA+9UtKnLFTqjQJXCTmNW0yr4kaHIMmqjnPyePyFH4mmUTiYXPmklSycy6LM01K5SaB556bC7A401RdEniWosjlh4tVj4nIyBg0Uc3ZWlsVuSTNuESX3tlV9I1Tu3MuSxE0PVqFlE5rNjYzUtzsy5ghEUsTxFceNu2sZ5ayd195+UxZYpHL7bv3kd7ZKfFsInNj0ER1odhB14TJ4Nv37gOSBACwtrYo+smp4ertlWfrpHQaidXmbjhbbo2mLDHAyuzuYTcS03JYppNQLHNWNtPkPtEHm+tpLpQkYTN8W4uhERkSgyaqC6+Y19SEM02KpbmTJw5t+ZHP2uKAU+hTl2jiXUrpvT3srkXk43Jmmuxul6KKtZhQ3mzSO7vK61jh8pzFakVbYEA+5hIdNTIGTVQXzb6DTmxWLAaQ5WAy+L7EyiN51s5it8PZc6Ss1zMZfJ+YW2hx2OE8Wt51FDEZnJoFgyaqC3G32M7jJ0jF4zqOpv7EJcly85myxJmApr7Zi3k4Khr15mPZgX2KJc7e3rKvo6hNyGvauLUI6WlQS9RoGDRRXbQe7c7lPaC5ZpskSVIuz5VZoynLLWytb+YddJUmgWe5GHwCUM5WVro0lyXONO1F17G7Fq3q/YiMikET1cV+O5VcsLDVREHT7loUqe3czJrnVGVBU/7Or2ZVaRJ4lpvLcwC0SQLPauloVyyTbt5iXhM1JgZNVDfiEl0zzTSJ+Uyt3V1wCA2MyyHOBiTXNxSBWDOptiCjeB131yJIC21EmklcSIKvdqYJyK/XxLwmakwMmqhuPE3ag66aopailk4fbM5W+bgZ+3xJklT1TJPz6BFYbLbsGzZl415JkhQzTVoETWLz3g3ONFGDYtBEdSMmQG/fvdc0hQW37lSfBA48bdzb5Et0e7F1pBMJ+biSm73FZlMUW23GZPC9aAzpnV35uNrlOQBoP5ubadoK30Ymlar6PYmMhkET1Y3ndK6xZ3pnFzuPm6NAozjT5K0wCTyr2ZPBxe/Z0d4Gh9db0fs0ezK4GHDvX8fKloxF3jOnYbHbAey3S2qmJXhqHgyaqG7sLhecPblK2M3wSzWzl1TclD0V1mjK4s1em+RlMReqGWeatEwCz7I6HIoaZBus10QNiEET1ZW43b4ZdtBt338APF2GtDjscB+rrL9XVrPf7LVoMJv/2qYMPjXOZ8oSl+g2WRmcGhCDJqorxQ66JkgGF79Hz8kTuQTkCilu9g8fNU1eWFZCo9pCLmGZM77ysOmKMWp1HfO1KZLBOdNEjYdBE9WVsp1K4wdNWxrtnMtyCTNVUjKFnSdrVb+nmcQ1WlYSA4V0PIHk+kZV4zIbra5jPrHIZWLlEZJbW5q9N5ERMGiiuhJ3jyUePUZ6Z0fH0dSeoudcFTvnsmzOVrR2d8nHzZQMnkkmsbP6WD6uZobE0eaFvS2XRN5MOxEzyaRiE4aWM03O3qNwCNd189aSZu9NZAQMmqiuXL1HYW1t2T+QJGzfva/vgGpIkiTl8pwGM01A8yaDJx6t5hr12myKTQWVUOSH8TpqwmKxKItccomOGgyDJqori9UKz8lc6YFG3kGXXN9AcjO3PFFpz7l8zZoMLgY2zp4jsD7d3l6pZk0G1/o65msXm/cyGZwaDIMmqjtxW3Ij76DbEmaZWnwdaGlv1+R9m/Vmr2ww21fimeqIuTzNtDyn9XXMJ840bd5aaroke2ps2v6JUSNTU1OYn59HIBDA4uIiAoEARkdHy36PxcX9v3pisRh8Ph+uXr0Kn89XgxFTKYrK4A2cDK5on1JlfSZR097sNU5eFoPPZlqeq1USeFb7MwOAxQJIElLb20isPNI0b4pIT4YPmsbGxhCLxTA5Oak4NzQ0hOnpadXvcfnyZQwPD8vnFhYW8OKLL2J+fl7zMVNp4jLV9p17kCQJFotFxxHVxlYN8pkA5c1+LxJFemcHNqdTs/c3Kq17pYm5YYnVx8ikUpovVRmR1tcxn93thvv4McTv7/dG3LwVZtBEDcPQy3PhcBgTExMYHx9XnB8fH8fMzAzm5uYOfY+FhQXEYjEEg0HF+WAwiFAohJmZGU3HTIfznMoFEKntOHbXIjqOpna03jmX1drdBWtLi3wcb5KGs1pVA5ffo7cHsD79FZjJYOfR49IvaBBaX8diFHlNbN5LDcTQQdPk5CR8Pl/RJbRgMKhqpunGjRsIh4vv4AgEAgc+RrXj8HoU2+YbschlJpWS/9IGtJ1pslitioaz4uc0quTGJlJb2/KxFjMXVrsdrp4j8nEzLHXW4joWwx101KgMHTTNzMzg/PnzRR/z+/24fv36oe/h9/sxNzeHiYmJgsemp6cRCoWqHieVTwwiGjEZPP7gIaR0GsD+tm73CW0TbhX5OE1wsxcDGrvHDUd7mybvq8gPa4K8plpdx3xiO5Xt2/eQ3turyecQ1Zuhg6ZwOHxgonZXVxdisdih7xEKhRAMBjE2NoZz587JM0vZvKj8ZTuqD2UyeOMFTeLSnPtEn+a5Mk13s89LXtYqB06ZDN74M3a1uo75PCdPyPXYpHQaW0u3a/I5RPVm2qzHbDCV3QlXyjvvvIOhoSHMzc0hEAggGAzitddeUxUwTU5OYmpqStWYbt68qep5BHj7G7udyvZtbdun5BO3ijfDTFOtkpebbSdirZPAsyw2G9r8A1i/+QGA/XpNHc+drdnnEdWLYYOmw2aRso9HIpFDgyafz4eRkREA+zlOCwsLuHLlCqanp+H3+0u+dmVlBQsLC2qHTSqJW/DjDx4is5eEtcWh44i0tXVH3DmnXRJ4lqJW08pDSJkMLFZDTxxXJS7MAmlZW0gRfDbDjF0dksCz2p/xy0HTJvOaqEEYNmjSsn7S0NAQLly4gNnZWcRiMYyNjWFqagqBQADz8/MlZ5z6+vpUL+HdvHkTiURCq2E3NPexXlgcdkjJ1H47lfsP0DbQr/ewNCMuOXo1rNGUJd7wMrt72I3E4DzSVeIV5qa42Ws4QyIGn8nNLSS3tuDweku8wtzqNdMEAG1CXtPGhwyaqDEYNmjKOmjGKRLZ36be1VX6RjE2NoYLFy7IxTB9Ph8mJycxNDQk/y9b9LKYkZEReZbqMOfOneOslEoWmw2ekyfkXIft23cbJmhKbmxiLxqTj2uxPGd3u9DS2YG96DoAILGy0rBBUyaVUpQDcGs4Q+LoaIfN5UL66R878QcP0fHsM5q9v5FI6fR+37mnah00tQs76HbXItiNRNHa1VnTzySqNUPP5/v9fjk4ypfNZTpsRmpiYkJR1DIrFArhnXfeQTgcVpVQTtpT7KBroLID4m5AR5sXLb6OmnyOqy+3tNTIyeA7q0/knYiwWBTlFqplsViapjJ4Iv869vbW9PNauzoVQRKX6KgRGDpoGhwcPLCOUiQSwaVLl1S9z0GBVTAYVBV4UW14G3QH3XZePlOtdig1S9kBcWnOefQIrA5tc9+aJRlc3B3oPNpdlxzCNkWRSwZNZH6GDpouX76MWCxWEDjFYjEsLCxgaGio4DX5s0alqn7HYrED60BR7SlrNd1tmMaeip5zNViay3I3SdmBWufhNMtMUz2TwLPEJTrmNVEjMHTQFAwGMTw8jLGxMcX5a9euYXR0tKAwZSAQwMDAgOLc5OQkxsbGCnKNwuFwWf3rSHtiD7rU5hb2Yus6jkY74s45sbSC1sSE6EYOmmp9s8/fidio6pkEniUWudwML0PKZOryuUS1YvhE8GydpJGREQQCAaytraG7u1tO7BYFg8GCWSm/34/5+Xlcu3YN165dkxPHfT4fpqenuTSno5b2drT4OuRgafvOPbR2+vQdVJWkdBrxuw/k41qUG8gSZ5p21yJI7+3BJvSkaxS1vtmLgVji4WrDlm8QA0J3n7YV6g/iHejf7++XySCzu4vtu/drspuUqF4MHzQBKJrIXcxBs0Y+n6+g6S8Zg6f/lBA03UXXj/yQziOqTuLhKjLJ5P6BxQL3yeM1+yxnzxFY7HZIqf2yDYmVRw15Q6pVuQH5Pft6AYsFkCRIqRR2Vp9ommxuFIpq4HWaabK1tsLbf0reJbvx4WJD/oxS82i8P6fIVJQ76MyfDC4uzbmPH6vpzE9+495GTAZPbceRXN+Qj7UsN5Bla2lRNJBuxCW6VDzvOtYpaAKUeU3cQUdmx6CJdKXcQWf+sgPKJPDa/0Xd6MngYiVwm7MVLTVavm30ZHDxZ6OW17EYRZFLBk1kcgyaSFfiTFP8/goyqZSOo6meWG+qljvnsho9GTx/aa4e5RsacaYpUadGvcWIM03x+ytIxeN1+2wirTFoIl25T/TBYrMBeJpEfd/cneYV7VPqEDSJM02NuDynSAKvYfKyq9Fn7BRJ4PVbmgMA17Fe2D2e/QNJwubiUl0/n0hLDJpIV1a7He4TuZuhmYtcprbj2H2yJh976pDwqpxpWmmYWldZ9UpeVhYKNXfgXoweSeBZFqsVbc/kSsFwiY7MjEET6S6/yKVZie1TbG6XIrm4VsSbfTqx0zC1rrISdZohEVvS7EXXkYo3VuNtxXWsc9AEsMglNQ4GTaQ7T4O0UxET2b01bJ8icni9cLR55eNGSmKWMhnEHz6Sj2t5s2/t8sHamtvp2EhLnVImg8RK7jrWqxq4qC1vB12jzYhS82DQRLoT67aYeQddvdqn5HM1aBLzzpM1SMncxgDXsdo1mLVYrcqdiA10HXefRHK1w1D/nCZAOdOU3NjEzurjuo+BSAsMmkh3YoCxF13H3sZGiWcbl7g8V88Cfo1adkCcNWs90g2bs7Wmn9eoyeBiANja1Vnz61iMo82rCHpZr4nMikET6a7F16FYYtq+c1/H0VRGymR0nGnK5eM00rKSWKOpHrMjjVqrSbyO9U4CF7Uxr4kaAIMm0p3FYsnLazLfEt3O6mNkdnf3DywWeE6dqNtnuxu0VlO9d3y5GnR5Tu8k8Kx2FrmkBsCgiQxB2U7FfEGTuDTn6j0Km9NZt88Wb4Q7q48V+StmVq+dc/JnKMoOPIKUydT8M+shnlfYUi9iXtPW8p2G+Tml5sKgiQzB258Lmsy4g25bUQm8vg1JnT1H5QKhkCQkHq3W9fNrpf4zTbmcm8zeHnYj0Zp/Zj0oCoQer12B0MN4+k/B6nAAAKRUClvLd3QbC1GlGDSRISiW5+7dh5RO6zia8umVzwTsFwh19hyRjxshHyeVSGAvGpOP67GsZHe5FD3ZGmGpM72zqwj+9Ng5l2W12+Ed6JePuURHZsSgiQzBffI48LSukZRMKerzmMFWndun5BNnEBohH0esK2RtaUFrV2ddPrfRksHFnwWrw4HWI7UvuFqKmNe0yWRwMiEGTWQItpYWxQ1r+7Z5lujSOzvYEZbE6r08BzTednllHk4vLNb6/KpqtGRwMS+sntfxIIoddJxpIhNi0ESGYdYddNt3cyUSbM5WxVJZvTTaDEm9k8Dlz2qw62iUJPCs9rMB+eud1cemrclGzYtBExmGsgedeWaaxN1+nlMndflrvtFmSPRqMNto11GZBK5/0NTa3YUWX4d8zCU6MhsGTWQYYi6QmXbQibNinjpWAheJN8TU1jaSG5u6jEMretUWEj9r98ka0tnaWyYV12nG7iAWiwVtrNdEJsagiQxDDDh2n6whubWt42jU27qt3865LEd7G+wet3xs5lkSKZPR7WbvPHoEFoddPk6YbEOCSJIkZU6TAWaaAGW9JgZNZDYMmsgwWru7YHO75OPtu8afbZIkSTErpsfOOWD/L/hGSQbfjcSQ2d2Tj+uZi2OxWuHqzdVrMvN13IvGkN7JzZQZYXkOUCaDb95aapgiotQcGDSRYVgsFnjFZHAT7KDbfbKGdCIhH+s10wQ0ThJzYiXXK62lswN2IZCuh0a5jmLA5+hoh93tLvHs+mnzn5HLi6QTCUVvPCKjY9BEhuJR5DUZfwedmLDeeqRb1xuTcqbJvDci5Y6v+lewbpRkcKMlgWfZXS5Fb0Y27yUzYdBEhuIV8prMsINODOy8OiWBZyka95r5Zq9zg9mGmWkSZuyMkAQualcs0TFoIvNg0ESGophpunvP8PkO2wZIAs9SNO599BiZVErH0VROnGnS42afH3xKklT3MWhBr7INaiiKXH64qONIiMrDoIkMxXPqhJzvkNndw87qY51HVJoiCVznmSZXb2+uFU06jZ3VJ7qOp1J63+zF5bl0Ygd7sfW6j0ELehUIVUMscrl99z7SOzs6joZIPQZNZCg2pxOu3qPysZGX6NJ7e4plML1nmqwtDjiPdsvHZlyiS+/uYvfJmnysx/Kcw+uBo71NPjbjEl1mL4mdx7nr6Dpe/9ywUtwn+mBzOfcPJAmbi8u6jodILQZNZDiKdiq3jZsMHr97H3i6dGN1OOA61nvIK2pPnCUx481erItkcdjhPFr/ljSA+ZPBE48eyT+bFpsNLh1a+5RisVrRFhiQj1mvicyCQRMZjrKdinGDJnEWzHPqhO7NUAHALcwomPFmr1ia69Wvwawir8mEwafyOvbAYrPpOJrilEUumddE5qD/b3miPIp2Kgau1aRon6Lz0lyW2Xd+GWWbvOI6mj34NFgSeFabkNe0eSts2oR7ai4MmshwxOW5ndXHSAnFI41ETAIXx6wnl8nLDohjrmcl8Hxmr65u5CTwLHGmaS+6jt21qI6jIVKHQRMZjrPnCGzOVvl4++59HUdTnCRJyuW5foPMNAk3yOT6BlLbcR1HUz4jzjTtrD5GJpnUbSyVUBYI1T/XrpiWjnY4hVyrTS7RkQkwaCLDsVit8JwSK4Mbb4luLxpDanNLPvYaZKappdOnCDjNVBlckiRlo14dgyZnz9FcHpAkIfFoVbexlCu/Ua+RqoHnU9ZrYjI4GR+DJjIkj1DzyIjtVMRArqWrE442r46jybFYLKZdotuLrSOdyNXr0XN5zmq3K2ZBzJQfltzYVMwwGjWnCQDan8nlNTEZnMyAQRMZkmIHnQGTwcWlOa9BksCz3EK/NjPd7MWxOtrb4PB6dByNeXciiktzdo8Hjra2Es/WV/vZ3EzTVvi2aavYU/Ng0ESGpNhBd+ee4XbWiPWjjLJzLstl0u3yRkkCLzYGM11HcWnOdfwYLE+rxBuRt/+0vAyaSSYNuRRPJGLQRIYkBiLpRAK7QnVjI1CWGzBGPlOWmAxupu3ycYMkgRcbg5lm7PTu3VcOa4sD3jOn5eNGLHK5uxbB/NX/H/7b/3sUm+FlvYdDVWLQRIZkd7vReiTXEsRIRS4zyaTixuQ1yM65LEVhxoePDN/0OMtoyctmrQputOt4GHGJbrMBm/d++Hv/J7aWbmPn8RPc/Yu/0ns4VCUGTWRYXkUyuHGm7eMPViCl0wCetqgw2F/zYjsXKZnCzhNjzdIdRLlNXv9rKgYcqa1tJDc2dRyNeuKOSSMngWe1KZLBG2umKfKP/4S1+X+UjznTZH4MmsiwPIq8JuPMNIlVyt0nj8Nqt+s4mkI2Zytau7vk4/h945cdyCST2Fl9LB8bYYbE0d4Gu8ctH5thtimTSmFn9Yl8bPTlOUBZ5DKx8gjJra0SzzaPTCqFW3/4J4pzO6uPkYqbq3YaKTFoIsMSZ5q2DDTTpNg512+sfKYsl8nagCQerSoazDp7juo8oqflG0yWDL6z+lieBYXFAtexHn0HpIKz96iiZMfmrSUdR6Ode9+aRWLlUcH5LQM3IafDMWgiwxJnmhIrj5De3dVxNDlG7DmXz22ym72YaO3sOWKY2TuzJYOL/62dR4/A6nDoOBp1LBZLXpFL8+c17UaiuPPWXxR9bGv5Tp1HQ1pi0ESG5TrWm/ulL0mI33ug74CeMmLPuXxmazirrATeV+KZ9WW2ZHCzJYFntZ9trLym8J9MI72z/0eevc2L3o9/TH6MQZO5MWgiw9pvp3JCPjbCtPbe+gb2YuvysdEKW2aZbVkpfl9ZW8gozDzTZIRkerXEmabNW0uGq8tWjvXvfR+rf/f38vHA5V+C74d+QD7eNsDvMaqcZkHT8vIyXn/9dVy9elU+t76+jnfffVerj6Am5DltrB504tKco6MdLb4OHUdzMPFmvxeNIZVI6Diawylmmgx0s1cETY9Wc/lCBmW0WldqtT8zADwtwpna3i6aC2QGUiaDW3+QS/72DvSj7xM/De8ZYSfw3fusfG5imgRNX/nKV+D3+zE6OoqpqSn5fEdHBzo7O/Hqq69q8THUhMTlLyMkg28pluaMOcsEAK3dXbC2tMjHRr4JSZKkmMUx0s3e1dsr38yldBoJYWeaEeVXAzcLu9ut+O++adIlupW5/6xYfnvm85+FxWqF+8RxWJ7m6UnptGFSDah8VQdNr732GsLhMBYXFxGJRBRBEwC88MILuHLlCl5//fVqP4qakKdfWXZA72l7sdyAUZfmgP2lTXHnlJGX6JKbm0htb8vHRrrZW1sccApFVhMPjFu+IZlXS8pIM3ZqKPOazJcMntzcwtL1t+Tj3o9/DB3PPQNgvwG05+Rx+bGt5dt1Hx9po+qgaXFxEdevX8fAwAAAFO1zlJ1xIiqXV5hpSm1tYy8a028wMHb7lHxiQrWRk8ETBm8wq+jlZ+TrKIzN5mxFS6dPv8FUQLGDzoQzTUtvvIXU1n7wb3M5MfCZIcXjYruYrWXmNZlV1UFTIBBQHB80E7C01Bi1N6i+HG1etHTlAm49k8GldBrbwrS6UWs0ZZmlca8iedmADWYVvfx4HWtGbKeyffse0nt7Oo6mPJtLt7Hyzn+Wj/t/6VNozQtalUETd9CZVdVBk9p/mIuL5ptuJWPwGiQZPL7yEFI2gdNqhfuEcbbGF2OWsgNGTQLPMstMk7JRr7F/NovxnDwBa+t+Hp6UTmNryRxLWJIk4dYffEMuzuo6fgwnfj5U8DxF0HT7jml6QpJS1UFTNBrFW2/l1nGLBVEvv/wyzp07V+1HUZMyyg468bPdx/sMXzjQnVdjyKi/pI2aBJ5llkKhZk0Cz7LYbGjzn5GPzVLkcvXv/h4bH9ySj5/5lc8ULc4qLuenEzuKdjdkHlWX3X3llVdw/vx5XLt2DZcvX8bi4iJ8Ph9isRjee+89TE1NIRQK4Utf+pIW46UmJP6y0bMHnbg0aOQk8CyxTk9mdw+7kRicR7pKvEIfcYPf7MVALrm+gVQ8DrvbXeIV+lDONBnvOqrR/kwA6ze/D8AcO+hSiQTCf3JdPu6+8AK6fuSHij7X7nbBdawHiYerAPZnm8zQ5oaUNOlVcOPGDUxMTGB0dBQAMDU1BUmS4PP5MD4+jitXrmjxMdSkvMIOuviDh8gkk7rM8igqgfcbP2iyu11o6ezAXnS/GGdiZcVwQVMmlcLOI6FRrwFv9i1dnbC2tiLztI1P/MFDRZNZI5AyGSQe5cpKGHHGTo22s2I7FeMHTbff+kv535fV4UDgc58u+XxP/+lc0LR8B0d//HzNx0ja0qy45ejoKDKZDBYXF/H222/LJQgYMFG1XH3HYLHZADytcXJfn23fYiVfo++cy3IJuS1GXFraWX1i+AazFosF7r5e+diIyeA7j59ASuYKJrqO9ZZ4tnGJwejuWgS7kaiOoykt/mAF9781Kx+f+tTPw3VIo2kmg5uf5m1UBgYG8OKLL8JisWB5eRkbGxtafwQ1GavdDrdY40SHJbrk1pbiF7gZlucA4yeDi0tzRm4wa/RkcDEgbu3ugs3ZquNoKtfa1YlWYbesUZfoJEnCrT/8Uzngbz3SjVOf+vlDX8egyfyqDpq6u7vxZ3/2ZwXnJUnC/Pw8vvrVr6KrqwtHjhyp9qOoiYnb+8UCk/Wyfee+/LXd41GUQTAyoycxGz0JPMvw19HgeWHlaDNB8961+X9E9Dv/XT4OfO4ybK2HB6pi0LQXjWFvnZMKZlN10HTmzBkMDg7i137t1xTnBwYG8NJLL+FrX/sawuEwMgbduUPmoPcOOkVRy/5TpqmBY/RaTYokcAPmM2UZfsauAZLAs8QlOiPmNaX39rD4R38qH/t+6Hkc+TF1u8NbfB1wdLTLx5xtMp+qE8G//OUv4/z58xgcHER3dzfeffdd/MiP/IjiOT6fD5cuXar4M6ampjA/P49AIIDFxUUEAgE56bwcMzMzeO+99xTnxsfHKx4X1Y+yB139l+fEnnNmWZoDlDfQ3SdrSO/uqvqLuF7MMtPkUlRXfwQpk4HFqnl2Q8XEQM7I11ENscjlZngZUjot5zQawb2//Gu5XIDFZsMzn/+M6j+iLBYLvGdOy7NUW7fvHrjbjoxJk+KWL7zwAhYXF/GlL30JwWAQv/Ebv1HwvPzK4WqNjY1hfn4ek5OTGB0dxeTkJNbW1jA0NHT4iwVDQ0MIh8MYHx/H+Pg4rl69irm5OYyNjVU0LqovMVBJrm9gL7Ze189XJoGbJ2hy9hyRG4UCQOKhsRr3Gr3cQJaYCJ5JJrG7FtFxNIUU1cBNPtPkHegHngakmd1dbN+7f8gr6mfn8RPc+fNvycfHP/kiPCdPlPUeYqoBe9CZj6Z/Ko2Pj+Pb3/42vv71r+PZZ5/Fd77zHfkxn89X9vuFw2FMTEwUzAaNj49jZmYGc3Nzqt4nGxjlz06Fw+GKgzmqr/xp7e279VuikzIZbN/N/eL2GLx9isjIjXuTW9tICjkdYq88o7E5nYo8NiNdx1QioejJaPaZJltrqyKwMNIS3eL/eR2Zp+1dHB3tODP4qbLfw3umX/6ay3Pmo0nDXlEoFEIkEsGP/MiPIBgM4rd+67cAqG+3IpqcnITP5ysacAWDQUxPTx/6HtnAa2RkRHHe5/MhGo1ieHi47HGRPsQZnnr2oEs8XJV/UcJiUXQrNwOj9k5TNJh1OdHi69BxNIdTXEcD5TVl6/4AgLWlBa3dxqrFVQkxr8koO+ii//QvePLfbsjH/v9psKIip94zuYAwsfII6Z1dTcZH9VF10DQzM1P0/PT0NN544w38+3//73HhwgXMz89X9N7nzxcv/uX3+3H9+vWij4mys1ShUGEvIDIXvXrQiZ/lOtZjqJwgNYy6XT4/ednoyfVugybVJx7k6pa5jvUYKteqUooilwYImjKpFG794Z/Ix21nA+j96Z+s6L1cx3phzf4OkSRdcjSpclUngi8uLuLs2bMYGRlBMBjEJz7xCfmxwcFBhEIhDA0NYWpqCr/zO79T1nuHw2EEg8Gij3V1dSEWix36HtevX5fbukxNTcnn19bWVCWBT05OKl5Xys2bN1U9jyqjbKdSv6BJ/KVmlqKWIqPONCnycEywpOTqM0HwaYLrqIY40xS/v6J765oHb7+L+L0H+wcWC85+/jMVB6cWqxXe0yfl3nrby3fR8ewzWg2VaqzqoClbSmB9fR2RSGFypM/nw+zsLN58881qP6rgfQEgFouVzJeKxWLw+/24du2aIkiamJiQd+OVsrKygoWFBS2GTFVS1Gq69wCZVKpoY0ytbZt051xW/kyTJEmGmNVR7PgyQfKyouyAkYJPk5RtKIfrWC/sHjdS23FAkrC5uITOj/6gLmPZi61jefrP5eNjP/txtAUGqnpP78BpOWhiMri5aHbH6ejoQEfHwTkJ5SZcHzaLlH08EokcGDRlnxMOh3H58mXFY6OjoxgbG8PY2FjJGae+vr4DZ7vy3bx5E4lEQtVzqXzuE337u2oyGUipFBIrj+A5Vd7OlUrk12gyG/Fmn07sYC+2jtZOn34Desp0M03CGHfXIkjv7Bqi8raybINxk+nLYbFa0faMX96av3ErrFvQtPTNN5F++nvd7nFj4NO/VPV7evuFyuB1zM+k6tX+z/SnxsbG8O1vf1v18yvZbVfqPYoFPsFgEFNTUyWDppGRkYIk8oOcO3eOs1I1ZHU44D7eh/jTLcjbd+7WPGhKxRNyTRYA8Jpwec7h9cLR3obkxiaA/Zus3kGTGRvMOo90w+Kwyz3eEg8fKSo860GSJMRXctfRDMGnWu1i0KTTDrqNDxfx8G//Tj4+M/Rv0NLeXuIV6og/N9t37hmuFhUdrKyg6eWXX0ZnZye++tWvyucuXLhw6OtisRjC4cp+6A+accouBXZ1Hb5TxO8v3pG8q6sLCwsLhy7xkXF4T5+Ug6atO/fQ8/+q7eeJpQZsLidaj3bX9gNrxNV3TA6a4isP4fvBj+g6HjM2mLVYrXAf65V/JuIPHuoeNO1Fosjs5nZfmWGZU622vB109V5WljIZ3PqDXPK35/RJHL/4s5q8t+fUSXnWPJNMIv7gYV1mzal6ZQVNb7/9NqxWqyJoikajCIVCJZffJEmqqPK23+8vmicF5HKZDgt2gsFgxQEbGY+n/yTwf/83APVJBlcszZ0+aYhcoEq4jx/DxgcfAjDGzi9Fg9kj3abZkejqO5YLmgyQDC5exxZfB+xul46j0ZaYDJ7c2MTO6mO4entKvEJbD//277C5uCQfP/P5z2o2G2RtccBzok/+WdpavsOgySTKCpqKJU37/X58/etfP/S1N27cOPQ5+QYHBw/cuRaJRFS1ZgmFQpiYmDjwPdQEXmQcinYqdcgFED/DjEtzWUbrnWa2JPAsoyWDN2ISeJajzQvXsV65iv3mrXDdgqbUdhxL38xtXjr6sR+D7wee0/QzvGdOK4Km3o9/TNP3p9qouqDH22+/rep5r732Wtnvffny5aJLe7FYDAsLC0VbqeQv52XzkYrlGi0sLODq1atlj4v0I+5e24tEkdzcqunnibNZZmqfkk+xXd4IN3uTJYFnKXcirpR4Zn2YpXdfpdp0at67PP0f5OVsa2sLAv+u8t6pB/EIS7usDG4eNa2Ctry8jOXlZQAoubPuIMFgEMPDwwX94a5du4bR0dGCgpWBQAADA8qtoH6/H+Pj47hy5YrifLauVCWNf0k/LV2dsHs88nEtl+j226eIQVNjzDTtrD5GJpnUcTQmnmnKq3klSZKOozFP775KtetQ5HL77j3cf/td+fj0v/mFmlRZF/Phtm7f0f1nidSpevfcV77yFSwtLaGrqwtDQ0P4xCc+gffffx+hUAhdXV144YUXYLFY8MYbb1T0/tnikiMjIwgEAlhbW0N3d3fRYOeg/KXR0VH4/X4MDQ2hq6sLkUgEFy5cwOTkZEVjIv1YLBZ4+k9h/V++B2C/8GStkpp3nqwhndiRjz2nzZtz4Ow5CovNBimdBiQJiUerZTca1ZJZZ5rELf3pnV3sRWNoFXrS1VvigTmDT7XEvKat5TvIJJOwOhw1+zxJkvDh7/8J8LT+oLO3B6d+4ZM1+Syx7lxqaxu7axE4j5hzo0kzqTpounDhAgKBgGImZ2hoCC+++KLc5mR9fR2vvvoqfv3Xf72iz1DbH65UL7rBwUEMDg5W9PlkLN7TJ+WgqZYzTeJ7O3uOwu4yb5Kt1W6Hs+cIEk+3pycePNQtaDJzg1m7xw1HR7vcaDi+8lC3oCm9t4edJ2vysZmuo1qe/lOwOhzIJJOQUilsLd9B+9naNVl//Pfvyb9bAOCZX/50zYI0h9eL1iPd2H3633Br+Q6DJhOoenluaWlJETC9+eabWFpawuuvvy6fO6zwJVE5PHXqQbd9Wyxqad58pixxlkTPnV8Joa6QtaVF15maShilLU3i4SrwdEnHYrPBefSIbmOpFavdDu9Av3xcy7ym9M4uwn+cWxHpeuGH0X3uR2v2eUDeEh3zmkyh6qApPxianZ2F3+9HuwYFwIiKEatyb9+9D+npVLrWthTtU8ybz5SlSAa/r9/NXrE019drugazLoM07hUDNtexnoYtjijmNW3WMK/pzp//J+xGogAAi92OwC//TzX7rKz8vCYyvqp/W3V3K6cT5+bmChK0AXVFKInU8Jw8Djytl5TZ29v/i7sG8ms0mZ07rwedXsyaBJ6lmGnS8TqKu/fMlBdWLsUOulule4VWKvFwFXf/8q/l45P/w8/B3Vf7gquKoGmJQZMZVB00ibWb3n//fYTD4YJSAP/4j/9o2qKAZDy21la4juXqtYjBjVbSO7uKYMzMO+eyXAbZ+SXOzrhPmK9XmhFnmswYfKol5jDtrD7B3saG5p+x+MffhJTar1Df0tWJ/n/7C5p/RjFi0LT7ZA3Jre26fC5VruqgaXBwEJcuXcLLL7+MF198EYODg/jEJz4BAHj33Xfx5S9/GS+++OKBrUyIKlHrIpfb9+7L+SLW1ha4eo9q/hn1Js40pba3kdzc1GUc8QfCDIkJb/ZigLLz+Ilu5RviDV6jKau1uwstvlwayKbGeU1r738Xa/P/KB8HPjsEm9Op6WccpLW7S1FChUt0xld10DQwMIDXXnsNoVAI77zzjrxjbmlpCYuLizh37hy+9rWvsZUJacpb42RwRVHLkydMl3dTjKO9DXaPWz7WI4lZymQUieBmvNk7e47k8ockqWbLw6XsN+oVc8PMN2OnlsViyVui0+5ekkkmsfiHfyofdzz/LI7+5I9r9v6HsVgsyua9y7XvckDVqbrkALCfDP7SSy8pzg0MDBQUlCTSiiIZvCZBk7hzzvxLc8D+L2hX3zE5mTb+4CE6PvJsXcewG4kis7cnH7vqkDeiNavdDmfvUTnojK/Uv9lqcn0D6XhCPjZj8FmO9rN+rN14H4C2QdO9b83KbVpgseCZz3+m7qkk3jOnEPvnmwCAreXbdf1sKp/5/3ympiTuZtt5/ASpeFzT99+63Vg757L0TgZXNJjt9Jm29pXeZQfE/3b2Ni8cbd66j6GexJmmzVtLmuyY3Y1Ecfutv5SPj1/8WXj7T5d4RW14z+RKKtSjnyZVh0ETmVLr0W7YXLm8g2zjSy1IkqRcnmuAGk1Z+cng9dYovdL0TgZvliTwrDb/GXnHbDqRUOTFVSr8jWlkdncB7AeeZy79m6rfsxLeM8Ks+b0HyOzp2+KISmPQRKZksViURS5va7dEtxeJIrWd28XiOdU4QZPuM02KPBzz3uzFQEXvGTszB59q2V0uxRJotUUuYze/j9X/6+/l44HLvwSHV5/ZOvfxPlgcTzNlMpn9TShkWAyayLTEZbMtDcsOiEUtW7u74PB6SjzbXBSNex89RubpNut6aZSZJnHsepRvaJTgsxztz2hT5FLKZHDrD74hH3sH+tH3iZ+uamzVsNhs8Ap/mLEyuLExaCLTUs40aRc0KdqnNEBRS5Grt1de5pDSaeysPqnr5zfKzd6lc/mGRgk+y6HYQfdh5UUuH8z9reLf+DNf+Kzuu2PZTsU8GDSRaYm1mrbv3tOsncqWohJ44ySBA4C1xaHoUVbPpaX07q7cnBQw983e0damqK9Tz/ywTCqFxOpj+biRq4GLxCKX23fvI72zU/Z7JDc2sfzGn8nHvT/9k+h49hlNxlcND4Mm02DQRKblOZ3LcUjv7GLnsTazJmISuLeBksCz8peW6kXe2g3A4rCbusGsxWLRLRl859FjIPsHgtUKV29P6Rc0CPeJvtzmD0nC5uJy2e+xdP3P5HxFm8sJ/2eGDnlFfSh70N2tWT9Nqp5mQdPGxgZeffVVXL58GRcuXMDly5fxW7/1W1q9PVEBu8sFZ0+uUrcW9Zoye0nFDbDRlueAvMa9dZxpUjTq7TVfo958eiWDK5Y4e47Aatek3J7hWaxWtAUG5ONy6zVtLt3Gyjv/WT7uf+lTikrjevKePpnrp7m7q0vBVFJHk99ab731Fs6cOYPR0VHMzs5CkiTMzs7ilVdeQXd3N77zne9o8TFEBcRyAFsaBE3b9x/If8VbHPaG3M6t20xTg+Xh6HUdFcFnA/58ltJeYfNeSZJw6/e/IbdGch/vw4l/VdhYXi82p1NR6JVLdMZVddC0tLSEL33pS7h69Sqi0SgikQhu3LiBSCSCaDSKL33pS/jEJz6BTZ36XFFjE3fQaZEMXtA+Jdsuo4G4dCo70ChJ4Fl6XceEUKOoEYLPcrQJeU2bH4ZV71pc/S//FRvfvyUfBz7/GcPN0ImFNdmDzriqDpomJibwzjvv4JVXXkFHh3Kqs6OjA+Pj45idncXo6Gi1H0VUwKNxDzpF+5QGXJoDlMtKyfUNpLa1raZ+kIabaRIb99axfEOjBZ/lEGea9mLr2F2LHPqaVDyB8J9My8dHLgTR9cM/WJPxVYM76Myh6qCpo6MDL7zwQsnnBINB+P3+ks8hqoS4uy3xaBXpnd2q3k9c4muk9imilk4fbM5W+ViL6sqHyW8w2whBk+tYjy7lG5TBZ+M26i2mpaMdzp7cBgI19Zpuv/WX2IutAwCsDgcCn/t0zcZXDQZN5lB10HTkiLodMIFA4PAnEZXJ1XsU1taW/QNJqqqariRJDV2jKUuPnV97sXWkE7kt4o0wQ2J11L98Q3JrC8nNLfm4EYLPcpVTryl+fwX3/2pWPj71qZ9XBF1G4hUagyfXN7Abjek3GDpQ1UGT2jXltbW1gnPvvvtutR9PTc5itcJzMld6oJq8puT6BpIbudy7Ruo5l8/dl5uhqEfQJM6OODraG6bKer2TwcX/VjaXC46O9pp/ptEok8EPnmmSJAm3/vBPIKXTAIDWI9049Yv/uubjq1SLrwMtnbkUF842GVPVQdPw8DBef/31ks956623cPny5YLzk5OT1X48ETz9YjuVyvOaxA7jLb4OtLQ37g1JnGlK1GGGRFwCbKQdifUu35CfF2Z5ujzYTMQil1vh2wfmkq3deB/R7/6zfBz45U/D1tJS8/FVw3umX/6aQZMxVb194NKlS4hEIhgbGyuatxSLxQAAPp+v4LGFhYVqP55IuYOuih50ip1zDbo0l6WoMVTnGZJGqmBd95mmJk4Cz/L2n4bFZoOUTiOTTGL7zj20+c8onpPe28PiH31TPvZ99Adw5EKwziMtn7f/FCLvfxcAsM0ddIZUddD03nvv4fz587hy5UpZr4tGowiHq+tUTQQol9G279yDJEkV/QWu2DnX35hJ4FmKm/2jR5AymZoWmxRnsxpqpqnOZQcabQdiJawtDnjPnMbm4hKA/SW6/KDp7l/+tdwhwGKz4ZnPf8YUs3KcaTK+qoMmv9+Pt99+u6LXRqPRaj+eCB6hQ3hqO47dtSicR7rKfp9m2DmX5TqWK6QnJVPYefykpu04GnamqUj5BrvHXbPPU8409ZZ4ZmNrP+uXg6bNDxeBn/uE/NjO4ye4+x/+k3x84l+9CM+J43UfYyXEHXSJh6tIJRKwu1w6jojyVf2n5fT09OFPOsD4+Hi1H08Eh9eD1u5ckFTJEl0mlUL83gP5uNGX52zOVsU1q+USXSaZVPQFbKSZpnqWb5AyGUV7jWadaQKAtmdyeU35yeCLf/wGMskkgP1NB/0v/WJdx1YNZ8+RXH89aFOwl7RVddA0MLDfC2h5eRmvv/46rl69Kj+2vr5ecodc9rVE1aq2yGVi5aG8y8Zis8F9ovHr39QrGTzxcFVuX2Gx2Qy75bsSBeUbangdd1afQBKSnsXZwmYj7qBLrDxCcmu/DEP0n/4FT/5hXn7M/5kh2N3mmamxWK3KyuDLDJqMRpMkhq985Svw+/0YHR3F1NSUfL6jowOdnZ149dVXtfgYogOJRS63Kphp2rqdC7TcJ/oM12KhFuqVDC4GEs7eow13bcXyDbVMBhevY+uRbthaW0s8u7E5e4/C0eaVjzdvLSGTSuHWH3xDPtd2NoDej39Mj+FVxXtG+F22fFvHkVAxVQdNr732GsLhMBYXFxGJRBRBEwC88MILuHLlyqFlCYiq4RWTwSuY0m6Gopb53PWaaXrQmEngWfUqFNro17EcFouloMjlg2+/i/j9lewTcPYLn63p5oZaUVQG5/Kc4VT9J9/i4iKuX78uHxfboZCdcSKqFTHQiT94iMxeEtYWh+rXbyl6zjV2EniW63h9Clw2ahJ4lhjA1DL4VCSBN+B1LFf72YC8PT/y/ncRX3kkP9b3sx8v2FFnFh5heW777n1kUqmGm501s6rD8Pz2KAdVCF9aWqr2o4gO5O47Bovj6S8WScL2/QelX5BnW7FzrvlmmvaiMaQSiZp8TrxByw1kidcx/nC/fEMtxDnTpCDONG2Gl5F++vNr97hx5tO/pNewquY5dQIWmw0AIKVSudkzMoSqgya1tS8WF0v3CCKqhsVmq7idSnJjE3tCn6dGr9GU1drVCatQITkh/KWuFUmSGr62UEH5hieFLaO0kFjJ3Tw50wS0PzMgN0wWnRn6t6au5m+12+E+mSuRwHpNxlJ10BSNRvHWW2/Jx8WCqJdffhnnzp2r9qOIShKX6Mppp7J1N/dcR5sXLb6OEs9uHBarVVHrpxZLdMnNTaS2t+XjRrzZ55dvqEUyeCqewF50XT5uxOCzXHa3u+A6eE6fxPGLP6PPgDSkyGti0GQoVQdNr7zyCr761a/iwoULePXVVzE7O4t3330Xb731Fq5evYru7m5EIhF86Utf0mK8RAeqtJ3K9m2xfcopU1QO1kqt83HEAMLu8cDR1qb5ZxhBrZPBxf821pYWtHYxRxRQLtEBwDOf/6y8tGVmyrIDDJqMRJPsshs3bmBiYgKjo6MAgKmpKUiSBJ/Ph/Hx8bJbrBBVQlGr6fZd1e1UFO1TmiSfKavWN/v8JPBGDUjdfccQ+6d/AVCb4DO/ErgZd4XVQtePfhSP/vP/BQDo+ckfh+8HntN5RNrwDog76O5U3BqKtKdZSv7o6ChGR0extLSEcDgMv9/P4pVUV2IPuuTmFpLrG6qW2hRJ4P3NFTTVuuxAoyeBZ7nrGHw28nUs19EfP4/Ur34Oye1tnPwffk7v4WjGK+RVpuOJ/TZHPUd1HBFlab6PcWBggMES6aKlvR0tvg7sxfZzP7Zu30XXIUGTlE5j++59+bhZyg1k5Re41Lpxb6MngWe5xOtY42XORswLq5TFasXxn/tZvYehObvbDWfPUeysPgYAbC/fYdBkEFX/dlxeXi56/s0338Rv/uZv4tVXXy3ZSoVIS8p2KofnNSUersp9qmCxKHatNAPxZp/Z28NuRNsm2oqZpga+2SvKN0SiSO/saPr+zXIdKUdMBt9kXpNhVB00jY2NFT3/0ksv4ZVXXsGv//qvo7OzkxXBqS7EcgFia5SDiEUt3X3HYBO24DcDu9uFls7cbJyWS0uZVAo7jx7Lx408Q9La3aUo3xDXsHyDlMkoykFwea45iEETG/caR9VB00HFLEUvvPBCtR9DpEq5O+jEfKZmqc+Uz1Wj3mk7q4/lJsiwWODq7dHsvY3GYrXCdSz3/SUeaFeQcDcSRWZvTz52MWhqCmJe09YSe9AZRV2KW25sbGB+fv7Q5xFVS9FO5f4KMkJX+GIUQVOT7ZzLUiQxa5iPI85aOXuOwupQ39bGjGqVDC6+V0tnB+xul2bvTcblHeiXv96NRJHc2NRxNJRVViL4+++/j8nJSYTDYTlYunHjBj75yU8WfX4kEkEsFkM4HMb09HT1oyU6hPtEHyw2G6R0GlI6jfiDhyXboogNMZulfUo+Ra0mDW/2iSbLw6lVMrgiCVyYFaTG1tLpg6PNi+TmFoD90gOdH/1BnUdFZQVNL7zwAr7+9a8DAGZmZjA8PIzu7u4Dd8sNDAwgEAggFApxiY7qwmq3w32iT55B2r5z98BgKBWPY1doedG0y3N1mGlqhiUl9/HaLHMyCbw5WSwWeM/0I/pP/wwA2Fq+y6DJACouOTA4OIhgMIivfOUrciBFZASe0ydzQdPte8BPFX+euDRnc7sUrTCaiTjTtPtkDendXdhaW6t+33iTlBvIUgafjzQrSJhgjaam5TlzSgiauIPOCKrKafL7/bh48aJWYyHShFhraatEMrhyaa652qeInD1HYLHn/n5KPNRm51eiSQpbZonfY2Z3F3salW9QVANvguCTctoUPeiYDG4EVSeCs0UKGY1XZa0mJoHvy9/5pUUSc3JrW5G42gw3e7vbpahAr8V1TO/uKpaQmyH4pByPEDTFHzxEendXx9EQoEHQlG95eRmvv/46i1qSbsTcpL3oOvY2Noo+b0vRPqU585mytE4GF2eZbC6nqnY2jUDrZHBx1s9it8PZc6Tq9yTzcPcdy9X/kiTFH3qkD9VB02/+5m/i7Nmz8v8++clP4q233lI85+WXX0YgEMDo6CjefvttjI6O4uzZs/ibv/kbzQdOdJAWXwccbV75ePvO/YLnSJkMZ5oEWieD5/dKa5alT0UvPw2CT0Uy/bEeNuptMharVfG7aYtFLnWnOhH8lVdegc/nw/T0NCYnJwt2zH3lK1/B1NQUXnnlFXzta1+Tz4fDYVy6dAkzMzM4c+aMZgMnOojFYoHn9CnE/vkmgP0lus4fel7xnJ3VJ8hkp7otFnhOnaj3MA1F651f8SbtlaZ18MkkcPKeOY3NW2EATAY3AtV/tiwtLWF+fh5vv/120RIDExMTCIVCioAJ2E8Wv379+oHtVohqQdmDrnBKW8x1cvUehc3prMu4jCq/wKWaSv+lNFsSeJbWy5xMAievIhmcQZPeVAdNU1NTB5YWePPNNwEAIyMjRR/3+/1V/xImKoe3X5jSLpIMvqVYmmvufCZAmYuTTuxgL7Ze1fs160yTGHzuPFlDWmh/UgnONJGiB92de5AyGR1HQ6qDpmj04O2zs7OzsFgsCIVCBz6nWXIayBjEQCh+90GuB9pTzGdScng9cLS3ycfVzJJImQwSj4QGs00UNDmPHoHFZts/kCQkHq5W/F6SJHGmifZTB57ePzN7e5oWoKXyqQ6aSgU9c3Nz8Pv9aG9vP/A5nZ2d5Y2MqAruk8dzv2iSScTzag+xfUohrXZ+7Tx+AimZ6/nnOtZb1bjMxGKz5TXurfw67sXWkU7syMfNFHxSjq21Fe4TuZzDrSUu0elJddC0trZW9PzS0hLC4TAGBwcPfO3S0hJ8Pl/ZgyOqlK2lRbGcsX07N7OU3tnBzqPcDACX5/Zp1XBWfG3rkW5NqoubiTIZfKXi9xEDLkebFw6vt8SzqZEp8ppuM2jSk+qg6eLFi3j11VcLzg8NDcFisRyYzwTsJ4n/xm/8RmUjJKqQWK9JTPzevpsrQWBztrL2zVPK7fJV3OybvFeaVsngXJqjLG8/k8GNQnXQdOXKFfzDP/wDPvnJT8rFK8+ePYuFhQWMj48XLSewsbGBT37ykzh37lzJpTuiWlDUNxFymMSlOc+pk6x985RieU6jmaamDJpqMGPHJPDmpkgGX77DjVU6Kqth7/Xr1/Hmm2/ijTfewMLCAoLBIK5fv44XXnhB8TzxOQDwta99DYuLi7h27Zp2Iyc6hPeAsgOKJPAmrwQuUuz8evwEmWQSVoej7PdR7Jxrwpu9qy+Xf5It31DJRpiEYqapr8QzqdGJQVNycwt7kWjTNhjXW1lBEwC89NJLeOmll6p+TjmmpqYwPz+PQCCAxcVFuep4NYaGhjA+Pg6/36/RKMloxIBo98kaUttx2D1u7pw7gLPnKCw22/5Ow6c7vyop+pkQ8niafaYpHU8gub5RURuZZp+xoxxHmxet3V3YXYsA2F+iY9CkD8OvS4yNjWF+fh6Tk5MYHR3F5OQk1tbWMDQ0VPF7Tk1NYWZmBrFYTLuBkuG0dnfB5nbJx1t37kGSJEXdJu6cy7Hm9TarZAddKp7AXjRX40mcdWkWjjYv7EIbn0quYyaZxM7qY/mYy3PEIpfGYOigKRwOY2JiAuPj44rz4+PjmJmZwdzcXNnvGYvFMD09rdUQycAsFgu8p5XJ4LtrEaTjCfkcZ5qUqm2nIi4pWVtb0Nrl02JYplNtMnji0SqQzVuxWuHsParV0MiklDvo2INOL4YOmiYnJ+Hz+YqWKwgGgxUFP9euXSu5048aS347lW3hl03rkW7Y3W49hmVY1SaDx/PapzRrkn21yeBioOXqOQqrvexMCmowXiHdYGv5to4jaW6G/o02MzOD8+fPF30s29OuHFNTUxgZGWHNqCaS3yFcsTTHJPAC+T3oytXsSeBZ1RYKZbkByuc90y9/vbP6BKntuI6jaV6G/vMlHA4jGAwWfayrq6usnKRweL9LtN/vl79WY3JyElNTU6qee/PmTdXvS/UhBkbbd+8pkie5NFfIlbesVO7OrwSTlwHk17yqLvhkPhMBQOvRbtg9bjlY2rp9F74feE7nUTUfQwdNpWRni2KxmKqZo8nJyYLcKDVWVlbk0glkPnLfJklCZncP0e/+d/kxzjQVEm/2qe1tJDc30VJGjTXFDEkT3+zF2aHE6mNkUqmyltgYfFI+i8UCT/9prP/L9wDsJ4MzaKo/wwZNh80iZR+PRCKHBk3ZZblK9PX1HTjble/mzZtIJBKHP5HqxuZ0wtV7VG6cKvby4kxTIUd7m+Kv2cSDh6qDJimTQWKlORv15nP19gBWK5DJAJkMdh49VvQPOwyX56gYb/8pRdBE9WfYoEmrvCNxWa4SIyMjqgOuc+fOcVbKgDynTxV0m7c6HE3VSFYti8UCV98xbN7a/3cTf/AQHR95VtVrdyNRZPb25GNXX/NeX6vdDlfPEfnnLr7yUHXQlNzYRGprWz7m8hxleQfYg05vhk4EBw6ecYpE9ot8dXWVLvA1OTmJ4eFhrYdFJlJsRslz6kTT7uw6jFh2oJwkZjEPp6XTB7vLVeLZja/SnYjiNbe5XXB0sAUV7RN70MXvPUAmmdRxNM3JsDNNwP7sUDY4ypfNZSo1I5Wt5ZRfCDM7+zQ2Ngafz4fLly9jcHBQs3GTsRQrYMmluYNVmsTMPBwlV98x4P3vAlDWrzpMfhJ4JS1YqDG5T/TBYrdDSqUgpdPYvvcAbQP9h7+QNGPooGlwcPDAnWuRSASXLl069PXFgqFsjtP4+LjqfCUyL8/pwoTvYudon6vCsgNMAleqtFaTGGAx+CSR1W6H59QJbC3t12naWr7DoKnODL0+cfnyZcRisYISAbFYDAsLC0VbqbA1CuVz9hyBzdmqOOfp50zTQcQcmp1H+zu/1OBMk5KiKnilwSevI+URK4NvM6+p7gwdNAWDQQwPD2NsbExx/tq1axgdHUUoFFKcDwQCGBgYOPR9xZ131PgsVis8p5RBkpczTQdyHevZL9MAQEqnsbP6RNXrFNXAjzdfz7l8YsCT3NhEUkjuLkURfDZh7z4qTcxr2lxi0FRvhl6eA3LFJUdGRhAIBLC2tobu7m6Mjo4WPDcYDJYsXDk1NYXZ2Vm5Z93IyAiCwSCuXr3KZboG5+k/hY0PFwEALV2dcAgNVUnJ6nDAefSI3DA2/mDl0Jmj9O4udp+sycecIQFafB2wuZxymYvEykM4zgZKvkZKpxU7PXkdKZ+4g2779h1ImQw3tdSR4YMmAKp3vx3Wi254eJg76ZpUm/8MVoSvqTT38WNy0KRmaUmsz2Rx2OE80l2zsZmFxWKBu+8YNsPLAPbzmtoPCZp2Hj+BlE5n32B/1o9I4Dl9Ui7Ym97Zxc7qY5ZPqSOGp9QUen/qYzhyIQivvx9nhn5R7+EYXrnb5RU7vo718i/fp1xlJoOLz3Ee6YatpaUm4yLzsrtc+8VTn2KRy/oyxUwTUbWsLQ784P/nf9F7GKZR7s4v7pwrrtxkcCaBkxreM6eQeLg/u7u1fAdHf+KCziNqHvxzkIgKKHqnqVme4865osqdaUqwUS+p4D2TKzPAmab6YtBERAXEG7aanV/xlRX5a86Q5CgKhT56BCmTKfl8MbDidaSDeIRm42ynUl8MmoioQEunT1HbqtRskyRJnCE5gJigKyVT2HlcunyDorAlryMdQCxouRddx15sXcfRNBcGTURUwGKxqF5a2ovGkN7ZlY9ZoynH1tqKVmEnYanrmIonFDc/LnPSQVp8HYqehFu37+o4mubCoImIihILK5a62YvJy46Odtg97pqOy2zUJoOL19Ha2oqWrs6ajovMTawMvrV8W8eRNBcGTURUlNpkcC7NlaZ2xk55HXvZqJdKUgZNnGmqFwZNRFSUW2WtJiYvl6Z6pukBk+lJPc406YNBExEVpXbnF5OXS1M908TrSGUQyw4kHq4ivbOj42iaB4MmIipK7c4vzjSVJgafe9EYUolE0efFWeuKyuDqPZrb4SpJ2Lp9T98BNQkGTURUlM3ZitbuLvm42CxJJplUBFOcISnU2tUJq9AORezTlyVlMnmNerkDkUqzWK2s16QDBk1EdCCxfECxfJzEw1VAkgAAFpsNzp4jdRubWVisVrj6crN2xYLP3bUIMnt78rG7jw1Y6XDefjGviUFTPTBoIqIDHZaPI26Td/YehdXOdpbFHJYMLl7blq5O2JzOuoyLzE1MBt9m0FQXDJqI6ECH3eyVPee4pHSQw4JPJoFTJRQ76O7eQyaV0nE0zYFBExEd6NCZJtZoUsV9SM0rJoFTJTwnT8BiswHY36yhprk2VYdBExEdqGDnV1y584u1hdRR1LxaeVhQvkFc5nQx+CSVrC0OuE/kZni3lrhEV2sMmojoQIU7v3I3d0mSlMtKDJoOJAZCmd097EZiiscTnGmiCimW6LiDruYYNBHRgQp2fglBUnJjE6ntuHzM5bmD2d0utHR2yMeJldwMXXpnF7trEfnYxZ1zVAbuoKsvBk1EVNJB7VTEr+1eDxztbXUdl9m4DmiAnHiYq9tkcdjhPMqyDaRefg866WkJEKoNBk1EVJKica94s+eOr7IclAyuqKje2wuLlb+WST2xwGVqexu7T9Z0HE3j479OIipJvNnHD7rZMw/nUAfO2DEvjKrg8HoUs5Nbt+/qOJrGx6CJiEpS1mrKNe5lEnh5DirfIM7ececcVcJzRminsnRbx5E0PgZNRFSSYufX3h52I1EAynIDXJ47nHiNdtciSD9tmxIXksIZfFIlvGf65a8501RbDJqIqKT8nV/xBw+RSaWws5pr1MvlucM5e47Akm0zI0n7s3aSxHIDVDWv2LiXO+hqikETER1K3PmVePAQO6uPIaXT+ycsFrh6e3QamXlYrFa4juWuU2LlIfaiMaR3duVzXJ6jSogzTbtP1pDc2tJxNI2NQRMRHSo/GVzMyXH2HIXV4dBjWKaTnwwuJoE72tvg8Hr0GBaZXGt3J+zCz87WMpfoaoVBExEdSpEM/uAhk8ArlJ8MziRw0oLFYsmr18Rk8Fph0EREh3KVmGnizV495U7Eh2zUS5pRVgbnTFOt2PUeABEZn2Ln15M1RY8r3uzVy59pcrR55WNeR6qGd4DtVOqBM01EdCjFzi8AW+Hc9D/LDagnBkbpRALr378lH3PGjqohzjTFH6zIJS1IWwyaiOhQ+zu/ijeSdZ/oK3qeCjm8XsXsUjqekL/mTBNVw338WG5DRiaD7bv39R1Qg2LQRESqFLup21wuODradRiNeRWraWWx2eDsOarDaKhRWGw2eE6flI+3uURXEwyaiEiVYstH7uPHYLFYdBiNeRVbznT2HIHVzhRTqo5yBx2Dplpg0EREqhSbaWIeTvlcxwuXM91FzhGVS7mDjkFTLTBoIiJVigVNzMMpH4NPqhXFDro7d+Xm2qQdBk1EpMpBy3NUnmLLc7yOpAXPqZPA0+XyzO4eEg8f6TyixsOgiYhUcXg9cLS3Kc5xhqR8zt6jgFX5q5fXkbRgc7YqgnIu0WmPQRMRqaa4uVsscPUVL0NAB7Pa7XDl7ZTjTBNpxXPmlPw1gybtMWgiItXEm3trdxdsLS06jsa8xLIDdo+7YAaPqFLeM/3y1wyatMegiYhUc588nvuaRS0rJi6huPpYtoG0k192QJIkHUfTeBg0EZFqxz7+k3D29sDmduHUL3xS7+GYlu+Hnpe/7hS+JqqWV1ieS25sYi8a028wDYjV1IhINUd7G37sf/8qpHQ617KBytb1ox/FR/7nK9hbX8fx0M/oPRxqIC3t7Wjp6sReJAoA2Lp9F61dnTqPqnEwaCKislisVlisnKSuhsViQe/HP6b3MKhBeftPIZINmpZvo/uFH9Z5RI2Dv/mIiIgaiDKv6a6OI9GWEfKzGDQRERE1kEbsQSdJEv7lf/s/cOfP/xOkdFq3cTBoIiIiaiBi0LTzaBWpeELH0Wjj4d/+HZ68t4ClP30T7/9/ryG5ta3LOBg0ERERNRDn0SOwuVzy8dZtcy/R7TxZw+If/al87PB6YPe4dRkLgyYiIqIGYrFaFaUHtm+bd4lOkiR8MPn7SCd2AAA2twvPDn9et9pmDJqIiIgajLe/MfKaVmb/FrF/+hf5+JnPf0bXEgoMmoiIiBpMIySDJx6tYvEb1+Xj7nM/it6P/6SOI2LQRERE1HDEoGn77n1kUikdR1M+KZPBB1//PWR2dwEAdq8Hz175Fd1bDjFoIiIiajDuk8dhsdkAAFI6jfj9BzqPqDz3//odrN/8vnx89lc/hxZfh44j2segiYiIqMFY7XZ4Tp2Qj7eWzLNEF3/wEEvffFM+PvoT59Hzkz+m44hyGDQRERE1IEVek0l20EmZDD74nd9FZm8PAODoaMfZX/2czqPKYdBERETUgDz9ubIDZkkGv/sfv42NDxfl42e/+Dk42tt0HJESgyYiIqIG5D3TL3+9tXwXUiaj42gOt333Ppav/5l83PNTP4EjP3ZOxxEVsus9ADWmpqYwPz+PQCCAxcVFBAIBjI6OlvUeY2NjiMViCIfDiEQiuHz5ctnvQUREZBZeYaYpnUhg5/ETuHp7dBzRwTKpFL73O69DerrLr6WzA898/rM6j6qQ4YOmbLAzOTmpODc0NITp6WlV7zE0NITXXnsNPp8PABAOh3Hx4kVMTk5icXGx9IuJiIhMyO52wdnbg51HqwD2l+iMGjTd/Yu/wlb4tnz87PAX4PB6dBxRcYZenguHw5iYmMD4+Lji/Pj4OGZmZjA3N3foe4yNjWF8fFwOmADA7/djcnIS4XAYIyMjWg+biIjIELwmyGvaun0Ht9/8C/n42M/8FLpf+GEdR3QwQwdNk5OT8Pl8ioAnKxgMqpppmpubw8WLFwvOh0Ih+XEiIqJG5B0wdmXwTCqF7/0fr0NKpwEArd1dCPzyp3Ue1cEMHTTNzMzg/PnzRR/z+/24fv160cdEXV1dCIfDiMViRR+PRCLVDJGIiMiwFD3obt/VcSTF3X7zL7B95558/NyXvwC7263jiEozdE5TOBxGMBgs+lhXV9eBgZBodna26Pnsa/1+f8nXT05OYmpq6tDPAYCbN2+qeh4REVE9iLWa9iJR7G1soKW9XccR5WwsLuHOn39LPj5+8WfR+dEf1HFEhzN00FRKdskuFosVXb47TDYQys+XyreysoKFhYWy35+IiEhvLZ0+ONrbkNzYBLBfeqDrh/UPTDJ7SXzw268DT8sgOHuOwP/ZIZ1HdTjDBk2HzSJlH49EImUHTbFYDNeuXcPw8LCc23SQvr6+A2e78t28eROJRKKssRAREdWKxWKB98xpRL/7zwD285qMEDQtT/8HxO+vyMfPffmLsDmdOo5IHcMGTZXMHqk1NDSEUCikKGNwkJGREdU77M6dO8dZKSIiMhRvfy5o2jZAMvj692/h7n/8a/n4xM+H4PuB53QckXqGTgQHDp5xyiZwd3V1lfV+Y2Nj8Pl8qms8ERERmZmRdtCld3fxwW//LiBJAADXsV4MfPolXcdUDkMHTX6//8DdbdlcpnJmpKamphCLxRgwERFR0xB30MVXHiK9s6vbWJa++SYSDx/tH1gseO7Xvghba6tu4ymXoYOmwcFBhMPhoo9FIhFcunRJ9XvNzc1hfn6+YElO7c44IiIiM3L19cLa2rJ/IEnYvnuv9AtqJPYvH+D+X+VqI576hX+Fjmef0WUslTJ00HT58mW5X5woFothYWEBQ0OFmfbFlvMWFhYwOztbNIdpfn5es/ESEREZjcVqhfe0vpXB0zs7+ODrvysfu08ex5mhf1P3cVTLsIngwH7V7+HhYYyNjSmW1K5du4bR0dGCnW+BQACRSATRaFQ+Fw6H5cTv/IRuFrYkIqJm4D1zGhsf7vda1SNoCn9jGjurT/YPrFZ85OUvwtriqPs4qmXooAnIFZccGRlBIBDA2toauru7MTo6WvDcYDBYMCs1NDSEcDh84DLcYXWaiIiIzE4sclnvoCn6T/+MB7N/Ix+f/sV/jbbAQF3HoBXDB00AMDw8rOp5xRK8ufxGRETNziMETdt37kFKp2Gx2Wr+ual4HB98/fdz4+g/hf6XPlXzz60VQ+c0ERERUfU8p04A1v1bfiaZRHzlYV0+d/GPvondtf1UGIvNho/82hdhtZtivqYoBk1EREQNztbSAvfxPvm4Hkt0awvfwcO//Tv5uP+lTynKH5gRgyYiIqImoMxrulvTz0pubeH7r/1B7rP9/Tj9i/+6pp9ZDwyaiIiImoD3jFh24HZNP+vWH/wp9qLrAACL3Y6PvPyluuRQ1RqDJiIioibgPdMvf711+y6kp61MtPbkvQWs/t1/lY/PXPq3+zlVDYBBExERURMQZ5pSm1vYXYuWeHZlkhub+P7rfyQft58N4NQvfFLzz9ELgyYiIqIm4PB60XqkWz7euq19MviHv/fHSK5vAACsLS147uUvwmJtnFCjcb4TIiIiKsnbX7t2Kqv/9z/g8d/fkI8HPv0S3MePafoZemPQRERE1CTEHXTbGgZNe7F1fPh7fywfdzz/HE78qxc1e3+jYNBERETUJGrRTkWSJHz/tT9EamsbAGBtbcVzX/5CQy3LZTXed0RERERFiUHTzuMnSG3Hq37P1f/yX7E2/4/yceCzl+Dq7an6fY2IQRMREVGTaD3SDbvHIx9XO9u0G4niwz/4hnzs++gPoO/iz1T1nkbGoImIiKhJWCyWvCKXlQdNkiThg8nfRzqeAADYXC48N/IFWCyWqsdpVAyaiIiImohH6P9WTdmBh3/zXxD9zn+XjwO//Gk4hZIGjYhBExERURNp0yAZfOfxEyz+8Tfl464XfhjHfuanqh6b0TFoIiIiaiIeIWiK319BZi9Z1uulTAYffP33kU7sAADsHjeevfIrDb0sl8WgiYiIqIm4jx+DxWEHAEjpNLbv3S/r9Q/m/haxf74pHz/z+c+itatT0zEaFYMmIiKiJmK12xUNdMtZoks8XEX4G9fl4+4LL6Dnp35C0/EZGYMmIiKiJuM90y9/rTZo2l+W+z1kdvcAAPY2L5794i83xbJcFoMmIiKiJqPoQadyB939v5rD+ve+Lx8/+8XPocXXofnYjIxBExERUZMRZ5q2b9+FlMmUfH78wQqWvvmmfHz0Yz+Goz9xoWbjMyoGTURERE3G238SeLqslt7ZReLR4wOfK6XT+N5v/y4yyf1ddo6Odpz91X9Xl3EaDYMmIiKiJmNzOuE6lusPt7V8+8Dn3v2P38bmrbB8/OyVX4GjzVvT8RkVgyYiIqIm5BUrgy/fLfqc7bv3sDz9H+Tj3o9/DEfOv1DroRkWgyYiIqIm5B0Qg6bCmaZMKoXv/fbvQkqlAAAtnT4EfuUzdRufETFoIiIiakL5yeD57vz5t7C1lAumnhv5AhxeT13GZlQMmoiIiJqQWHZgL7aOvdi6fLy5dBt33vpL+fjYJ34aXT/60bqOz4gYNBERETWhFl8HWjpzdZayRS4zySQ++J3fhZROAwBaj3Qj8O8u6zJGo2HQRERE1KSUyeD7QdPtN/8C23fuyeefG/kC7G5X3cdmRAyaiIiImpT3jDJo2lhcwp0//5Z87vjP/Sw6P/oDegzNkBg0ERERNSkxaNpcXMIHv/06IEkAAGfPUfg/M6TX0AzJrvcAiIiISB9i0LTz+EnuAYsFz738RdicTh1GZVycaSIiImpSzp6jsLkKA6MTP38Rvuef1WFExsagiYiIqElZrFZ4Tp9SnHMdP4aBT/+STiMyNgZNRERETUxcooPFgo+8/EXYWlr0G5CBMWgiIiJqYkcuBOWvT//bX0D72YCOozE2JoITERE1sc4feh4v/P//V6TiCXT+8A/qPRxDY9BERETU5Di7pA6X54iIiIhUYNBEREREpAKDJiIiIiIVGDQRERERqcCgiYiIiEgFBk1EREREKjBoIiIiIlKBQRMRERGRCgyaiIiIiFRg0ERERESkAoMmIiIiIhUYNBERERGpwKCJiIiISAWLJEmS3oNoFF1dXYhGo3C5XHj++ef1Hg4RERGpcPPmTSQSCXR2diISiRz4PAZNGnK73UgkEnoPg4iIiCrgcrkQj8cPfNxex7E0vJ6eHqyursLpdGJgYECz981GwJzBqg6vozZ4HbXB66gNXkdtNPt1XFpaws7ODnp6eko+j0GThpaXl2vyvufOncPCwgKef/55zM/P1+QzmgGvozZ4HbXB66gNXkdt8Dqqw0RwIiIiIhUYNBERERGpwKCJiIiISAUGTUREREQqMGgiIiIiUoFBExEREZEKDJqIiIiIVGDQRERERKQCgyYiIiIiFRg0EREREanANiomMDw8jJWVFfT19ek9FFPjddQGr6M2eB21weuoDV5HdSySJEl6D4KIiIjI6Lg8R0RERKQCgyYiIiIiFRg0EREREanARHCDm5qawvz8PAKBABYXFxEIBDA6Oqr3sExlbGwMsVgM4XAYkUgEly9f5jXUyNDQEMbHx+H3+/UeiunMzMzgvffeU5wbHx/XaTTmNDU1hcXFRQBALBaDz+fD1atX4fP59B2YQY2NjQEo/XPGe84hJDKs0dFRaXh4uODc4OCgTiMyn8HBQSkajcrHi4uLkt/vl/x+v36DahCTk5MSAGl+fl7voZjO4OCgND4+Lh9Ho1EpGAxKo6OjOo7KXEZHRwt+9ubn56VgMKjTiIxpeHhYGhwclEZHRyUAJX/GeM85HIMmg1pcXJQAKG74WQCk2dnZ+g/KZEZHR6XFxcWC87OzsxKAgl8OpF40GpVCoRCDpgoUuwlFo1HJ5/NJk5OTOo3KXObn5w/89zs6OipNT0/XeUTmUCpo4j1HHeY0GdTk5CR8Pl/RaeZgMIjp6en6D8pk5ubmcPHixYLzoVBIfpwqc+3aNYyMjOg9DNMJh8OYmJgouHY+nw/RaBTDw8M6jcxcbty4gXA4XPSxQCBw4GN0MN5z1GHQZFAzMzM4f/580cf8fj+uX79e5xGZT1dXF8LhMGKxWNHHI5FIfQfUIKampjAyMsK8kQpkc0mygTtVxu/3Y25uDhMTEwWPTU9P8/pWgPccdZgIblDhcBjBYLDoY11dXQcGApQzOztb9Hz22jF5uXzZv+D9fj//mq/A9evX4fP5EIvFMDU1JZ9fW1tjEngZQqEQgsEgxsbG8MYbb2B6ehp+vx9jY2MYGho68HcnHYz3HHUYNJlQ9i/87G4RKk/2ZsWbVPkmJyd53aoQi8Xg9/tx7do1xXWcmJiQdyuROu+88w6GhoYwNzeHQCCAYDCI1157jQFTDfCek8PlOQM6LKLPPs7lpfLFYjFcu3YNw8PDnMIvU3ZZjiqT/XcbDodx+fJlxWOjo6MIh8PylnA6nM/nw8jICEKhEHw+HxYWFnDlyhXOgFaA9xz1GDQZULNH8rU0NDSEUCiEyclJvYdiKuKyHFVG/HddbDYkGAwqluyotKGhIYTDYczOzmJpaQnDw8NYWFhAIBDAwsKC3sMzFd5z1GPQZGCHJTB3dXXVcTTmNzY2Bp/Px10gFZicnOTOLo0cFHhm80aYO3K4sbExXLhwQS666PP5MDk5idnZWfh8PgwNDek8QnPiPedwzGkyKL/ff+BUaHZdmX8dqDc1NYVYLMaAqQIzMzOYm5sruBFlZ5+ywejly5cxODioxxBNIxgMcvlIAxMTE4hGowXnQ6EQ3nnnHZw7d475N2XiPUcdzjQZ1ODg4IG/XCORCC5dulTnEZnX3Nwc5ufnC5bkuBSizuDgIObn5zE9Pa34Xza/aXx8HNPT0wyYVAiFQiX/mueNSb2DrlMwGOR1rADvOeowaDKoy5cvy/3SRLFYDAsLC5x+VmlhYQGzs7NFc5jm5+d1GBE1s2ygWSznZmFhAVevXq33kEwpFAphZmam6GOxWOzAekN0MN5z1LFIkiTpPQgqbmRkBJFIRLGkpKbhIu0Lh8O4ePFi0V1y2WloLtdVbmJiAmNjY5idneVOxDJMTEzgjTfeUATtIyMjuHHjBgN5lbL/tqenpxVJ9eFwGCMjI5ienuZMU55YLIbOzk4MDw8fuBGG95zDMWgyOLHj9NraGrq7u9lxWqVz586V3EUzPj7Oa1mBqakpzM7OYm5uTq47FAwGcfXqVdbIUWlmZgZvvPEGurq6EIlEFEnNpE62fEg4HJYTlH0+H65evcqASTA2NoZwOIyFhQV5FilbpqHYv1nec0pj0ERERESkAnOaiIiIiFRg0ERERESkAoMmIiIiIhUYNBERERGpwKCJiIiISAUGTUREREQqMGgiIiIiUoFBExEREZEKDJqIiIiIVGDQRERERKQCgyYi0s3Y2BguXrwIi8UCi8WCixcvsps6ERkWe88Rke7OnTuHcDiMaDRa9PGFhQXDNgM+bGyBQAChUOjAzvJEZB6caSIi3WW71B/EyAGHmrH5fL7aD4SIas6u9wCIiA4TDof1HsKBDhvb4uJinUZCRLXGmSYiMrSZmRm9h3AgI4+NiLTHoImIDCscDuPKlSt6D6MoI4+NiGqDy3NEZEhTU1OYnZ1FV1cXbty4odhVNz4+Dr/fr3j+xMSEnDu0uLiIQCCA4eFhAPsBztDQEMLhMC5duoTx8XFMTU0BAGZnZzE7Oyu/TywWw9TUlPxe8/PzGBkZUSR7qx3bxYsXEQ6H4fP5MD8/X/A9zszMyI/HYjEAwOjoqPy4OO7z589jdnZWHncsFsN7771X9FoQUY1IREQ6C4VCks/nK/rY8PCwFAqFSr4+GAxK09PTinODg4PS6OhowecMDg5K4+PjkiRJ0uzsrARAWlxclJ+T/5poNCr5fD5pdna2orENDw9LwWCw4Pzg4KA0OTmpOLe4uCgFg0HFeLLPDYVC0uTkpBSNRuXz09PTB143ItIel+eIyNQmJiYAAIODg4rz4+PjmJiYUCRqB4NBLCwsIBQKAQBCoRCi0ag8U7OwsCDP/mT5fD4MDw9jbGysovEFAoGCc1NTUwiHw/JMWJbf78fIyAhGRkYKzt+4cQPnz59X7MQLhUKIxWJYWFioaGxEVB4GTURkamNjY7h8+XLBeb/fD5/Ph7m5OcX5SCSiWGoTgxCfz4dIJFKwIy4QCGi6g++gMQPApUuXMDc3pxh3d3c3YrFYQT2o7NgjkYhmYyOigzGniYhMKxvILC4uHriTLX/Lf6n8H7/fryiwGQ6HEYvFiuYjVSr7ngcVxMwGQuKMWHZsRKQvBk1EZFrZoGloaEgRYGTlL9kBhxfSjMViuHbtGmKxGM6dO4dQKIRz587h+vXrmo65FJ/Ph/fee6/gHBHpi8tzRGQ62Vml7OxLdudZtcLhMAYGBhAIBDA5OYnh4WH4/f5DA61iYzuImjHHYjHOLBEZEIMmIjK8/Jyd7GxNNm8pf1ZGVE5ANTQ0BL/fX5Cgnf/5Yr7RQWM7SDYYOuh52fMXLlxQN2giqhsGTURkaIFAoGTgI9ZcyrewsIAbN26o/qz8PKKs+fl5xRiygc1hYzvI+Pj4gT3rZmZmEAwGiy4tEpG+GDQRke5K7f4KhUJy8jSwH9iISdTDw8MIhUIF2/RjsRjm5uYUQVAsFjv0s/J324XDYVy8eFF+/cLCAs6fP69qbOLnikZHRxEMBgvKGCwsLGBychLT09OK82tra4cu5xFR7VkkSZL0HgQRNaexsTGEw2E5DygUCsHv9xfMwszMzGB2dhbnzp0DgILlM2C/9tH8/DwCgQD8fj8ikYiiIvjY2Bjm5uYQi8UwODgIv9+P8fHxgvcZGRlBJBKRAyW/349QKISJiQnMzs5iaGhI8fkHjS0Wi+HKlSvyZ4ZCIYyPjxdUFl9cXER3dzeA/eDo6tWrctJ3/nsMDg7i8uXLGBwclMczNzcHv9+PYDBYEGwRkbYYNBERERGpwOU5IiIiIhUYNBERERGpwKCJiIiISAUGTUREREQqMGgiIiIiUoFBExEREZEKDJqIiIiIVGDQRERERKQCgyYiIiIiFRg0EREREanAoImIiIhIBQZNRERERCowaCIiIiJS4f8BL1CUzr2D5AoAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot([step_size for ind, step_size in enumerate(all_step_sizes)], color=palette[\"light red\"])\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Step size\")\n",
    "plt.title(\"Step size\")\n",
    "\n",
    "plt.savefig(\"figures/convergence_step_sizes.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ccmm.matching.weight_matching import solve_linear_assignment_problem\n",
    "\n",
    "fw_permutations = {symb: {other_symb: None for other_symb in symbols.difference(symb)} for symb in symbols}\n",
    "fw_permutations[fixed_symbol][permutee_symbol] = {\n",
    "    p: solve_linear_assignment_problem(perm) for p, perm in perm_matrices.items()\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "updated_params = {fixed_symbol: {permutee_symbol: None}}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:55:25 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Permuting model b into a.                                                   <a href=\"file:///tmp/ipykernel_2371794/3276615573.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">__main__</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///tmp/ipykernel_2371794/3276615573.py#5\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">5</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:55:25\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Permuting model b into a.                                                   \u001b]8;id=154493;file:///tmp/ipykernel_2371794/3276615573.py\u001b\\\u001b[2m__main__\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=735826;file:///tmp/ipykernel_2371794/3276615573.py#5\u001b\\\u001b[2m5\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> GPU available: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span> <span style=\"font-weight: bold\">(</span>cuda<span style=\"font-weight: bold\">)</span>, used: <span style=\"color: #00ff00; text-decoration-color: #00ff00; font-style: italic\">True</span>      <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1751\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1751</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m GPU available: \u001b[3;92mTrue\u001b[0m \u001b[1m(\u001b[0mcuda\u001b[1m)\u001b[0m, used: \u001b[3;92mTrue\u001b[0m      \u001b]8;id=314043;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=715042;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1751\u001b\\\u001b[2m1751\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> TPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> TPU cores    <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1754\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1754</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m TPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m TPU cores    \u001b]8;id=339246;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=640823;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1754\u001b\\\u001b[2m1754\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> IPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> IPUs         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1757\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1757</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m IPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m IPUs         \u001b]8;id=900220;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=110543;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1757\u001b\\\u001b[2m1757\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> HPU available: <span style=\"color: #ff0000; text-decoration-color: #ff0000; font-style: italic\">False</span>, using: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span> HPUs         <a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">pytorch_lightning.utilities.rank_zero</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1760\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">1760</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m HPU available: \u001b[3;91mFalse\u001b[0m, using: \u001b[1;36m0\u001b[0m HPUs         \u001b]8;id=104370;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py\u001b\\\u001b[2mpytorch_lightning.utilities.rank_zero\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=329319;file:///home/ANONYMIZED/miniconda3/envs/ccmm/lib/python3.9/site-packages/pytorch_lightning/trainer/trainer.py#1760\u001b\\\u001b[2m1760\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/2 [00:00<?, ?it/s]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                    </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Evaluating interpolated model with lambda: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.5</span>                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.utils.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">167</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m                   \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Evaluating interpolated model with lambda: \u001b[1;36m0.5\u001b[0m                    \u001b]8;id=932801;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\u001b\\\u001b[2mccmm.utils.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=200779;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\u001b\\\u001b[2m167\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 1/1 [00:00<00:00, 20.36it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.5752000212669373     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">     2.705787181854248     </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.5752000212669373    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m    2.705787181854248    \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 5/5 [00:00<00:00, 81.63it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.5702000260353088     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    2.7664754390716553     </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.5702000260353088    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   2.7664754390716553    \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 50%|█████     | 1/2 [00:04<00:04,  4.39s/it]"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">2024-05-22 07:55:29 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Evaluating interpolated model with lambda: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span>                    <a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">ccmm.utils.utils</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">167</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m2024-05-22 07:55:29\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Evaluating interpolated model with lambda: \u001b[1;36m1.0\u001b[0m                    \u001b]8;id=694922;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py\u001b\\\u001b[2mccmm.utils.utils\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=996508;file:///media/ANONYMIZED/Extra-storage/Code/model-merging/cycle-consistent-model-merging/src/ccmm/utils/utils.py#167\u001b\\\u001b[2m167\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 1/1 [00:00<00:00, 23.03it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.9909999966621399     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.02507270872592926    </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.9909999966621399    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.02507270872592926   \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Testing DataLoader 0: 100%|██████████| 5/5 [00:00<00:00, 82.36it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">        Test metric        </span>┃<span style=\"font-weight: bold\">       DataLoader 0        </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         acc/test          </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.9602000117301941     </span>│\n",
       "│<span style=\"color: #008080; text-decoration-color: #008080\">         loss/test         </span>│<span style=\"color: #800080; text-decoration-color: #800080\">    0.22009167075157166    </span>│\n",
       "└───────────────────────────┴───────────────────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m       Test metric       \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      DataLoader 0       \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━┩\n",
       "│\u001b[36m \u001b[0m\u001b[36m        acc/test         \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.9602000117301941    \u001b[0m\u001b[35m \u001b[0m│\n",
       "│\u001b[36m \u001b[0m\u001b[36m        loss/test        \u001b[0m\u001b[36m \u001b[0m│\u001b[35m \u001b[0m\u001b[35m   0.22009167075157166   \u001b[0m\u001b[35m \u001b[0m│\n",
       "└───────────────────────────┴───────────────────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2/2 [00:08<00:00,  4.23s/it]\n"
     ]
    }
   ],
   "source": [
    "from scripts.evaluate_matched_models import evaluate_pair_of_models\n",
    "\n",
    "restore_original_weights(models, model_orig_weights)\n",
    "\n",
    "pylogger.info(f\"Permuting model {permutee_symbol} into {fixed_symbol}.\")\n",
    "\n",
    "# perms[a, b] maps b -> a\n",
    "updated_params[fixed_symbol][permutee_symbol] = apply_permutation_to_statedict(\n",
    "    permutation_spec, fw_permutations[fixed_symbol][permutee_symbol], models[permutee_symbol].model.state_dict()\n",
    ")\n",
    "restore_original_weights(models, model_orig_weights)\n",
    "\n",
    "lambdas = [0.5, 1.0]\n",
    "\n",
    "fw_results = evaluate_pair_of_models(\n",
    "    models,\n",
    "    fixed_symbol,\n",
    "    permutee_symbol,\n",
    "    updated_params,\n",
    "    train_loader,\n",
    "    test_loader,\n",
    "    lambdas,\n",
    "    core_cfg,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.2731918841600418"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fw_results[\"test_loss_barrier\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ccmm",
   "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
