{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "collapsed": true
   },
   "source": [
    "# Approximating a region of the sine function"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In this notebook we will approximate a region of the sine function with a neural network to get a sense of how architecture and hyperparameters affect neural network performance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "USING pytorch VERSION:  1.1.0\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import copy\n",
    "import numpy as np\n",
    "from matplotlib import pyplot\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch import optim\n",
    "from torch.nn.parameter import Parameter\n",
    "import torch.nn.functional as F\n",
    "import torch.backends.cudnn as cudnn\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data.dataset import Dataset\n",
    "\n",
    "# Seeds\n",
    "seed = 42\n",
    "cudnn.benchmark = True\n",
    "torch.manual_seed(seed)\n",
    "if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed(seed)\n",
    "cudnn.enabled = True\n",
    "np.random.seed(seed)\n",
    "\n",
    "print(\"USING pytorch VERSION: \", torch.__version__)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generate training data\n",
    "We can synthesize our own data for this practice problem by computing the sin(x) for a range of x values, and adding some noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "src x min:  [-8.99979057]\n",
      "src x max: [8.99864688]\n",
      "src y min:  [-0.6232363]\n",
      "src y max: [0.58639164]\n",
      "tg x min:  [-8.9837304]\n",
      "tg x max: [8.96049342]\n",
      "tg y min:  [-0.22131497]\n",
      "tg y max: [0.44569052]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "src_n_x_train = 30000   # the number of source training datapoints\n",
    "src_n_x_test = 8000     # the number of source testing datapoints\n",
    "\n",
    "tg_n_x_train = 1000   # the number of training datapoints\n",
    "tg_n_x_test = 800     # the number of testing datapoints\n",
    "\n",
    "src_x_train = np.random.rand(src_n_x_train,1)*18 - 9  # Initialize a vector of with dimensions [n_x, 1] and extend\n",
    "src_y_train = (np.sin(src_x_train))/2.5           # Calculate the sin of all data points in the x vector and reduce amplitude\n",
    "src_y_train += (np.random.randn(src_n_x_train, 1)/20)  # add noise to each datapoint\n",
    "\n",
    "tg_x_train = np.random.rand(tg_n_x_train,1)*18 - 9  # Initialize a vector of with dimensions [n_x, 1] and extend\n",
    "tg_y_train = ((np.sinc(tg_x_train))/2.5) #(np.sqrt(np.sin(tg_x_train))/2.5) + (np.sqrt(np.cos(tg_x_train))/2.5) # Calculate the sin of all data points in the x vector and reduce amplitude\n",
    "tg_y_train += (np.random.randn(tg_n_x_train, 1)/20)  # add noise to each datapoint\n",
    "\n",
    "src_x_test = np.random.rand(src_n_x_test, 1)*18 - 9   # Repeat data generation for test set\n",
    "src_y_test = (np.sin(src_x_test))/2.5\n",
    "src_y_test += (np.random.randn(src_n_x_test, 1)/20)\n",
    "                                                  \n",
    "tg_x_test = np.random.rand(tg_n_x_test,1)*18 - 9  # Initialize a vector of with dimensions [n_x, 1] and extend\n",
    "tg_y_test = ((np.sinc(tg_x_test))/2.5) #np.array([np.sin(tg_x)/2.5 for tg_x in tg_x_test]) #(np.sqrt(np.sin(tg_x_test))/2.5) + (np.sqrt(np.cos(tg_x_test))/2.5 )   # Calculate the sin of all data points in the x vector and reduce amplitude\n",
    "tg_y_test += (np.random.randn(tg_n_x_test, 1)/20)  # add noise to each datapoint\n",
    "\n",
    "\n",
    "print(\"src x min: \", min(src_x_train))\n",
    "print(\"src x max:\", max(src_x_train))\n",
    "print(\"src y min: \", min(src_y_train))\n",
    "print(\"src y max:\", max(src_y_train))\n",
    "\n",
    "                                                \n",
    "print(\"tg x min: \", min(tg_x_train))\n",
    "print(\"tg x max:\", max(tg_x_train))\n",
    "print(\"tg y min: \", min(tg_y_train))\n",
    "print(\"tg y max:\", max(tg_y_train))\n",
    "                                                \n",
    "fig0_0 = pyplot.figure()  # initialize a plot\n",
    "pyplot.scatter(src_x_train, src_y_train, marker='o', s=0.2)  # plot x vs y\n",
    "pyplot.savefig('sim_src_data.png')\n",
    "pyplot.savefig('sim_src_data.pdf')\n",
    "pyplot.show()  # open a window with the plot (you have to close it for the script to finish)\n",
    "\n",
    "fig0_1 = pyplot.figure()  # initialize a plot\n",
    "pyplot.scatter(tg_x_train, tg_y_train, marker='v', s=0.2)  # plot x vs y  \n",
    "pyplot.savefig('sim_tg_data.png')\n",
    "pyplot.savefig('sim_tg_data.pdf')\n",
    "pyplot.show()  # open a window with the plot (you have to close it for the script to finish)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define a pytorch Dataset object to contain the training and testing data\n",
    "Pytorch handles data shuffling and batch loading, as long as the user provides a \"Dataset\" class. This class is just a wrapper for your data that casts the data into pytorch tensor format and returns slices of the data. In this case, our data is in numpy format, which conveniently pytorch has a method for converting to their native format."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "class SineDataset(Dataset):\n",
    "    def __init__(self, x, y):\n",
    "        x_dtype = torch.FloatTensor\n",
    "        y_dtype = torch.FloatTensor     # for MSE or L1 Loss\n",
    "\n",
    "        self.length = x.shape[0]\n",
    "\n",
    "        self.x_data = torch.from_numpy(x).type(x_dtype)\n",
    "        self.y_data = torch.from_numpy(y).type(y_dtype)\n",
    "\n",
    "    def __getitem__(self, index):\n",
    "        return self.x_data[index], self.y_data[index]\n",
    "\n",
    "    def __len__(self):\n",
    "        return self.length"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define training methods for the model\n",
    "These methods use an initialized model and training data to iteratively perform the forward and backward pass of optimization. Aside from some data reformatting that depends on the input, output, and loss function, these methods will always be the same for any shallow neural network."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_x = None\n",
    "sample_src_feat = None\n",
    "def train_auto_route(model, src_model, loader, optimizer,src_optimizer, loss_fn, pairs, wts, epochs=5):\n",
    "    losses = list()\n",
    "    global sample_x\n",
    "    sample_src_feat = None\n",
    "    sample_y_predicts = list()\n",
    "    sample_tg_feats = list()\n",
    "    sample_tg_params = list()\n",
    "    \n",
    "    model.train()\n",
    "    src_model.eval()\n",
    "    batch_index = 0\n",
    "    for e in range(epochs):\n",
    "        for x, y in loader:\n",
    "            with torch.no_grad():\n",
    "                _, src_feats = src_model.forward(x)\n",
    "                \n",
    "            # Run forward calculation\n",
    "            y_predict,_ = model.forward(x, src_feats, pairs, wts)\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                if not sample_x:\n",
    "                    sample_x = x[4].unsqueeze(0)\n",
    "                    _, src_feats = src_model.forward(sample_x)\n",
    "                    sample_src_feat = model.ru[-1][-1](src_feats[-1])\n",
    "                sample_y_predict, tg_feats = model.forward(sample_x)\n",
    "                sample_tg_feats.append(tg_feats[-1])\n",
    "                sample_y_predicts.append(sample_y_predict)\n",
    "                param = copy.deepcopy(model.linear4.weight.data.numpy())\n",
    "                sample_tg_params.append(param)\n",
    "                \n",
    "            # Compute loss.\n",
    "            loss = loss_fn(y_predict, y)\n",
    "            # Before the backward pass, use the optimizer object to zero all of the\n",
    "            # gradients for the variables it will update (which are the learnable weights\n",
    "            # of the model)\n",
    "            optimizer.zero_grad()\n",
    "            src_optimizer.zero_grad()\n",
    "            # Backward pass: compute gradient of the loss with respect to model\n",
    "            # parameters\n",
    "            loss.backward()\n",
    "            nn.utils.clip_grad_norm_(model.parameters(), 5.)\n",
    "            # Calling the step function on an Optimizer makes an update to its\n",
    "            # parameters\n",
    "            optimizer.step()\n",
    "            src_optimizer.step()\n",
    "            losses.append(loss.data.item())\n",
    "\n",
    "            batch_index += 1\n",
    "\n",
    "#         print(\"Epoch: \", e+1)\n",
    "#         print(\"Batches: \", batch_index)\n",
    "    sample_results = (sample_x, sample_src_feat, sample_y_predicts, sample_tg_feats, sample_tg_params)\n",
    "    return losses, sample_results\n",
    "\n",
    "\n",
    "def train_l2t(model, fm, src_model, loader, optimizer, loss_fn, beta=1, epochs=5):\n",
    "    losses = list()\n",
    "    global sample_x\n",
    "    sample_src_feat = None\n",
    "    sample_y_predicts = list()\n",
    "    sample_tg_feats = list()\n",
    "    sample_tg_params = list()\n",
    "    \n",
    "    model.train()\n",
    "    src_model.eval()\n",
    "    batch_index = 0\n",
    "    for e in range(epochs):\n",
    "        for x, y in loader:\n",
    "            with torch.no_grad():\n",
    "                _, src_feats = src_model.forward(x)\n",
    "            # Run forward calculation\n",
    "            y_predict, tg_feats = model.forward(x)\n",
    "\n",
    "            with torch.no_grad():\n",
    "                if not sample_x:\n",
    "                    sample_x = x[4].unsqueeze(0)\n",
    "                    _, src_feats = src_model.forward(sample_x)\n",
    "                    sample_src_feat = fm[-1](src_feats[-1])\n",
    "                sample_y_predict, tg_feats = model.forward(sample_x)\n",
    "                sample_tg_feats.append(tg_feats[-1])\n",
    "                sample_y_predicts.append(sample_y_predict)\n",
    "                param = copy.deepcopy(model.linear4.weight.data.numpy())\n",
    "                sample_tg_params.append(param)\n",
    "                \n",
    "            # Compute loss.\n",
    "            obj_loss = loss_fn(y_predict, y)\n",
    "            fm_loss = fm(src_feats, tg_feats, beta)\n",
    "\n",
    "            loss = obj_loss + fm_loss\n",
    "            # Before the backward pass, use the optimizer object to zero all of the\n",
    "            # gradients for the variables it will update (which are the learnable weights\n",
    "            # of the model)\n",
    "            optimizer.zero_grad()\n",
    "\n",
    "            # Backward pass: compute gradient of the loss with respect to model\n",
    "            # parameters\n",
    "            loss.backward()\n",
    "\n",
    "            # Calling the step function on an Optimizer makes an update to its\n",
    "            # parameters\n",
    "            optimizer.step()\n",
    "\n",
    "            losses.append(loss.data.item())\n",
    "            batch_index += 1\n",
    "\n",
    "#         print(\"Epoch: \", e+1)\n",
    "#         print(\"Batches: \", batch_index)\n",
    "\n",
    "    sample_results = (sample_x, sample_src_feat, sample_y_predicts, sample_tg_feats, sample_tg_params)\n",
    "    return losses, sample_results\n",
    "\n",
    "\n",
    "def train(model, loader, optimizer, loss_fn, epochs=5):\n",
    "    losses = list()\n",
    "    global sample_x\n",
    "    sample_src_feat = None\n",
    "    sample_y_predicts = list()\n",
    "    sample_tg_feats = list()\n",
    "    sample_tg_params = list()\n",
    "    model.train()\n",
    "    batch_index = 0\n",
    "    for e in range(epochs):\n",
    "        for x, y in loader:\n",
    "            # Run forward calculation\n",
    "            y_predict,_ = model.forward(x)\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                if not sample_x:\n",
    "                    sample_x = x[1].unsqueeze(0)\n",
    "                sample_y_predict, tg_feats = model.forward(sample_x)\n",
    "                sample_tg_feats.append(tg_feats[-1])\n",
    "                sample_y_predicts.append(sample_y_predict)\n",
    "                param = copy.deepcopy(model.linear4.weight.data.numpy())\n",
    "                sample_tg_params.append(param)\n",
    "                \n",
    "            # Compute loss.\n",
    "            loss = loss_fn(y_predict, y)\n",
    "            # Before the backward pass, use the optimizer object to zero all of the\n",
    "            # gradients for the variables it will update (which are the learnable weights\n",
    "            # of the model)\n",
    "            optimizer.zero_grad()\n",
    "            # Backward pass: compute gradient of the loss with respect to model\n",
    "            # parameters\n",
    "            loss.backward()\n",
    "\n",
    "            # Calling the step function on an Optimizer makes an update to its\n",
    "            # parameters\n",
    "            optimizer.step()\n",
    "            losses.append(loss.data.item())\n",
    "\n",
    "            batch_index += 1\n",
    "\n",
    "#         print(\"Epoch: \", e+1)\n",
    "#         print(\"Batches: \", batch_index)\n",
    "    sample_results = (sample_x, sample_src_feat, sample_y_predicts, sample_tg_feats, sample_tg_params)\n",
    "    return losses, sample_results\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define testing methods for the model\n",
    "These methods are like training, but we don't need to update the parameters of the model anymore because when we call the test() method, the model has already been trained. Instead, this method just calculates the predicted y values and returns them, AKA the forward pass."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(model, loader):\n",
    "    model.eval()\n",
    "    y_vectors = list()\n",
    "    y_predict_vectors = list()\n",
    "\n",
    "    batch_index = 0\n",
    "    for x, y in loader:\n",
    "        # run forward calculation\n",
    "        y_predict, feats = model.forward(x)\n",
    "        y_vectors.append(y.data.numpy())\n",
    "        y_predict_vectors.append(y_predict.data.numpy())\n",
    "\n",
    "        batch_index += 1\n",
    "\n",
    "    y_predict_vector = np.concatenate(y_predict_vectors)\n",
    "\n",
    "    return y_predict_vector\n",
    "\n",
    "\n",
    "def test_auto_route(model, loader, pairs, wts=None):\n",
    "    model.eval()\n",
    "    y_vectors = list()\n",
    "    y_predict_vectors = list()\n",
    "\n",
    "    batch_index = 0\n",
    "    for x, y in loader:\n",
    "        # run forward calculation\n",
    "        with torch.no_grad():\n",
    "                _, src_feats = src_model.forward(x)\n",
    "                \n",
    "        # Run forward calculation\n",
    "        y_predict,feats = model.forward(x, src_feats, pairs, wts)\n",
    "        y_vectors.append(y.data.numpy())\n",
    "        y_predict_vectors.append(y_predict.data.numpy())\n",
    "\n",
    "        batch_index += 1\n",
    "\n",
    "    y_predict_vector = np.concatenate(y_predict_vectors)\n",
    "    return y_predict_vector\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define plotting method for loss\n",
    "This is a plotting method for looking at the behavior of the loss over training iterations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_loss(losses, show=True):\n",
    "    fig = pyplot.gcf()\n",
    "    fig.set_size_inches(8,6)\n",
    "    ax = pyplot.axes()\n",
    "    ax.set_xlabel(\"Iteration\")\n",
    "    ax.set_ylabel(\"Loss\")\n",
    "    x_loss = list(range(len(losses)))\n",
    "    pyplot.plot(x_loss, losses)\n",
    "\n",
    "    if show:\n",
    "        pyplot.show()\n",
    "\n",
    "    pyplot.close()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define model architecture\n",
    "Finally we can define a model to be trained. This is a very simple template that will not perform well on a complicated task. Without the activation function, this model would be a NN implementation of linear regression.\n",
    "\n",
    "The following architecture parameters are defined here:\n",
    "- number of layers\n",
    "- size of layers\n",
    "- activation function\n",
    "\n",
    "This is where your weight matrices are defined. Between each layer, the weight matrix needs to have dimensions i x j where i is your input size and j is your output size. In other words, each weight contained in a matrix connects the i'th input node of the previous layer with the j'th output node of next layer. If your input layer is 40 and your output layer is 90, you need a 40 x 90 matrix to store all the connecting weights: torch.nn.Linear(40, 90).\n",
    "\n",
    "In the forward() method, the input vector x is sequentially operated on by the layers of the model. The training and testing method calls forward() to calculate the model's output.\n",
    "\n",
    "See the pytorch documentation for a full list of available activation functions:\n",
    "http://pytorch.org/docs/master/nn.html#non-linear-activation-functions\n",
    "\n",
    "Try switching between these 3 and see if there is a notable difference in the rate of convergence or closeness of the fit:\n",
    "- `relu()`\n",
    "- `sigmoid()`\n",
    "- `tanh()`\n",
    "\n",
    "Try adding more layers to the model by defining them in the init method and adding them to the forward pass method."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "class ShallowLinear(nn.Module):\n",
    "    '''\n",
    "    A simple, general purpose, fully connected network for Source Network\n",
    "    '''\n",
    "    def __init__(self, conf=[1, 64, 64, 64, 1], auto=False, auto_src_conf=[]):\n",
    "        # Perform initialization of the pytorch superclass\n",
    "        super(ShallowLinear, self).__init__()\n",
    "        self.conf = conf\n",
    "        # Define network layer dimensions\n",
    "        D_in, H1, H2, H3, D_out = conf    # These numbers correspond to each layer: [input, hidden_1, output]\n",
    "        \n",
    "        # Define layer types\n",
    "        self.linear1 = nn.Linear(D_in, H1)\n",
    "        self.linear2 = nn.Linear(H1, H2)\n",
    "        self.linear3 = nn.Linear(H2, H3)\n",
    "        self.linear4 = nn.Linear(H3, D_out)\n",
    "        \n",
    "        self.ru = nn.ModuleList([])\n",
    "        self.cs = nn.ModuleList([])\n",
    "        if auto:\n",
    "            for ii, tg_H in enumerate(self.conf[1:-1]):\n",
    "                self.cs.append(nn.ModuleList([]))\n",
    "                self.ru.append(nn.ModuleList([]))\n",
    "                for jj, src_H in enumerate(auto_src_conf[1:-1]):\n",
    "                    self.ru[ii].append(nn.Linear(src_H, tg_H, bias=False))\n",
    "                    self.cs[ii].append(nn.Linear(2,1,bias=False))\n",
    "                    self.cs[ii][jj].weight.data.fill_(1)\n",
    "            \n",
    "            \n",
    "\n",
    "    def forward(self, x, src_x=None, pairs=None, wts=None):\n",
    "        '''\n",
    "        This method defines the network layering and activation functions\n",
    "        '''\n",
    "        i=0\n",
    "        x1 = self.linear1(x) # hidden layer = out 64\n",
    "        if src_x:\n",
    "            assert pairs is not None\n",
    "            src_id, tg_id = pairs[i]\n",
    "            if src_id>=0:\n",
    "                s1 = self.ru[tg_id][src_id](src_x[src_id])\n",
    "#                 s1 = src_x[src_id]\n",
    "                if wts:\n",
    "                    wt = wts[i]\n",
    "                    x1 = wt[0]*s1 + wt[1]*x1\n",
    "                else:\n",
    "                    x1 = torch.stack([s1,x1],dim=-1)\n",
    "                    x1 = self.cs[tg_id][src_id](x1).squeeze()\n",
    "#         x1 = torch.tanh(x1)\n",
    "        x11 = F.relu(x1)\n",
    "        \n",
    "        i=1\n",
    "        x2 = self.linear2(x11) # hidden layer out 64\n",
    "        if src_x:\n",
    "            assert pairs is not None\n",
    "            src_id, tg_id = pairs[i]\n",
    "            if src_id>=0:\n",
    "                s2 = self.ru[tg_id][src_id](src_x[src_id])\n",
    "#                 s2 = src_x[src_id]\n",
    "                if wts:\n",
    "                    wt = wts[i]\n",
    "                    x2 = wt[0]*s2 + wt[1]*x2\n",
    "                else:\n",
    "                    x2 = torch.stack([s2,x2],dim=-1)\n",
    "                    x2 = self.cs[tg_id][src_id](x2).squeeze()\n",
    "#         x2 = torch.tanh(x2)       # activation function\n",
    "        x22 = F.relu(x2)\n",
    "        \n",
    "        i=2\n",
    "        x3 = self.linear3(x22) # hidden layer out 64\n",
    "        if src_x:\n",
    "            assert pairs is not None\n",
    "            src_id, tg_id = pairs[i]\n",
    "            if src_id>=0:\n",
    "                s3 = self.ru[tg_id][src_id](src_x[src_id])\n",
    "#                 s3 = src_x[src_id]\n",
    "                if wts:\n",
    "                    wt = wts[i]\n",
    "                    x3 = wt[0]*s3 + wt[1]*x3\n",
    "                else:\n",
    "                    x3 = torch.stack([s3,x3],dim=-1)\n",
    "                    x3 = self.cs[tg_id][src_id](x3).squeeze()  \n",
    "\n",
    "#         x3 = torch.tanh(x3)       # activation function\n",
    "        x33 = F.relu(x3)\n",
    "        \n",
    "        out = self.linear4(x33) # output layer\n",
    "        \n",
    "        return out, [x1, x2, x3]\n",
    "\n",
    "    \n",
    "class FeatureMatching(nn.ModuleList):\n",
    "    def __init__(self, src_conf, tg_conf, pairs):\n",
    "        super(FeatureMatching, self).__init__()\n",
    "        self.src_conf = src_conf\n",
    "        self.tg_conf = tg_conf\n",
    "        self.pairs = pairs\n",
    "        self.beta_wts = nn.Parameter(torch.ones(len(pairs)) * 1)\n",
    "        for src_idx, tgt_idx in pairs:\n",
    "            self.append(nn.Linear(self.src_conf[src_idx],self.tg_conf[tgt_idx], bias=False))\n",
    "\n",
    "    def forward(self, source_features, target_features, beta):\n",
    "\n",
    "        matching_loss = 0.0\n",
    "        for i, (src_idx, tgt_idx) in enumerate(self.pairs):\n",
    "            diff = self[i](source_features[src_idx]) - target_features[tgt_idx]\n",
    "#             diff = source_features[src_idx] - target_features[tgt_idx]\n",
    "            diff = diff.pow(2)\n",
    "            diff = diff.mean(1)\n",
    "            diff = diff.mean(0)\n",
    "            diff=diff.mul(self.beta_wts[i])\n",
    "            matching_loss = matching_loss + beta*diff\n",
    "        return matching_loss\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Method to define hyperparameters, train, and test\n",
    "\n",
    "Here we define the following parameters for training:\n",
    "\n",
    "- batch size\n",
    "- learning rate\n",
    "- optimizer\n",
    "- loss function\n",
    "\n",
    "Ideally, numeric parameters would be tested empirically with an exhaustive search. When testing manually, It is recommended to maximize the model fit with one parameter at a time to avoid confounding your results. \n",
    "\n",
    "Try these learning rates:\n",
    "- 5e-2, 1e-2, 5e-3, 1e-3, 5e-4, 1e-4, 5e-5\n",
    "\n",
    "Try these optimizers:\n",
    "- `optim.SGD(shallow_model.parameters(), lr=learning_rate)`\n",
    "- `optim.Adam(shallow_model.parameters(), lr=learning_rate)`\n",
    "\n",
    "See the pytorch documentation pages for an extensive list of options:\n",
    "- Optimizers: http://pytorch.org/docs/master/optim.html#algorithms\n",
    "- Loss: http://pytorch.org/docs/master/nn.html#id46\n",
    "\n",
    "Read this page for a detailed comparison of optimizers: http://ruder.io/optimizing-gradient-descent/\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run(model, dataset_train, dataset_test, lr, epochs=5):\n",
    "    # Batch size is the number of training examples used to calculate each iteration's gradient\n",
    "    batch_size_train = 16\n",
    "    \n",
    "    data_loader_train = DataLoader(dataset=dataset_train, batch_size=batch_size_train, shuffle=True)\n",
    "    data_loader_test = DataLoader(dataset=dataset_test, batch_size=len(dataset_test), shuffle=False)\n",
    "    \n",
    "    # Define the hyperparameters\n",
    "    learning_rate = lr\n",
    "    shallow_model = model\n",
    "    \n",
    "    # Initialize the optimizer with above parameters\n",
    "    optimizer = optim.Adam(shallow_model.parameters(), lr=learning_rate)\n",
    "\n",
    "    # Define the loss function\n",
    "    loss_fn = nn.MSELoss()  # mean squared error\n",
    "\n",
    "    # Train and get the resulting loss per iteration\n",
    "    loss, sample_results = train(model=shallow_model, loader=data_loader_train, optimizer=optimizer, loss_fn=loss_fn, epochs=epochs)\n",
    "    \n",
    "    # Test and get the resulting predicted y values\n",
    "    y_predict = test(model=shallow_model, loader=data_loader_test)\n",
    "\n",
    "    return loss, sample_results, y_predict\n",
    "\n",
    "def run_l2t(model, fm, src_model, dataset_train, dataset_test, lr, epochs=5):\n",
    "    # Batch size is the number of training examples used to calculate each iteration's gradient\n",
    "    batch_size_train = 16\n",
    "    \n",
    "    data_loader_train = DataLoader(dataset=dataset_train, batch_size=batch_size_train, shuffle=True)\n",
    "    data_loader_test = DataLoader(dataset=dataset_test, batch_size=len(dataset_test), shuffle=False)\n",
    "    \n",
    "    # Define the hyperparameters\n",
    "    learning_rate = lr\n",
    "    shallow_model = model\n",
    "    \n",
    "    # Initialize the optimizer with above parameters\n",
    "    optimizer = optim.Adam(list(shallow_model.parameters())+list(fm.parameters()), lr=learning_rate)\n",
    "\n",
    "    # Define the loss function\n",
    "    loss_fn = nn.MSELoss()  # mean squared error\n",
    "\n",
    "    # Train and get the resulting loss per iteration\n",
    "    loss, sample_results = train_l2t(model=shallow_model, fm=fm, src_model=src_model, loader=data_loader_train, optimizer=optimizer, loss_fn=loss_fn, epochs=epochs)\n",
    "\n",
    "    # Test and get the resulting predicted y values\n",
    "    y_predict = test(model=shallow_model, loader=data_loader_test)\n",
    "\n",
    "    return loss, sample_results, y_predict\n",
    "\n",
    "def run_auto_route(model, src_model, dataset_train, dataset_test, lr, pairs, wts, epochs=5):\n",
    "    # Batch size is the number of training examples used to calculate each iteration's gradient\n",
    "    batch_size_train = 16\n",
    "    \n",
    "    data_loader_train = DataLoader(dataset=dataset_train, batch_size=batch_size_train, shuffle=True)\n",
    "    data_loader_test = DataLoader(dataset=dataset_test, batch_size=len(dataset_test), shuffle=False)\n",
    "    \n",
    "    # Define the hyperparameters\n",
    "    learning_rate = lr\n",
    "    shallow_model = model\n",
    "    \n",
    "    # Initialize the optimizer with above parameters\n",
    "    target_params = [param for name, param in shallow_model.named_parameters()\n",
    "                     if ('cs' not in name ) and param.requires_grad is True]\n",
    "    weight_params = [param for name, param in shallow_model.named_parameters()\n",
    "                         if ('cs' in name) and param.requires_grad is True]\n",
    "    \n",
    "    optimizer = optim.Adam(target_params, lr=learning_rate)\n",
    "    src_optimizer = optim.Adam(weight_params, lr=learning_rate)\n",
    "\n",
    "    # Define the loss function\n",
    "    loss_fn = nn.MSELoss()  # mean squared error\n",
    "\n",
    "    # Train and get the resulting loss per iteration\n",
    "    loss, sample_results = train_auto_route(model=shallow_model, src_model=src_model, loader=data_loader_train, optimizer=optimizer, src_optimizer=src_optimizer, loss_fn=loss_fn, pairs=pairs, wts=wts, epochs=epochs)\n",
    "    \n",
    "    # Test and get the resulting predicted y values\n",
    "    y_predict = test_auto_route(model=shallow_model, loader=data_loader_test, pairs=pairs, wts=wts)\n",
    "\n",
    "    return loss, sample_results, y_predict\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Initiate training, plot testing results\n",
    "In this cell we put all the previous methods together to train and test the model. By default we will iterate through the training dataset 5 times before looking at the results. This problem is an unusal one in that our loss is the best quantitative metric of the model performance. Classification problems require further analysis of true/false positives/negatives. \n",
    "\n",
    "Rerun this cell several times without editing any parameters. Is the result the same?\n",
    "\n",
    "Try a larger batch size, how is the training time affected?\n",
    "\n",
    "Look at the slope and noise level of the loss plot. Does it look like the training converged on a local minimum? "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Source Train set size:  30000\n",
      "Source Test set size:  8000\n",
      "Source Final loss: 0.0033671503933146597\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "ShallowLinear(\n",
       "  (linear1): Linear(in_features=1, out_features=64, bias=True)\n",
       "  (linear2): Linear(in_features=64, out_features=64, bias=True)\n",
       "  (linear3): Linear(in_features=64, out_features=64, bias=True)\n",
       "  (linear4): Linear(in_features=64, out_features=1, bias=True)\n",
       "  (ru): ModuleList()\n",
       "  (cs): ModuleList()\n",
       ")"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Define the hyperparameters\n",
    "learning_rate = 1e-3\n",
    "\n",
    "# Source Model Learning\n",
    "src_dataset_train = SineDataset(x=src_x_train, y=src_y_train)\n",
    "src_dataset_test = SineDataset(x=src_x_test, y=src_y_test)\n",
    "\n",
    "print(\"Source Train set size: \", src_dataset_train.length)\n",
    "print(\"Source Test set size: \", src_dataset_test.length)\n",
    "\n",
    "src_conf = [1, 64, 64, 64, 1]\n",
    "src_model = ShallowLinear(conf=src_conf)\n",
    "src_losses, _, src_y_predict = run(dataset_train=src_dataset_train, dataset_test=src_dataset_test, model=src_model, lr=learning_rate, epochs=10) # number of epochs reduced for demo here\n",
    "\n",
    "print(\"Source Final loss:\", sum(src_losses[-100:])/100)\n",
    "plot_loss(src_losses)\n",
    "\n",
    "fig2 = pyplot.figure()\n",
    "fig2.set_size_inches(8,6)\n",
    "pyplot.scatter(src_x_test, src_y_test, marker='o', s=0.2, c='black')\n",
    "pyplot.scatter(src_x_test, src_y_predict, marker='o', s=0.3, c='red')\n",
    "pyplot.text(-9, 0.4, \"-Source Prediction\", color=\"red\", fontsize=20)\n",
    "pyplot.text(-9, 0.5, \"- Sine (with noise)\", color=\"black\", fontsize=20)\n",
    "pyplot.show()\n",
    "\n",
    "src_model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target Train set size:  1000\n",
      "Target Test set size:  800\n"
     ]
    }
   ],
   "source": [
    "# Define the hyperparameters\n",
    "learning_rate = 1e-3\n",
    "tg_conf = [1, 16, 16, 16, 1]\n",
    "\n",
    "# Indep Target Task Learning\n",
    "tg_dataset_train = SineDataset(x=tg_x_train, y=tg_y_train)\n",
    "tg_dataset_test = SineDataset(x=tg_x_test, y=tg_y_test)\n",
    "\n",
    "print(\"Target Train set size: \", tg_dataset_train.length)\n",
    "print(\"Target Test set size: \", tg_dataset_test.length)\n",
    "\n",
    "# Source Model\n",
    "src_y_predict = test(model=src_model, loader=tg_dataset_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Indep Target Final loss: 0.0032995474187191578\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Independent Target Learning\n",
    "sample_x = None\n",
    "sample_src_feat = None\n",
    "tg_model = ShallowLinear(conf=tg_conf)\n",
    "tg_losses, sample_result, tg_y_predict = run(dataset_train=tg_dataset_train, dataset_test=tg_dataset_test, model=tg_model, lr=learning_rate, epochs=50)\n",
    "sample_x = sample_result[0]\n",
    "sample_src_feat = sample_result[1]\n",
    "print(\"Indep Target Final loss:\", sum(tg_losses[-100:])/100)\n",
    "plot_loss(tg_losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L2T Final loss: 0.12538399524986743\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# L2T Learning to Transfer\n",
    "l2t_tg_model = ShallowLinear(conf=tg_conf)\n",
    "fm = FeatureMatching(src_conf[1:-1], tg_conf[1:-1], [(0,0),(0,1),(0,2),(1,0),(1,1),(1,2),(2,0),(2,1),(2,2)])\n",
    "l2t_tg_losses, l2t_sample_result, l2t_tg_y_predict = run_l2t(dataset_train=tg_dataset_train, dataset_test=tg_dataset_test, model=l2t_tg_model, fm=fm, src_model=src_model, lr=learning_rate, epochs=50)\n",
    "sample_x = l2t_sample_result[0]\n",
    "sample_src_feat = l2t_sample_result[1]\n",
    "print(\"L2T Final loss:\", sum(l2t_tg_losses[-100:])/100)\n",
    "plot_loss(l2t_tg_losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Auto-Transfer Final loss: 0.003017549017095007\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "seed = 42\n",
    "cudnn.benchmark = True\n",
    "torch.manual_seed(seed)\n",
    "if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed(seed)\n",
    "cudnn.enabled = True\n",
    "np.random.seed(seed)\n",
    "\n",
    "# Auto-Transfer \n",
    "pairs = [(0,0),(1,1),(2,2)] #(src,tg) format\n",
    "\n",
    "# Sanity Checks\n",
    "# wts   = [(1,0),(1,0),(1,0)] # Pass through Source Only\n",
    "# wts   = [(0,1),(0,1),(0,1)] # Revert to Independent targettask learning\n",
    "# wts   = [(0.5,0.5),(0.5,0.5),(0.5,0.5)] # Equal weights\n",
    "# wts   = [(1,1),(1,1),(1,1)] # SimpleAdd\n",
    "\n",
    "wts   = None # Automatically select weights\n",
    "auto_tg_model = ShallowLinear(conf=tg_conf, auto=True, auto_src_conf=src_conf)\n",
    "auto_tg_losses, auto_sample_result, auto_tg_y_predict = run_auto_route(dataset_train=tg_dataset_train, dataset_test=tg_dataset_test, model=auto_tg_model, src_model=src_model, lr=learning_rate, pairs=pairs, wts=wts, epochs=50)\n",
    "sample_x = auto_sample_result[0]\n",
    "sample_src_feat = auto_sample_result[1]\n",
    "print(\"Auto-Transfer Final loss:\", sum(auto_tg_losses[-100:])/100)\n",
    "plot_loss(auto_tg_losses)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig3 = pyplot.figure()\n",
    "fig3.set_size_inches(8,6)\n",
    "pyplot.scatter(tg_x_test, tg_y_test, marker='o', s=0.5, c='black', label='[Black]- Sinc (with noise)')\n",
    "pyplot.text(1.5, 0.44, \"- Sinc (with noise)\", color=\"black\", fontsize=20)\n",
    "pyplot.scatter(tg_x_test, src_y_predict, marker='o', s=0.5, c='grey', label='[Blue]- Prediction (Source)')\n",
    "pyplot.text(1.5, 0.16, \"- Source Prediction\", color=\"grey\", fontsize=20)\n",
    "pyplot.scatter(tg_x_test, tg_y_predict, marker='o', s=2.5, c='blue', label='[Orange]- Prediction (Target)')\n",
    "pyplot.text(1.5, 0.23, \"- Scratch\", color=\"blue\", fontsize=20)\n",
    "pyplot.scatter(tg_x_test, l2t_tg_y_predict, marker='o', s=2.5, c='red', label='[Green]- Prediction (L2T)')\n",
    "pyplot.text(1.5, 0.30, \"- L2T-ww\", color=\"red\", fontsize=20)\n",
    "pyplot.scatter(tg_x_test, auto_tg_y_predict, marker='o', s=2.5, c='green', label='[Red]- Prediction (Auto)')\n",
    "pyplot.text(1.5, 0.37, \"- Auto-Transfer\", color=\"green\", fontsize=20)\n",
    "# \n",
    "# pyplot.legend()\n",
    "\n",
    "pyplot.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
