{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "AUfr5HyEg7uw"
      },
      "source": [
        "# Understanding Why Generalized Reweighting Does Not Improve Over ERM\n",
        "Anonymous Authors\n",
        "\n",
        "This notebook contains all the codes of this paper. To *exactly* reproduce the results in the paper, please refer to the last section."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "kFLEYq8NhYbs"
      },
      "source": [
        "## Preliminaries"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "lhUS1MOURTM4",
        "outputId": "f639e093-acd8-46af-baee-00d1092b19b3"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "(CVXPY) Jan 04 09:18:12 AM: Encountered unexpected exception importing solver MOSEK:\n",
            "AttributeError(\"module 'mosek' has no attribute 'conetype'\")\n"
          ]
        }
      ],
      "source": [
        "import numpy as np\n",
        "from copy import deepcopy\n",
        "import matplotlib.pyplot as plt\n",
        "import pickle\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "from torch.utils.data import DataLoader\n",
        "from torch.optim import SGD\n",
        "from torchvision.datasets import MNIST\n",
        "from torchvision import transforms\n",
        "from PIL import Image\n",
        "import cvxpy as cp\n",
        "\n",
        "plt.rcParams.update({'font.size': 20})\n",
        "device = 'cuda'\n",
        "k = 0"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ZwhxXXiGRfWT"
      },
      "outputs": [],
      "source": [
        "class LinearModel(nn.Module):\n",
        "  def __init__(self, input_dim):\n",
        "    super(LinearModel, self).__init__()\n",
        "    self.input_dim = input_dim\n",
        "    self.fc = nn.Linear(input_dim, 1, bias=False)\n",
        "\n",
        "  def forward(self, x):\n",
        "    x = x.view(-1, self.input_dim)\n",
        "    return self.fc(x).flatten()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "A4EJBTZjR3IB"
      },
      "outputs": [],
      "source": [
        "# Prepare the dataset\n",
        "n0 = 5\n",
        "n1 = 1\n",
        "n = n0 + n1\n",
        "transform = transforms.Compose([transforms.ToTensor()])\n",
        "dataset = MNIST(root='./data', download=True, transform=transform)\n",
        "d0 = dataset.data[dataset.targets == 0]\n",
        "d1 = dataset.data[dataset.targets == 1]\n",
        "dataset.data = torch.cat((d0[:n0], d1[:n1]))\n",
        "dataset.targets = torch.zeros((n0+n1,))\n",
        "\n",
        "# Labels: -1, 1\n",
        "dataset.targets[:n0] = -1\n",
        "dataset.targets[n0:] = 1\n",
        "size_dataset = len(dataset.targets)\n",
        "dataloader = DataLoader(dataset, batch_size=size_dataset, shuffle=False) # full batch"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 280
        },
        "id": "OPNy_xhx706n",
        "outputId": "2876251f-1293-4327-ce1b-2b8d478f91c8"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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6N0s/fr1i7mdPXxT79aZPn16wsezF/3RuxHsu8Z1Xbt2NfJnn322n/7HP/6R8PHJNGLEiJTe17Zt24S3tWcj1ReTzxc8EyAichgbASIih7ERICJyGK8JANi0aZOf1q8B2N58800jX1JSEnNbu5+Zsk/vk//mm29ibldRUWHkr7rqqoT2b08j8sILLxh5fWqIeOwhxPpUIZS6Ll26GPnXXnstofctWrQo4WM89dRTRn748OEJvzcseCZAROQwNgJERA5jdxCAG264wU/bi33oQ/vidf/kgj4ToX0HoouLzOgzvgLmLJ/2rI320L5UNGnSJO19RKPHLkyzTeYbe1GXeHfpXnnllX66ffv2CR9j4sSJSdcrbHgmQETkMDYCREQOYyNAROQwJ68JvP3220ZeHzpmrxAWb7qBXNP7OO16l5aWZrs6OaHfpv/73//eKNNnhA3TrI2277//3sh/9913fjrM9Q6jyy67zE/Hu57SqVMnI2+v/pco+9pbvGNecsklfvqCCy5I6XhB4DeMiMhhbASIiBzGRoCIyGFOXhPYs2ePkd+7d6+fbt26tVHWq1evrNQpFn2a63grhF100UVG/vbbbw+sTmGiTw2xYcOGHNYkdStXrjTynD46cevXrzfyq1ev9tP29ZR419CSoU8fs2XLlpjHsKU6tXXQeCZAROQwNgJERA5zsjsongYNGhj5ww8/PKvH17t/AOCBBx7w03/+85+NsuLiYj89evRoo8yemdJ1jz/+eK6rYNi6dauf1oc12uypSg4+mD9Z3bvvvmvkg+gStIfwzp8/309v37495vuWLFli5E888cTMVixDeCZAROQwNgJERA5jI0BE5DB2MFouv/zyrB9TnwJ50qRJRtn999/vpwcOHGiUpXqru4uOPPLInB5fvwYAAGeddZaftocZtmrVyk/bw0UTXa2M4rv00ksT3vYvf/mLkY83VFvXokWLpOqUKzwTICJyGBsBIiKHJdQdJCJNAfQB0AtAJwC/APA9gHcBPArgUaXUAdPnichpAP4HwKkAGgDYAOARANOVUukv7ZQie+Y/PT9nzhyjbMyYMRk//pNPPmnkb7zxRj/91VdfGWVDhw7101OmTMloPWpqavDss8/ixRdfxLvvvovNmzejfv366NSpEwYOHIiBAwdGvQMyTHFNdBUue4bRTKwsZrOHEl5//fV++tFHH435vo4dOxr5FStW+OnmzZsnXY9CiGvQrrrqqphlM2bMMPLZWKEslxK9JtAPwAMAPgdQCWATgCMBXAhgNoDzRKSf0n6RItIbwAIAewA8BWA7gHIAUwB08fZJOTR//nwMHjwYrVq1Qvfu3dG2bVt8+eWXWLhwIQYNGoSXXnoJ8+fPN26xZ1zDj3GlZCTaCKwH8AcAL+p/8YvI7QD+D0BfRBqEBd7rRwB4CMB+AGcqpaq818cAeAXARSLSXyk1L1P/EEpeSUkJnnvuOfTq1cv46+buu+/GySefjAULFmDhwoXo27cvAMY1XzCulIyErgkopV5RSj1vd/kopb4AMNPLnqkVXQSgOYB5tV8ob/s9iJxuAsDgVCtNmVFWVoby8vIDTm9btmyJ6667DoDZNQHGNS8wrpSMTAwR/cF71uc7KPOel+BArwHYDeA0ETlUKbU3yjaBsmcQ1POffvqpUTZ+/Hg/ffXVVxtljRs39tPvvfeeUfbggw/6aXuWyOrqaiOv9x3279/fKNOvCWTTIYccAuCAaQpCF1d9+N7rr79ulMW7pb/2r2DgwO/DH//4Rz997LHHGmX698G+tqSvCAaYwzvtoZ0VFRV+ury83ChL5TpAovIlromKt7JXvGtE+myjgPkbta8BxNuPPostAEydOjV2ZUMqrdFBInIwgCu8rP4Fqv3lmPO8AlBK7QOwEZEG6JfpHJ+CsW/fPjz22GMAgB49euhFjGseY1wpmnSHiE4EcAKAvyullmqvF3nPO2O8r/b1n0UrFJFrRaRKRKrsm2woeKNGjcLatWvRs2dPnHvuuXoR45rHGFeKJuXuIBEZCuBmAP8BkOxttrXn3ypaoVJqFoBZAFBaWhp1m6DYQwf10/+HH37YKGvSpImftmczjOe8884z8vpfZfbpZbZNmzYNkydPRseOHVOZeTPrcT3uuOP8tN3t1rVrVz9tdw0tWrTIT9t954sXL07o2HY3gb2fPn36+OnBg80u9e7duyd0jEzJt7gmyu7Kizd8Uy/r2bNnQtvVVX7HHXfUVcXQS+lMQERuADAVwPsAuiul7M7X2r8cihDdEdZ2FAL33Xcfhg0bhuOPPx6VlZVGI+dhXPMQ40rxJN0IiMhwADMArEWkAfgiymbrvOcSu8C7jnA0IheSP0r2+BSMiooKDBkyBCeccAIqKyvRsmXLaJsxrnmGcaW6JNUIiMhIRG4eeQeRBmBLjE1f8Z57RCk7A8BhAFaFbaSBqyZNmoSbbroJnTt3RmVlZbyJrxjXPMK4UiISvibg3TgyHsBqAOdE6QLSPQNgEoD+IjJdu/mkAYDaMX0PxHpz0H71q18ZeX1KgZdffjnm++zho/rsnzb9B2f3BwcxFUWqJkyYgLFjx+Kkk07CsmXLonUV6EIdV3sVLn2VqdpRMbUyMfS2TZs2Rv7888838pMnT/bT9op1QSukuMbTtGlTI6+vBPj1119n5BidOnUy8rfddpufLiqK1YOWPxKdO2gAIg3AfgArAQy1L8gAqFZKzQEApdTXInINIl+uFSIyD5Hb0P+AyHC0ZxC5NZ1yaO7cuRg7dizq1auHrl27Rp0it7i42J8PhXHND4wrJSPRM4Gjved6AIbH2OZVAHNqM0qpRSLSDcBoRKaVqJ2QagSAacq+y4OybuPGjQAiI6L0m5d03bp1MybFYlzDj3GlZEjYY1taWqqqqqrq3jANu3bt8tPxug3sz0o/G7IXnrjmmmv8tH3Kmo9KS0tRVVV1wOlfGvsLPK7xvPLKK3565MiRRtk777zjp+3FwSdOnOin27Zta5Tly6yRukKL6wsvvOCne/fubZTVNfQzlh9++KHujUJIRFYrpUrr2o7rCRAROYyNABGRw9gIEBE5jAvNwxxWpq8GFS1PhaGsrMxPv/XWWzmsCWWSPkx35syZRpn+W7av5+jTiLiGZwJERA5jI0BE5DB2BxFRQdKHaUfLUwTPBIiIHMZGgIjIYWwEiIgcxkaAiMhhbASIiBzGRoCIyGFsBIiIHMZGgIjIYWwEiIgcxkaAiMhhoV9ZTES2AvgWwLZc16WANUPdn287pVTzTB3Qi+vHCR6bUlfX58u45qeM/WZD3wgAgIhUJbJMGqUml58vYxusXH2+jGuwMvn5sjuIiMhhbASIiByWL43ArFxXoMDl8vNlbIOVq8+XcQ1Wxj7fvLgmQEREwciXMwEiIgoAGwEiIoeFthEQkTYi8oiIfCYie0WkWkQqROTnua5bPhCRpiIySESeFZENIvKdiOwUkddF5GoROcjavlhEVJzHvAzWjbFNEeNamHIZ11CuMSwi7QGsAtACwGIA/wFwMoBhAHqISBelVE0Oq5gP+gF4AMDnACoBbAJwJIALAcwGcJ6I9FMHXhRaA2BRlP2tzUSlGNu0Ma6FKXdxVUqF7gFgKQAF4Ebr9Xu912fmuo5hfwAoA1AO4CDr9ZbeF0wB6Ku9Xuy9NoexDe+DcS3MRy7jmvN/fJQP45feP25jlA+kMYBdiEwj0SjXdc3XB4Dbvc94uvZa4P9ZMLaMa64/o3x8BB3XMHYHlXnPy5RSP+oFSqlvROQNAOcAOBXA8mxXrkD84D3vi1LWWkT+BKApgBoA/1RK/TtDx2Vsg8W4FqZA4xrGRuBY73l9jPIPEflClYBfqKSJyMEArvCyS6Jscrb30N+zAsAApdSmNA/P2AaEcS1M2YhrGEcHFXnPO2OU177+s+CrUpAmAjgBwN+VUku113cDmADgJAA/9x7dELlIdSaA5SLSKM1jM7bBYVwLU+BxDWMjUBfxnnmrc5JEZCiAmxEZuXG5XqaU2qKUGquU+pdSaof3eA2Rv+D+F0AHAIOCrmJtdQI+TkFhXAtTtuIaaCOQ4rjh2r8aimKUH2FtRwkQkRsATAXwPoDuSqntibxPKbUPkSFqAHCGt69Ux4MzthmWybh6++NvNgQyHdd4ArsmkMa44XXec0mMXR/jPcfqfySLiAwHMAWRscNnKaW2JLmLrd5zozTHgzO2GZTJuHr74282BDId1zoFOKwppXHDANqj7uFmu8HhZonGYaT3eb4NoFmK+/irt4/7U40rYxvuuHp5/mYLMK51bh/QPyStccPp/EfDh/F5jfE+ryoATerY9hQA9aO8XgZgj7efi9KJK2Mb2riext9s7h9BxDWR4wYylbSIDALwEIBZSqk/RSlfisgFjN8rpQ4YMqafljZt2hTFxcUZryMlp7q6GjU1Ndcgjbh627QHsKpp06YtGNfcq66uxrZt2yRTv1nGNTxWr169TSWwxnBQ1wTSGjeslPqviJQCGF9cXHxlVVVVMLWkhJWWlqKmpibt8eC1sS0uLt7EuOZeaam/TG1GfrOMa3iIyMeJbBdUI5DWuGERuRbAtQCwdevWaJtQbjCuhSvl2DKu+S1X9wnEHTeslJqllCpVSpU2b17n2QyFB+NauGLGlnHNb0E1Ahw3XJgY18LF2DoqqEaA44YLE+NauBhbRwXVCFR6z+dEWRGnMYAuAL4D8GZAx6dgMK6Fi7F1VCCNgFLqvwCWITLn9Q1W8Z2I3Mn2mFLq2yCOT8FgXAsXY+uuIKeSvh6Rsf7TROQsAB8gcoNDd0ROKUcHeGwKDuNauBhbBwU2Osj7y6IUwBxEvkg3I3J7+TQAv1NcbzQvMa6Fi7F1U6CLyiilPgEwMMhjUPYxroWLsXVPPq4nQEREGcJGgIjIYWwEiIgcFsaF5gvemjVrjPyJJ57op9u2bWuULVq0yE8fc8wxRtlhhx2W+coRkVN4JkBE5DA2AkREDmMjQETkMF4TCIGDDvqpLf7000+NMm3RDwwYMMAomz17drAVowN89tlnftpePOWCCy5IaZ/26n5NmjTx0x988IFR1qJFi5SOQdnx0EMP+enrrrvOKPvxxx/99Lp164yykpJY8/YFj2cCREQOYyNAROQwdgcFZM+ePX761ltvNcqef/75lPb5u9/9Lq06UWJqan6aIufFF180yu666y4//eGHHxplIoJU2O/bsWOHny4vLzfKnn76aT/drl27lI5HmbN8ubnc8ogRI/y03s1rS/W7EgSeCRAROYyNABGRw9gIEBE5jNcEAvLJJ5/4abvfUC8D4vcd6uwhZ7/5zW/8tD6UlJKzd+9eI3/JJZf4aTt22WYPQ3399df9NK8J5N769eaSy/q1wHzBMwEiIoexESAichi7gwKyc+dOP/31118HcozevXv7aXvYqT4zKR14mj569E/L5T7xxBNG2bZt2zJ+/AYNGhj5Zs2a+Wn7LnEKt/fff99Pjxs3LuZ29m9w2bJlfrpRo0YZr1eqeCZAROQwNgJERA5jI0BE5DBeE0jDhAkT/HS8vkGbPptgOvQZLaurq40yXhMwvfrqq0a+oqIiq8c/7rjjjLw+/UTPnj2zWhdKzoYNG4y8Hq/t27fHfN/EiRONfFFRUWYrliE8EyAichgbASIih7E7KA36TICJ3vUbjX4n8Nlnn22U6cPK9AUrbE8++aSR79Gjh592dUH6Xbt2+en7778/I/vUu5HsLp6FCxca+QcffNBP/+1vfzPK7LuUKbzsxZvsO/51F154oZ/u3r17YHXKJJ4JEBE5jI0AEZHD2AgQETmM1wTq8M033/jpd955xyibPn16zPc1bdrUT7dq1cooO+OMM4z8pEmT/PQhhxxilG3evDmhei5atMjI69MkuHpNQB/K98Ybb8Tczr6e07x5cz89ZswYo2zQoEF+2o5Vly5djPz48eP9tL54PAB8//33UfcJHNgHTdm1e/duI3/PPfcYef37ov/OAXPYeL7gmQARkcPYCBAROYzdQRb9LlwA6NOnj5+2F/iINyx02LBhfvq2225L+Pj6IucAMHz48ITf6zr7rum1a9cm9D69+wc48DuQqIYNG8bN6/QhovqMs5QbO3bs8NP67Lx1sWcK6NixY4ZqlD08EyAichgbASIih7ERICJyGK8JWP75z38a+X/9619ZPX7jxo2NvL4Clj7zZF3uvPNOPz116tT0K5YH9CGZQOJ97fYw0Gx48803/fT8+fOzfnwyrVy50k+vWrUq7rb9+vXz01deeWVQVcoangkQETmMjQARkcPYHQTz7s01a9YYZfoCMPZiMKWlpX56+fLlRtnhhx+ekbrFO76e1+sCJNd15CJ9NlD7jl0qfG+99ZaRHzBgQMxty8vLjbw+m2+DBg0yW7Ec4JkAEZHD2AgQETmMjQARkcN4TQDAlClT/PRf//pXoyze1BD6dBCZugagz1pq18eui34d4NlnnzXKMlWfsJs7d66fnjNnTszt7Jlcu3bt6qft2UCz4dxzz/XTI0aMMMomT54c8332dSFKnD41xKmnnprw+zp06GDkGzVqlKkqhQLPBIiIHMZGgIjIYWwEiIgcxmsCOHDMcKL0KYf3799vlNWrVy+tOiXimWee8dOtW7cO/HhhJCJR07YrrrjCyHfu3DmoKiXNvtYT798R7xoVxadfa0nmcxw5cmQQ1QkNfqOIiBzGRoCIyGHsDgJw4YUX+unFixcn/L4VK1b4aXs2wXiLu+tD1QBzyokvvvgi5vvsY+hTXBx11FGxK0rkoM2bNxt5vfs0noEDBxp5e+W5QsMzASIih7ERICJyGBsBIiKH8ZoAgIkTJya0XVlZmZHXp5SNdw3A9vHHHxv5/v37J/S+oUOHGvlOnTolfMxCoQ/LBfJnyux9+/YZ+aeeespPz5gxI+b7Lr30UiN/8cUXZ7ZiBcyeXn3btm0xt9Wn8YgXj0LEMwEiIocl1AiISFMRGSQiz4rIBhH5TkR2isjrInK1iETdj4icJiJ/F5HtIrJbRP4tIsNFJPg7qahONTU1mD17Nvr06YMOHTqgYcOGKCoqwumnn46HH3445mRljGu4Ma6UjES7g/oBeADA5wAqAWwCcCSACwHMBnCeiPRTSqnaN4hIbwALAOwB8BSA7QDKAUwB0MXbZyh069bNT7/33nsxt3v55ZeN/L333uun9WGmALBgwQI/bXdZ2D/CeHcv6ounZ7r7Z/78+Rg8eDBatWqF7t27o23btvjyyy+xcOFCDBo0CC+99BLmz59v35Wb07jad0aPHj3aT9tD+8JE7/4BDryDOZb69esb+URmPM3HuAZhy5YtRj7e70y/K9j+zAtdoo3AegB/APCiUsr/H0xEbgfwfwD6ItIgLPBePwLAQwD2AzhTKVXlvT4GwCsALhKR/kqpeZn6h1DySkpK8Nxzz6FXr17GD+Tuu+/GySefjAULFmDhwoXo27cvAMY1XzCulIyEuoOUUq8opZ7XGwDv9S8AzPSyZ2pFFwFoDmBe7RfK234PgP/xsoNTrTRlRllZGcrLyw/4C6lly5a47rrrAJg3xIFxzQuMKyUjExeGf/Ce9eEPtcNolkTZ/jUAuwGcJiKHZuD4FIDaboeDDzZOFhnXPMe4ki2tIaIicjCA2s5N/Qt0rPe83n6PUmqfiGwE8CsAvwTwQTp1yIQ2bdr46WRmF7z77rujpm117VMvt1fAysWQwH379uGxxx4DAPTo0UMvyqu45po+TcG1116b8PuKior89M0335yx+rgQ11tuucVPJ7MK269//esgqpMX0j0TmAjgBAB/V0ot1V6v/RbvjPG+2td/Fq1QRK4VkSoRqdq6dWuaVaRkjRo1CmvXrkXPnj2N8dNgXPMa40rRpNwIiMhQADcD+A+Ay5N9u/esohUqpWYppUqVUqWFPnlT2EybNg2TJ09Gx44d8fjjjyf7dsY1pBhXiiWl7iARuQHAVADvAzhLKbXd2qT2L4ciRHeEtV1OpbqoTKoaN25s5I8++mg/bS8YX1xcnI0qAQDuu+8+DBs2DMcffzyWL1+OJk2a2JvkVVx1+t3dALBkyU+9l88//7xRFuXfHdWmTZuM/CWXXGLkq6ur/fSePXuMsoYNG/rpI444wiirrKz008ceeyzSVchxjTdTqN0Ne+ihP13SuOOOO4yyQls8PhlJnwmIyHAAMwCsBdDdGyFkW+c9l0R5/8EAjkbkQvJHyR6fglFRUYEhQ4bghBNOQGVlJVq2bBltM8Y1zzCuVJekGgERGYnIzSPvINIAbImx6Svec48oZWcAOAzAKqXU3mSOT8GYNGkSbrrpJnTu3BmVlZVo0aJFrE0Z1zzCuFIiEm4EvBtHJgJYjUgXUOzZmIBnAGwD0F9E/FmcRKQBgL942QeSry5l2oQJEzBq1CicdNJJWL58OZo1axZvc8Y1TzCulKiErgmIyAAA4xG5o3AlgKFRFsOuVkrNAQCl1Ncicg0iX64VIjIPkdvQ/4DIcLRnELk1PRRqh80BwIABA4yyRYsWpb1/e0Ww3r17G/nzzz8/7WOkYu7cuRg7dizq1auHrl27Ytq0aQdsU1xc7Nc/jHHV+8z1ob4A8Omnn/rpr776yijT8+3atUvp2NosKQDiLxCvD/sEgEceecRPX3DBBSkdP5ZCiGuidu3aZeTtawQ6/fpaoS8en4xELwzXXrmsB2B4jG1eBTCnNqOUWiQi3QCMRmRaiQYANgAYAWCasn9BlHUbN24EAOzfvx8VFRVRt+nWrZvRiDGu4ce4UjISagSUUuMAjEt250qpNwD0TPZ9lB3jxo3DuHHjkn4f4xpujCslg4vKwFwQZvbs2UbZzp0/jYrTF4S36UMOARgX4dq3bx/zeJSeU045xU+fddZZRtncuXOzXZ2Y7O9VpruAiFLFRWWIiBzGRoCIyGFsBIiIHMZrAhZ7KN+yZctyVBNK1qRJk4z84sWL/fSOHTsCP/6wYcOM/JAhQ/x0Nqf/cMkvfvELI9+rVy8/bU8HQtHxTICIyGFsBIiIHMbuICoY9jTGNTU1OaoJZcvhhx9u5DNxh79reCZAROQwNgJERA5jI0BE5DA2AkREDmMjQETkMDYCREQOYyNAROQwNgJERA5jI0BE5DA2AkREDpOwLx0qIlsBfAtgW67rUsCaoe7Pt51Sqnkd2yTMi+vHCR6bUlfX58u45qeM/WZD3wgAgIhUKaVKc12PQpXLz5exDVauPl/GNViZ/HzZHURE5DA2AkREDsuXRmBWritQ4HL5+TK2wcrV58u4Bitjn29eXBMgIqJg5MuZABERBYCNABGRw0LbCIhIGxF5REQ+E5G9IlItIhUi8vNc1y0fiEhTERkkIs+KyAYR+U5EdorI6yJytYgcZG1fLCIqzmNeBuvG2KaIcS1MuYxrKNcYFpH2AFYBaAFgMYD/ADgZwDAAPUSki1KKC8jG1w/AAwA+B1AJYBOAIwFcCGA2gPNEpJ868KLQGgCLouxvbSYqxdimjXEtTLmLq1IqdA8ASwEoADdar9/rvT4z13UM+wNAGYByAAdZr7f0vmAKQF/t9WLvtTmMbXgfjGthPnIZ15z/46N8GL/0/nEbo3wgjQHsQmQaiUa5rmu+PgDc7n3G07XXAv/PgrFlXHP9GeXjI+i4hrE7qMx7XqaU+lEvUEp9IyJvADgHwKkAlme7cgXiB+95X5Sy1iLyJwBNAdQA+KdS6t8ZOi5jGyzGtTAFGtcwNgLHes/rY5R/iMgXqgT8QiVNRA4GcIWXXRJlk7O9h/6eFQAGKKU2pXl4xjYgjGthykZcwzg6qMh73hmjvPb1nwVflYI0EcAJAP6ulFqqvb4bwAQAJwH4uffohshFqjMBLBeRRmkem7ENDuNamAKPaxgbgbqI98xbnZMkIkMB3IzIyI3L9TKl1Bal1Fil1L+UUju8x2uI/AX3vwA6ABgUdBVrqxPwcQoK41qYshXXMDYCtX81FMUoP8LajhIgIjcAmArgfQDdlVLbE3mfUmofIkPUAOCMNKvB2GYY41qYshnXMDYC67znkhjlx3jPsfofySIiwwHMQGTscHel1BdJ7mKr95xutwFjm0GMa2HKdlzD2AhUes/nRLlLrjGALgC+A/BmtiuWj0RkJIApAN5B5Au1JYXdnOo9f5RmdRjbDGFcC1NO4prrMbAxxsXyxpPMfI5jvM+rCkCTOrY9BUD9KK+XAdjj7ec0xjb3D8a1MB+5imsop5KOcgv6B4j8o7sjckp5muIt6HGJyAAAcwDsBzAd0ftjq5VSc7ztVwD4FYAVAD71yn+Nn8aAj1FK/SUD9WJs08C4FqacxjXXrV+clu4oAI8iMpfG94gsXj0VdbSQfPif3zhE/hqI91ihbX81gBcAVCNyh+deRG5XfwpAV8Y2HA/GtTAfuYxrKM8EiIgoO8J4YZiIiLKEjQARkcPYCBAROYyNABGRw9gIEBE5jI0AEZHD2AgQETmMjQARkcPYCBAROYyNABGRw/4fOObFMzFdwd0AAAAASUVORK5CYII=",
            "text/plain": [
              "<Figure size 432x288 with 6 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Show the samples\n",
        "k += 1\n",
        "plt.figure(k)\n",
        "for i in range(n):\n",
        "  plt.subplot(2, 3, i + 1)\n",
        "  plt.imshow(dataset.data[i].view(28, 28).int(), cmap='Greys')"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "jymNJzMN3qiY"
      },
      "source": [
        "### Loss Functions"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "JgUfRZpjTWvj"
      },
      "outputs": [],
      "source": [
        "# Losses\n",
        "squared_loss = nn.MSELoss(reduction='none')\n",
        "logistic_loss = nn.SoftMarginLoss(reduction='none')\n",
        "\n",
        "# poly_tailed_loss\n",
        "class PolyTailedLoss(nn.SoftMarginLoss):\n",
        "  def __init__(self, alpha, beta, **kwargs):\n",
        "    super(PolyTailedLoss, self).__init__(**kwargs)\n",
        "    self.alpha = alpha\n",
        "    self.beta = beta\n",
        "\n",
        "  def forward(self, x, y):\n",
        "    x = x * y\n",
        "    a = (x >= self.beta).detach()\n",
        "    x[a] = (x[a] - self.beta + 1) ** (-self.alpha)\n",
        "    x[~a] = x[~a] - self.beta - np.log(np.e - 1)\n",
        "    x[~a] = torch.log(torch.exp(-x[~a]) + 1)\n",
        "    if self.reduction == 'mean':\n",
        "      x = x.mean()\n",
        "    elif self.reduction == 'sum':\n",
        "      x = x.sum()\n",
        "    return x\n",
        "\n",
        "poly_tailed_loss = PolyTailedLoss(1.0, 0.0, reduction='none')"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "yuK8pHLxb3Ud"
      },
      "source": [
        "### Training Algorithms"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "j5XRK6APXUpd"
      },
      "outputs": [],
      "source": [
        "# Training algorithms\n",
        "def erm(model, loader, optimizer, criterion, device, w0=None, mu=None):\n",
        "  for _, (inputs, targets) in enumerate(loader):\n",
        "    inputs, targets = inputs.to(device), targets.float().to(device)\n",
        "\n",
        "    outputs = model(inputs)\n",
        "    loss = criterion(outputs, targets).mean()\n",
        "    if w0 is not None:\n",
        "      loss += mu / 2 * torch.norm(model.fc.weight.flatten() - w0) ** 2\n",
        "    optimizer.zero_grad()\n",
        "    loss.backward()\n",
        "    optimizer.step()\n",
        "\n",
        "def iw(model, loader, optimizer, criterion, device, sample_weights, w0=None, mu=None):\n",
        "  '''Importance weighting'''\n",
        "  for _, (inputs, targets) in enumerate(loader):\n",
        "    inputs, targets = inputs.to(device), targets.float().to(device)\n",
        "\n",
        "    outputs = model(inputs)\n",
        "    loss = torch.dot(criterion(outputs, targets), sample_weights)\n",
        "    if w0 is not None:\n",
        "      loss += mu / 2 * torch.norm(model.fc.weight.flatten() - w0) ** 2\n",
        "    optimizer.zero_grad()\n",
        "    loss.backward()\n",
        "    optimizer.step()\n",
        "\n",
        "def group_dro(model, loader, optimizer, criterion, device, group_weights, nu=1.0, w0=None, mu=None):\n",
        "  '''Group DRO: using target labels as group labels as in class imbalance tasks'''\n",
        "  num_groups = 2\n",
        "  classes = [-1, 1]\n",
        "  for _, (inputs, targets) in enumerate(loader):\n",
        "    inputs, targets = inputs.to(device), targets.float().to(device)\n",
        "\n",
        "    outputs = model(inputs)\n",
        "    loss = criterion(outputs, targets)\n",
        "    group_loss = torch.zeros((num_groups,)).float().to(device)\n",
        "    for i in range(num_groups):\n",
        "      group_loss[i] = loss[targets == classes[i]].mean()\n",
        "    weighted_loss = torch.dot(group_loss, group_weights)\n",
        "    if w0 is not None:\n",
        "      weighted_loss += mu / 2 * torch.norm(model.fc.weight.flatten() - w0) ** 2\n",
        "    optimizer.zero_grad()\n",
        "    weighted_loss.backward()\n",
        "    optimizer.step()\n",
        "\n",
        "    group_loss = group_loss.detach()\n",
        "    group_weights *= torch.exp(nu * group_loss)\n",
        "    group_weights /= group_weights.sum()\n",
        "    \n",
        "def get_sample_weights():\n",
        "  sample_weights = torch.zeros(size_dataset).float()\n",
        "  sample_weights[:n0] = 0.5 / n0\n",
        "  sample_weights[-n1:] = 0.5 / n1\n",
        "  return sample_weights"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "2P8Jbn8zi0uC"
      },
      "outputs": [],
      "source": [
        "def test(model, loader, criterion, device):\n",
        "  num_samples = 0\n",
        "  total_loss = 0\n",
        "  for _, (inputs, targets) in enumerate(loader):\n",
        "    inputs, targets = inputs.to(device), targets.float().to(device)\n",
        "    batch_size = len(inputs)\n",
        "    outputs = model(inputs)\n",
        "    loss = criterion(outputs, targets).sum()\n",
        "    total_loss += loss\n",
        "    num_samples += batch_size\n",
        "  loss = total_loss / num_samples\n",
        "  # print('Loss: {}'.format(loss))\n",
        "  return loss"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "5HqlqKNrhfg2"
      },
      "source": [
        "## Regression"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "L0jiUDGFflze"
      },
      "source": [
        "### Squared Loss"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "xXJHKPlkbkhL"
      },
      "outputs": [],
      "source": [
        "# Ensure that the models have the same initial point\n",
        "seed = 2022\n",
        "torch.manual_seed(seed)\n",
        "\n",
        "model_erm = LinearModel(784)\n",
        "model_iw = deepcopy(model_erm)\n",
        "model_gdro = deepcopy(model_erm)\n",
        "\n",
        "model_erm = model_erm.to(device)\n",
        "model_iw = model_iw.to(device)\n",
        "model_gdro = model_gdro.to(device)\n",
        "\n",
        "lr = 1e-3\n",
        "opt_erm = SGD(model_erm.parameters(), lr=lr)\n",
        "opt_iw = SGD(model_iw.parameters(), lr=lr)\n",
        "opt_gdro = SGD(model_gdro.parameters(), lr=lr)\n",
        "\n",
        "sample_weights = get_sample_weights().to(device)\n",
        "group_weights = torch.tensor([0.5, 0.5]).to(device)\n",
        "\n",
        "num_epochs = 5000\n",
        "freq = 1\n",
        "loss_erm_arr = np.zeros((num_epochs // freq,))\n",
        "loss_iw_arr = np.zeros((num_epochs // freq,))\n",
        "loss_gdro_arr = np.zeros((num_epochs // freq,))\n",
        "nerm_arr = np.zeros((num_epochs // freq,))\n",
        "diw_arr = np.zeros((num_epochs // freq,))\n",
        "dgdro_arr = np.zeros((num_epochs // freq,))\n",
        "\n",
        "gw_arr = np.zeros((num_epochs // freq, 2))\n",
        "\n",
        "for i in range(num_epochs):\n",
        "  erm(model_erm, dataloader, opt_erm, squared_loss, device)\n",
        "  iw(model_iw, dataloader, opt_iw, squared_loss, device, sample_weights)\n",
        "  group_dro(model_gdro, dataloader, opt_gdro, squared_loss, device, group_weights, 1)\n",
        "  # print(group_weights)\n",
        "\n",
        "  w_erm = model_erm.fc.weight.data.flatten()\n",
        "  w_iw = model_iw.fc.weight.data.flatten()\n",
        "  w_gdro = model_gdro.fc.weight.data.flatten()\n",
        "  if (i + 1) % freq == 0:\n",
        "    j = (i + 1) // freq - 1\n",
        "    loss_erm_arr[j] = test(model_erm, dataloader, squared_loss, device)\n",
        "    loss_iw_arr[j] = test(model_iw, dataloader, squared_loss, device)\n",
        "    loss_gdro_arr[j] = test(model_gdro, dataloader, squared_loss, device)\n",
        "    diw_arr[j] = torch.norm(w_iw - w_erm).item()\n",
        "    dgdro_arr[j] = torch.norm(w_gdro - w_erm).item()\n",
        "    nerm_arr[j] = torch.norm(w_erm).item()\n",
        "    gw_arr[j] = group_weights.detach().cpu().numpy()\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 311
        },
        "id": "J5idgsdF4W_1",
        "outputId": "85119b3b-edc3-4311-d05b-71008494a77c"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(diw_arr, label=r'$\\| \\theta_{iw} - \\theta_{erm} \\|_2$')\n",
        "plt.plot(dgdro_arr, label=r'$\\| \\theta_{gdro} - \\theta_{erm} \\|_2$')\n",
        "plt.legend()\n",
        "plt.xlabel(r'Epochs')\n",
        "plt.ylabel('Norm of Difference')\n",
        "plt.gcf().subplots_adjust(left=0.2, bottom=0.2)\n",
        "plt.savefig('linear_squared_nd.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 311
        },
        "id": "OdLClga6SNxq",
        "outputId": "974d1d44-4103-403f-8617-7e7c8f0d6c5a"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZQAAAEDCAYAAAASpvJbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAyN0lEQVR4nO3deZwU1bn/8c8zM8yw76KAAkrcMInbKAZcAA2CMS7XLb94FY243Jgoiea6RFlcEr1RXHOTiAvRiEtQYzTugqioSeAGlIjiwqgIqDjAIMswy/P7o6rHpqd7pmumZ7qn5/t+vepVdtWpU6ensZ8+59Q5x9wdERGR5irIdgFERCQ/KKCIiEhGKKCIiEhGKKCIiEhGKKCIiEhGKKCIiEhGFGW7APmib9++PmTIkGwXQ0SkRS1cuHCNu2+X7JwCSoYMGTKEBQsWZLsYIiItysw+SnVOTV4iIpIRCigiIpIRCigiIpIRCigiIpIRCigiIpIRCigiIpIRCihZtGD6CSy6/shsF0NEJCM0DiWLireuo2N1RbaLISKSEQooWWXZLoC0c5WVlZSXl7NhwwZqamqyXRxpZYWFhXTr1o3evXtTUlLS7PwUULLIAUMrZkp2VFZW8vHHH9OrVy+GDBlChw4dMNOPnPbC3amqqqKiooKPP/6YQYMGNTuoqA8lm8xASzBLlpSXl9OrVy/69u1LcXGxgkk7Y2YUFxfTt29fevXqRXl5ebPzVEDJKlMNRbJmw4YNdO/ePdvFkBzQvXt3NmzY0Ox8FFCyyNWHIllUU1NDhw4dsl0MyQEdOnTISB+aAko2mWookl1q5hLI3L8DBZQsCmooCigikh8UULJN8URE8oQCShYZemxYRPKHAkoWudqvRbLOzLbpQ1i4cCFmxkEHHZQ0/axZs+quWb58eb3zmzdvpmPHjnTu3JnKysoWK3cuUkDJKnXKi+Safffdl169erFgwQIqKupPjTRnzpy6ADRnzpx65+fPn09lZSUHH3xwRkaftyUKKFmlTnmRXFNQUMCoUaOoqalh3rx59c7PmTOHUaNG0adPn6QBJXbs8MMPb/Gy5hoFlCxyPTYskpNiwSAxYJSVlbF8+XIOP/xwDjvsMObOnVvvWgUUyRIFFJFcNGbMGABefPHFbY7HXo8ZM4bRo0ezatUq3n777brzFRUVLFiwgJ49e7Lffvu1XoFzhAKKiEiCPffckwEDBrBkyRK++OKLuuNz5syha9euHHDAAYwePbruWMy8efOoqalh9OjRFBS0v69XzTacRY5hmhxSctC0J/7N2ytze62eYQO6M+X7e7VY/qNHj+b+++9n7ty5nHzyyQDMnTuXQw45hKKiIvbaay/69evHnDlz+MlPfgK07+YuyKEaipntaGZ3m9lKM6s0szIzu9nMeqV5/Rlm5o1sNQnXDGkk/YMt827rCoA65UVyU2I/ytKlS1m1alVdzQRg1KhRvPTSS9TW1m6T9ogjjmjl0uaGnKihmNlQ4DWgH/A48A5wIHAhMM7MRrr7l41kswiYluLcIcAY4OkU5xcDf0lyfEkj92wm0/SQkpNa8pd/WxELKLF+k/j+k5hRo0bx8MMP869//YvBgwfz1ltvMXDgQHbffffWL3AOyImAAvwvQTC5wN1vix00s+nAz4BrgfMaysDdFxEElXrM7PXwP+9Icfkid58aqcSZoKe8RHLWoEGDGDp0KO+//z6ffPIJc+bMoWfPnuy77751aeL7UQYPHoy7t9vmLsiBJi8z2wUYC5QBv004PQXYCJxmZl2amP83gYOAT4G/Nb2kmafp60VyWyw4vPDCC8ybN4/DDjtsm872PfbYg/79+zNnzpx2338CORBQCJqiAJ5z99r4E+6+AZgPdCYICk1xbri/y91TTfg/wMzONbPLw/23m3ivSG7q9ikX7VDYGrcSkSaINW/ddNNNlJeXb9N/EjNq1CheeeUVnnvuOUABJdtijY3LUpx/L9zvFjVjM+sE/CdQC9zZQNLvAr8naFr7PbDYzOaa2aCo94yiFqdGlRSRnDVmzBjMjLfeeqvudaLRo0ezceNGli9fzu67787AgQNbu5g5IxcCSo9wvz7F+djxnk3I++Twuqfd/ZMk5zcBVwP7A73C7TBgLjAKeLGhpjYzO8fMFpjZgvhn1dOlHhSR3LbddtvxrW99C4C+ffvyzW9+s16a+FpLe66dQO50yjck9hu+Kd+954T7PyQ76e6fA5MTDr9sZmOBV4HhwETglhTX30HY0V9aWqrYINIGeSNjwRYvXtzg+W984xuN5tFe5EINJVYD6ZHifPeEdGkxs2HACGAF8FSUa929mq+byA6Ncq2ISHvV7BqKme0BjCdoPnrQ3SN98QPvhvtUfSS7hvtUfSyppNMZ35BYG1aTni5Lh5npl42I5I20ayhmNtnMVplZ77hjRwD/Am4gGEvyf2bWJ2IZYtN1jjWzbcpjZt2AkcBm4I0IZe0InEbQGX9XxPLExJ4q+7CJ1zdOsURE8kiUJq/xwDvuXh537NcEX4tTgN8BOxOMbk+bu38APAcMAc5POD2NoIZwr7tvBDCzDma2Rzi6PpWTCDrYn0rRGU+Y13AzK05yfAzBgEqAP6X7XqLTI14ikj+iNHkNAR6LvTCzgQRPR01392vCY3sAx1G/o7sxPyaYeuVWMzscWErQIT6aoKnrl3FpB4bnPwrLlEysMz7VyPiY64G9zOwlgr4WgG/z9diYK939tbTfRURmoBYvEckXUWoovYD42slIgtrJk3HHFgKRx26EtZRSYCZBILkIGArcCnwnjXm86pjZnsDBpNcZfx/wd+AA4GyCwLYr8DBwaCxQthTVT0Qkn0SpoXxBUDuIGQ1UEXwhxxTTxCfHwqapM9NIV0YD38XuvrSh8wlp76LpfSwZoJAiIvkjSkBZBBwTzo21BTgFeNXdN8elGQKsyljp2gG1eIlIvohSm/gfgrEiiwke9e0B3Bg7GT5ZNQpYkMHy5TWthiIi+STtGoq7v2JmRxP0NThwv7vHry8ygmDG4MeSXC5JqclLRPJHpIGN7v4M8EyKc3OAfZOdkwYopohInsjI1Ctm1qup65W0Z2ryEpF8EmWk/OFm9j/xa7ybWT8zmwesAcrDFRYlbaqeiEj+iFJD+SnwH+6+Nu7YDQTrtb8PfAlcaGYnZ7B8eU0ryotIPokSUPYmmNIdqFu86kTgeXffnWChrE9oZO13iWPgavQSyQnLli3j5z//Ofvttx+9e/emQ4cO9O7dm+HDh3PxxRezcOHCbdJPnToVM6vbCgoK6N69O4MHD+aoo47i+uuv59NPP016r7Kysm2uNTOKioro168f48aN4/HHH2+wrO7OI488wrHHHsuAAQMoLi6mT58+HHzwwUyfPp1NmzZl7O8SRZRO+X7AyrjXw4GOBKPbcfcNZvYkcHzGSici0sLcnauuuoqrrrqK2tpa9ttvP0455RR69+7Nhg0bePPNN7ntttu48cYbuf322zn//G2nHDzssMMYNWoUABs3bmTVqlXMnz+fp59+milTpjB16lQuvfTSpPfu0aMHkyZNAqCyspJ///vfPPnkkzz77LP85je/4eKLL653zbp16zj55JN5/vnn6dGjB0cddRRDhgyhvLycZ599losuuojbbruNJ598kr322iujf6tGuXtaG8G0KzfFvb4SqAEGxh37FbA53Tzzadt///09qjNmHOpH37FH5OtEMuHtt9/OdhFywtSpUx3wnXbayV999dWkaT777DO/7LLL/Nprr607NmXKFAd8ypQp9dLX1tb67NmzvXfv3g74r3/9623OL1++3AEfPHhwvWsfeOABB7xz586+cePGbc7V1NT4EUcc4YAfeeSRvmbNmm3OV1VV+WWXXeaADxgwwFevXp3mXyH9fw/AAk/xPRilyWs5X0+aCHAC8J67x9fpdiLooJd0mJ7yEsmmDz/8kGuuuYbi4mKefvppRo4cmTRdv379+NWvfsV///d/p5WvmXHCCScwe/ZsAKZNm8aqVelNInLKKafQtWtXNm3axNtvv73NuVmzZvHCCy+wyy678Oijj9Knz7arhRQVFfGrX/2KU045hZUrV3LFFVekdc9MiRJQ/gh8y8z+bmavAN8CZiWk2Y+vF8ySNCigiGTPPffcQ3V1NSeeeGJazUNFRdHWJBw9ejQHH3wwW7Zs4dFHH037Og+nIe/QocM2x2fMmAHAxRdfTOfOnVNeP3lyMOH7fffdx5YtWyKVuTmiBJTfAQ8SzAo8kmCW4etjJ83sQGBP4KUMli+v6SkvkeyaP38+AGPGjGkkZdPF+lf+8Y9/pJX+/vvvZ+PGjWy33Xbsvvvudcerq6t5441gncEjjjiiwTyGDRvGgAEDqKysZMGC1psNK8rUK1XAD83svOClb0hI8iHBSPmyzBUvvymcSM56+lJY/Va2S9GwHb4F469rVharV68GYODAgfXOlZWVMXPmzG2O9ezZs64TPV2xvL/44ot659atW8fUqVOBoFN+yZIl/O1vf6O4uJg//OEPdOzYsS5teXk5W7duBWCnnXZq9L477bQTK1euZOXKlY2mzZTIa8q7e0WK42tQ/0lEpiYvkSyKNS2Z1f95V1ZWxrRp07Y5Nnjw4MgBpaF7rF+/vt49SkpKePzxxznyyCOT5pOJ+7aUyAHFzDoD/0FQG+kJrAf+D3jMw2V6JX2uaorkomb+8m8r+vfvzzvvvJN0vMioUaPqvpSrq6vr9WekK1ZD2G677eqdGzx4MGVlZQBUVFTw/PPPM3HiRE4++WRef/11hg0bVpe2T58+FBcXs3XrVj755BN23XXXBu+7YsWKuvfYWiLN5WVmRxEsvftHgjXXzwQmha/LwtmIJU3qQxHJrthTXS+++GKL3WPu3LkADB8+vMF03bt354QTTuD++++noqKC008/fZtaSVFRUV0eL7zwQoN5LV26lJUrV1JSUsL+++/fzHeQvihzee0HPEpQK7kf+BEwPtzfHx6fbWatV/q2TvFEJKvOOOMMioqKmD17NkuXLs14/nPmzGH+/Pl06tSJ449Pb8z3UUcdxbhx41i4cCGzZm37IO3EiRMBmD59Ops3b052OQDXXBOsXn7aaafRqVOnJpY+uig1lF8SPOV6iLuf7u4z3f3ZcH86wTruDlzeEgXNT+pDEcmmoUOHcsUVV7B161bGjx/Pa6+9ljTdunXrIuXr7jz66KOcdNJJQDAOZYcddkj7+quvvhqAKVOmUF1dXXf81FNPZfTo0bz//vuceOKJrF27dpvrampqmDx5MrNmzaJ///51+bSWKH0ohwB/dvc3kp1097+b2WzgyGTnpT5VUESyb/Lkybg7V199NSNHjmT//ffnwAMPpHfv3qxbt46ysrK6JqZDDz203vUvvfRS3ZNamzdvZuXKlcyfP5/ly5dTUlLC9ddfzy9+8YtIZSotLeXYY4/l8ccf56677uLcc88FoLCwkEceeYQTTzyRp556il122YXvfe97DB48uG7qleXLlzNkyBCeeOKJSEEsI1INoU/cgErg2kbSXAtsSTfPfNqaMvXKxLsO9yNnaOoVyQ5NvbKtd955xydNmuR777239+jRw4uKirxXr15eWlrqkyZN8oULF26TPjb1SmwzM+/atasPGjTIx48f79ddd52vWLEi6b0amnolZtGiRW5mPnDgQN+8efM252pra/2hhx7yo48+2nfYYQfv0KGD9+rVy0eMGOE33HBDvSlb0pGJqVfM03wUzcyWA++7+3cbSPMssJu779ycINcWlZaWetQBROfcfQQf1X7KsxMz33Yr0pilS5ey5557ZrsYkiPS/fdgZgvdvTTZuSh9KE8BY8zsUjMrTLhBgZldBBwRppO0qA9FRPJHlD6Uq4HjCJq1zg3n81oF7EDQIT8EWA1ck9ki5i/1oYhIPoky9cpqMxsJ/AH4LjA4IcnzwHnunt6UmgKmGoqI5I9II+XdvQw40swGEoyU70EwUv5fvu009pIuCx6M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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(loss_iw_arr, label='IW')\n",
        "plt.plot(loss_gdro_arr, label='GDRO')\n",
        "plt.plot(loss_erm_arr, label='ERM')\n",
        "plt.legend()\n",
        "plt.xlabel(r'Epochs')\n",
        "plt.ylabel('Training Loss')\n",
        "plt.gcf().subplots_adjust(left=0.17, bottom=0.2)\n",
        "plt.savefig('linear_squared_train.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 277
        },
        "id": "EJ7hP14lSV-D",
        "outputId": "0a1dc53f-1b07-4a68-a85b-2546369ca6cc"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(nerm_arr)\n",
        "plt.xlabel(r'Epochs')\n",
        "plt.ylabel('Norm of ERM Model')\n",
        "plt.gcf().subplots_adjust(left=0.22, bottom=0.2)\n",
        "plt.savefig('linear_squared_erm.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 279
        },
        "id": "E-apYhyRHmGf",
        "outputId": "a6dbca69-b8a5-4420-8c33-0daa7e703e6d"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(gw_arr[:, 0])\n",
        "plt.plot(gw_arr[:, 1])\n",
        "plt.xlabel(r'Epochs')\n",
        "plt.ylabel('Group Weight')\n",
        "plt.gcf().subplots_adjust(left=0.17, bottom=0.2)\n",
        "plt.savefig('linear_squared_gw.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "p2fbDBZQHhAT"
      },
      "outputs": [],
      "source": [
        "data = {\n",
        "    'loss_erm_arr': loss_erm_arr,\n",
        "    'loss_iw_arr': loss_iw_arr,\n",
        "    'loss_gdro_arr': loss_gdro_arr,\n",
        "    'nerm_arr': nerm_arr,\n",
        "    'diw_arr': diw_arr,\n",
        "    'dgdro_arr': dgdro_arr,\n",
        "    'gw_arr': gw_arr,\n",
        "}\n",
        "with open('linear_squared.pkl', 'wb') as f:\n",
        "  pickle.dump(data, f)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "xhmQnIq3U79X"
      },
      "source": [
        "### Squared Loss, with Regularization"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "D_nQCiasU-AC",
        "outputId": "688a9845-ac84-4328-fcd8-d63c71799802"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "mu = 0.1\n"
          ]
        },
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "mu = 10\n"
          ]
        },
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        },
        {
          "data": {
            "image/png": "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ESkAkafPAAgTQYtkYGbzgGPdvecNhOu+KU9ERLpcpOkz2mEMcFDM58wvqjmISAGIOzn0WDv6HJQcRCT/KTnEZMcIaXVIi0j+U3KIm8Y5iEgBUHKISeOsrOpzEJECoOQQO9UcRCT/tXkrq5mVRzzfvp2IJa9pEJyIFJKdjXOY0oFz9vBvRzUriUj+21lymNotURSAhAUtdOqPFpFC0Gafg7sv7ciju4LPJankgNVnNxCRHszMdvp46qmnGssvWLCgxf7S0lLGjh3LV7/6VVauXJnxfebOndtY/owzzmg1nqVLlzaWKysri/lf27U6NH2GtJS6W0k1B5HsmzNnTqv7Mn1JH3jggZxwwgkAVFVVsWzZMhYtWsTixYt58sknmTRpUsZzFRUV8cc//pGbbrqJQYMGtdg/f/58ioqKmiwPmi+UHGKSCCthrj4HkaxLLfXZXgcddFCLY84991xuvfVWLrvsMpYsWZLxuGOPPZY//elPLFy4kPPPP7/Jvo0bN7J48WKOO+447rvvvkjx5ALdyhqTxj6Hnt4fL1IgzjrrLABeeOGFVsvMmDGD3Xbbjfnz57fYd8cdd7Bt2zbOOeecLouxKyk5xGTHYj9KDiKFILWEcnFxcatlkskkX//611m5ciXNlxaeP38+ZWVlHH300V0aZ1dRs1JMVHMQyR2tNSv16tWLiy++uF3nSNUGJk+e3Ga5s846i6uuuor58+czYUKwHPPzzz/Pq6++ylVXXZX2wzG/KDnERH0Okquu/du1rK5cne0w2rTvkH256LCLYjvfvHnzMm4fOHBgxuTw0ksvNSaUqqoqnnnmGZYvX86oUaO4/vrr23yvMWPGMH36dO68805uuOEG+vbty/z580kmk5x55pmd/rdki5JDTBp/HajiIJJ1HvG2wZUrV7a4bXXMmDE888wzjBkzZqfHn3POOTzyyCP84Q9/4OSTT+auu+7ii1/8IqNGjcrLO5VAySE2jc1KpuwguSXOX+SF6owzzmDBggW4Ox9++CG33XYbl112GccddxzPPfccffr0afP4L33pS+y66678+te/pra2li1btuRtR3RKu5ODmc1uR7EGoApYBSx195qOBpZvdoyQVnIQyVdmxi677MKll17Kxo0bue6667jsssu44YYb2jyuqKiIr33ta1xzzTW899577LbbbsycObObou4aUWoOc2na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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        },
        {
          "data": {
            "image/png": "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Xl5OVVUVzzzzDN/73ve48847eeKJJ9h///1T+lntkru360GwdMbtca+vBRqBUXHbfgDUtLfOTH0ceuihHtVfPvqLHzDvAJ//P1+OfKxIZ73zzjvpDiEjzJ492wHfY489/JVXXklY5qOPPvKrrrrKb7zxxuZts2bNcsBnzZrVqnxTU5M/9NBDXlpa6oD/8Ic/3Gn/qlWrHPDRo0e3Ovb+++93wHv37u1bt27daV9jY6NPnTrVAf/Sl77kGzZs2Gl/fX29X3XVVQ74yJEj/cMPP2znp9D+vwdgqSf5HozSrbSKHSuoApwK/N3d49taexAMTvdgjekOQKRH+uc//8kNN9xAUVERTz31FBMmTEhYbtiwYfzgBz/gP//zPxPub8nMOPXUU3nooYcAmDNnDuvXt28hiDPPPJO+ffuybds23nnnnZ32LViwgOeff5699tqLhx9+mMGDd77bQUFBAT/4wQ8488wzWbduHddcc0273jNVoiSHXwOfM7M/mtnLwOeABS3KHMKOGc89ioWjDu0eKReRlPrVr35FQ0MDp512Wru6YAoKol3JP3nyZCZOnMj27dt5+OGH232ch13NhYWFO22fO3cuAJdffjm9e/dOevzMmTMBuO+++9i+fXukmDsjSnL4H+ABgktOJxCsxnpzbGe48N2+wIspjC/raEBaJD2WLFkCwJQpU3ZRsuNi4xF/+tOf2lV+/vz5bN26laFDhzJ27Njm7Q0NDbz2WrDow9SpU9usY7/99mPkyJHU1taydGnU1Yk6LsryGfXAV83swuClb2lR5J8EM5ErUxde9jENSEumeepK+PCtdEfRtuGfg+k3daqKDz/8EIBRo0a12ldZWcm8efN22jZw4MDmAeT2itWdaFn/TZs2MXv2bCAYkH777bf5/e9/T1FREXfffTclJSXNZauqqqirqwNgjz322OX77rHHHqxbt45169btsmyqRJ4h7e7VSbZvoAePN2iGtEh6xbpvdvy/uENlZSVz5szZadvo0aMjJ4e23mPz5s2t3qO4uJjHHnuML33pSwnrScX7dpXIycHMegP/h6CVMJBgKe2/AI94x5fPyCFKDpJhOvmLPFuMGDGCFStWJJyPMGnSpOYv2IaGhlb9/+0V++We6J4vo0ePprKyEoDq6mqee+45zj//fM444wxeffVV9ttvv+aygwcPpqioiLq6Otas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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Squared loss with regularization\n",
        "for mu in [0.1, 10]:\n",
        "  print('mu = {}'.format(mu))\n",
        "\n",
        "  seed = 2022\n",
        "  torch.manual_seed(seed)\n",
        "\n",
        "  model_erm = LinearModel(784)\n",
        "  model_iw = deepcopy(model_erm)\n",
        "  model_gdro = deepcopy(model_erm)\n",
        "\n",
        "  model_erm = model_erm.to(device)\n",
        "  model_iw = model_iw.to(device)\n",
        "  model_gdro = model_gdro.to(device)\n",
        "\n",
        "  w0 = torch.tensor(model_erm.fc.weight.data.detach().cpu().numpy()).to(device)\n",
        "\n",
        "\n",
        "  lr = 1e-3\n",
        "  opt_erm = SGD(model_erm.parameters(), lr=lr)\n",
        "  opt_iw = SGD(model_iw.parameters(), lr=lr)\n",
        "  opt_gdro = SGD(model_gdro.parameters(), lr=lr)\n",
        "\n",
        "  sample_weights = get_sample_weights().to(device)\n",
        "  group_weights = torch.tensor([0.5, 0.5]).to(device)\n",
        "\n",
        "  num_epochs = 5000\n",
        "  freq = 1\n",
        "  loss_erm_arr = np.zeros((num_epochs // freq,))\n",
        "  loss_iw_arr = np.zeros((num_epochs // freq,))\n",
        "  loss_gdro_arr = np.zeros((num_epochs // freq,))\n",
        "  nerm_arr = np.zeros((num_epochs // freq,))\n",
        "  diw_arr = np.zeros((num_epochs // freq,))\n",
        "  dgdro_arr = np.zeros((num_epochs // freq,))\n",
        "\n",
        "  gw_arr = np.zeros((num_epochs // freq, 2))\n",
        "\n",
        "  for i in range(num_epochs):\n",
        "    erm(model_erm, dataloader, opt_erm, squared_loss, device, w0, mu)\n",
        "    iw(model_iw, dataloader, opt_iw, squared_loss, device, sample_weights, w0, mu)\n",
        "    group_dro(model_gdro, dataloader, opt_gdro, squared_loss, device, group_weights, 1, w0, mu)\n",
        "    # print(group_weights)\n",
        "\n",
        "    w_erm = model_erm.fc.weight.data.flatten()\n",
        "    w_iw = model_iw.fc.weight.data.flatten()\n",
        "    w_gdro = model_gdro.fc.weight.data.flatten()\n",
        "    if (i + 1) % freq == 0:\n",
        "      j = (i + 1) // freq - 1\n",
        "      loss_erm_arr[j] = test(model_erm, dataloader, squared_loss, device)\n",
        "      loss_iw_arr[j] = test(model_iw, dataloader, squared_loss, device)\n",
        "      loss_gdro_arr[j] = test(model_gdro, dataloader, squared_loss, device)\n",
        "      diw_arr[j] = torch.norm(w_iw - w_erm).item()\n",
        "      dgdro_arr[j] = torch.norm(w_gdro - w_erm).item()\n",
        "      nerm_arr[j] = torch.norm(w_erm).item()\n",
        "      gw_arr[j] = group_weights.detach().cpu().numpy()\n",
        "\n",
        "  k += 1\n",
        "  plt.figure(k)\n",
        "  plt.plot(diw_arr, label=r'$\\| \\theta_{iw} - \\theta_{erm} \\|_2$')\n",
        "  plt.plot(dgdro_arr, label=r'$\\| \\theta_{gdro} - \\theta_{erm} \\|_2$')\n",
        "  plt.legend()\n",
        "  plt.xlabel(r'Epochs')\n",
        "  plt.ylabel('Norm of Difference')\n",
        "  plt.gcf().subplots_adjust(left=0.2, bottom=0.2)\n",
        "  plt.savefig('reg_squared_{}_nd.eps'.format(mu))\n",
        "\n",
        "  k += 1\n",
        "  plt.figure(k)\n",
        "  plt.plot(loss_iw_arr, label='IW')\n",
        "  plt.plot(loss_gdro_arr, label='GDRO')\n",
        "  plt.plot(loss_erm_arr, label='ERM')\n",
        "  plt.legend()\n",
        "  plt.ylim([0, 0.5])\n",
        "  plt.xlabel(r'Epochs')\n",
        "  plt.ylabel('Training Loss')\n",
        "  plt.gcf().subplots_adjust(left=0.17, bottom=0.2)\n",
        "  plt.savefig('reg_squared_{}_train.eps'.format(mu))"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "MW3P7E8yh3Rw"
      },
      "source": [
        "## Classification"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "iJC4AuQdfoK1"
      },
      "source": [
        "### Logistic Loss"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "aMjl1Gn_eyqK"
      },
      "outputs": [],
      "source": [
        "# Logistic loss\n",
        "seed = 2022\n",
        "torch.manual_seed(seed)\n",
        "\n",
        "# Ensure that the models have the same initial point\n",
        "model_erm = LinearModel(784)\n",
        "model_iw = deepcopy(model_erm)\n",
        "model_gdro = deepcopy(model_erm)\n",
        "\n",
        "model_erm = model_erm.to(device)\n",
        "model_iw = model_iw.to(device)\n",
        "model_gdro = model_gdro.to(device)\n",
        "\n",
        "lr = 1e-3\n",
        "opt_erm = SGD(model_erm.parameters(), lr=lr)\n",
        "opt_iw = SGD(model_iw.parameters(), lr=lr)\n",
        "opt_gdro = SGD(model_gdro.parameters(), lr=lr)\n",
        "\n",
        "sample_weights = get_sample_weights().to(device)\n",
        "group_weights = torch.tensor([0.5, 0.5]).to(device)\n",
        "\n",
        "num_epochs = 10000000\n",
        "freq = 10000\n",
        "loss_erm_arr = np.zeros((num_epochs // freq,))\n",
        "loss_iw_arr = np.zeros((num_epochs // freq,))\n",
        "loss_gdro_arr = np.zeros((num_epochs // freq,))\n",
        "nerm_arr = np.zeros((num_epochs // freq,))\n",
        "diw_arr = np.zeros((num_epochs // freq,))\n",
        "dgdro_arr = np.zeros((num_epochs // freq,))\n",
        "\n",
        "gw_arr = np.zeros((num_epochs // freq, 2))\n",
        "\n",
        "for i in range(num_epochs):\n",
        "  erm(model_erm, dataloader, opt_erm, logistic_loss, device)\n",
        "  iw(model_iw, dataloader, opt_iw, logistic_loss, device, sample_weights)\n",
        "  group_dro(model_gdro, dataloader, opt_gdro, logistic_loss, device, group_weights, 0.1)\n",
        "\n",
        "  w_erm = model_erm.fc.weight.data.flatten()\n",
        "  w_iw = model_iw.fc.weight.data.flatten()\n",
        "  w_gdro = model_gdro.fc.weight.data.flatten()\n",
        "  if (i + 1) % freq == 0:\n",
        "    j = (i + 1) // freq - 1\n",
        "    loss_erm_arr[j] = test(model_erm, dataloader, logistic_loss, device)\n",
        "    loss_iw_arr[j] = test(model_iw, dataloader, logistic_loss, device)\n",
        "    loss_gdro_arr[j] = test(model_gdro, dataloader, logistic_loss, device)\n",
        "    diw_arr[j] = torch.norm(w_iw / torch.norm(w_iw) - w_erm / torch.norm(w_erm)).item()\n",
        "    dgdro_arr[j] = torch.norm(w_gdro / torch.norm(w_gdro) - w_erm / torch.norm(w_erm)).item()\n",
        "    nerm_arr[j] = torch.norm(w_erm).item()\n",
        "    gw_arr[j] = group_weights.detach().cpu().numpy()\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 318
        },
        "id": "65xY9XUefTcZ",
        "outputId": "3f220e89-30a8-4c33-b7a1-3501a2321da9"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(diw_arr, label=r'$\\| \\tilde{\\theta}_{iw} - \\tilde{\\theta}_{erm} \\|_2$')\n",
        "plt.plot(dgdro_arr, label=r'$\\| \\tilde{\\theta}_{gdro} - \\tilde{\\theta}_{erm} \\|_2$')\n",
        "plt.legend()\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Norm of Difference')\n",
        "plt.gcf().subplots_adjust(left=0.2, bottom=0.2)\n",
        "plt.savefig('linear_logistic_nd.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 315
        },
        "id": "M7TkuhXUfc60",
        "outputId": "673f0e62-f360-469f-adee-58e4844d343d"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(loss_erm_arr, label='ERM')\n",
        "plt.plot(loss_iw_arr, label='IW')\n",
        "plt.plot(loss_gdro_arr, label='GDRO')\n",
        "plt.legend()\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Training Loss')\n",
        "plt.gcf().subplots_adjust(left=0.25, bottom=0.2)\n",
        "plt.savefig('linear_logistic_train.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 281
        },
        "id": "1zwPhxtWfeLL",
        "outputId": "2bfceb01-d19d-48d5-fa1b-bedd837d1e91"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(nerm_arr)\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Norm of ERM Model')\n",
        "plt.gcf().subplots_adjust(left=0.17, bottom=0.2)\n",
        "plt.savefig('linear_logistic_erm.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 280
        },
        "id": "b5qyTpysffMi",
        "outputId": "74cf9051-b3da-4f7e-8bc2-dd9e20c032cf"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(gw_arr[:, 0])\n",
        "plt.plot(gw_arr[:, 1])\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Group Weight')\n",
        "plt.gcf().subplots_adjust(left=0.2, bottom=0.2)\n",
        "plt.savefig('linear_logistic_gw.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "XRBd5nr6fhrD"
      },
      "outputs": [],
      "source": [
        "data = {\n",
        "    'loss_erm_arr': loss_erm_arr,\n",
        "    'loss_iw_arr': loss_iw_arr,\n",
        "    'loss_gdro_arr': loss_gdro_arr,\n",
        "    'nerm_arr': nerm_arr,\n",
        "    'diw_arr': diw_arr,\n",
        "    'dgdro_arr': dgdro_arr,\n",
        "    'gw_arr': gw_arr,\n",
        "}\n",
        "with open('linear_logistic_10m_1e3.pkl', 'wb') as f:\n",
        "  pickle.dump(data, f)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "P4s3veUJnFrx"
      },
      "source": [
        "### Polynomially Tailed Loss"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "9mcLBgT8nE3d"
      },
      "outputs": [],
      "source": [
        "# Poly tailed loss\n",
        "seed = 2022\n",
        "torch.manual_seed(seed)\n",
        "\n",
        "# Ensure that the models have the same initial point\n",
        "model_erm = LinearModel(784)\n",
        "model_iw = deepcopy(model_erm)\n",
        "model_gdro = deepcopy(model_erm)\n",
        "\n",
        "model_erm = model_erm.to(device)\n",
        "model_iw = model_iw.to(device)\n",
        "model_gdro = model_gdro.to(device)\n",
        "\n",
        "lr = 1e-3\n",
        "opt_erm = SGD(model_erm.parameters(), lr=lr)\n",
        "opt_iw = SGD(model_iw.parameters(), lr=lr)\n",
        "opt_gdro = SGD(model_gdro.parameters(), lr=lr)\n",
        "\n",
        "sample_weights = get_sample_weights().to(device)\n",
        "group_weights = torch.tensor([0.5, 0.5]).to(device)\n",
        "\n",
        "num_epochs = 10000000\n",
        "freq = 10000\n",
        "loss_erm_arr = np.zeros((num_epochs // freq,))\n",
        "loss_iw_arr = np.zeros((num_epochs // freq,))\n",
        "loss_gdro_arr = np.zeros((num_epochs // freq,))\n",
        "nerm_arr = np.zeros((num_epochs // freq,))\n",
        "diw_arr = np.zeros((num_epochs // freq,))\n",
        "dgdro_arr = np.zeros((num_epochs // freq,))\n",
        "\n",
        "gw_arr = np.zeros((num_epochs // freq, 2))\n",
        "\n",
        "for i in range(num_epochs):\n",
        "  erm(model_erm, dataloader, opt_erm, poly_tailed_loss, device)\n",
        "  iw(model_iw, dataloader, opt_iw, poly_tailed_loss, device, sample_weights)\n",
        "  group_dro(model_gdro, dataloader, opt_gdro, poly_tailed_loss, device, group_weights, 0.1)\n",
        "\n",
        "  w_erm = model_erm.fc.weight.data.flatten()\n",
        "  w_iw = model_iw.fc.weight.data.flatten()\n",
        "  w_gdro = model_gdro.fc.weight.data.flatten()\n",
        "  if (i + 1) % freq == 0:\n",
        "    j = (i + 1) // freq - 1\n",
        "    loss_erm_arr[j] = test(model_erm, dataloader, poly_tailed_loss, device)\n",
        "    loss_iw_arr[j] = test(model_iw, dataloader, poly_tailed_loss, device)\n",
        "    loss_gdro_arr[j] = test(model_gdro, dataloader, poly_tailed_loss, device)\n",
        "    diw_arr[j] = torch.norm(w_iw / torch.norm(w_iw) - w_erm / torch.norm(w_erm)).item()\n",
        "    dgdro_arr[j] = torch.norm(w_gdro / torch.norm(w_gdro) - w_erm / torch.norm(w_erm)).item()\n",
        "    nerm_arr[j] = torch.norm(w_erm).item()\n",
        "    gw_arr[j] = group_weights.detach().cpu().numpy()\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 315
        },
        "id": "OCLvGY7knWYG",
        "outputId": "a723d34e-fd84-4085-ab50-b1d15e2b2ec4"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(diw_arr, label=r'$\\| \\tilde{\\theta}_{iw} - \\tilde{\\theta}_{erm} \\|_2$')\n",
        "plt.plot(dgdro_arr, label=r'$\\| \\tilde{\\theta}_{gdro} - \\tilde{\\theta}_{erm} \\|_2$')\n",
        "plt.legend()\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Norm of Difference')\n",
        "plt.gcf().subplots_adjust(left=0.2, bottom=0.2)\n",
        "plt.savefig('linear_poly_nd.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 315
        },
        "id": "5lflPHfJnXyC",
        "outputId": "7c490561-1dd0-49b3-989c-3147b8400f9c"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
            "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(loss_erm_arr, label='ERM')\n",
        "plt.plot(loss_iw_arr, label='IW')\n",
        "plt.plot(loss_gdro_arr, label='GDRO')\n",
        "plt.legend()\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Training Loss')\n",
        "plt.gcf().subplots_adjust(left=0.25, bottom=0.2)\n",
        "plt.savefig('linear_poly_train.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 281
        },
        "id": "fRpJvm2KnYuL",
        "outputId": "9c5fd2be-7a61-452a-b24b-1fd3d225cbea"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(nerm_arr)\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Norm of ERM Model')\n",
        "plt.gcf().subplots_adjust(left=0.17, bottom=0.2)\n",
        "plt.savefig('linear_poly_erm.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 280
        },
        "id": "Prv92kF_nZ46",
        "outputId": "89525d36-2b83-46ff-b790-49dba63a748d"
      },
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          },
          "output_type": "display_data"
        }
      ],
      "source": [
        "plt.plot(gw_arr[:, 0])\n",
        "plt.plot(gw_arr[:, 1])\n",
        "plt.xlabel(r'$\\times 10000$ epochs')\n",
        "plt.ylabel('Group Weight')\n",
        "plt.gcf().subplots_adjust(left=0.2, bottom=0.2)\n",
        "plt.savefig('linear_poly_gw.eps')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-aAQCAUannPL"
      },
      "outputs": [],
      "source": [
        "data = {\n",
        "    'loss_erm_arr': loss_erm_arr,\n",
        "    'loss_iw_arr': loss_iw_arr,\n",
        "    'loss_gdro_arr': loss_gdro_arr,\n",
        "    'nerm_arr': nerm_arr,\n",
        "    'diw_arr': diw_arr,\n",
        "    'dgdro_arr': dgdro_arr,\n",
        "    'gw_arr': gw_arr,\n",
        "}\n",
        "with open('linear_poly_10m_1e3.pkl', 'wb') as f:\n",
        "  pickle.dump(data, f)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "M1GC6tUd2MPJ"
      },
      "source": [
        "## Reproducing Paper Results\n",
        "In the above implementations, we used the fixed random seed 2022 for all experiments. Thus, when the notebook is run in the same environment, the results in the paper can be exactly reproduced. Here we list the specs of our experiment environment:\n",
        "- GPU: NVIDIA 1080ti (1 GPU)\n",
        "- OS: Ubuntu 18.04.6\n",
        "- Python Version: 3.9.0\n",
        "- Pytorch Version: 1.10.0\n",
        "- CUDA Version: 10.2"
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "collapsed_sections": [],
      "name": "dist_shift_erm.ipynb",
      "provenance": [],
      "toc_visible": true
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
