{"cells":[{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":15994,"status":"ok","timestamp":1727861029615,"user":{"displayName":"秋山俊太","userId":"03114718366633972315"},"user_tz":-540},"id":"CBdVtd0iTWIX","outputId":"3c5214a1-e915-474d-da42-a5a0310aaa86"},"outputs":[],"source":["from __future__ import print_function, division\n","import numpy as np\n","import pandas as pd\n","import torch\n","import torch.nn as nn\n","import torch.nn.functional as F\n","from torch.autograd import Variable\n","import torch.optim as optim\n","import torchvision\n","from torchvision import datasets, models, transforms, utils\n","from torch.utils.data import Dataset, DataLoader\n","import matplotlib.pyplot as plt\n","import time\n","import os\n","import copy\n","\n","print(\"PyTorch Version:\", torch.__version__)\n","print(\"Torchvision Version:\", torchvision.__version__)\n","print(\"GPU is available?\", torch.cuda.is_available())"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"pJn7fK-_TwkB"},"outputs":[],"source":["from sklearn.datasets import make_regression, load_diabetes\n","from sklearn.model_selection import train_test_split\n","from sklearn.preprocessing import StandardScaler"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"afSpv3-S09n5"},"outputs":[],"source":["class BlockCoordinateNN(nn.Module):\n","    def __init__(self, input_dim = 10, r = 30, L = 4):\n","        super(BlockCoordinateNN, self).__init__()\n","        self.layers = [nn.Linear(input_dim, r)]\n","        for _ in range(L-2):\n","          self.layers.append(nn.Linear(r, r))\n","        self.layers.append(nn.Linear(r, 1))\n","        self.activation = nn.LeakyReLU(negative_slope=0.5)\n","        self.loss = [[] for _ in range(2*L)]\n","        self.L = L\n","        self.test_loss = []\n","\n","    def forward(self, x):\n","        Vs = []\n","        V = x\n","        for layer in self.layers[:-1]:\n","          Vnext = self.activation(layer(V))\n","          Vs.append(Vnext)\n","          V = Vnext\n","        output = self.layers[-1](Vnext)\n","        return output, Vs\n","\n","    def apply_singular_value_bounding(self):\n","        with torch.no_grad():\n","            for name, param in self.named_parameters():\n","                if 'weight' in name:\n","                    param.copy_(singular_value_bounding(param))"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"mbjnWaRYWO4L"},"outputs":[],"source":["def singular_value_bounding(W):\n","    # Perform Singular Value Decomposition (SVD)\n","    U, Sigma, Vt = np.linalg.svd(W, full_matrices=False)\n","\n","    # Apply bounding to singular values\n","    bounded_Sigma = [max(3/4, min(5/4, s)) for s in Sigma]\n","\n","    # Construct the diagonal matrix of bounded singular values\n","    Sigma_bounded = np.diag(bounded_Sigma)\n","\n","    # Reconstruct the matrix using the bounded singular values\n","    W_bounded = U @ Sigma_bounded @ Vt\n","\n","    return W_bounded"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"Gz7-5kqX7EQB"},"outputs":[],"source":["def compute_loss(model, Vs, batch_y, criterion, layer_index, Vnext=None):\n","    if layer_index == model.L-2:\n","        return criterion(model.layers[layer_index + 1](Vs[layer_index]).view(-1), batch_y)\n","    else:\n","        return criterion(model.activation(model.layers[layer_index + 1](Vs[layer_index])), Vnext)\n","\n","def update_weights(model, optimizer, loss, retain_graph=False):\n","    optimizer.zero_grad()\n","    loss.backward(retain_graph=retain_graph)\n","    optimizer.step()\n","\n","def train_vj(model, criterion, Vj, batch_y, Vnext, layer_index, eta, num_inner_iters=1000):\n","    if layer_index == model.L-2:\n","        for _ in range(1):\n","            loss_Vj = criterion(model.layers[layer_index + 1](Vj).view(-1), batch_y)\n","            grad = torch.autograd.grad(loss_Vj, Vj, retain_graph=True)[0]\n","            Vj = Vj - eta * grad\n","    else:\n","        for _ in range(num_inner_iters):\n","            loss_Vj = criterion(model.activation(model.layers[layer_index + 1](Vj)), Vnext)\n","            grad = torch.autograd.grad(loss_Vj, Vj, retain_graph=True)[0]\n","            Vj = Vj - eta * grad\n","    return Vj.detach(), loss_Vj\n","\n","def print_loss(model, epoch, num_epochs):\n","    print(f'Epoch [{epoch + 1}/{num_epochs}], W{model.L} Loss: {model.loss[-1][-1]:.4f}')\n","    for j in range(model.L - 1, 0, -1):\n","        print(f'Epoch [{epoch + 1}/{num_epochs}], V{j} Loss: {model.loss[2 * j][-1]:.4f}')\n","        print(f'Epoch [{epoch + 1}/{num_epochs}], W{j} Loss: {model.loss[2 * j - 1][-1]:.4f}')\n","    print(f'Epoch [{epoch + 1}/{num_epochs}], Total Loss: {model.loss[0][-1]:.4f}')"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"SYwqpESZ6RAS"},"outputs":[],"source":["def train_bcd(model, X_train_tensor, y_train_tensor, num_epochs=100, batch_size=None, eta=0.1, num_inner_iters=100):\n","    \"\"\"\n","    Train the BCD model using the given training data.\n","\n","    Parameters:\n","    - model: The model to be trained.\n","    - X_train_tensor: Tensor of training features.\n","    - y_train_tensor: Tensor of training labels.\n","    - num_epochs: Number of epochs to train (default: 100).\n","    - batch_size: Size of each training batch (default: None, meaning use full dataset).\n","    - eta: Learning rate (default: 0.1).\n","    - num_inner_iters: Number of inner iterations (default: 1).\n","\n","    Returns:\n","    - None\n","    \"\"\"\n","\n","    if batch_size is None:\n","        batch_size = len(X_train_tensor)\n","\n","    criterion = nn.MSELoss()\n","    optimizer_list = [optim.SGD(layer.parameters(), lr=eta) for layer in model.layers]\n","\n","    batch_X, batch_y = X_train_tensor, y_train_tensor\n","\n","    for epoch in range(num_epochs):\n","        outputs, Vs_init = model(batch_X)\n","        loss = criterion(outputs.view(-1), batch_y)\n","\n","        if epoch == 0:\n","            Vs = Vs_init\n","\n","        new_Vs = []\n","\n","        Vnext = None  # Initialization\n","\n","        for j in range(model.L-2, -1, -1):\n","            model.zero_grad()\n","            for param in model.layers[j + 1].parameters():\n","                param.requires_grad = True\n","\n","            loss_Wj = compute_loss(model, Vs, batch_y, criterion, j, Vnext)\n","            update_weights(model, optimizer_list[j + 1], loss_Wj, retain_graph=True)\n","\n","            model.loss[2 * (j + 1) + 1].append(loss_Wj.item())\n","\n","            for param in model.layers[j + 1].parameters():\n","                param.requires_grad = False\n","\n","            Vj = Vs[j].clone().detach().requires_grad_(True)\n","            Vj, loss_Vj = train_vj(model, criterion, Vj, batch_y, Vnext, j, eta, num_inner_iters)\n","\n","            Vnext = Vj.clone().detach().requires_grad_(False)\n","            new_Vs.insert(0, Vj)\n","            model.loss[2 * (j + 1)].append(loss_Vj.item())\n","\n","        for param in model.layers[0].parameters():\n","            param.requires_grad = True\n","\n","        for _ in range(num_inner_iters):\n","            loss_W0 = criterion(model.activation(model.layers[0](batch_X)), Vnext)\n","            update_weights(model, optimizer_list[0], loss_W0)\n","\n","        model.loss[1].append(loss_W0.item())\n","\n","        for param in model.layers[0].parameters():\n","            param.requires_grad = False\n","\n","        Vs = new_Vs\n","        model.loss[0].append(loss.item())\n","\n","        if (epoch + 1) % 10 == 0:\n","          print_loss(model, epoch, num_epochs)\n","          outputs, _ = model(X_test_tensor)\n","          test_loss = criterion(outputs.view(-1), y_test_tensor)\n","          model.test_loss.append(test_loss.item())\n","          print(f\"test_loss:{test_loss.item()}\")"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":1076745,"status":"ok","timestamp":1727842926252,"user":{"displayName":"秋山俊太","userId":"03114718366633972315"},"user_tz":-540},"id":"SzviIT4IlFw6","outputId":"927ef50e-bf7f-488d-bc36-199992fceebf"},"outputs":[],"source":["model = BlockCoordinateNN(input_dim=input_dim, L = 5)\n","model.apply_singular_value_bounding()\n","train_bcd(model, num_epochs = 5000, eta = 1., X_train_tensor = X_train_tensor, y_train_tensor = y_train_tensor, num_inner_iters=100)"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":478},"executionInfo":{"elapsed":899,"status":"ok","timestamp":1727861131913,"user":{"displayName":"秋山俊太","userId":"03114718366633972315"},"user_tz":-540},"id":"LI5WF15cXMmc","outputId":"7051a4fd-a37d-462f-a892-6a4fa0686164"},"outputs":[{"data":{"text/plain":["<matplotlib.legend.Legend at 0x77fb9d360340>"]},"execution_count":6,"metadata":{},"output_type":"execute_result"},{"data":{"image/png":"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//13lJSUAAAOHjyIS5cuYcqUKQgPD5fKBgcHIzU1tdZ1rcrhcODbb79F7969ceutt7pte/755yGTybBmzRoAgFarhVqtxr59+646QD80NBRlZWVYt26dX29Vxm67AMTwRESNSVBQkPSLuLGpLth4U8eOHatdf/bsWbzwwgvYuHEjioqK3LbVpRuxXbt2bq8jIyMBAPn5+df1/qr7CA4ORkZGBgBIXY6VVbeutnJzc1FSUoKuXbt6bIuIiEBsbCzS09MBACqVCv/617/w5JNPIjExEV26dMHIkSMxYcIE3HzzzdL75syZgx9//BETJkxAZGQkhg0bhrFjx+Lee++tVTemtzA8BSCOeSKixkQQBLeWluakunBWUlKCoUOHorS0FE899RS6d+8OvV4PmUyG1157DT/88EOt9y+Xy6tdX9tWl5reX5d9NJTU1FSMHz8e69atw44dO/D111/j3Xffxb333osvvvgCANChQwecOHECW7duxdatW7Fjxw5Mnz4d8+bNw48//ugxJs1X2G0XgNjyRETke9c76/fWrVtx6dIlvPXWW5g/fz7uuusujB49GikpKSgtLfVyLevP1a136tQpj23Vraut6Oho6PV6HD9+3GNbYWEhsrOzPVrGYmNjMW3aNHz66ae4ePEi7rvvPnz55Zf4+eefpTJqtRq33norFi1ahAMHDmDdunW4dOkS/vnPf153XeuK4SkAMTwREflecHAwAOcl9HXhau2p2rKzadOmOo13aig33ngjYmNjsWzZMhQWFkrrS0pKsHjx4uver0wmw7hx43D48GFs2LDBbdvrr78Oh8OBO+64AwBQVlbmccWmXC5Hjx49AFz5GeTl5Xkc54YbbnAr0xDYbReAGJ6IiHyvb9++kMlkWLBgAQoLC6HT6ZCYmIj+/ftf9X2DBw9GTEwM/vKXv+DcuXOIj4/HkSNH8Omnn6J79+44evRoA32C2lEoFHjzzTfxwAMPoF+/fnjkkUegUCiwbNkyREZGIiMj47pb4V599VVs3rwZEyZMwMyZM9G+fXv8+OOP+PLLLzF06FA89NBDAIDffvsNw4YNwx133IFu3bohPDwcJ0+exAcffIDExERpaofRo0cjLCwMQ4YMQUJCAoqKiqQ5tx588EGvnZNrYXgKQBzzRETke61bt8aHH36If/zjH5gxYwasViseeuiha4ansLAw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AcMTERERUR0wPBERERHVAcMTERERUR0wPBERERHVAcMTERERUR0wPBERERHVAcMTEVEjMn/+fAiCgOHDh/u7KkRUA4YnIiIiojpgeCIiIiKqA4YnIiIiojpgeCIiIiKqA4YnIgoY586dw1NPPYWuXbsiODgYQUFBSE5OxpNPPonMzEyP8suWLYMgCGjbti0AYPPmzRg7diyio6Oh1WrRtWtXvPLKKygvL7/qcc+ePYsZM2agQ4cO0Gq1CAkJwQ033ICXXnoJRqPxqu91OBxYuXIlJkyYgLi4OKjVakRHR6NPnz6YPXs2jh07dtX3b926Fbfddhuio6Oh0WjQuXNnvPjii9esMxH5kEhEFACWL18uqtVqEYAIQFSr1aJWq5Ve6/V6cePGjW7v+eijj0QAYps2bcT33ntPFARBBCCGhYWJCoVCem/v3r3FgoKCao/75Zdfuh1Xr9e7vU5ISBBPnDhR7Xtzc3PFoUOHSmVdxw4ODpZejx8/3u098+bNEwGIw4YNE9944w1REARREAQxLCxMqj8AccSIEaLNZvPKuSWiumHLExE1eps3b8bkyZNht9vx17/+FRkZGTCZTCgtLUVaWhruueceFBcX45577qm2BSo3NxdPPfUU7r77bmRmZqKwsBBGoxEffPAB1Go1Dh8+jEceecTjfYcOHcIf//hHmM1m3HTTTfj1119hNBpRVlaGb7/9FrGxsbhw4QLGjRuHkpISt/fabDZMmDABP/74I9RqNf7xj38gJycHhYWFKC4uRlZWFpYsWYIuXbpU+5l/+eUXPPfcc3juueek9xUVFWHu3LkAgG3btuHjjz/2wtklojrzd3ojIroau90udujQQQQgLlmypMZyt99+uwhAfPLJJ6V1rpYnVLTk2O12j/f997//lcrs37/fbdstt9wiAhDbt28vlpaWerz30KFDUgvWwoULq92vIAjiunXrav15XS1PAMR58+ZVW+bOO+8UAYgpKSm13i8ReQ9bnoioUfvxxx9x+vRpREVFYdq0aTWWmzx5MgBg48aN1W7/29/+BpnM87+8hx9+GPHx8QCAL774QlpfVFQk7evZZ59FUFCQx3t79+6NO++8EwDw+eefu2378MMPAQC33norbr311hrrXRO1Wo1Zs2ZVu238+PEAgF9//bXO+yWi+lP4uwJERFeza9cuAIDBYECrVq1qLGexWAAA58+f99imUCgwZMiQat8nk8kwfPhwLF++HAcOHJDWHzp0CKIoAgBSUlJqPO6oUaOwcuVK/Prrr7BarVAqlbDZbPj5558BAOPGjbvGJ6yea1B8dVznoaCg4Lr2TUT1w/BERI3apUuXAABWqxWXL1++ZnmTyeSxLioqCmq1usb3xMXFAQBycnKkdZWXXdur42q1stlsKCgoQMuWLZGfnw+r1QoAaNOmzTXrXB29Xl/jNoVCIR2TiBoeu+2IqFGz2+0AgP79+0MUxVo9/E0QBH9XgYh8iOGJiBq1mJgYANV3x9VWXl6e1K1XnaysLABAixYtpHWVly9evFjje13bFAoFIiIiAAARERFQKpX1rjcRNU4MT0TUqN10000AgN9//91tTFJd2Gw2/PTTT9VuE0URO3bsAADceOON0vobbrhBGmC+devWGve9ZcsWAEDPnj2lwKRQKNCvXz8AwP/+97/rqjMRNV4MT0TUqI0YMQLt27cHADz99NNXbUECah5EvWDBAjgcDo/1H3/8MS5cuAAAuPfee6X1YWFhGDNmDABg4cKFKCsr83jvL7/8glWrVgEA7rvvPrdtrnmj1q9fj/Xr11+1zkQUWBieiKhRUygUWLx4MRQKBXbu3ImhQ4di69at0oBsAEhPT8fixYvRt29fvP/++x77CAoKws6dO3H//fdL3Wzl5eX497//jRkzZgBwXv7vai1yeeWVV6BUKnHmzBmMGTMGR48eBeC85cr69etx6623wmazISkpCY899pjbex988EEMHjwYoijirrvuwsKFC5GXlydtv3TpEt566y3Mnj3bOyeKiBqOX2aXIiKqozVr1oh6vV6aQFKpVIqRkZFut0oBIL7yyivSeyrfnuXdd9+Vbm8SHh4uKpVK6T09e/YU8/Lyqj3uF198IapUKqlsSEiIqNFoan17liFDhkhlXbdZqe3tWWqybds26f1E1PDY8kREAWHChAk4c+YM5s2bh379+iE4OBhFRUVQq9Xo2bMnpk2bhjVr1uDZZ5+t9v2PP/44Nm7ciFtuuQUymQwymQzJycl46aWXsGfPHkRGRlb7vnvvvRfHjx/HY489hqSkJJjNZigUCvTq1Qsvvvgijh07hs6dO1f73qioKGzfvh3Lly+XbkhcWlqKoKAg9OnTB8899xxeffVVr50jImoYgig2gut6iYh8YNmyZXj44YfRpk0bnDt3zt/VIaImgi1PRERERHXA8ERERERUBwxPRERERHXA8ERERERUBxwwTkRERFQHbHkiIiIiqgOGJyIiIqI6YHgiIiIiqgOGJyIiIqI6YHgiIiIiqgOGJyIiIqI6YHgiIiIiqgOGJyIiIqI6+H9005ZVZ+anZQAAAABJRU5ErkJggg==","text/plain":["<Figure size 640x480 with 1 Axes>"]},"metadata":{},"output_type":"display_data"}],"source":["plt.plot(model.loss[0][:2500], label = \"training loss\",color = \"black\")\n","\n","\n","plt.plot(model.loss[1][:2500], label = f\"layer{1}\")\n","for idx in range(model.L-2):\n","  plt.plot(model.loss[2*(idx+1)][:2500], label = f\"layer{idx+2}\")\n","  # plt.plot(model.loss[2*(idx)-1], label = f\"W{idx+1} loss\")\n","plt.ylim([10**(-7),3*10**2])\n","plt.xlabel(\"epoch\", fontsize=18)\n","plt.ylabel(\"loss\", fontsize=18)\n","plt.yscale(\"log\")\n","plt.tick_params(labelsize=11)\n","plt.legend(fontsize=13)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"rDHemWyyXY6u"},"outputs":[],"source":[]}],"metadata":{"accelerator":"GPU","colab":{"authorship_tag":"ABX9TyOIJhGAPjV+KZ88vK3Mlcnk","gpuType":"T4","provenance":[]},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}
