{
 "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.008371458400506526\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAfsAAAF3CAYAAACi+eJxAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvnQurowAAIABJREFUeJzt3Xl4VNX9P/D3h0DYd6JFkB0XFAWNKC64gaC0oK1VbPv90WpLtVqtdhGrouJGtaJ1rRtqXUAFVJRdkEWUJewECISwhUAIJCQh+2Q+vz/mzuTOPpPMzWRu3q/nycPMXWbOnQx533PuueeIqoKIiIjsq0m8C0BERETWYtgTERHZHMOeiIjI5hj2RERENsewJyIisjmGPRERkc0x7ImIiGyOYU9ERGRzDHsiIiKbY9gTERHZXNN4FyBWunTpor169Yp3MYiIiOrN+vXrj6lqSrjtbBP2vXr1QlpaWryLQUREVG9EZH8k27EZn4iIyOYY9kRERDbHsCciIrI5hj0REZHNMeyJiIhsjmFPRERkcwx7IiIim2PYExER2RzDnoiIyOYY9kRERDbHsCciIrI5hn0Q1U7FnryT8S4GERFRnTHsg3h5yW5c+8Jy7M4tjndRiIiI6oRhH8T6/QUAgCNF5XEuCRERUd0w7ImIiGyOYR+GarxLQEREVDcM+yBE4l0CIiKi2GDYExER2RzDnoiIyOYY9kRERDbHsCciIrI5hj0REZHNMeyJiIhsjmEfBm+zJyKiRMewJyIisjmGPRERkc0x7ImIiGyOYU9ERGRzDHsiIiKbszTsRWSUiGSISKaITAyw/k4R2Soim0TkexEZYFr3kLFfhoiMtLKcREREdmZZ2ItIEoDXAFwPYACA28xhbvhEVQeq6iAAzwGYauw7AMA4AOcAGAXgdeP16p1yjlsiIkpwVtbshwDIVNUsVa0EMAPAWPMGqlpketoaNbe1jwUwQ1UrVHUvgEzj9eqNcI5bIiKyiaYWvnY3AAdNz7MBXOy7kYjcDeABAMkArjHtu9pn327WFJOIiMjerKzZB6oa+7WJq+prqtoXwIMAHolmXxGZICJpIpKWl5dXp8ISERHZlZVhnw3gdNPz7gByQmw/A8CN0eyrqm+paqqqpqakpNSxuERERPZkZdivA9BfRHqLSDJcHe7mmDcQkf6mp6MB7DYezwEwTkSai0hvAP0BrLWwrERERLZl2TV7VXWIyD0AFgJIAjBNVdNFZDKANFWdA+AeERkOoApAAYDxxr7pIvIZgO0AHADuVtVqq8pKRERkZ1Z20IOqzgMwz2fZJNPj+0Ls+zSAp60rHRERUePAEfQCcDoVK3a5OvzxLnsiIkp0DHsiIiKbY9gHwPF0iIjIThj2AXD0PCIishOGPRERkc0x7ImIiGyOYU9ERGRzDPswqhxOlFdxPB8iIkpclg6qYwcTPlwPANg3ZXScS0JERFQ7rNkTERHZHMOeiIjI5hj2RERENsewJyIisjmGPRERkc0x7ImIiGyOYU9ERGRzDHsiIiKbY9gTERHZHMOeiIjI5hj2RERENsewJyIisjmGPRERkc0x7ImIiGyOYU9ERGRzDHsiIiKbY9gTERHZHMOeiIjI5hj2RERENsewJyIisjmGPRERkc0x7ImIiGyOYU9ERGRzDHsiIiKbY9gTERHZHMOeiIjI5hj2RERENsewJyIisjlLw15ERolIhohkisjEAOsfEJHtIrJFRJaISE/TumoR2WT8zLGynERERHbW1KoXFpEkAK8BGAEgG8A6EZmjqttNm20EkKqqpSJyF4DnANxqrCtT1UFWlY+IiKixsLJmPwRApqpmqWolgBkAxpo3UNXvVLXUeLoaQHcLy0NERNQoWRn23QAcND3PNpYFcweA+abnLUQkTURWi8iNVhSQiIioMbAy7CXAMg24ochvAKQCeN60uIeqpgL4FYCXRKRvgP0mGCcEaXl5ebEos8fSv14Z09cjIiKKFyvDPhvA6abn3QHk+G4kIsMBPAxgjKpWuJerao7xbxaAZQAG++6rqm+paqqqpqakpMS08J1bN4/p6xEREcWLlWG/DkB/EektIskAxgHw6lUvIoMBvAlX0B81Le8oIs2Nx10AXAbA3LHPeoHaJYiIiBKQZb3xVdUhIvcAWAggCcA0VU0XkckA0lR1DlzN9m0AfC4iAHBAVccAOBvAmyLihOuEZIpPL37LNWHYExGRTVgW9gCgqvMAzPNZNsn0eHiQ/X4AMNDKsoVjnHx4rNydh8v7dfFbTkRE1NBxBL0gfCP9/95di7lbD8elLERERHXBsA8iUAU+50RZ/ReEiIiojhj2QUiAHnoa8MZBIiKiho1hHwQvzRMRkV0w7ImIiGyOYR9EoJo9W/GJiCgRMeyDaMJ2fCIisgmGfRABB/Zn1Z6IiBIQwz6IQIPnKBvyiYgoATHsg2AjPhER2QXDPghesiciIrtg2AcRsBmfrfhERJSAGPZEREQ2x7AnIiKyOYY9ERGRzTHsiYiIbI5hHwVlDz0iIkpADHsiIiKbY9hHgRV7IiJKRAz7EF65bTBS2jaPdzGIiIjqhGEfws/OPw23pHaPdzGIiIjqhGEfhphGyWcrPhERJSKGfRjmUXN5zZ6IiBIRwz6MjQdOxLsIREREdcKwD2N/fonnMeezJyKiRMSwJyIisjmGfRi8Tk9ERImOYR+GOewZ/ERElIgY9lFg1hMRUSJi2BMREdkcw56IiMjmGPZhKC/aExFRgmPYh8F4JyKiRMewD8OrYh+/YhAREdUawz4KbMUnIqJExLAPg0PkEhFRomPYExER2ZylYS8io0QkQ0QyRWRigPUPiMh2EdkiIktEpKdp3XgR2W38jLeynJFiLZ+IiBKRZWEvIkkAXgNwPYABAG4TkQE+m20EkKqq5wGYCeA5Y99OAB4DcDGAIQAeE5GOVpU1FF6nJyKiRGdlzX4IgExVzVLVSgAzAIw1b6Cq36lqqfF0NYDuxuORABarar6qFgBYDGCUhWUNypz1DH4iIkpEVoZ9NwAHTc+zjWXB3AFgfi33tYx5UB1mPRERJaKmFr62BFgWMC9F5DcAUgFcGc2+IjIBwAQA6NGjR+1KGYaTCU9ERAnOypp9NoDTTc+7A8jx3UhEhgN4GMAYVa2IZl9VfUtVU1U1NSUlJWYFN6tm2hMRUYKzMuzXAegvIr1FJBnAOABzzBuIyGAAb8IV9EdNqxYCuE5EOhod864zltU7pynsec2eiIgSkWXN+KrqEJF74ArpJADTVDVdRCYDSFPVOQCeB9AGwOciAgAHVHWMquaLyJNwnTAAwGRVzbeqrKE4WLMnIqIEZ+U1e6jqPADzfJZNMj0eHmLfaQCmWVe6yDi9Ougx+ImIKPFwBL0w2HRPRESJjmEfRrUp7bPySuJYEiIiotph2IfxzvhUz+PF23OxJ+9kHEtDREQUPYZ9GP1PaeP1PLewPE4lISIiqh2GfZR4CZ+IiBINwz4M45ZAD3bYIyKiRMOwj9Jv3l0T7yIQERFFhWEfRqBB+omIiBIJw56IiMjmGPZhSICq/bp9cRm5l4iIqFYY9mFIgIb8X/73R2Qe5f32RESUGBj2tTR86vJ4F4GIiCgiDPswAjXjExERJRKGPRERkc0x7MNgxZ6IiBIdw56IiMjmGPbhsGpPREQJjmFPRERkcwz7MALdZ09ERJRIGPZh8NY7IiJKdAx7IiIim2PYh8GKPRERJbqIwl5E+opIc+PxVSJyr4h0sLZoREREFAuR1uxnAagWkX4A3gXQG8AnlpWqARFetCciogQXadg7VdUB4CYAL6nq/QC6WlcsIiIiipVIw75KRG4DMB7AN8ayZtYUqWFhvZ6IiBJdpGH/OwBDATytqntFpDeAj6wrVsPBVnwiIkp0TSPZSFW3A7gXAESkI4C2qjrFyoIRERFRbETaG3+ZiLQTkU4ANgN4T0SmWlu0hoEj6BERUaKLtBm/vaoWAfg5gPdU9UIAw60rFhEREcVKpGHfVES6ArgFNR30GgdW7ImIKMFFGvaTASwEsEdV14lIHwC7rSsWERERxUqkHfQ+B/C56XkWgF9YVaiGhL3xiYgo0UXaQa+7iHwhIkdFJFdEZolId6sLR0RERHUXaTP+ewDmADgNQDcAXxvLbI8VeyIiSnSRhn2Kqr6nqg7j530AKRaWq8Godmq8i0BERFQnkYb9MRH5jYgkGT+/AXDcyoIRERFRbEQa9rfDddvdEQCHAdwM1xC6IYnIKBHJEJFMEZkYYP0wEdkgIg4RudlnXbWIbDJ+5kRYzpjr0Co5Xm9NREQUExGFvaoeUNUxqpqiqqeo6o1wDbATlIgkAXgNwPUABgC4TUQG+Gx2AMBvEXi63DJVHWT8jImknFY589S28Xx7IiKiOom0Zh/IA2HWDwGQqapZqloJYAaAseYNVHWfqm4B4KxDOYiIiCiEuoR9uI7q3QAcND3PNpZFqoWIpInIahG5MerSEREREYAIB9UJIlw39UAnA9F0be+hqjnGaH1LRWSrqu7xegORCQAmAECPHj2ieOnocGAdIiJKZCFr9iJSLCJFAX6K4brnPpRsAKebnncHkBNpwVQ1x/g3C8AyAIMDbPOWqqaqampKSqO4E5CIiChqIcNeVduqarsAP21VNVyrwDoA/UWkt4gkAxgH18A8YYlIRxFpbjzuAuAyANsj2ZeIiIi81eWafUiq6gBwD1wT6OwA8JmqpovIZBEZAwAicpGIZAP4JYA3RSTd2P1sAGkishnAdwCmqCrDnoiIqBbqcs0+LFWdB2Cez7JJpsfr4Gre993vBwADrSwbERFRY2FZzZ6IiIgaBoZ9BITd8YmIKIEx7ImIiGyOYU9ERGRzDPsINGErPhERJTCGfQRe+9UF8S4CERFRrTHsI9CrS2vsmzI63sUgIiKqFYY9ERGRzTHsiYiIbI5hH4V7r+kX7yIQERFFjWEfhTGDwk30R0RE1PAw7KPQLMn749p5pChOJSEiIoocwz4KPTu39no+6qWVcSoJERFR5Bj2RERENsewJyIisjmGfYw4qp14cOYWHDheGu+iEBEReWHYR+mNX1+AAV3b+S1P21+AT9MO4m8zN8ehVERERMEx7KN0/cCuuKRPZ7/lqnEoDBERUQQY9rUgnAWPiIgSCMO+jsqrquNdBCIiopAY9rVgrtif9egC7D1WEnAdERFRQ8CwrwXfy/MZHEmPiIgaMIZ9DFQ7AfU7BSAiImoYGPa14NtUX23qis/Oe0RE1NAw7GPA6WStnoiIGi6GfS341t6rGfZERNSAMexjoJoj6hARUQPGsK+F7IIyr+eq6t9Fn4iIqIFg2NfC/G1HvJ5XO2seC++0JyKiBoZhHwNONuMTEVEDxrCPAd5uR0REDRnDPkZYtyciooaKYR9jrOUTEVFDw7CPgVeXZsa7CEREREEx7GPgcGF5vItAREQUFMOeiIjI5hj2McK774iIqKGyNOxFZJSIZIhIpohMDLB+mIhsEBGHiNzss268iOw2fsZbWc5oDenVyW/ZyYoqAMCPWcdRWumo7yIREREFZVnYi0gSgNcAXA9gAIDbRGSAz2YHAPwWwCc++3YC8BiAiwEMAfCYiHS0qqzRuv3yXn7L7vxoAwBXDX/irK31XCIiIqLgrKzZDwGQqapZqloJYAaAseYNVHWfqm4B4PTZdySAxaqar6oFABYDGGVhWaMiYe6v25VbXE8lISIiCs/KsO8G4KDpebaxzOp9LRfuVvpwJwNERET1ycqwD5R4kXZji2hfEZkgImkikpaXlxdV4eqiaRLDnIiIEoeVYZ8N4HTT8+4AcmK5r6q+paqpqpqakpJS64JGa1j/+nsvIiKiurIy7NcB6C8ivUUkGcA4AHMi3HchgOtEpKPRMe86Y1mD0DSJdywSEVHisCy1VNUB4B64QnoHgM9UNV1EJovIGAAQkYtEJBvALwG8KSLpxr75AJ6E64RhHYDJxrKEwEZ+IiJqSJpa+eKqOg/APJ9lk0yP18HVRB9o32kApllZPqtwfB0iImpI2B5tkb3HSnDgeGm8i0FERGRtzb4xu/rfywAA+6aMjm9BiIio0WPN3gK8Zk9ERA0Jw56IiMjmGPZEREQ2x7C3AEfLJSKihoRhT0REZHMMewuk5xTFuwhEREQeDHsiIiKbY9gTERHZHMM+jpZlHMWyjKPxLgYREdkcR9CLo9++tw4AR9kjIiJrsWZPRERkcwx7IiIim2PY17NzJi3Am8v3xLsYRETUiDDs61lJZTWenb8z3sUgIqJGhGFPRERkcwx7IiIim2PYExER2RzDPk4c1c54F4GIiBoJhn2c9Ht4fryLQEREjQTDvh6pap32nbH2AEorHTEsERERNQYM+1rq1blV1PvUIevx457jmDh7KyZ/vb32L0JERI0Sw76Wlv396qj3cdYh7UsqqwEAecUVtX4NIiJqnBj29Shc1H8XYhY8ifA1iIiIfHHWu3oUrmL/uxCz4In4LSIiIooIa/b1SGNQL69LJz8iImqcGPb1qC457a7ZM+qJiChaDPsEIcZV+4P5pdh/vMRr3ZHC8ngUiYiIEgTDvh70mjgXf/1sc51q9u4eenvySnDl88s8i3/IPIZLnl2CuVsO16mMRERkXwz7ejJrQ3bE1+z/G2C++2D989JzigAAGw4U1LZoRERkcwx7iz3w2SbP40hr9lM43z0REcUQw95iszcc8jwOlvUFJZVhX0fC3HvHO/OIiCgYhn09CjaC3q1v/Rh233Bhzl76REQUDMO+HgVrxt+VexLHT3oPg7s9pwiZR08CAEorHUEnwOFgO0REFA5H0KtPIarft7+/zuv5DS+vBOAaTe/iZ5aguDz2s90dLSpHp9bJaJrEcz4iIjvjX/kY+O2lvSLaLlRv/M3ZhUHXRRL00d7Wd7LCgSHPLMGkOenR7UhERAnH0rAXkVEikiEimSIyMcD65iLyqbF+jYj0Mpb3EpEyEdlk/PzXynLWl4Y00m1phesEYlF6bpxLQkREVrMs7EUkCcBrAK4HMADAbSIywGezOwAUqGo/AC8C+Jdp3R5VHWT83GlVOeuTlVlfVe3E/Z9uQs6Jsoi2r+nd34DOQIiIyBJWXrMfAiBTVbMAQERmABgLYLtpm7EAHjcezwTwqoS7x6wBGdqnM37MOh7x9rWZxGbl7ryItlu68ygOnShDaaUD557WHkXlVXh4tOvc6tJnl2BI7054adxgz/aesfaZ9UREtmdlM343AAdNz7ONZQG3UVUHgEIAnY11vUVko4gsF5ErLCxnrX14xxBkPDUq4u1rk6v/9+7agMvvnb4x8Hso8MLiXXh75V7PspzCcny5KSdmZSIiosRiZdgHqqH7ZkuwbQ4D6KGqgwE8AOATEWnn9wYiE0QkTUTS8vIiqwHHUtOkJmjeNCmibTu3To5pLXrO5rqFt6cRn1V7IiLbszLsswGcbnreHYBvQnm2EZGmANoDyFfVClU9DgCquh7AHgBn+L6Bqr6lqqmqmpqSkmLBIcSOiGBL9omYvuaU+Tvx1Nwdxuu7lkWa3U2MHRj18XW4sAxF5VXxLgYR2ZyVYb8OQH8R6S0iyQDGAZjjs80cAOONxzcDWKqqKiIpRgc/iEgfAP0BZFlY1joZ0rtT2G2OnazAHR+kxfR9zRPmeMI7wrTnNXtvqoqHZm/Fun359fq+Q59dihFTl9frexJR42NZ2BvX4O8BsBDADgCfqWq6iEwWkTHGZu8C6CwimXA117tvzxsGYIuIbIar496dqlq/f4WjcMPArnh3fGq8ixEVd8gHOzk4UVqJxdsbz2151U7F9LUHcOub4YcujrXcoorwGxER1YGlI+ip6jwA83yWTTI9LgfwywD7zQIwy8qyxdo1Z50S7yIAiLxZXk3/bsk+gY6tknF6p1ae9RM+XI+1e/Ox/pHh6NymeZ3LdaK0EqpAx9bJdX4tKyXQzSBERBHjCHo2kVfsqh2GasZ/dt4O/4UKjHl1Fa547juvxfuOlQAAqqpj084/aPJiDH5ycUxeywq8mkFEdsawj5F41wjLqqoBhA6tN1fUdHtwnxT4bn/T66vw8pLdnud1OazDhWW4+5MNQSfxaUjYd4GI7IwT4SSwJgI4fULK93kwnmZ8U8o9O28HNh44gY0HTqB9y2Z1Lt8jX2zDkp1HceMg3+EVGp5Q8xYQESU6hn0CayICp0+V1Cu85+/Am8sD38Tg6aBnWmau+ReW1e12sOMnKzwT+LRo1vAbkFizJyI7a/h/hSkoR5hqfKCgf2j2FlzyzBLP83AhV9tW/Auf+hZrjdvYwr1H5tFiHD/JHukNUXlVNd5YtgeOame8i0JEdcCwj6E7r+wb7yKENX3tQRwpKvc0W4dtvo5BV4RKR+igGD51Ba55IT73mpe7+zo00Jr9Z2kHMWt9dtze/+Ulu/GvBTsxa0P8ykBEdcewj6GJ158V7yKgOsKL9k8bI+9FE3L7j5dg/tbDUZfp9/8LP5hQXS8b1Mb6/QU469EFWL4rr8Fes//HzC346+eb4/b+J42pkMsqq+NWBiKqO4a9zYRr2nf7ypgYJ9zWYqraj3hxBe76eIPX+vlbD2NV5rGIy5dzoizo7YG9Js7F1MW7InqdE6WVOFFaGfH7BpJmXGZYlXmswdbszQpKKiM+mYsV9+cS77tNiKhuGPY2E3UYhNk8zTR8bKDm+Ls+3oBfv7MGJRUOz9j/oe71v3TKUkxfezDo+peX7MbDX2wNWabsglIMmrwYgybH7r79hp71xeVVGPzkYk+LTH1xt3gw64kSG8PeZtyD60QqXPP1XR9vwLcRDJt7zycbMObVVThZ4QhbSw43/vzHaw54Hh8tLvdcV992qBAXPf1t0Gl/A/lhz7Ggw/6ai+m+q6HaqXA6/e9wmLk+G68s2Y3C0uguN8Tq8kSRcWfD/G3RX0apC0/Nvl7flYhijWFvMwfyS6PaPpIR8rILvF/z6wDT667fXwAAcFQ7w9aSjxaXR1y+IU8vwS/e+AEA8MbyPcgrrsBeY3S/SPzq7TX4g9FnYE3WcfSaOBe7c4u9WkAE3n0Xqn3OVpbtysPfPt+MFxbvwj+/DN3qYLZ8Vx7Of2JRVJc5GqxGUrWfvSEb6/c32Gk4iGqNYU9hZReUeT3/8/SNeO27TE+NG6ipJYtI2Jn3Kqqiu40rPafI+00isCX7BP69MMNr2dsr9wJw9T144ut07Motrllpeu3Lpiz12s89XgAAFEVRU1+79zgAYINxIhTOsZMVYW9xc0furtxiXPHcUuSX1K3fQjjRXN4oKq/CmqzjlpWlPjzw2Wb84o36nwyJyGoMewrrne/3+g15+/zCDLz2XWbNAiMVzn9iEZ5f5B2y9UlVkV1QijGvrsKr5vIBSDJ92//3437M3nDItQ+A4oqaED/qcynEXKetTUe+SCrFpZUOpD71LR6bkx7Ra76xbA8O5pdhWcbR6AsUhWia8f/00Qbc+tZqFJXX/50V5K+sshoVjrrfRbEl+wTeWrEn/IbUoDHsKSLDA9wHb65Veo3EF2TUvvrwWdpBXP6v7/yW7ztWgqQmwSMr0D5uTUxp7dvH4evNOUGbfaM5MXDf2jZ/25GItg/XehI7kXfQ237Y1QITblyFhiK3qBy7za07NnP2pAW4/qWVdX6dMa+uwjPzdsagRPXnRGmld8sdMewpMjmF/tfZK0x/1GMdPpsPnqjVfuuDNJlf9e9lQdeFM3VxTUuFqqtnvDuc/zx9Y9BmX/OljXDcJxR1ubVuUfoRfGLq3BhLEkHd3n0u5TuEc22VVjosHVnx4meWYMSLKyx7/YYg61gJVP07ndrdmFdX4Tqb/26jxbCnWjtkupYfzd+SSDZ9Y1mAZsMIapdNQgRrblHg4HCE6aS4J6+mQ6BTFQMfX4Qrn/dvCZi6KAOL0mtq5tFkXhMjKd1/lMurqtFr4lzTa4V/sQkfrsc/Q9y2mHOiDMcChOemgyeC9hWILrdj24lv7KurcOFT38b0NRujR7/ahj7/nBfvYtSraDsqNwYMe6q1H02dsaIZgS7SGnbGEZ9muAjeokmIpvpgpq3aG/G27pMa3+v6APDy0kxM+HC957n7M/k87SAKwnSkc9/S564VB7tlz7eVIJLm9QpHNZZlHMWlU5Yi1Sc8tx0qxI2vrfIMZuR0qtfthTWD6oR/n5qdIt/U6dSgJzK7j54EAPxlxsYo3txlw4EC9Jo4F0/P3Y4HPt0U9f6R+i7jaIO/bPHRamtaeyixMOwpJqy4hDzypfDNcC8sysDHa/YDcN32V2XxH16/E5BQjM9k3/FS3OcTONkFpV4h99fPXevdt/2Z73Soq2fm7sBv31sXcF16TiEAYFtOEUoqHHhlaSbOn7zIM16DZ1CdIK9dVe3EnM05UFXPCUE0X4U+/5yHf8zcEnKbLzf53+rpa++xEq/OaO7bQ99euRezNx7C0aJyjJ+2NupxEkLZcKAAv3tvHZ6dX78DHYWTnlOIo0X+l93qr59HeHuPlXj9Lt5asQefrQs+2BbVHae4pZiI9d+RBeneHdWCXXN8Zamrx/2vL+6JG19fhW2HimJbEB+RDpLjdCpW763puHfM1BKwdm8+bnnzR0y95fya9Scrjf0CT01s/nyPFpcHvSQRiPkyhOu1FG+vzMIZp7bFg7Nczf7HT1bgnMcWerbJLSpHStvmnvd95/u9GDekBwBg1vpsz3j9KW2bI6+4AkkiEV+zX7+/APkllRgx4FQAwOfrs/H8L8/32uadlZF38jxZ4cDV/16GsYNOw3/GDTaO0XubIcZMjzM3ZOOOy3t7res1cS5W/uNqnN6pVcTvCcDTWrP/eN2ajL/adAhLdx7Fg6POwmkdWvqtzyuuwEVPf4spPx/o+R0Es+1QIX76yvdonZzkt86pQFIDGS7h6n8vQ49OrbDiH1cDgKcD4C0XnR7PYtkaa/YUE5UWT4FaWlWNNXuDD3YyY+0BS4LePRFMIFWmYzZfXweA/yzZ7dXJUARYsO0IjhaX45Y3XR36ftjjf0+6UzXg3Qz3mZqyhzy9xOsSChB6ohrf8N16qBDPzNvpVds/4tMB03efTKNJHYDXxDzuFoB5Ww97OvGF67/xizd+8Ax0ZFZeVY0EKz/lAAAcwElEQVRrX1iGH/ccx1MRDAu871gJ1mQd9xz797trBi+KthYbVYsNXLej7clzfSbR5OfB/FLPsNJu983YhK825eBSn/Ed3A7ku07WPk3zrvluPFCA//24z/P8xz3H8dNXvgcAlAT4PtR1XoVYtwxEcl19+a48fLfT2ttLGwvW7CmuSkKEqdm5plpnIBNnRz6yXTRCvW//h+cHXD5v62FsPVTotay0shp3frTea9lM09S17lEBfUfvc9twwBUQh06UBVzv+35uC7Yd9jupqAhwqeO4T58CpwKLt+fic1MZl+zIxbVnnxrwfeZuPYyftGvh2jdIqKhqyBOBZRl52JNXgie+jmysgav+vQwAsO7h4QC8+xV88OP+oGUIuDyid6wx5tVVnsfm9y2vqsajX27D5f27YOygbn77XfGcq2Pnvimjg752haMaBSVV+En7Fu53MMruvd1Nr7tGlrxxcDe0a9EMB8OEp1MVWXkn0aVtc7Rr0SzktoGo1m0gxc/SDqJvSmtc2LNTxPuMn+YaGjvU5xVrX2zMxkW9OqF7x+haeho61uwtsvj+YfEuQoPndCp+9c6aeBcj5gKNxR9praq2ladAven3HSvBnR9t8FseSVmOFVf41b7v+CD0VMXuIDC//pHCck/N+/mFGegbpFe4q6zrA66rD8FOApbsyI1geOeaBHz3+734fH027puxqdb9Lu6bvgmXPLsEmUeLUelwei6PuEtYXlWNrzYd8mz/r/muJvBwQexUxTUvLMfNxvDT0br+Pyv9BteKxj9mbrF0dMIjheURVx6CcToV93+62TNE96frDuCrTYfQa+Jc/Ofb3bEoZtww7GNs1l2X4rGfDUD/U9vGuygNWq+JczF86vJa309vtbqMAhcoTK2+Fcj8lmWV1SitdHhqvv7bhg/73CjmL3BzZ01ReZXn/vhLnl2CsyctwKETZfhfkNo24H2ZIFDLg9s7K7M8l0FqI9ihBzr/cVQ7cccHafjV26FPSJsIMGjyIkxdvAvPm4ZoXujT7+RAhNf23f1Vhk9dgce/TvfcTuo+IXni6+24b0ZNh89yY/jpULedAjXfy125JwOuf2/VXizZEXzSq4zcYmzNDtyCBAB78k6i18S5nk6f9e2SZ5fg56/X7kTG7ZoXlgGouU33wVlbPZ/1i9/uwv7jkc/L0dAw7GPswp4d8bvLeoffkJAVxYQ29e28xxdhUy1PRKo1+O1kVjhRWonfvFsTSGdPWoABk4JffnBG0L0iWPHPfCTwpQuzMcb98eZb0v7fu2v8PhPz8+9Mw/4Gm+hoT95JPDV3B9buzccPe2quz7tvG4zkIw92i2hxeZXf5Qf308yjJ7Fg2xFc/My3AYefFQFOlFbh5SXeNb+XjJqgqqK4vAojXvQfhTKcNVnHPTV290laVl7gsG4S5q95uN/7E19vxx0fpOGh2VsiGoSnvKoaj321DcXGifEc466JryK4e8Is2KWp2sz7kBFm1LysvJMhB57aF+aELNydI4DrNtrDhWV+d0Sk5xSi90Nzg87CaTWGPVEQN762KvxGAVRHMJNgrJRWVmPaqn1R7TP+vfBTBAcbajRUrdt3DIALn1zseezbJwDwDuc2zUN3H3I6Fdeahmw217anrz3geY+dR4pq1RHt7zO34EhR8E6Kd360HrlFFX4dGYHwowt+svYABj6+yOuz+3LjIa8BmEJxn/y4J5AKVoEPV7MP1aJjvlQxfe1B/GtB4OFxzbNkfrR6Pz74cT9e+841ANZ/jJMd8+dfUuHAFxuzQ578mufYeGj2VpyscGB3bjEuMH1/Mo/GZujbG19bhX9+sRWq6jXAVKStLmv25uP1Za7yniitDDjGwtUvLMPQZ5diyDNLMHeLa0rqjCPFGP3y91CtGWmyvrGDHlGMLUg/giv6d6mX93r0y21RjV4IRHbNPlSTezC+f9CLTddPA50AvbG8ZpTEN1eEvtUu0rs9Rr20Ek1D/DXde6wEh06U4WS5/7Vdc294R7XTM1GS2VebcnDP1f28lgVrLXCH9MJ0/5rcX4xxF25NDX+r2SNfbgNQM8iQb6hH2opk7vy5ZEcuLuvXBS2auW7RG/L0Eq9t31yRhV+mdke/U7wvR/7m3TXo1qElVk28Bg7je+R7ElHtVOw7VoKmSYKRL65ASWU1jp8MXktv26ImhqavPYBT2jbH2V3beW3z0eoDeHzMOf7H5FTsyi1Gr86tPcsOF/q3FBSXV6FpkyYoMn7vn647iImzt+KV2wZjyvydOHSiDP8ZNyhoGc2eW5CBP13VD4MmL8aVZ6Tgg9uHeK03t0hsPFCA0ed1xctLa1p9ajPwVyww7OvB+7+7KOigJmRPK3fXzxz2DWnI81BlcTjVr0b6/MLIZ0e8/F+Bb0sL9l7BTF97ENPXhh+85fmFGZ5gMJu6eBfO7eYdRIHC3CxUGPveTjfVZ8bIw4XlKDXdRne0uNwv7GdvPITZGw/htjD34JtP8u74IA3jh/bEE2PPxQc/7Au4fbBWnGDN7m5OVb/+IuZbKe/+uKbTaK+Jc3HXVX29tq2qdvq1erz/w76AYf/St7s8Y224DX225rviGuxJMPDxRTjNc3cDsGJ3HgDX3BZu7oGY3CKZl2H5rryQ65OaCHbnFntq+ACQVJdbGuqAzfj1YNDpHTyP66vGR1TffJvBzaqdWqeBl46FqBlaYXXW8aDzBdz+fui7EszScwqjuqzwsk9wlfrcLz/k6SWea+S+3JczgqnyOZ59x0vx9eacoNMqu297C+TsRxd4Lmm8tSIL75uGnA53vHO3HvZ67jvq5bRVrlEPfe3JO4kZxjHeN2MjfvbK92H71Zi/czmF5TX9HwL8ar/d4X0/f6h5GcwncNO+34sfA4yZAbhq8b7f3VCzb1qJNft6YP7Cvffbi+BwKpo2ETRNaoJp3+/F5G+2x69wRPXA4XQiqYn/qG4NlcI/HGsj/VBRrTqahVLbOzt8y7F2b37Imumxk5VBT3jKqqrxvqlF4PGva/6GfRzlzIvlPp0e3XcX+HL32Rg3pIenE2C4SvL499biL8P7e54nicCh6jdCZ7R6P1RzC6n773dqz45I85n3IyvvJC7p09lrWbi+FVZh2FuoXYumuOrMU7yWNU1qgqamv3nu3/u53dpZPtQrUbw41RUQiaKwrAo7oxxVL5BF23NjftwFtRzf3zwQEBDZ76NfkIGjYinaiXrMM06Gay1aufuY1yW1UJd46so36AHXJR7fyzys2dvQlsdHAqgZQ7tDK/9Rq9xneeZmpd9c0gPdO7bClPmBe8QSkbXqOt6927ch7lun2onV7yZeGPY21r5lM1zRvwv+OKyv3zr37/2Cnh2w/bCrZv/UjQMBAF9sOBT2vlEiIkoc8Qp7dtCrB02aCD6842JcHqBz3s0Xno5fXtgdD4w402/dUzedWx/FIyKiehKv3vis2cdZy+Qkz/Sen064BPtMwzH2P6VNVK/14R1DUFHlxO8DzChGRETxF26kQ8veNz5vS4Fc3Kczbr2o5l7ZDq2SMf++KzzPX//1BXju5vMC7vvHK/vgiv4pGD4g8KxkREQUf8lJ8Yldhn2COOsnbXHDwK64JcCIWw+MOAMPjjzL8zy5aWx/rb++OPRgHUREFJlWYYaGtgrDPkEEusVkw6MjsGnSCNx7bX+vIRj7pfg3/79822DP4x8fusYz9/hHd1zsuVzwyOizMe23qX77PjJ6QF2LH5WbL+we1faPjD475Hpz6whRMHufvaHOrzHrrktjUBKXYK14Vrvv2v7hNyKP4WefEn4jk1bN4jPeBMO+gXOPXX1Ku+aeZWf9xDVedafWyejQKtlvnw9uH+IV7u593v/dRXj6pnPRtX1Lz/39vVNao3cX17jS3Tu2wjVnneo19vfkseegZXLNl/NMY+reOfdcho2PjsCFPTsGLPdTN/p3Llz78LVhj/e3l/bCv40+DG5bHr8u5D6X9Qs9KmFK2+a4rF/ngOvuuNx/hsJAJzwN0Uu3DkLPzq3CbtcxwC2foQzwGZe8Meib0tpvIp/aCPb/AQBuj3I2zFCvZaVzTovt73/DoyPwJ58hcW8a3C2m7xHM1WemWP4eQ3p3injbLm2SA96CXR8sDXsRGSUiGSKSKSITA6xvLiKfGuvXiEgv07qHjOUZIjLSynI2ZL27tMbUW87Hy+NqwnvWXZfih4nXBN0npW1zjDn/NABAy2ZJWHT/MJxxaltcdeYp+PXFPQHAa47sR386ACPPORVXGf8x/jay5s6Aq41BgQZ2aw8AmDHhEsz+06U4r3sHdGydjJ+e1xUAMO4i1+WFe6/tjyk/H+gZp3v0wK4449Q2uPPKvjilbc3Y1ObjA1y1+Z+e1xV/vsZ7kpE/DuuDtqZmL98TASDw8JzmP6zNmjTBqHN+4nnu/iM6Y8IlePSn3q0Wn/1xKC7o4f9HNuuZG/Dirf7vff7pHfDczefhtiHBJzS54/Le+Pngbl5jlzdtItjzzA0h9wPg2WfCsD54+AbvFoyhfTtj+d+vxuL7h/mNJGaeDKZvShvsfHIUvvnz5X6v376l/x+eL+72r51OveV8/HFYn5BlXfmPqwEA3Tq0RJ8U1+9135TRIfcx69re//sRSssgNaTBPTrgy7svw99Het/hEmrSmTYtgv8BbmdM1DJ20Gn41y8G4u8jz8RQ06ho6x4eHlF5mzWt+Z2k9uyIF289H/umjMb2yYH/vPX1aaHrk9IaPz50DZ4cew7+Mrw/Hhl9tufk2+29310UsgyBTuT+cEXN/5XRA7ti+NmnBr09bNsTIz3fo24dWmLTpBF4/ubzPH9vfF3erws6tU7G/SPO8Foe6AR9/NCeeDrCO5BeujWySWue/bmrdSTSu90mDOvj9zconAt6dMTrv77Aa9k3f7484MQ6qx+6NiYnlbUhVs27LSJJAHYBGAEgG8A6ALep6nbTNn8CcJ6q3iki4wDcpKq3isgAANMBDAFwGoBvAZyhqkGHfEpNTdW0NPZCNyutdKCJiKd1wOz+Tzfhi42HsOHREejU2r91YPmuPJxxaht0bd8SgGuqyuJyB37i8wdZVVHhcKJpE8Havfm41PSfuKraiSQRr0sMY1/9Hqe0a4FbUk/Hl5sO4ZVxgzF74yGMHtjVqwWh3z/nweFU7HxyFFo0S0JecQUKyyrR75S26DVxLjq3TsbMuy7FgfxSXNq3MyZ9lY5L+3bGO9/vxT+vPwsX9+mM2Ruy8eQ325H2yAhUOxXv/7AXF/fujLO7tvPq17D3WAleXLwLA7u1xx+G9UFhaRXOn7zIs/7OK/ti4vU1fSJe+y4Tzy/MwD1X98Ofr+2H5k2TUOlwYtJX2zBjnWtik3fHp2L5rjzkl1Ti1V+5/hDkFVdg9oZsjD6vK1onN0VH43O/d/pG3DDwJ8g4chIvfrsLT449BxUOJ352/mk4tZ33591r4lwArpMP39mzFm/PRdsWTdGpdTK6dWiJcx5zzWnv/h0XllXh/Cdcx7Vp0ghsPVSIHp1a4b1V+3CksBw/7DmGzY9dBxHBJc8s8Yx1v/vp69HM6FRUVF6FKocTn6/PxtVnnoKRL60AAOyYPAotk5OwKvMYendpjY6tklHhqEaHVsmeMv995Jl4fmEG/nBFb/x95Fk4UliO0ioHsvPL8MGP+/C/24dg6mLXxCbnnNYOc++9AlMX78LLS3bjj8P64LYhPXCkqBzdOrREx9bJWLkrD3eZJlWZe+/lWLn7GP44rI/nD+q+YyWeSVnm33cF+p3SBuVV1ViWkYeUts3xt883w1GtmHnXUHTv2ApPfJ0Op9N1ArwtpwintW+BU9q1wKETZTi1bXM0NXWuOnC8FEXlVTi3W3vc8f46rN2Xj62Pj/Qc7ye/vxhLdh5F+5bNkF1Qikk/OwejXlqB7IIyfHX3ZTjfNGfGlPk78V/TLICbJo1Ah1bJmL0hGwvTj+CR0QOQ0ra53/9l8+8UcJ1c5ZwoQ1ITwbKMo3hw1lbPuqduPBd9U9rgtrdXAwAe/ekAjB/a0+uY3PbkncSs9dl4fdkez2fXuU2y54R95e48DO3T2bPv3z/fjM/XZ+OMU9tg+h8uweqsfLzzfRY+nTDU839tS/YJdO/YCmVV1ejWoSUO5peiwlGN4VNX4KVbB+HGwd2wPacIN7y8EkDN8LMPjDgDNw7qhspq17bu43Q6FYuN2fsqHU5M+F8a0vYX4OXbBuPe6Rsx/Q+XYGjfzth88ARaNEvCyJdW4PROLfHXEWd6Zh0EgF9e2B1tWjTFe6v2YeadQ5HaqxOeW7ATC7Ydwdd/vhyVDicGm6bbBYA9z9yA5xbuxC2pp3tOyg4XluHOjzZg1Dk/8Uzus/FAAW56/QfP9/Oc09r7fdZ1JSLrVTV8c6SqWvIDYCiAhabnDwF4yGebhQCGGo+bAjgGQHy3NW8X7OfCCy9UilxZpUN3Hi6KdzFqZf+xEi0sq7T0PWatP6hHCst0a/YJdTqdfus37M/X6mr/5e+szNJXl+6u1XuWVTr09e8ytdJRHXSbSke1FpRURPR6X206pLtzvX/Hafvytbi8Kuy+jmqnZheU6oHjJSG3G/vq99rzwW9CbrPxQIF+u/2IqqqmHyoM+HnWxu7cYu354Df64uKMkNv9c/aWWv9OauPJr9P107UHAq4rKKnQT9bs9/sMnE6nbtifrz0f/EZvffOHqN/zsa+26cNfbPFatmLXUe354Df69oo9eqig1LO8oir498vXU9+k6/r9+WG3e3rudu354Dc67fusyAsdQGmFQwc9sVCX7sgNuL7ng9/o1f/+LuC6vOJyfWdlVkTfrwPHS9RR7dSlO3PVEeD/sa8N+/P1gU836dbsE5pbVBZ2e1+R/J+rLQBpGkEmW1mzvxnAKFX9vfH8/wBcrKr3mLbZZmyTbTzfA+BiAI8DWK2qHxnL3wUwX1Vn+rzHBAATAKBHjx4X7t8f/RzcRFR7pZUOFJRWoVuHlnF5/z15J9GzU6uAtdNEdKSwHKe2ax6zpt60ffm4oEdHy+dQLyyrwpT5O/DI6AFobWFv8+MnK9CiWZKl75FoIq3ZW/mJBfp2+Z5ZBNsmkn2hqm8BeAtwNeNHW0AiqptWyU3RKjl+f3h9r2snOt/LZHWV2ivyzmN10b5lM8/1cSt1btM8/EYUkJWnw9kAzD1iugPICbaNiDQF0B5AfoT7EhERUQSsDPt1APqLSG8RSQYwDsAcn23mABhvPL4ZwFLjGsQcAOOM3vq9AfQHsNbCshIREdmWZe1vquoQkXvg6lyXBGCaqqaLyGS4OhTMAfAugA9FJBOuGv04Y990EfkMwHYADgB3a4ie+ERERBScZR306htvvSMiosYm0g569ujCSkREREEx7ImIiGyOYU9ERGRzDHsiIiKbY9gTERHZHMOeiIjI5hj2RERENsewJyIisjmGPRERkc3ZZgQ9EckDEOs5brsAOBbj10wkjf34AX4GPP7GffwAP4OGfvw9VTUl3Ea2CXsriEhaJMMQ2lVjP36AnwGPv3EfP8DPwC7Hz2Z8IiIim2PYExER2RzDPrS34l2AOGvsxw/wM+DxU2P/DGxx/LxmT0REZHOs2RMREdkcwz4AERklIhkikikiE+NdHiuJyD4R2Soim0QkzVjWSUQWi8hu49+OxnIRkZeNz2WLiFwQ39JHT0SmichREdlmWhb18YrIeGP73SIyPh7HUltBPoPHReSQ8T3YJCI3mNY9ZHwGGSIy0rQ8If+fiMjpIvKdiOwQkXQRuc9Y3ii+ByGOvzF9B1qIyFoR2Wx8Bk8Yy3uLyBrj9/mpiCQby5sbzzON9b1MrxXws2lwVJU/ph8ASQD2AOgDIBnAZgAD4l0uC493H4AuPsueAzDReDwRwL+MxzcAmA9AAFwCYE28y1+L4x0G4AIA22p7vAA6Acgy/u1oPO4Y72Or42fwOIC/Bdh2gPF/oDmA3sb/jaRE/n8CoCuAC4zHbQHsMo6zUXwPQhx/Y/oOCIA2xuNmANYYv9vPAIwzlv8XwF3G4z8B+K/xeByAT0N9NvE+vkA/rNn7GwIgU1WzVLUSwAwAY+Ncpvo2FsAHxuMPANxoWv4/dVkNoIOIdI1HAWtLVVcAyPdZHO3xjgSwWFXzVbUAwGIAo6wvfWwE+QyCGQtghqpWqOpeAJlw/R9J2P8nqnpYVTcYj4sB7ADQDY3kexDi+IOx43dAVfWk8bSZ8aMArgEw01ju+x1wfzdmArhWRATBP5sGh2HvrxuAg6bn2Qj9HyHRKYBFIrJeRCYYy05V1cOA6w8DgFOM5Xb9bKI9Xrt+DvcYzdTT3E3YsPlnYDTHDoarZtfovgc+xw80ou+AiCSJyCYAR+E6UdsD4ISqOoxNzMfjOVZjfSGAzkigz4Bh708CLLPzLQuXqeoFAK4HcLeIDAuxbWP7bIIdrx0/hzcA9AUwCMBhAC8Yy237GYhIGwCzAPxFVYtCbRpgWcJ/BgGOv1F9B1S1WlUHAegOV2387ECbGf8m/GfAsPeXDeB00/PuAHLiVBbLqWqO8e9RAF/A9aXPdTfPG/8eNTa362cT7fHa7nNQ1Vzjj58TwNuoaYq05WcgIs3gCrqPVXW2sbjRfA8CHX9j+w64qeoJAMvgumbfQUSaGqvMx+M5VmN9e7guhSXMZ8Cw97cOQH+jV2YyXJ0x5sS5TJYQkdYi0tb9GMB1ALbBdbzunsXjAXxlPJ4D4P8ZvZMvAVDobvZMcNEe70IA14lIR6Op8zpjWcLy6XtxE1zfA8D1GYwzeiP3BtAfwFok8P8T41rruwB2qOpU06pG8T0IdvyN7DuQIiIdjMctAQyHq+/CdwBuNjbz/Q64vxs3A1iqrh56wT6bhifePQQb4g9cvW93wXUN5+F4l8fC4+wDV0/SzQDS3ccK17WoJQB2G/92MpYLgNeMz2UrgNR4H0Mtjnk6XE2UVXCdld9Rm+MFcDtcnXEyAfwu3scVg8/gQ+MYt8D1B6yrafuHjc8gA8D1puUJ+f8EwOVwNbVuAbDJ+LmhsXwPQhx/Y/oOnAdgo3Gs2wBMMpb3gSusMwF8DqC5sbyF8TzTWN8n3GfT0H44gh4REZHNsRmfiIjI5hj2RERENsewJyIisjmGPRERkc0x7ImIiGyOYU/UCInISePfXiLyqxi/9j99nv8Qy9cnougx7Ikat14Aogp7EUkKs4lX2KvqpVGWiYhijGFP1LhNAXCFMX/5/cbkIM+LyDpjQpQ/AoCIXGXMgf4JXAOvQES+NCZQSndPoiQiUwC0NF7vY2OZuxVBjNfeJiJbReRW02svE5GZIrJTRD42RnkjohhpGn4TIrKxiXDNYf5TADBCu1BVLxKR5gBWicgiY9shAM5V11SeAHC7quYbw42uE5FZqjpRRO5R1wQjvn4O1yQr5wPoYuyzwlg3GMA5cI0rvgrAZQC+j/3hEjVOrNkTkdl1cI0DvwmuaU87wzXeNwCsNQU9ANwrIpsBrIZrMpD+CO1yANPVNdlKLoDlAC4yvXa2uiZh2QTX5QUiihHW7InITAD8WVW9JnQRkasAlPg8Hw5gqKqWisgyuMYPD/fawVSYHleDf5uIYoo1e6LGrRhAW9PzhQDuMqZAhYicYcyI6Ks9gAIj6M+Ca3pQtyr3/j5WALjV6BeQAmAYGuoMYUQ2w7NnosZtCwCH0Rz/PoD/wNWEvsHoJJcH4MYA+y0AcKeIbIFrtq/VpnVvAdgiIhtU9dem5V8AGArXLIsK4B+qesQ4WSAiC3HWOyIiIptjMz4REZHNMeyJiIhsjmFPRERkcwx7IiIim2PYExER2RzDnoiIyOYY9kRERDbHsCciIrK5/w+s1w1tSuxBPAAAAABJRU5ErkJggg==\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.0586781301908195\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.0036264000023948028\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
}
