{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "id": "L7FWUGf-Tx4U"
   },
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "import string\n",
    "import random\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "DEVICE = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "mpl.rcParams['lines.linewidth'] = 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "WOUJIKULAZBX"
   },
   "source": [
    "### Functions for generating the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "id": "eRam8haPT1cl"
   },
   "outputs": [],
   "source": [
    "def generate_data(size, scheme, seed, a=5.0, b1=7.0, b2=14.0, c=0.0):\n",
    "    \"\"\"\n",
    "    Generates data that serves as input to the function.\n",
    "    Args:\n",
    "        size: (int) the total number of data points\n",
    "        scheme: (str) the nature of the generated data\n",
    "        seed: (int) the number used to initialize random number generation\n",
    "        a: (float) constant parameter\n",
    "        b1: (float) time-varying parameter\n",
    "        b2: (float) time-varying parameter\n",
    "\n",
    "    Returns:\n",
    "        (torch.tensor) values for a\n",
    "        (torch.tensor) values for b\n",
    "    \"\"\"\n",
    "\n",
    "    A = [a for i in range(size)]\n",
    "    B = [b1 for i in range(size)]\n",
    "    C = [c for i in range(size)]\n",
    "    if scheme == \"step\":\n",
    "        B = [b1 if i < size/2 else b2 for i in range(size)]\n",
    "    elif scheme == \"random\":\n",
    "        random.seed(seed)\n",
    "        B = [float(random.uniform(b1, b2)) for i in range(size)]\n",
    "    elif scheme == \"alternate\":\n",
    "        B = [b1 if i % 2 == 0 else b2 for i in range(size)]\n",
    "    elif scheme == \"shift\":\n",
    "        C = [c if i < size / 2 else 5 for i in range(size)]\n",
    "    elif scheme == \"random_shift\":\n",
    "        random.seed(seed)\n",
    "        B = [float(random.uniform(b1, b2)) for i in range(size)]\n",
    "        C = [c if i < size / 2 else 5 for i in range(size)]\n",
    "\n",
    "    return torch.tensor(np.array(A)), torch.tensor(np.array(B)), torch.tensor(np.array(C))\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def cost(a, b, c, x):\n",
    "    \"\"\"\n",
    "    the cost function\n",
    "    Args:\n",
    "        a, b, c: (torch.tensor) the parameters\n",
    "        x: (torch.Parameter) the variable\n",
    "    \"\"\"\n",
    "\n",
    "    return torch.log(a) + torch.log(torch.exp(-b * (x-c)) + torch.exp(b * (x-c)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "XLqjqgCLAUtx"
   },
   "source": [
    "### Optimizers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "id": "14cOR2atUkg5"
   },
   "outputs": [],
   "source": [
    "def optimize_cost(n_iters, lr, x0, optimizer_name, a_vec, b_vec, c_vec,\n",
    "                  decay=False, normalize=False):\n",
    "    \"\"\"\n",
    "    optimizes the cost function\n",
    "    \"\"\"\n",
    "\n",
    "    loss_values = []\n",
    "    x = torch.tensor(x0, dtype=torch.float, requires_grad=True)\n",
    "    x_values = [x.item()]\n",
    "    optimizer = optim.Adagrad([x], lr=lr)\n",
    "    if optimizer_name == \"Adam\":\n",
    "        optimizer = optim.Adam([x], lr=lr)\n",
    "    elif optimizer_name == \"GD\":\n",
    "        optimizer = optim.SGD([x], lr=lr)\n",
    "    for i in tqdm(range(n_iters)):\n",
    "        if optimizer_name == \"Adam\":\n",
    "            if i >= 1:\n",
    "                optimizer.param_groups[0]['lr']=lr/np.sqrt(i)\n",
    "        if decay:\n",
    "            if i >= 1:\n",
    "                optimizer.param_groups[0]['lr']=lr/np.sqrt(i)\n",
    "        if normalize:\n",
    "            optimizer.param_groups[0]['lr']=lr / (b_vec[i] ** 2)\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss = cost(a_vec[i], b_vec[i], c_vec[i], x)\n",
    "        #print(loss)\n",
    "        loss_values.append(loss.item())\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        x_values.append(optimizer.param_groups[0]['params'][0].item())\n",
    "\n",
    "    ## the parameters and loss after the final update\n",
    "    #loss = cost(a_vec[i], b_vec[i], c_vec[i], x)\n",
    "    #loss_values.append(loss.item())\n",
    "    #x_values.append(optimizer.param_groups[0]['params'][0].item())\n",
    "\n",
    "    return np.array(loss_values) #, np.array(x_values)\n",
    "\n",
    "def optimize_cost_ht(gamma, n_iters,x0, a_vec, b_vec, c_vec):\n",
    "    \"\"\"\n",
    "    optimizers the cost using higher order tuner\n",
    "    \"\"\"\n",
    "    \n",
    "    loss_values = []\n",
    "    x_values = []\n",
    "    x = torch.tensor(x0, dtype=torch.float, requires_grad=True)\n",
    "    y = torch.tensor(x0, dtype=torch.float)\n",
    "    z = torch.tensor(x0, dtype=torch.float)\n",
    "\n",
    "    beta = 1 / gamma\n",
    "    for i in tqdm(range(n_iters)):\n",
    "        N_t = b_vec[i] ** 2\n",
    "        mu=1\n",
    "        alpha = mu / N_t\n",
    "        eta = gamma / N_t\n",
    "        x = beta * z + (1 - beta) * y\n",
    "        x.requires_grad = True\n",
    "        loss = cost(a_vec[i], b_vec[i], c_vec[i], x)\n",
    "        loss_values.append(loss.item())\n",
    "        loss.backward()\n",
    "        with torch.no_grad():\n",
    "            y = x - alpha * x.grad\n",
    "            z = z - eta * x.grad\n",
    "\n",
    "        x_values.append(x.item())\n",
    "        x.grad = None\n",
    "\n",
    "    #loss = cost(a_vec[i], b_vec[i], c_vec[i], x)\n",
    "    #loss_values.append(loss.item())\n",
    "    #x_values.append(x.item())\n",
    "\n",
    "    return np.array(loss_values)#, np.array(x_values)\n",
    "\n",
    "def optimize_cost_NAGD(n_iters, x0, a_vec, b_vec, c_vec, mu=1, gamma=1,\n",
    "                       normalize=False):\n",
    "    \"\"\"\n",
    "    optimizes the function using Nesterov's Accelerated Gradient Descent\n",
    "    \"\"\"\n",
    "\n",
    "    loss_values = []\n",
    "    x_values = []\n",
    "    x = torch.tensor(x0, dtype=torch.float, requires_grad=True)\n",
    "    y = torch.tensor(x0, dtype=torch.float)\n",
    "    ## this corresponds to tilde z\n",
    "    z = torch.tensor(x0, dtype=torch.float) * 2\n",
    "\n",
    "    for i in tqdm(range(n_iters)):\n",
    "        N_t = 1\n",
    "        gamma = i / 2\n",
    "        if normalize:\n",
    "            N_t = b_vec[i] ** 2\n",
    "            eta = gamma / N_t\n",
    "        else:\n",
    "            # assuming we are provided with TN-rate\n",
    "            eta = gamma * mu\n",
    "        alpha = mu / N_t\n",
    "\n",
    "        beta = 2 / (i + 1)\n",
    "        beta_next = 2 / (i + 2)\n",
    "        x = z + (1 - beta) * y\n",
    "        x.requires_grad = True\n",
    "        loss = cost(a_vec[i], b_vec[i], c_vec[i], x)\n",
    "        loss_values.append(loss.item())\n",
    "        loss.backward()\n",
    "        with torch.no_grad():\n",
    "            y = x - alpha * x.grad.data\n",
    "            z = beta_next / beta * z - beta_next * eta * x.grad.data\n",
    "\n",
    "        x_values.append(x.item())\n",
    "        x.grad = None\n",
    "\n",
    "    return np.array(loss_values)#, np.array(x_values)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "QY9N_i_AAjB2"
   },
   "source": [
    "### Generate the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "id": "RolbK3vJVc0j"
   },
   "outputs": [],
   "source": [
    "N = 100\n",
    "data_a_step, data_b_step, data_c_step = generate_data(N, \"step\", 101, b1=7.0, b2=21.0)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Initialize values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "start = 7"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "wfQlrv4QApGh"
   },
   "source": [
    "### Changing b from 7 to 21 halfway"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "e8anyLNceThE",
    "outputId": "a323df19-9257-47b4-8bf4-b54a7b7cb89b"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:00<00:00, 7659.85it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 5799.73it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 8798.99it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 9666.30it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 10900.52it/s]\n"
     ]
    }
   ],
   "source": [
    "adam_step_loss = np.zeros(N)\n",
    "adagrad_step_loss = np.zeros(N)\n",
    "ht_step_loss = np.zeros(N)\n",
    "normalized_gd_step_loss = np.zeros(N)\n",
    "normalized_nagd_step_loss = np.zeros(N)\n",
    "gd_step_loss = np.zeros(N)\n",
    "nagd_step_loss = np.zeros(N)\n",
    "\n",
    "\n",
    "ht_step_loss = optimize_cost_ht(1.5, N, start, data_a_step, data_b_step,data_c_step) \n",
    "normalized_gd_step_loss = optimize_cost(N, 1, start, \"GD\", data_a_step,data_b_step, data_c_step, normalize=True) \n",
    "normalized_nagd_step_loss = optimize_cost_NAGD(N, start, data_a_step, data_b_step, data_c_step, normalize=True) \n",
    "gd_step_loss = optimize_cost(N, 1/49, start, \"GD\", data_a_step,data_b_step, data_c_step, normalize=False) \n",
    "nagd_step_loss = optimize_cost_NAGD(N, start, data_a_step, data_b_step,data_c_step, mu=1/49, normalize=False) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 850x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "COLOR_DICT = {\"GD\": \"tab:blue\", \"Adam\": \"tab:green\",\n",
    "             \"Adagrad\":\"tab:orange\", \"NAGD\":\"tab:red\",\n",
    "             \"TN-GD\":\"brown\", \"TN-NAGD\":\"tab:pink\",\n",
    "              \"HT\": \"black\"}\n",
    "\n",
    "def draw_axes(axes, data_dict, list_keys, x_label, y_label,\n",
    "             axes_label=None, set_legend=True, linewidth=0.5):\n",
    "\n",
    "    axes.set_xlabel(x_label)\n",
    "    axes.set_ylabel(y_label,labelpad=9)\n",
    "    #print(data_dict)\n",
    "    for key in list_keys:\n",
    "        y_data = data_dict[key]\n",
    "        x_data = np.arange(0, len(y_data))\n",
    "        #print(x_data)\n",
    "        axes.plot(x_data, y_data, linewidth=2, alpha=0.75, color=COLOR_DICT[key],\n",
    "                 label=key)\n",
    "        if axes_label is not None:\n",
    "            #axes.set_title(axes_label, loc=\"left\", fontweight=\"bold\")\n",
    "            axes.text(-0.05, 1.01, axes_label, transform=axes.transAxes, fontsize=12, fontweight='bold')\n",
    "\n",
    "    if set_legend:\n",
    "        axes.legend(prop={'size': 9})\n",
    "\n",
    "def make_figure(data_dict, panel_a_opt, panel_b_opt,\n",
    "               location=\"fig_output\", name=\"figure.pdf\",\n",
    "               x_label=r\"$t$\", y_label=\"\\n$f_t(x_t)$\"):\n",
    "    \"\"\"\n",
    "    makes the figures\n",
    "\n",
    "    Args:\n",
    "        data_dict: (str) optimizer name -> (np.ndarray) results\n",
    "        panel_a_opt:(List[str])\n",
    "        panel_b_opt:(List[str])\n",
    "  \n",
    "    \"\"\"\n",
    "\n",
    "    fig = plt.figure(figsize=(8.5, 2.5), layout='constrained')\n",
    "    #plt.subplots_adjust(left=.2)\n",
    "    axes1 = fig.add_subplot(1, 2, 1)\n",
    "    axes2 = fig.add_subplot(1, 2, 2)\n",
    "\n",
    "\n",
    "    draw_axes(axes1, data_dict, panel_a_opt, x_label, y_label, \"A\")\n",
    "    draw_axes(axes2, data_dict, panel_b_opt, x_label, y_label, \"B\")\n",
    "    \n",
    "    fig.savefig(name, pad_inches=0,bbox_inches='tight')\n",
    "\n",
    "def make_plot(x, y_dict, x_label, y_label, title):\n",
    "\n",
    "    fig = plt.figure(figsize=(8.5, 2.55), layout='constrained')\n",
    "    axes = fig.add_subplot(1, 1, 1)\n",
    "    axes.set_xlabel(x_label)\n",
    "    axes.set_ylabel(y_label)\n",
    "    axes.set_title(title)\n",
    "\n",
    "    for key in y_dict:\n",
    "        axes.plot(x, y_dict[key], label=key)\n",
    "        axes.legend(prop={'size': 7})\n",
    "    \n",
    "\n",
    "    fig.savefig(name, bbox_inches='tight', pad_inches=0)\n",
    "    #plt.close()\n",
    "\n",
    "\n",
    "results_step = {\"TN-NAGD\":normalized_nagd_step_loss, \"TN-GD\": normalized_gd_step_loss,\n",
    "             \"GD\": gd_step_loss, \"HT\": ht_step_loss, \"NAGD\":nagd_step_loss,\n",
    "             \"Adam\": adam_step_loss, \"Adagrad\":adagrad_step_loss}\n",
    "panel_a = [\"HT\", \"GD\", \"NAGD\"]\n",
    "panel_b = [\"HT\", \"TN-GD\", \"TN-NAGD\"]\n",
    "panel_c = [\"HT\", \"Adam\", \"Adagrad\"]\n",
    "make_figure(results_step, panel_a, panel_b, name='figure2.pdf')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "kernelspec": {
   "display_name": "opt",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
