{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7baceb7e",
   "metadata": {},
   "source": [
    "# ADAM\n",
    "\n",
    "ADAM linear regression from $n$ to $m$ dimensions with observation noise, stochastic covariate shift with randomly changing domain sampling mean."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3c83ecd2",
   "metadata": {
    "tags": [
     "parameters"
    ]
   },
   "outputs": [],
   "source": [
    "# This cell is tagged 'parameters', so all variables will be overwritten by papermill.\n",
    "\n",
    "run_id = 0\n",
    "sweep_name = 'test'\n",
    "\n",
    "# Learning params\n",
    "step_size = 0.01\n",
    "beta_1 = 0.95\n",
    "beta_2 = 0.999\n",
    "iterations = 10000\n",
    "\n",
    "# Problem params\n",
    "input_dimensions = 5\n",
    "output_dimensions = 1\n",
    "target_weight_variance = 0.25\n",
    "weight_init_variance = 0.25\n",
    "observation_noise_variance = 0.01\n",
    "batch_size = 20\n",
    "\n",
    "# Sampling params\n",
    "instantaneous_domain_variance = 0.25\n",
    "mean_switching_variance = 1.0\n",
    "mean_switching_interval = 10\n",
    "\n",
    "# Storage params\n",
    "database = 'adam'\n",
    "user = 'postgres'\n",
    "password = 'password'\n",
    "host = 'localhost'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0197e74a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Using jax for its jit and autograd capabilities.  Will not get around to GPU backends for now.\n",
    "import jax.numpy as jnp\n",
    "from jax import value_and_grad, jit, vmap\n",
    "from jax import random\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "import helpers\n",
    "import data_storage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ee0af5bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b6a906347e6c449090fc80c5ab8b527f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rand_key = random.PRNGKey(run_id)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "target_weights = helpers.random_weights(input_dimensions + 1, output_dimensions, target_weight_variance, subkey)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "weights = helpers.random_weights(input_dimensions + 1, output_dimensions, weight_init_variance, subkey)\n",
    "m_t = jnp.zeros_like(weights)\n",
    "v_t = jnp.zeros_like(weights)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "means = helpers.stochastic_vector_mean_sequence(input_dimensions, mean_switching_interval, mean_switching_variance, iterations, subkey)\n",
    "\n",
    "\n",
    "steps = []\n",
    "losses = []\n",
    "target_distances = []\n",
    "for step, mean in enumerate(tqdm(means)):\n",
    "    rand_key, subkey = random.split(rand_key)\n",
    "\n",
    "    loss, weights, m_t, v_t = helpers.train_step_adam(\n",
    "        mean,\n",
    "        instantaneous_domain_variance,\n",
    "        batch_size,\n",
    "        input_dimensions,\n",
    "        target_weights,\n",
    "        observation_noise_variance,\n",
    "        step_size,\n",
    "        beta_1,\n",
    "        beta_2,\n",
    "        weights,\n",
    "        m_t,\n",
    "        v_t,\n",
    "        step + 1,\n",
    "        rand_key,\n",
    "    )\n",
    "    if step % 10 == 0:\n",
    "        steps.append(step)\n",
    "        losses.append(loss)\n",
    "        target_distances.append(jnp.linalg.norm(weights - target_weights))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "468d322e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f0ee07c70b8>]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 4), dpi=120)\n",
    "plt.plot(target_distances[:mean_switching_interval * 10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "eef29b3e-95d6-4bc3-bb4f-1900b24cae64",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f0ee0711e80>]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 4), dpi=120)\n",
    "plt.plot(target_distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efa59f5e-9f54-43ca-8287-835b5fac5dd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "if run_id != 0:\n",
    "    data_storage.write_losses(run_id, steps, losses, target_distances, database, user, password, host)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a86252a-e7ec-4982-acfb-4eb6e8b03c3c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
