{
 "nbformat": 4,
 "nbformat_minor": 0,
 "metadata": {
  "colab": {
   "provenance": [],
   "gpuType": "L4",
   "machine_shape": "hm"
  },
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3 (ipykernel)",
   "language": "python"
  },
  "language_info": {
   "name": "python"
  },
  "accelerator": "GPU"
 },
 "cells": [
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:25.639312Z",
     "start_time": "2025-09-24T09:30:25.627902Z"
    }
   },
   "cell_type": "code",
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "from tqdm.auto import tqdm\n",
    "import numpy as np\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import random\n",
    "\n",
    "from iclr.common import *\n",
    "import yaml\n",
    "import matplotlib.colors as mcolors\n",
    "import pickle"
   ],
   "outputs": [],
   "execution_count": 33
  },
  {
   "cell_type": "markdown",
   "source": "import library",
   "metadata": {
    "id": "IdHqQ6x-rn-q"
   }
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:25.667034Z",
     "start_time": "2025-09-24T09:30:25.652245Z"
    }
   },
   "cell_type": "code",
   "source": [
    "device = torch.device(\"cuda\")\n",
    "sns.set_theme(style=\"whitegrid\", font=\"cmr10\", font_scale=1.9)\n",
    "plt.rcParams[\"axes.formatter.use_mathtext\"] = True\n",
    "colors = sns.color_palette()\n",
    "colors"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(0.2980392156862745, 0.4470588235294118, 0.6901960784313725),\n",
       " (0.8666666666666667, 0.5176470588235295, 0.3215686274509804),\n",
       " (0.3333333333333333, 0.6588235294117647, 0.40784313725490196),\n",
       " (0.7686274509803922, 0.3058823529411765, 0.3215686274509804),\n",
       " (0.5058823529411764, 0.4470588235294118, 0.7019607843137254),\n",
       " (0.5764705882352941, 0.47058823529411764, 0.3764705882352941),\n",
       " (0.8549019607843137, 0.5450980392156862, 0.7647058823529411),\n",
       " (0.5490196078431373, 0.5490196078431373, 0.5490196078431373),\n",
       " (0.8, 0.7254901960784313, 0.4549019607843137),\n",
       " (0.39215686274509803, 0.7098039215686275, 0.803921568627451)]"
      ],
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#4c72b0;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#dd8452;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#55a868;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#c44e52;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8172b3;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#937860;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#da8bc3;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8c8c8c;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ccb974;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#64b5cd;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 34
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "default plot setting"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:25.727820Z",
     "start_time": "2025-09-24T09:30:25.677498Z"
    }
   },
   "cell_type": "code",
   "source": [
    "with open(\"linear/config.yaml\", 'r', encoding='utf-8') as f:\n",
    "    configs_linear = yaml.safe_load(f)\n",
    "with open(\"deep/config.yaml\", 'r', encoding='utf-8') as f:\n",
    "    configs_deep = yaml.safe_load(f)\n",
    "with open(\"mlp/config.yaml\", 'r', encoding='utf-8') as f:\n",
    "    configs_mlp = yaml.safe_load(f)\n",
    "\n",
    "config = configs_mlp\n",
    "loss_type = \"VICReg\""
   ],
   "outputs": [],
   "execution_count": 35
  },
  {
   "cell_type": "code",
   "source": [
    "def sample(batch, sizes, device, mul=0.01):\n",
    "    x_out = torch.zeros((batch, 0), device=device)\n",
    "    for size in sizes:\n",
    "        rand = torch.rand((batch, 1), device=device).round() * 2 - 1\n",
    "        x_out = torch.cat([x_out, rand.repeat(1, size)], dim=-1)\n",
    "    epsilon1 = mul * torch.randn_like(x_out)\n",
    "    epsilon2 = mul * torch.randn_like(x_out)\n",
    "    return x_out + epsilon1, x_out + epsilon2"
   ],
   "metadata": {
    "id": "lAiXuGepZPHw",
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:25.789213Z",
     "start_time": "2025-09-24T09:30:25.780080Z"
    }
   },
   "outputs": [],
   "execution_count": 36
  },