{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "toc_visible": true,
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "# Overview\n",
        "\n",
        "In this notebook we present code for the main results of the paper. We show results for the risk - the parameter norm can be computed as the squared 2-norm of the linear regression parameters.\n",
        "\n",
        "For smoother results, the number of averages of number of values $\\gamma=m/n$ or $\\mu=n_p/n$ should be increased which linearly increases the runtime."
      ],
      "metadata": {
        "id": "MY-BujtAE32A"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "from scipy import linalg\n",
        "from scipy.integrate import cumtrapz\n",
        "from tqdm import tqdm\n",
        "from sklearn.model_selection import train_test_split\n",
        "import matplotlib.pyplot as plt"
      ],
      "metadata": {
        "id": "yxUgSaQL8tAv"
      },
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "---\n",
        "# Models"
      ],
      "metadata": {
        "id": "GtaHjHuv8p7f"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## A) PCA-regression model"
      ],
      "metadata": {
        "id": "DlgvpGC8FLsy"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "class ModelPca(object):\n",
        "    def __init__(self, n_latent):\n",
        "        super(ModelPca, self).__init__()\n",
        "        \"\"\"\n",
        "        This is a model of the form\n",
        "        input x --[PCA]--> z_hat --[Regression]--> output\n",
        "        \"\"\"\n",
        "        # save to self\n",
        "        self.n_latent = n_latent\n",
        "\n",
        "        # allocation\n",
        "        self.components = None\n",
        "        self.theta_hat = None\n",
        "\n",
        "    def fit(self, x_train, y_train):\n",
        "        U, S = self.fit_encode(x_train)\n",
        "        # get least squares solution by using pre-computed SVD\n",
        "        self.theta_hat = np.diag(1. / S[:self.n_latent]) @ (U[:, :self.n_latent].T @ y_train)\n",
        "\n",
        "    def fit_encode(self, x_train):\n",
        "        U, S, Vt = linalg.svd(x_train, full_matrices=False)\n",
        "        V = Vt.T\n",
        "        self.components = V[:, :self.n_latent]\n",
        "        return U, S\n",
        "\n",
        "    def encode(self, x):\n",
        "        z_hat = x @ self.components\n",
        "        return z_hat\n",
        "\n",
        "    def fit_regression(self, x_train, y_train):\n",
        "        # transform to latent\n",
        "        z_hat = self.encode(x_train)\n",
        "        # get least squares solution\n",
        "        self.theta_hat, _, _, _ = linalg.lstsq(z_hat, y_train)\n",
        "\n",
        "    def predict(self, x_test):\n",
        "        # transform to latent\n",
        "        z_hat = self.encode(x_test)\n",
        "        # make prediction\n",
        "        y_pred = z_hat @ self.theta_hat\n",
        "        return y_pred"
      ],
      "metadata": {
        "id": "e1gE3w2U8zp_"
      },
      "execution_count": 2,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## B) PCA-regression model (analytical solution)"
      ],
      "metadata": {
        "id": "wTX_UWcgH3xV"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "class ModelPcaAnalytical(object):\n",
        "    def __init__(self, n_latent, n_features, n_data, r, sigma2_y, gamma):\n",
        "        super(ModelPcaAnalytical, self).__init__()\n",
        "        \"\"\"\n",
        "        only holds in the isotropic case\n",
        "        \"\"\"\n",
        "        self.n_latent = n_latent  # latent space dim\n",
        "        self.n_features = n_features  # number of features\n",
        "        self.n_data = n_data  # number of train data points\n",
        "        self.r = r  # norm of true parameter\n",
        "        self.sigma2_y = sigma2_y  # noise variance\n",
        "        self.gamma = gamma  # overparametrization factor\n",
        "\n",
        "        # risk: bias\n",
        "        if self.gamma < 1:\n",
        "            self.risk_bias = r ** 2 * (1 - min(self.n_latent, self.n_features) / self.n_features)\n",
        "        else:\n",
        "            self.risk_bias = r ** 2 * (1 - min(self.n_latent, self.n_data) / self.n_features)\n",
        "        # risk: variance\n",
        "        self.risk_var = None\n",
        "\n",
        "    def fit(self):\n",
        "        \"\"\"\n",
        "        more evaluation points are better, especially if we integrate from 0 since then MP has its mass concentrated\n",
        "        closer to zero. A logspace would be more suited but this would not be appropriate otherwise...\n",
        "        \"\"\"\n",
        "        num_eval_points = 1_000_000\n",
        "        # bounds of the MP distribution\n",
        "        gamma_p = (1 + np.sqrt(self.gamma)) ** 2\n",
        "        gamma_n = (1 - np.sqrt(self.gamma)) ** 2\n",
        "        # get mp\n",
        "        x = np.linspace(gamma_n, gamma_p, num_eval_points)\n",
        "        mp = self.compute_marchenko_pastur(x, gamma_p, gamma_n, self.gamma)\n",
        "        # cumulative integrate it\n",
        "        mp_integrate = cumtrapz(mp, x)\n",
        "        # find lambda_min\n",
        "        cond = 1 - self.n_latent / self.n_features\n",
        "        idx = np.where(mp_integrate > cond)[0][0] - 1\n",
        "        # integrate over mp * 1/x\n",
        "        x1 = np.linspace(x[idx], gamma_p, num_eval_points)\n",
        "        mp_integrate1 = np.trapz(self.compute_marchenko_pastur(x1, gamma_p, gamma_n, self.gamma) * 1 / x1, x1)\n",
        "        # get final solution\n",
        "        self.risk_var = self.sigma2_y * self.n_features / self.n_data * mp_integrate1\n",
        "\n",
        "\n",
        "    def get_risk(self):\n",
        "        return self.risk_bias + self.risk_var + self.sigma2_y, self.risk_bias, self.risk_var\n",
        "\n",
        "    @staticmethod\n",
        "    def compute_marchenko_pastur(x, gamma_p, gamma_n, gamma):\n",
        "        mp = 1 / (2 * np.pi) * np.sqrt((gamma_p - x) * (x - gamma_n)) / (gamma * x)\n",
        "        return mp * gamma if gamma > 1 else mp"
      ],
      "metadata": {
        "id": "yCT64EQcH9Vr"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## C) Direct regression model"
      ],
      "metadata": {
        "id": "l6JI5Hk_FsWS"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "class ModelDirRegression(object):\n",
        "    def __init__(self):\n",
        "        super(ModelDirRegression, self).__init__()\n",
        "        \"\"\"\n",
        "        This is a direct regression model for comparison of the form\n",
        "        input x --[Regression]--> output\n",
        "        \"\"\"\n",
        "\n",
        "    def fit(self, x_train, y_train):\n",
        "        # get least squares solution\n",
        "        self.theta_hat, _, _, _ = linalg.lstsq(x_train, y_train)\n",
        "\n",
        "    def predict(self, x_test):\n",
        "        # make prediction\n",
        "        y_pred = x_test @ self.theta_hat\n",
        "        return y_pred"
      ],
      "metadata": {
        "id": "d0zKSGW7_DJ2"
      },
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "---\n",
        "# Data generators"
      ],
      "metadata": {
        "id": "huKYLvOY80gn"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Isotropic data generator\n",
        "def get_dataset_isotropic(n_data, n_features, sigma2_y=1, r_theta=1):\n",
        "    # ####### generate x #######\n",
        "    x = np.random.randn(n_data, n_features)\n",
        "    # parameters\n",
        "    theta = np.ones(n_features) * r_theta / np.sqrt(n_features)\n",
        "    # model noise\n",
        "    epsilon = np.random.randn(n_data) * np.sqrt(sigma2_y)\n",
        "    # output\n",
        "    y = x @ theta + epsilon\n",
        "    return x, y\n",
        "\n",
        "\n",
        "# Latent variable data generator\n",
        "def get_dataset_latent(n_data, n_features, n_latent,\n",
        "                       snr_x=1, r_theta=1, sigma2_y=0, decay_rate=0):\n",
        "    # sample latent variable\n",
        "    temp = np.random.randn(n_data, n_latent)\n",
        "    # matrix for decay rate\n",
        "    A = np.sqrt(np.exp(-decay_rate * np.linspace(1, n_latent, n_latent))) * np.eye(n_latent)\n",
        "    z = temp @ A\n",
        "\n",
        "    # ####### generate x #######\n",
        "    # correction factor for SNR\n",
        "    c_factor = np.sqrt(snr_x * n_features / n_latent) * np.sqrt(n_latent / np.trace(A ** 2))\n",
        "    # auxiliary weights\n",
        "    aux = np.random.randn(n_features, n_latent)\n",
        "    q, r = np.linalg.qr(aux, mode='complete')\n",
        "    # weights\n",
        "    q1 = q[:, :n_latent]\n",
        "    D = c_factor * q1\n",
        "    # features\n",
        "    features = z @ D.T\n",
        "\n",
        "    noise_x = np.random.randn(n_data, n_features)\n",
        "\n",
        "    # data\n",
        "    x = features + noise_x\n",
        "\n",
        "    # ####### generate y #######\n",
        "    # noise\n",
        "    noise_y = np.sqrt(sigma2_y) * np.random.randn(n_data, 1)\n",
        "    # weights\n",
        "    theta = np.sqrt(r_theta ** 2 * n_latent) / np.sqrt(n_latent * np.trace(A**2)) * np.ones([n_latent, 1])\n",
        "    y = z @ theta + noise_y\n",
        "\n",
        "    return x, y"
      ],
      "metadata": {
        "id": "OQ2avrpG82DP"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "---\n",
        "# Supervised case\n",
        "\n",
        "The following results correspond to the results in section 4.2."
      ],
      "metadata": {
        "id": "AbwpMt0B85z-"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## A) Results with isotropic \n",
        "\n",
        "This result corresponds to the risk in Figure 2."
      ],
      "metadata": {
        "id": "3Ste_PaB9UUD"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# dataset options\n",
        "train_size = 400\n",
        "test_size = 400\n",
        "r_theta = 1\n",
        "sigma2_y = 1\n",
        "\n",
        "# model options\n",
        "gamma_min, gamma_max, gamma_num = 0.3, 20, 30\n",
        "gamma_list = np.logspace(np.log10(gamma_min), np.log10(gamma_max), gamma_num)\n",
        "n_latent_list = [25, 50, 100]\n",
        "num_avgs = 20"
      ],
      "metadata": {
        "id": "XptMWu6TwoBA"
      },
      "execution_count": 6,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "seed = 42\n",
        "\n",
        "##############################\n",
        "# Setup\n",
        "##############################\n",
        "# define risk\n",
        "compute_risk = lambda y_, y_pred_: 1 / len(y_) * np.linalg.norm(y_ - y_pred_) ** 2\n",
        "\n",
        "# allocate \n",
        "logs_list = ['risk_dirreg']\n",
        "for i in range(len(n_latent_list)):\n",
        "    logs_list.append('risk_pca{}'.format(i))\n",
        "logs = dict()\n",
        "for lgs in logs_list:\n",
        "    logs[lgs] = np.zeros([num_avgs, gamma_num])\n",
        "for i in range(len(n_latent_list)):\n",
        "    logs['risk_pca_analytical{}'.format(i)] = np.zeros([1,gamma_num])\n",
        "\n",
        "##############################\n",
        "# overparametrization loop\n",
        "##############################\n",
        "# loop over averagings\n",
        "for i_avgs in range(num_avgs):\n",
        "    desc = \"run {}/{}\".format(i_avgs+1, num_avgs)\n",
        "\n",
        "    # loop over gamma\n",
        "    for i_gamma, gamma in tqdm(enumerate(gamma_list), total=len(gamma_list), desc=desc):\n",
        "        # compute number of features\n",
        "        n_features = int(gamma * train_size)\n",
        "\n",
        "        # get data\n",
        "        x, y = get_dataset_isotropic(train_size + test_size,\n",
        "                                    n_features=n_features,\n",
        "                                    sigma2_y=sigma2_y,\n",
        "                                    r_theta=r_theta)\n",
        "        x_train, x_test, y_train, y_test = train_test_split(x, y,\n",
        "                                                    random_state=seed + i_avgs,\n",
        "                                                    train_size=train_size,\n",
        "                                                    test_size=test_size)\n",
        "        \n",
        "        # loop over multiple PCA models\n",
        "        for i_latent, n_latent in enumerate(n_latent_list):\n",
        "            # Model PCA\n",
        "            model = ModelPca(n_latent=n_latent)\n",
        "            model.fit(x_train, y_train)\n",
        "            y_pred = model.predict(x_test)\n",
        "            risk = compute_risk(y_test, y_pred)\n",
        "            logs['risk_pca{}'.format(i_latent)][i_avgs, i_gamma] = risk\n",
        "        \n",
        "        # direct regression model\n",
        "        model_dirreg = ModelDirRegression()\n",
        "        model_dirreg.fit(x_train,y_train)\n",
        "        y_pred = model_dirreg.predict(x_test)\n",
        "        risk = compute_risk(y_test,y_pred)\n",
        "        logs['risk_dirreg'][i_avgs, i_gamma] = risk\n",
        "\n",
        "        # analytical model\n",
        "        if i_avgs == 0:\n",
        "            # compute number of features\n",
        "            n_features = int(gamma * train_size)\n",
        "\n",
        "            # loop over multiple PCA models\n",
        "            for i_latent, n_latent in enumerate(n_latent_list):\n",
        "\n",
        "                # analytical model\n",
        "                model_analytical = ModelPcaAnalytical(n_latent=n_latent,\n",
        "                                                    n_features=n_features,\n",
        "                                                    n_data=train_size,\n",
        "                                                    r=r_theta,\n",
        "                                                    sigma2_y=sigma2_y,\n",
        "                                                    gamma=gamma)\n",
        "                model_analytical.fit()\n",
        "                risk, bias, var = model_analytical.get_risk()\n",
        "                logs['risk_pca_analytical{}'.format(i_latent)][:, i_gamma] = risk"
      ],
      "metadata": {
        "id": "u8RC2umU9rFI",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "829de844-4ed4-4f57-d4f0-15e13ebf421b"
      },
      "execution_count": 7,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "run 1/20: 100%|██████████| 30/30 [00:24<00:00,  1.21it/s]\n",
            "run 2/20: 100%|██████████| 30/30 [00:17<00:00,  1.74it/s]\n",
            "run 3/20: 100%|██████████| 30/30 [00:17<00:00,  1.75it/s]\n",
            "run 4/20: 100%|██████████| 30/30 [00:16<00:00,  1.77it/s]\n",
            "run 5/20: 100%|██████████| 30/30 [00:17<00:00,  1.72it/s]\n",
            "run 6/20: 100%|██████████| 30/30 [00:17<00:00,  1.75it/s]\n",
            "run 7/20: 100%|██████████| 30/30 [00:18<00:00,  1.65it/s]\n",
            "run 8/20: 100%|██████████| 30/30 [00:17<00:00,  1.76it/s]\n",
            "run 9/20: 100%|██████████| 30/30 [00:17<00:00,  1.76it/s]\n",
            "run 10/20: 100%|██████████| 30/30 [00:16<00:00,  1.78it/s]\n",
            "run 11/20: 100%|██████████| 30/30 [00:16<00:00,  1.79it/s]\n",
            "run 12/20: 100%|██████████| 30/30 [00:16<00:00,  1.77it/s]\n",
            "run 13/20: 100%|██████████| 30/30 [00:17<00:00,  1.74it/s]\n",
            "run 14/20: 100%|██████████| 30/30 [00:16<00:00,  1.78it/s]\n",
            "run 15/20: 100%|██████████| 30/30 [00:16<00:00,  1.78it/s]\n",
            "run 16/20: 100%|██████████| 30/30 [00:17<00:00,  1.75it/s]\n",
            "run 17/20: 100%|██████████| 30/30 [00:17<00:00,  1.75it/s]\n",
            "run 18/20: 100%|██████████| 30/30 [00:18<00:00,  1.66it/s]\n",
            "run 19/20: 100%|██████████| 30/30 [00:16<00:00,  1.78it/s]\n",
            "run 20/20: 100%|██████████| 30/30 [00:16<00:00,  1.78it/s]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# average the runs\n",
        "logs_avg = dict()\n",
        "for key in logs:\n",
        "    logs_avg[key] = np.mean(logs[key], axis=0)\n",
        "\n",
        "##############################\n",
        "# show results\n",
        "###############################\n",
        "n_plots = 1\n",
        "fig, axs = plt.subplots(1, n_plots, figsize=(n_plots * 6.4, 4.8))\n",
        "# colors\n",
        "cmap = plt.get_cmap('rainbow')  # rainbow, jet\n",
        "colors = cmap(np.linspace(0, 1, len(n_latent_list)))\n",
        "\n",
        "# pca model\n",
        "for i in range(len(n_latent_list)):\n",
        "    axs.errorbar(gamma_list,\n",
        "                    logs_avg['risk_pca{}'.format(i)],\n",
        "                    color=colors[i],\n",
        "                    label='pca, d={}'.format(n_latent_list[i]))\n",
        "    # analytical solutoin\n",
        "    axs.plot(gamma_list,\n",
        "             np.squeeze(logs['risk_pca_analytical{}'.format(i)]),\n",
        "             color=colors[i],\n",
        "             marker='x',\n",
        "             linestyle='none')\n",
        "# direct regression results\n",
        "axs.errorbar(gamma_list,\n",
        "            logs_avg['risk_dirreg'],\n",
        "            color='k',\n",
        "            label='dir. reg')\n",
        "# reference lines\n",
        "axs.axvline(x=1, color='k', linestyle='dashed', alpha=0.5)\n",
        "# formatting\n",
        "axs.set_xscale(\"log\")\n",
        "axs.set_xticks([0.5, 1.0, 2.0, 5.0, 10.0])\n",
        "axs.set_xticklabels([0.5, 1.0, 2.0, 5.0, 10.0])\n",
        "axs.set_xlim([gamma_min, gamma_max])\n",
        "# plot setting\n",
        "axs.set_title('Supervised results on isotropic data')\n",
        "axs.set_ylabel('Risk')\n",
        "axs.set_xlabel(r'$\\gamma=m/n$')\n",
        "axs.set_ylim(bottom=1.25, top=2.75)\n",
        "axs.legend()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 361
        },
        "id": "B1ix6atcv5xh",
        "outputId": "31f86523-f0e4-4928-cb83-f8d9bb452039"
      },
      "execution_count": 8,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7f60ce9eb190>"
            ]
          },
          "metadata": {},
          "execution_count": 8
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 460.8x345.6 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## B) Results with latent variable data \n",
        "\n",
        "This result corresponds to the risk in Figure 3 (left) since by default in this notebook we choose $\\alpha=0.25$. You can simply change it with the paramter decay_rate."
      ],
      "metadata": {
        "id": "bwgET9lV9SVt"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# options\n",
        "train_size = 400\n",
        "test_size = 400\n",
        "snr_x = 1\n",
        "r_theta = 1\n",
        "sigma2_y = 0\n",
        "n_latent_true = 20\n",
        "decay_rate = 0.25\n",
        "\n",
        "# model options\n",
        "gamma_min, gamma_max, gamma_num = 0.3, 20, 30\n",
        "gamma_list = np.logspace(np.log10(gamma_min), np.log10(gamma_max), gamma_num)\n",
        "n_latent_list = [5, 15, 20, 40]\n",
        "num_avgs = 10"
      ],
      "metadata": {
        "id": "7MgjvMU19slv"
      },
      "execution_count": 9,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "seed = 42\n",
        "\n",
        "##############################\n",
        "# Setup\n",
        "##############################\n",
        "# define risk\n",
        "compute_risk = lambda y_, y_pred_: 1 / len(y_) * np.linalg.norm(y_ - y_pred_) ** 2\n",
        "\n",
        "# allocate \n",
        "logs_list = ['risk_dirreg']\n",
        "for i in range(len(n_latent_list)):\n",
        "    logs_list.append('risk_pca{}'.format(i))\n",
        "logs = dict()\n",
        "for lgs in logs_list:\n",
        "    logs[lgs] = np.zeros([num_avgs, gamma_num])\n",
        "\n",
        "##############################\n",
        "# overparametrization loop\n",
        "##############################\n",
        "# loop over averagings\n",
        "for i_avgs in range(num_avgs):\n",
        "    desc = \"run {}/{}\".format(i_avgs+1, num_avgs)\n",
        "\n",
        "    # loop over gamma\n",
        "    for i_gamma, gamma in tqdm(enumerate(gamma_list), total=len(gamma_list), desc=desc):\n",
        "        # compute number of features\n",
        "        n_features = int(gamma * train_size)\n",
        "\n",
        "        # get data\n",
        "        x, y = get_dataset_latent(n_data=train_size + test_size,\n",
        "                                  n_features=n_features,\n",
        "                                  n_latent=n_latent_true,\n",
        "                                  snr_x=snr_x,\n",
        "                                  r_theta=r_theta,\n",
        "                                  sigma2_y=sigma2_y,\n",
        "                                  decay_rate=decay_rate)\n",
        "        x_train, x_test, y_train, y_test = train_test_split(x, y,\n",
        "                                                    random_state=seed + i_avgs,\n",
        "                                                    train_size=train_size,\n",
        "                                                    test_size=test_size)\n",
        "        \n",
        "        # loop over multiple PCA models\n",
        "        for i_latent, n_latent in enumerate(n_latent_list):\n",
        "            # Model PCA\n",
        "            model = ModelPca(n_latent=n_latent)\n",
        "            model.fit(x_train, y_train)\n",
        "            y_pred = model.predict(x_test)\n",
        "            risk = compute_risk(y_test, y_pred)\n",
        "            logs['risk_pca{}'.format(i_latent)][i_avgs, i_gamma] = risk\n",
        "        \n",
        "        # direct regression model\n",
        "        model_dirreg = ModelDirRegression()\n",
        "        model_dirreg.fit(x_train,y_train)\n",
        "        y_pred = model_dirreg.predict(x_test)\n",
        "        risk = compute_risk(y_test,y_pred)\n",
        "        logs['risk_dirreg'][i_avgs, i_gamma] = risk"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "yMR1xFIp0Iy1",
        "outputId": "a90eb47d-d9ea-45cf-f80c-4c05397738bb"
      },
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "run 1/10: 100%|██████████| 30/30 [00:24<00:00,  1.20it/s]\n",
            "run 2/10: 100%|██████████| 30/30 [00:24<00:00,  1.20it/s]\n",
            "run 3/10: 100%|██████████| 30/30 [00:24<00:00,  1.20it/s]\n",
            "run 4/10: 100%|██████████| 30/30 [00:24<00:00,  1.22it/s]\n",
            "run 5/10: 100%|██████████| 30/30 [00:24<00:00,  1.22it/s]\n",
            "run 6/10: 100%|██████████| 30/30 [00:24<00:00,  1.20it/s]\n",
            "run 7/10: 100%|██████████| 30/30 [00:25<00:00,  1.16it/s]\n",
            "run 8/10: 100%|██████████| 30/30 [00:24<00:00,  1.20it/s]\n",
            "run 9/10: 100%|██████████| 30/30 [00:24<00:00,  1.20it/s]\n",
            "run 10/10: 100%|██████████| 30/30 [00:24<00:00,  1.21it/s]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# average the runs\n",
        "logs_avg = dict()\n",
        "for key in logs:\n",
        "    logs_avg[key] = np.mean(logs[key], axis=0)\n",
        "\n",
        "##############################\n",
        "# show results\n",
        "###############################\n",
        "n_plots = 1\n",
        "fig, axs = plt.subplots(1, n_plots, figsize=(n_plots * 6.4, 4.8))\n",
        "# colors\n",
        "cmap = plt.get_cmap('rainbow')  # rainbow, jet\n",
        "colors = cmap(np.linspace(0, 1, len(n_latent_list)))\n",
        "\n",
        "# pca model\n",
        "for i in range(len(n_latent_list)):\n",
        "    axs.errorbar(gamma_list,\n",
        "                    logs_avg['risk_pca{}'.format(i)],\n",
        "                    color=colors[i],\n",
        "                    label='pca, d={}'.format(n_latent_list[i]))\n",
        "# direct regression results\n",
        "axs.errorbar(gamma_list,\n",
        "            logs_avg['risk_dirreg'],\n",
        "            color='k',\n",
        "            label='dir. reg')\n",
        "# reference lines\n",
        "axs.axvline(x=1, color='k', linestyle='dashed', alpha=0.5)\n",
        "# formatting\n",
        "axs.set_xscale(\"log\"), axs.set_yscale(\"log\")\n",
        "axs.set_xticks([0.5, 1.0, 2.0, 5.0, 10.0])\n",
        "axs.set_xticklabels([0.5, 1.0, 2.0, 5.0, 10.0])\n",
        "axs.set_xlim([gamma_min, gamma_max])\n",
        "# plot setting\n",
        "axs.set_title('Supervised results on latent variable data, ' + \n",
        "              r'$\\alpha={}$'.format(decay_rate))\n",
        "axs.set_ylabel('Risk')\n",
        "axs.set_xlabel(r'$\\gamma=m/n$')\n",
        "axs.set_ylim(bottom=None, top=0.5)\n",
        "axs.legend()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 363
        },
        "id": "AM9FlXko0KZn",
        "outputId": "5b17de94-911e-4929-d3bf-89c81f4a02ce"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7f60ce3e5dd0>"
            ]
          },
          "metadata": {},
          "execution_count": 11
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 460.8x345.6 with 1 Axes>"
            ],
            "image/png": "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T58+5ObmsmPHjhq/J5IQomqUUpu11r1Lfc1Tk9Dy5cvPJpqipJOQkACAUopOnToRExNDr169WLlyJcuXL6dt27bMmDGDsWPHuuULzWaz8dFHH/HMM89w4sQJfHx8GDJkCCNGjGD48OF06tRJvmhLmDNnDvfeey/r1q1jwIAB7g5HCFGKBpeEfHx8dGFhIWAknA4dOtC7d29iYmLo3bs3PXv2vKAW8cMPPzBlyhR27tzJwIEDmTlzJn369Km1mH/88Ucee+wxtm/fTr9+/Zg2bRpXXHGFxwww2Lt3L2D0XblSVlYWzZo1Y8yYMXz00UcuLVsI4RrlJSG01h43hYWF6VdffVWvWbNGp6ena2cVFhbqd999V0dGRmpA33777frYsWNOr18V27dv18OHD9eAbtu2rV64cKG22+01uk13+PDDD/WHH35YI2Xff//92s/PT6elpdVI+UKI6gE26TK+rz1yYELbtm159NFHGTJkCMHBwU6v5+Xlxb333sv+/ft56qmnWLRoER06dOCZZ54hKyvLpTGePHmSe+65h549e/L7778zc+ZM4uLiuPHGG6XJrZImTpxIXl4eH3/8sbtDEUJUkkcmoeoKDg7mxRdfZO/evYwZM4Z//etfREdH88EHH2Cz2apVdlZWFs8//zzt27fn448/ZtKkSRw4cIDJkyfXiUER9dHFF19M3759mT17NtoDm5eF8GSShMrRunVrPv30UzZs2EDbtm25++67iYmJYcmSJezZs4fU1FTsdrtTZdlsNt5//306dOjAc889x6hRo4iLi2PmzJmEhYXV8J54vokTJxIXF8evv/7q7lCEEJUgJ6s6oV+/fqxbt46FCxcydepUrrvuurOvmc1mwsPDiYiIoHHjxkRERFww2e12XnrpJXbu3En//v354osvZCSXi40bN47Jkycze/ZsBg0a5O5whBBO8sjRcWWdJ+QKeXl5rFu3jqSkJFJSUkhJSeHUqVNnHxdNaWlp5zUNtWvXjpdfftltw7/dLT09HaBG7+b60EMPMWfOHBISEggPD6+x7QghKqfBDdGuySTkLJvNRmpqKikpKWRkZNCrVy/p86lhO3bsoEePHsycOZPJkye7OxwhhIMkIeF2Rde469atW41uZ8CAAaSlpREXF9cga5xC1EXlJSEZmCBqxaZNm6iNHwYTJ05k7969Lr13kRCi5nhk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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "---\n",
        "# Extension for pre-training\n",
        "\n",
        "This result corresponds to the full risk with pre-training in Figure 5 (right) sinec we choose $\\alpha=0.25$ in this notebook. You can simply change it with the paramter decay_rate. The second result here corresponds to the slices risk in figure 6."
      ],
      "metadata": {
        "id": "STp3LSx-9lqh"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# options\n",
        "train_size = 400\n",
        "test_size = 400\n",
        "snr_x = 1\n",
        "r_theta = 1\n",
        "sigma2_y = 0\n",
        "n_latent_true = 20\n",
        "n_latent = 20\n",
        "decay_rate = 0.25\n",
        "\n",
        "# model options\n",
        "gamma_min, gamma_max, gamma_num = 0.3, 12, 20\n",
        "gamma_list = np.logspace(np.log10(gamma_min), np.log10(gamma_max), gamma_num)\n",
        "mu_min, mu_max, mu_num = 1, 5, 5\n",
        "mu_list = np.linspace(mu_min, mu_max, mu_num)\n",
        "num_avgs = 10"
      ],
      "metadata": {
        "id": "GtblIULi90wa"
      },
      "execution_count": 12,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "seed = 42\n",
        "##############################\n",
        "# Setup\n",
        "##############################\n",
        "# define risk\n",
        "compute_risk = lambda y_, y_pred_: 1 / len(y_) * np.linalg.norm(y_ - y_pred_) ** 2\n",
        "\n",
        "# allocate \n",
        "logs['risk_dirreg'] = np.zeros([num_avgs, gamma_num])\n",
        "logs['risk_pca_nopretrain'] = np.zeros([num_avgs, gamma_num])\n",
        "logs['risk_pca'] = np.zeros([num_avgs, gamma_num, mu_num])\n",
        "\n",
        "##############################\n",
        "# overparametrization loop\n",
        "##############################\n",
        "# loop over averagings\n",
        "for i_avgs in range(num_avgs):\n",
        "    desc = \"run {}/{}\".format(i_avgs+1, num_avgs)\n",
        "\n",
        "    # loop over gamma\n",
        "    for i_gamma, gamma in tqdm(enumerate(gamma_list), total=len(gamma_list), desc=desc):\n",
        "        # compute number of features\n",
        "        n_features = int(gamma * train_size)\n",
        "        \n",
        "        # loop over different amount of pre-training\n",
        "        for i_mu, mu in enumerate(mu_list):\n",
        "            # get number of pre-training data points\n",
        "            pretrain_size = int(mu * train_size)\n",
        "\n",
        "            # get data\n",
        "            num_data = train_size + test_size + pretrain_size\n",
        "            x, y = get_dataset_latent(n_data=num_data,\n",
        "                                    n_features=n_features,\n",
        "                                    n_latent=n_latent_true,\n",
        "                                    snr_x=snr_x,\n",
        "                                    r_theta=r_theta,\n",
        "                                    sigma2_y=sigma2_y,\n",
        "                                    decay_rate=decay_rate)\n",
        "            x_, x_test, y_, y_test = train_test_split(x, y,\n",
        "                                                      random_state=seed + i_avgs,\n",
        "                                                      train_size=pretrain_size + train_size,\n",
        "                                                      test_size=test_size)\n",
        "            x_pretrain, x_train, y_pretrain, y_train = train_test_split(x_, y_,\n",
        "                                                                        random_state=seed + i_avgs,\n",
        "                                                                        train_size=pretrain_size,\n",
        "                                                                        test_size=train_size)\n",
        "            \n",
        "            # Model PCA with pre-training\n",
        "            model = ModelPca(n_latent=n_latent)\n",
        "            model.fit_encode(x_pretrain) # pre-training\n",
        "            model.fit_regression(x_train, y_train) # training\n",
        "            y_pred = model.predict(x_test)\n",
        "            risk = compute_risk(y_test, y_pred)\n",
        "            logs['risk_pca'][i_avgs, i_gamma, i_mu] = risk\n",
        "\n",
        "        \n",
        "        # Model PCA without pre-training\n",
        "        model = ModelPca(n_latent=n_latent)\n",
        "        model.fit(x_train, y_train)\n",
        "        y_pred = model.predict(x_test)\n",
        "        risk = compute_risk(y_test, y_pred)\n",
        "        logs['risk_pca_nopretrain'][i_avgs, i_gamma] = risk\n",
        "        \n",
        "        # direct regression model\n",
        "        model_dirreg = ModelDirRegression()\n",
        "        model_dirreg.fit(x_train,y_train)\n",
        "        y_pred = model_dirreg.predict(x_test)\n",
        "        risk = compute_risk(y_test,y_pred)\n",
        "        logs['risk_dirreg'][i_avgs, i_gamma] = risk"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ET_uUaDR37XQ",
        "outputId": "f9d10498-fea9-4751-b775-d0badf1f39a0"
      },
      "execution_count": 13,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "run 1/10: 100%|██████████| 20/20 [01:34<00:00,  4.71s/it]\n",
            "run 2/10: 100%|██████████| 20/20 [01:34<00:00,  4.73s/it]\n",
            "run 3/10: 100%|██████████| 20/20 [01:34<00:00,  4.74s/it]\n",
            "run 4/10: 100%|██████████| 20/20 [01:37<00:00,  4.89s/it]\n",
            "run 5/10: 100%|██████████| 20/20 [01:41<00:00,  5.08s/it]\n",
            "run 6/10: 100%|██████████| 20/20 [01:40<00:00,  5.04s/it]\n",
            "run 7/10: 100%|██████████| 20/20 [01:42<00:00,  5.13s/it]\n",
            "run 8/10: 100%|██████████| 20/20 [01:35<00:00,  4.79s/it]\n",
            "run 9/10: 100%|██████████| 20/20 [01:35<00:00,  4.79s/it]\n",
            "run 10/10: 100%|██████████| 20/20 [01:34<00:00,  4.71s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# average the runs\n",
        "logs_avg = dict()\n",
        "for key in logs:\n",
        "    logs_avg[key] = np.mean(logs[key], axis=0)\n",
        "\n",
        "# setup plot\n",
        "n_plots = 2\n",
        "fig, axs = plt.subplots(1, n_plots, figsize=(n_plots * 6.4, 4.8))\n",
        "\n",
        "##############################\n",
        "# show full results for pre-training\n",
        "###############################\n",
        "im = axs[0].imshow(np.log10(logs_avg['risk_pca'].T), \n",
        "                   origin='lower')\n",
        "# plot options\n",
        "fig.colorbar(im, ax=axs[0])\n",
        "axs[0].set_title('Log10(Full Risk) for pre-training, ' + r'$\\alpha={}$'.format(decay_rate))\n",
        "axs[0].set_xlabel(r'$\\gamma=m/n$')\n",
        "axs[0].set_ylabel(r'$\\mu=n_p/n$')\n",
        "axs[0].set_aspect('auto')\n",
        "# ticks\n",
        "axs[0].set_yticks([0,1,2,3,4])\n",
        "axs[0].set_yticklabels([1,2,3,4,5])\n",
        "xtickslabels = [0.5, 1, 2, 5, 10]\n",
        "log10gamma_list = np.log10(gamma_list)\n",
        "inc = (log10gamma_list[-1] - log10gamma_list[0]) / (len(log10gamma_list) - 1)\n",
        "xticks = [(np.log10(x) - log10gamma_list[0]) / inc for x in xtickslabels]\n",
        "axs[0].set_xticks(xticks)\n",
        "axs[0].set_xticklabels(xtickslabels)\n",
        "\n",
        "##############################\n",
        "# show horizontal slices mu=const.\n",
        "###############################\n",
        "# colors\n",
        "cmap = plt.get_cmap('rainbow')  # rainbow, jet\n",
        "colors = cmap(np.linspace(0, 1, len(mu_list)))\n",
        "\n",
        "# pca model with pre-training\n",
        "for i, i_mu in enumerate(range(mu_num)):\n",
        "    axs[1].plot(gamma_list,\n",
        "                logs_avg['risk_pca'][:, i_mu],\n",
        "                color=colors[i],\n",
        "                label='pca, pre-train, mu={}'.format(mu_list[i_mu]))\n",
        "# pca model without pre-training\n",
        "axs[1].errorbar(gamma_list,\n",
        "                logs_avg['risk_pca_nopretrain'],\n",
        "                color='k',\n",
        "                linestyle='dashed',\n",
        "                label='pca, no pre-train')\n",
        "# direct regression results\n",
        "axs[1].errorbar(gamma_list,\n",
        "            logs_avg['risk_dirreg'],\n",
        "            color='k',\n",
        "            label='dir. reg')\n",
        "# reference lines\n",
        "axs[1].axvline(x=1, color='k', linestyle='dashed', alpha=0.5)\n",
        "# formatting\n",
        "axs[1].set_xscale(\"log\"), axs[1].set_yscale(\"log\")\n",
        "axs[1].set_xticks([0.5, 1.0, 2.0, 5.0, 10.0])\n",
        "axs[1].set_xticklabels([0.5, 1.0, 2.0, 5.0, 10.0])\n",
        "axs[1].set_xlim([gamma_min, gamma_max])\n",
        "# plot setting\n",
        "axs[1].set_title('Pre-training risk for different' + \n",
        "              r'$\\mu, \\alpha={}$'.format(decay_rate))\n",
        "axs[1].set_ylabel('Risk')\n",
        "axs[1].set_xlabel(r'$\\gamma=m/n$')\n",
        "axs[1].set_ylim(bottom=None, top=0.5)\n",
        "axs[1].legend()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 363
        },
        "id": "Vq4n7AFM-vV1",
        "outputId": "70e7681f-fafb-4fa3-f550-0712ca36e143"
      },
      "execution_count": 14,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7f60ce1e5090>"
            ]
          },
          "metadata": {},
          "execution_count": 14
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 921.6x345.6 with 3 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    }
  ]
}