
  {
   "cell_type": "markdown",
   "source": "sample makes [+1, -1] datas",
   "metadata": {
    "id": "mz6MdhVWVigh"
   }
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:25.811651Z",
     "start_time": "2025-09-24T09:30:25.803142Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def create_segment_vectors(sizes):\n",
    "    total_length = sum(sizes)\n",
    "    cumsum = torch.cumsum(torch.tensor(sizes), dim=-1)\n",
    "\n",
    "    result = torch.zeros((len(sizes), total_length))\n",
    "\n",
    "    for i in range(len(sizes)):\n",
    "        start_idx = cumsum[i - 1] if i > 0 else 0\n",
    "        end_idx = cumsum[i]\n",
    "\n",
    "        result[i, start_idx:end_idx] = 1\n",
    "\n",
    "    return result"
   ],
   "outputs": [],
   "execution_count": 37
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:25.833565Z",
     "start_time": "2025-09-24T09:30:25.825207Z"
    }
   },
   "cell_type": "code",
   "source": [
    "batch = config[\"batch\"]\n",
    "if \"batch\" in config[loss_type]:\n",
    "    batch = config[loss_type][\"batch\"]\n",
    "sizes = config[\"sizes\"]\n",
    "if \"sizes\" in config[loss_type]:\n",
    "    sizes = config[loss_type][\"sizes\"]\n",
    "s_in = sum(sizes)\n",
    "s_out = len(sizes)"
   ],
   "outputs": [],
   "execution_count": 38
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:26.040181Z",
     "start_time": "2025-09-24T09:30:25.848432Z"
    }
   },
   "cell_type": "code",
   "source": [
    "sample_data = sample(batch, sizes, device, mul=0.01)\n",
    "gamma = torch.bmm(sample_data[0].unsqueeze(dim=2), sample_data[1].unsqueeze(dim=1))  # b x n x n\n",
    "gamma = gamma + gamma.permute(0, 2, 1)\n",
    "gamma = torch.mean(gamma, dim=0).squeeze() / 2  # n x n\n",
    "sns.heatmap(gamma.cpu())\n",
    "plt.show()\n",
    "gamma_l, gamma_v = torch.linalg.eig(gamma)\n",
    "gamma_l = gamma_l.real.cpu()\n",
    "gamma_v = gamma_v.real.cpu()\n",
    "print(gamma_l, gamma_v)"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ],
      "image/png": "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Vrt375Ykde3atcS4zWZTZGSkJGnDhg0ezb1p0yYdPXpUUVFRatiwYbGxli1bqkOHDgoNDVXPnj09mpfFrwAAVFHbtm2T0+lUSEiIgoODS72mVatWkqSdO3d6NPeyZcskSb169Sox5ufnp7Vr13oY7TVUTAAAMJlVKibHjh2TJDVu3LjMawrH7Ha70tLS3Jr3xx9/VFJSkqRra1XMRMUEAACzOW03vuYWSElJkSQFBgaWeU1QUJDru91uV6NGjW44b9Hqym233aaEhAQtWrRI58+fV05Ojrp27arx48eXmxCVhcQEAAALu9EajfJ2vWRkZEiSateuXeY1fn5+ru+ZmZluxVRYiZGubReOjY3V0qVLVadOHWVkZGjSpEnq27evVqxYobZt27o1ZyFaOQAAmMwqrZycnBxJkq+vb5nXFB27dOmSW/MWbfm8++67mjlzpurUqSNJCg4O1vz585WTk6Px48fr/PnzHsVMxQQAAJM5Hea1cjw9B6SovLw8SSq2lfd6Dsf/ZT+FicyNZGdnu763a9dOtWrVKjbepEkTtW/fXrt379by5cv13HPPuR0zFRMAAExmlYpJ0TZNWfLz813f69at6/G8DzzwQKnX/OxnP5Mkbdy40a05C5GYAABQRdWvX/+G11y5csX13d/f3615iy6Ybd68eanXFC64tdvtOnHihFvzSiQmAACYzum0mfapiKZNm0qScnNzy7zm4sWLru+hoaFuzVv0urKqLEXXrri7DVlijQkAAKazytuFW7RoIUm6cOFCmdfY7XZJko+Pj8LCwtya995773V9z83NLbHGRJKcTqfre0BAgFvzSlRMAACosjp06CBJSk5OLvOao0ePSpJat25d7u6doiIiIlSjxrUUoqxdN4Utolq1arkqN+4gMQEAwGROh820T0VEREQoKChIGRkZrpNar7dnzx5JUu/evd2et1GjRrr//vsllZ30nDlzRpLUvXv3cs9Rud5NT0wuXbqkAwcO6MSJE8XKOgAAVFVOp3mfivD19VW/fv0klb47JikpSQcPHlRAQIAGDBhQbOzAgQPq0aOHevfurcTExBL3jhw5UtK19/Fcr6CgQAkJCapZs6bGjBnjUcyGEpP09HStXbtWb7/9trZv366CgoIS12RmZuq5557Tgw8+qMGDB6t3797q3r271qxZY+SRAADAgIkTJ6phw4Za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5x4+fFgnTpyQpDIrKmXxODG5evWqtm7dqtOnT6tnz5668847i41nZmZq+fLl2rBhQ7GSUK1atdS9e3eNGTNGrVu39vSxAABUGmae/NqzZ89yx7du3VrmWE5OjiTJ19e3zGuKjl26dMnD6Eq3bNkySVKDBg00evRoj+71KDE5e/ashg0bptOnT+vq1atas2aNvvjiC9f4gQMHNG7cOKWnp5foJ129elX//Oc/tXXrVk2aNEljx471KFAAAOCZvLw8Sdd235TF4fi/lSyFiUxFxMfHKy4uTj4+PnrllVeKtYrc4VFisnDhQk2cOFHx8fFav369QkNDXWN2u10jR45UTk6OOnXqpJ/97GcKDAyUr6+vnE6nrly5ojNnzmj37t169dVX1aBBAz3xxBMeBQsAQGVQ0W2+RZVXEbmRom2asuTn57u+161b1/CzpGtdkxkzZqhGjRqaN2+eunTp4vEcHiUmBw4c0Lx58xQVFaWnnnpKLVu2dI29+eab+vnPf6758+e7tgiVxuFwaO3atVq0aJF+/etfu06LAwCgqrDK24Xr169/w2uuXLni+m7k3TaFCgoK9MwzzygjI0MLFizQI488Ymgej7YL16xZ89pNNWqoTZs2xRaz7tixQ4sXLy43KSm898knn1Tv3r0VHx9vIGQAAOCOpk2bSpJyc3PLvKboGSNFOyGemj17tvbu3aslS5YYTkokDxMTh8NR5pn3tWvX9qiP1LFjRx0/ftyTxwMAUClY5SV+LVq0kHTtkLOy2O12SZKPj4/CwsIMPeftt9/Wpk2b9NZbb5Vo35w8ebJYu+hGPEpMevToodmzZ5c6FhwcXOwwlRs5e/asR/uaAQCoLKxy8muHDh0kScnJyWVec/ToUUlS69aty929U5YtW7bozTff1MqVK13PK2rixInFFtjeiEeJydChQ/Xtt99q0qRJrr3RhSZNmuR6UdCNnDhxQjExMWrfvr0njwcAAB6IiIhQUFCQMjIylJSUVOo1e/bskST17t3b4/n37dunF198UcuXL1e7du1KjOfm5iovL8+jc8w8WvwaHBysv//97xo3bpyioqLUt29f9ezZU+Hh4erYsaNq1KihadOmqV27dnrggQfUvHlz1a5dW3l5ebpw4YKSkpL05Zdf6v3339cjjzyiu+66y5PHAwBQKZi5K6cifH191a9fP61atUobN27U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"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([ 6.0002e+00,  1.9999e+00,  3.0489e-06,  2.0529e-06, -2.3300e-06,\n",
      "        -1.3077e-06,  5.9003e-07, -8.4627e-08]) tensor([[-0.4082,  0.0023, -0.1658,  0.3136, -0.1841,  0.2568,  0.8082,  0.0281],\n",
      "        [-0.4082,  0.0023, -0.2924,  0.2828,  0.5705, -0.4974, -0.0311, -0.2981],\n",
      "        [-0.4082,  0.0024, -0.0502,  0.1345, -0.1526,  0.6621, -0.4891, -0.3953],\n",
      "        [-0.4082,  0.0024,  0.3572, -0.6051,  0.5254,  0.1547,  0.0337,  0.2062],\n",
      "        [-0.4083,  0.0024, -0.2893, -0.5228, -0.5050, -0.3801, -0.1210, -0.0888],\n",
      "        [-0.4082,  0.0023,  0.4406,  0.3970, -0.2541, -0.1960, -0.2007,  0.5479],\n",
      "        [-0.0040, -0.7071,  0.4895, -0.0576, -0.1041, -0.1439,  0.1588, -0.4491],\n",
      "        [-0.0041, -0.7071, -0.4894,  0.0575,  0.1041,  0.1439, -0.1589,  0.4491]])\n"
     ]
    }
   ],
   "execution_count": 39
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:26.161083Z",
     "start_time": "2025-09-24T09:30:26.092401Z"
    }
   },
   "cell_type": "code",
   "source": [
    "import os\n",
    "\n",
    "if os.path.exists(f\"{config[\"network\"]}/data.npy\"):\n",
    "    output_dict = np.load(f\"{config[\"network\"]}/data.npy\", allow_pickle=True).item()\n",
    "else:\n",
    "    output_dict = {}"
   ],
   "outputs": [],
   "execution_count": 40
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:30:26.257548Z",
     "start_time": "2025-09-24T09:30:26.203627Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def train(loss_type, lambd=None, slope=None):\n",
    "    if lambd is None:\n",
    "        target_output_dict = output_dict[loss_type]\n",
    "    elif slope is not None:\n",
    "        if lambd not in output_dict[loss_type]:\n",
    "            output_dict[loss_type][lambd] = {}\n",
    "        output_dict[loss_type][lambd][slope] = {}\n",
    "        target_output_dict = output_dict[loss_type][lambd][slope]\n",
    "    else:\n",
    "        output_dict[loss_type][lambd] = {}\n",
    "        target_output_dict = output_dict[loss_type][lambd]\n",
    "    set_seed(config[loss_type][\"seed\"])\n",
    "    if config[\"network\"] == \"linear\":\n",
    "        encoder = nn.Linear(s_in, s_out, bias=False, device=device)\n",
    "    elif config[\"network\"] == \"deep\":\n",
    "        mid_size = config[\"mid_layer_size\"]\n",
    "        total_layer = int(config[\"layer\"])\n",
    "        mid_layer = []\n",
    "        for _ in range(total_layer - 2):\n",
    "            mid_layer.append(nn.Linear(mid_size, mid_size, bias=False, device=device))\n",
    "        encoder = nn.Sequential(nn.Linear(s_in, mid_size, bias=False, device=device), *mid_layer, nn.Linear(mid_size, s_out, bias=False, device=device))\n",
    "    else:\n",
    "        mid_size = config[\"mid_layer_size\"]\n",
    "        total_layer = int(config[\"layer\"])\n",
    "        if \"layer\" in config[loss_type]:\n",
    "            total_layer = int(config[loss_type][\"layer\"])\n",
    "        mid_layer = []\n",
    "        if slope is not None and \"leakyrelu\" in loss_type:\n",
    "             def activation_types():\n",
    "                return nn.LeakyReLU(negative_slope=float(slope), inplace=True)\n",
    "        else:\n",
    "             def activation_types():\n",
    "                return nn.ReLU(inplace=True)\n",
    "        for _ in range(total_layer - 2):\n",
    "            mid_layer.append(nn.Linear(mid_size, mid_size, bias=False, device=device))\n",
    "            mid_layer.append(activation_types())\n",
    "        encoder = nn.Sequential(nn.Linear(s_in, mid_size, bias=False, device=device), activation_types(), *mid_layer,\n",
    "                                nn.Linear(mid_size, s_out, bias=False, device=device))\n",
    "    print(encoder)\n",
    "    epochs = int(config[loss_type][\"epochs\"])\n",
    "    lr = float(config[loss_type][\"lr\"])\n",
    "    scaling = float(config[loss_type][\"scaling\"])\n",
    "\n",
    "    optimizer = torch.optim.SGD(encoder.parameters(), lr, momentum=0, weight_decay=0)\n",
    "\n",
    "    encoder.train()\n",
    "\n",
    "    loss_values = []\n",
    "    eiglist = [[] for i in range(s_out)]\n",
    "    feature_alignment = [[] for _ in range(s_out)]\n",
    "    weight_singular = [[] for _ in range(s_out)]\n",
    "    subspace_alignment = []\n",
    "    feature_weight_r_singular_alignment = [[[] for _ in range(2)] for _ in range(2)]\n",
    "\n",
    "    if config[\"network\"] != \"linear\":\n",
    "        scale_weights(encoder, scaling ** (1 / config[\"layer\"]))\n",
    "    else:\n",
    "        scale_weights(encoder, scaling)\n",
    "\n",
    "    w = get_total_weight(encoder).detach().clone()\n",
    "    u0, s0, v0T = torch.linalg.svd(w)\n",
    "    v0 = v0T.T\n",
    "\n",
    "    print(f\"before {s0}\")\n",
    "    if config[\"network\"] == \"deep\" and \"BarlowTwins\" in loss_type and config[loss_type][\"balanced\"]:\n",
    "        with torch.no_grad():\n",
    "            layer_s_value = s0 ** (1 / config[\"layer\"])\n",
    "            before_v = None\n",
    "            modules = list(filter(lambda l: isinstance(l, nn.Linear), encoder.modules()))\n",
    "            for index in reversed(range(len(modules))):\n",
    "                module = modules[index]\n",
    "                u, s, vt = torch.linalg.svd(module.weight.detach())\n",
    "                s_next = torch.zeros(u.shape[0], vt.shape[0], device=u.device)\n",
    "                for i in range(s.shape[0]):\n",
    "                    s_next[i, i] = s[i]\n",
    "                for i in range(layer_s_value.shape[0]):\n",
    "                    s_next[i, i] = layer_s_value[i]\n",
    "                if before_v is not None:\n",
    "                    if index == 0 and config[loss_type][\"aligned\"]:\n",
    "                        vt.T[:, :] = gamma_v[:, :].to(device)\n",
    "                    module.weight.copy_(before_v @ s_next @ vt)\n",
    "                else:\n",
    "                    module.weight.copy_(u @ s_next @ vt)\n",
    "                before_v = vt.T.clone()\n",
    "            w = get_total_weight(encoder).detach().clone()\n",
    "            u0, s0, v0T = torch.linalg.svd(w)\n",
    "            v0 = v0T.T\n",
    "\n",
    "            print(f\"after {s0}\")\n",
    "    w = get_total_weight(encoder).detach().clone()\n",
    "    u0, s0, v0T = torch.linalg.svd(w)\n",
    "    print(f\"after {s0}\")\n",
    "    v0 = v0T.T\n",
    "\n",
    "    target_output_dict[\"w\"] = w.cpu()\n",
    "    target_output_dict[\"u0\"] = u0.cpu()\n",
    "    target_output_dict[\"s0\"] = s0.cpu()\n",
    "    target_output_dict[\"v0\"] = v0.cpu()\n",
    "\n",
    "    for i in range(s_out):\n",
    "        weight_singular[i].append(s0[i].cpu().item())\n",
    "        feature_alignment[i].append(torch.norm(e[i].unsqueeze(dim=0) @ w.T).cpu().item())\n",
    "    subspace_alignment.append(\n",
    "        (torch.norm(v0[:, :2].T @ gamma_v[:, :2].cuda(), p='fro') ** 2 / 2).cpu().item())\n",
    "    print(subspace_alignment[0])\n",
    "\n",
    "    for i in range(2):\n",
    "        for j in range(2):\n",
    "            feature_weight_r_singular_alignment[i][j].append(\n",
    "                ((u0[:, i] @ w @ e[j].cuda()).cpu()).item())\n",
    "\n",
    "    eig_reversed = False\n",
    "    bar = tqdm(range(1, epochs + 1))\n",
    "    u_prev = None\n",
    "\n",
    "    for epoch in bar:\n",
    "        optimizer.zero_grad()\n",
    "        x0, x1 = sample(batch, sizes, device, mul=0.01)\n",
    "        z0, z1 = torch.chunk(encoder(torch.cat([x0, x1], dim=0)), 2, dim=0)\n",
    "        c, loss = lossFn(z0, z1)\n",
    "        c = c.detach()\n",
    "        v = reversed(torch.linalg.eigvalsh(c))\n",
    "        for i in range(len(v)):\n",
    "            # print(s0[0].item()**2 * gamma_l[0].item(), v[0].item())\n",
    "            eiglist[i].append(v[i].cpu().item())\n",
    "        loss_values.append(loss.item())\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        if epoch % 10 == 0:\n",
    "            bar.set_description(f'loss: {loss.item():.4f} {v[0].item():.8f}  {v[1].item():.8f}')\n",
    "\n",
    "        w_current = get_total_weight(encoder).detach().clone()\n",
    "        u_w_current, s_w_current, v_w_current_h = torch.linalg.svd(w_current)\n",
    "        v_w_current = v_w_current_h.T\n",
    "        if epoch > 100:\n",
    "            s_diff = abs(s_w_current[0] - s_w_current[1])\n",
    "            if s_diff < 0.0005 and not eig_reversed:\n",
    "                eig_reversed = True\n",
    "                # u_w_current, s_w_current, v_w_current = align_svd_components(u_w_current, s_w_current, v_w_current, u_prev)\n",
    "                # original_score = (abs(F.cosine_similarity(u_prev[0][:, 0], u_w_current[:, 0], dim=0)) + abs(F.cosine_similarity(u_prev[0][:, 1], u_w_current[:, 1], dim=0)))\n",
    "                # flipped_score =  (abs(F.cosine_similarity(u_prev[0][:, 0], u_w_current[:, 1], dim=0)) + abs(F.cosine_similarity(u_prev[0][:, 1], u_w_current[:, 0], dim=0)))\n",
    "                # eig_reversed = flipped_score > original_score\n",
    "                # bar.set_description(f'loss: {loss.item():.4f} {original_score.item():.8f} {flipped_score.item():.8f}')\n",
    "                # if eig_reversed:\n",
    "                print(\"reversed\")\n",
    "        if eig_reversed:\n",
    "            u_w_current = u_w_current[:, [1, 0]]\n",
    "            s_w_current = s_w_current[[1, 0]]\n",
    "            v_w_current = v_w_current[:, [1, 0]]\n",
    "        if u_prev is None:\n",
    "            u_prev = [u_w_current.clone()]\n",
    "        if epoch > 100:\n",
    "            u_prev.pop(0)\n",
    "            u_prev.append(u_w_current.clone())\n",
    "\n",
    "        # Measurement\n",
    "\n",
    "        for i in range(s_out):\n",
    "            weight_singular[i].append(s_w_current[i].cpu().item())\n",
    "            feature_alignment[i].append(torch.norm(e[i].unsqueeze(dim=0) @ w_current.T).cpu().item())\n",
    "        subspace_alignment.append(\n",
    "            (torch.norm(v_w_current[:, :2].T @ gamma_v[:, :2].cuda(), p='fro') ** 2 / 2).cpu().item())\n",
    "\n",
    "        for i in range(2):\n",
    "            for j in range(2):\n",
    "                feature_weight_r_singular_alignment[i][j].append(\n",
    "                    ((u_w_current[:, i] @ w_current @ e[j].cuda()).cpu()).item())\n",
    "\n",
    "    feature_weight_r_singular_alignment = np.array(feature_weight_r_singular_alignment)\n",
    "    target_output_dict[\"loss\"] = np.array(loss_values)\n",
    "    target_output_dict[\"eiglist\"] = np.array(eiglist)\n",
    "    target_output_dict[\"weight_singular\"] = np.array(weight_singular)\n",
    "    target_output_dict[\"subspace_alignment\"] = np.array(subspace_alignment)\n",
    "    target_output_dict[\"feature_weight_r_singular_alignment\"] = feature_weight_r_singular_alignment\n",
    "    target_output_dict[\"feature_alignment\"] = np.array(feature_alignment)"
   ],
   "outputs": [],
   "execution_count": 41
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:31:08.162728Z",
     "start_time": "2025-09-24T09:30:26.270165Z"
    }
   },
   "cell_type": "code",
   "source": [
    "e = create_segment_vectors(sizes).to(device)\n",
    "\n",
    "output_dict[loss_type] = {}\n",
    "if \"BarlowTwins\" in loss_type:\n",
    "    for lambd in config[loss_type][\"lambdas\"]:\n",
    "        if \"slope\" in config[loss_type]:\n",
    "            for slope in config[loss_type][\"slope\"]:\n",
    "                lossFn = BTLoss(use_batchnorm=False, in_feature=s_out, lambd=float(lambd)).to(device)\n",
    "                train(loss_type, lambd=lambd, slope=slope)\n",
    "        else:\n",
    "            lossFn = BTLoss(use_batchnorm=False, in_feature=s_out, lambd=float(lambd)).to(device)\n",
    "            train(loss_type, lambd=lambd)\n",
    "elif loss_type == \"SimCLR\":\n",
    "    lossFn = SimCLRLoss(batch, 0.5).to(device)\n",
    "    train(loss_type)\n",
    "else:\n",
    "    if \"lambdas\" in config[loss_type]:\n",
    "        for lambd in config[loss_type][\"lambdas\"]:\n",
    "            lossFn = VICRegLoss(cov_coeff=float(lambd)).to(device)\n",
    "            train(loss_type, lambd=lambd)\n",
    "    else:\n",
    "        lossFn = VICRegLoss(cov_coeff=float(\"1\")).to(device)\n",
    "        train(loss_type)"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sequential(\n",
      "  (0): Linear(in_features=8, out_features=8, bias=False)\n",
      "  (1): ReLU(inplace=True)\n",
      "  (2): Linear(in_features=8, out_features=8, bias=False)\n",
      "  (3): ReLU(inplace=True)\n",
      "  (4): Linear(in_features=8, out_features=8, bias=False)\n",
      "  (5): ReLU(inplace=True)\n",
      "  (6): Linear(in_features=8, out_features=2, bias=False)\n",
      ")\n",
      "before tensor([0.0648, 0.0522], device='cuda:0')\n",
      "after tensor([0.0648, 0.0522], device='cuda:0')\n",
      "0.2448514848947525\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "loss: 0.0049 4.23613787  1.35864186: 100%|██████████| 4000/4000 [00:41<00:00, 95.60it/s] \n"
     ]
    }
   ],
   "execution_count": 42
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:31:08.323965Z",
     "start_time": "2025-09-24T09:31:08.279713Z"
    }
   },
   "cell_type": "code",
   "source": [
    "lambda_show = \"0\"\n",
    "plt.plot(output_dict[loss_type][lambda_show][\"eiglist\"][0])\n",
    "plt.plot(output_dict[loss_type][lambda_show][\"eiglist\"][1])\n",
    "# plt.yscale('log')"
   ],
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'0'",
     "output_type": "error",
     "traceback": [
      "\u001B[31m---------------------------------------------------------------------------\u001B[39m",
      "\u001B[31mKeyError\u001B[39m                                  Traceback (most recent call last)",
      "\u001B[36mCell\u001B[39m\u001B[36m \u001B[39m\u001B[32mIn[43]\u001B[39m\u001B[32m, line 2\u001B[39m\n\u001B[32m      1\u001B[39m lambda_show = \u001B[33m\"\u001B[39m\u001B[33m0\u001B[39m\u001B[33m\"\u001B[39m\n\u001B[32m----> \u001B[39m\u001B[32m2\u001B[39m plt.plot(\u001B[43moutput_dict\u001B[49m\u001B[43m[\u001B[49m\u001B[43mloss_type\u001B[49m\u001B[43m]\u001B[49m\u001B[43m[\u001B[49m\u001B[43mlambda_show\u001B[49m\u001B[43m]\u001B[49m[\u001B[33m\"\u001B[39m\u001B[33meiglist\u001B[39m\u001B[33m\"\u001B[39m][\u001B[32m0\u001B[39m])\n\u001B[32m      3\u001B[39m plt.plot(output_dict[loss_type][lambda_show][\u001B[33m\"\u001B[39m\u001B[33meiglist\u001B[39m\u001B[33m\"\u001B[39m][\u001B[32m1\u001B[39m])\n\u001B[32m      4\u001B[39m \u001B[38;5;66;03m# plt.yscale('log')\u001B[39;00m\n",
      "\u001B[31mKeyError\u001B[39m: '0'"
     ]
    }
   ],
   "execution_count": 43
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:31:33.905775Z",
     "start_time": "2025-09-24T09:31:33.614501Z"
    }
   },
   "cell_type": "code",
   "source": [
    "for i in range(2):\n",
    "    plt.plot(output_dict[loss_type][\"eiglist\"][i])"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    }
   ],
   "execution_count": 44
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:31:36.621354Z",
     "start_time": "2025-09-24T09:31:36.499132Z"
    }
   },
   "cell_type": "code",
   "source": " np.save(f\"{config[\"network\"]}/data.npy\", output_dict)",
   "outputs": [],
   "execution_count": 45
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T09:31:23.910993Z",
     "start_time": "2025-09-17T06:57:33.801835Z"
    }
   },
   "cell_type": "code",
   "source": "\n",
   "outputs": [],
   "execution_count": 256
  }
 ]
}
