{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/d0x00ar/anaconda3/lib/python3.6/site-packages/h5py/__init__.py:36: FutureWarning: Conversion of the second argument of issubdtype from `float` to `np.floating` is deprecated. In future, it will be treated as `np.float64 == np.dtype(float).type`.\n",
      "  from ._conv import register_converters as _register_converters\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import numpy as np\n",
    "import random \n",
    "import tensorflow as tf\n",
    "from matplotlib import pylab as plt\n",
    "import matplotlib as mpl\n",
    "from tensorflow import keras\n",
    "\n",
    "# In[210]:\n",
    "\n",
    "from weight import simulation, learn, utils, config\n",
    "\n",
    "mpl.rcParams['figure.dpi']= 150"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# random.seed(1234)\n",
    "# np.random.seed(2345)\n",
    "# tf.random.set_seed(3456)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Linear model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "X, y = simulation.lin_sep()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def weighted_loss(y_true, y_pred):\n",
    "    y_hat = y_pred[:,0]\n",
    "    weights = y_pred[:,1]\n",
    "    loss = tf.exp(-tf.multiply(y_true, y_hat))\n",
    "    weighted_loss = tf.multiply(weights, loss)\n",
    "    \n",
    "    return tf.reduce_mean(weighted_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "random.seed(1234)\n",
    "np.random.seed(234)\n",
    "tf.random.set_seed(345)\n",
    "\n",
    "tf.keras.backend.clear_session()\n",
    "\n",
    "inputs = keras.Input(shape=2)\n",
    "reg1 = keras.layers.Dense(units=1)\n",
    "reg2 = keras.layers.Dense(units=1)\n",
    "output1 = reg1(inputs)\n",
    "output2 = reg2(inputs)\n",
    "output2 = tf.exp(output2) / (1 + tf.exp(output2)) + 1\n",
    "\n",
    "model = keras.Model(inputs=inputs, outputs=tf.concat([output1, output2], axis=-1))\n",
    "model.compile(loss = weighted_loss,\n",
    "             optimizer = keras.optimizers.SGD(0.1),\n",
    "             metrics=[\"accuracy\"])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "report_every = 20\n",
    "num_epochs = 1000\n",
    "\n",
    "epoch = 0\n",
    "weights_list, loss_list, accuracy_list = [], [], []\n",
    "while epoch <= num_epochs:\n",
    "    model.fit(X, y, batch_size = X.shape[0], epochs = report_every, verbose=0)\n",
    "    res = model(X).numpy()\n",
    "    weights_list.append(res[:,1])\n",
    "    loss_acc = model.evaluate(X,y, verbose=0)\n",
    "    loss_list.append(loss_acc[0])\n",
    "    accuracy_list.append(loss_acc[1])\n",
    "    epoch += report_every"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x216 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_index = [0, 5, 10, 15, 20]\n",
    "figure, axes = plt.subplots(ncols=5, figsize=(20, 3))\n",
    "for i,ax in enumerate(axes):\n",
    "    _ = ax.hist(weights_list[plot_index[i]], bins=100, range=(0.5, 1.5))\n",
    "    title = \"steps: \" + str((plot_index[i]+1)*report_every) + \", loss: \" + str(loss_list[plot_index[i]])[:6]\n",
    "    ax.set_title(title)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn import svm\n",
    "\n",
    "clf = svm.SVC(kernel='linear', C=1000)\n",
    "clf.fit(X, y)\n",
    "if clf.score(X,y) == 1:\n",
    "    margin = np.abs(clf.decision_function(X))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0,0.5,'correlation')"
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "margin_weight_corr = [np.corrcoef(weights, margin)[0,1] for weights in weights_list]\n",
    "plot_epochs = [report_every * i for i in range(len(margin_weight_corr))]\n",
    "plt.plot(plot_epochs, margin_weight_corr)\n",
    "plt.title(r\"Correlation between $\\gamma_i$ and $g(\\psi, x_i)$)\")\n",
    "plt.xlabel(\"epoch\")\n",
    "plt.ylabel(\"correlation\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Nonlinear model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "metadata": {},
   "outputs": [],
   "source": [
    "X, y = simulation.non_lin_moon(0.05)\n",
    "X = np.array(X)\n",
    "y = np.array(y) * 1.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [],
   "source": [
    "random.seed(1234)\n",
    "np.random.seed(234)\n",
    "tf.random.set_seed(345)\n",
    "\n",
    "tf.keras.backend.clear_session()\n",
    "\n",
    "inputs = keras.Input(shape=2)\n",
    "reg1 = keras.layers.Dense(units=5, activation = 'relu')\n",
    "reg11 = keras.layers.Dense(units=1)\n",
    "reg2 = keras.layers.Dense(units=1)\n",
    "output1 = reg11(reg1(inputs))\n",
    "output2 = reg2(inputs)\n",
    "output2 = tf.exp(output2) / (1 + tf.exp(output2)) + 1\n",
    "\n",
    "model = keras.Model(inputs=inputs, outputs=tf.concat([output1, output2], axis=-1))\n",
    "model.compile(loss = weighted_loss,\n",
    "             optimizer = keras.optimizers.SGD(0.1),\n",
    "             metrics=[\"accuracy\"])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:Layer dense_2 is casting an input tensor from dtype float64 to the layer's dtype of float32, which is new behavior in TensorFlow 2.  The layer has dtype float32 because it's dtype defaults to floatx.\n",
      "\n",
      "If you intended to run this layer in float32, you can safely ignore this warning. If in doubt, this warning is likely only an issue if you are porting a TensorFlow 1.X model to TensorFlow 2.\n",
      "\n",
      "To change all layers to have dtype float64 by default, call `tf.keras.backend.set_floatx('float64')`. To change just this layer, pass dtype='float64' to the layer constructor. If you are the author of this layer, you can disable autocasting by passing autocast=False to the base Layer constructor.\n",
      "\n",
      "WARNING:tensorflow:Layer dense is casting an input tensor from dtype float64 to the layer's dtype of float32, which is new behavior in TensorFlow 2.  The layer has dtype float32 because it's dtype defaults to floatx.\n",
      "\n",
      "If you intended to run this layer in float32, you can safely ignore this warning. If in doubt, this warning is likely only an issue if you are porting a TensorFlow 1.X model to TensorFlow 2.\n",
      "\n",
      "To change all layers to have dtype float64 by default, call `tf.keras.backend.set_floatx('float64')`. To change just this layer, pass dtype='float64' to the layer constructor. If you are the author of this layer, you can disable autocasting by passing autocast=False to the base Layer constructor.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "report_every = 20\n",
    "num_epochs = 2000\n",
    "\n",
    "epoch = 0\n",
    "nl_weights_list, nl_loss_list, nl_accuracy_list = [], [], []\n",
    "while epoch <= num_epochs:\n",
    "    model.fit(X, y, batch_size = X.shape[0], epochs = report_every, verbose=0)\n",
    "    res = model(X).numpy()\n",
    "    nl_weights_list.append(res[:,1])\n",
    "    loss_acc = model.evaluate(X,y, verbose=0)\n",
    "    nl_loss_list.append(loss_acc[0])\n",
    "    nl_accuracy_list.append(loss_acc[1])\n",
    "    epoch += report_every"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x216 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_index = [0, 7, 14, 21, 28]\n",
    "figure, axes = plt.subplots(ncols=5, figsize=(20, 3))\n",
    "for i,ax in enumerate(axes):\n",
    "    _ = ax.hist(nl_weights_list[plot_index[i]], bins=100, range=(0.5, 1.5))\n",
    "    title = \"steps: \" + str((plot_index[i]+1)*report_every) + \", loss: \" + str(nl_loss_list[plot_index[i]])[:6]\n",
    "    ax.set_title(title)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [],
   "source": [
    "margin = np.abs(model.predict(X)[:,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.44, 0.455)"
      ]
     },
     "execution_count": 139,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "nl_margin_weight_corr = [np.corrcoef(weights, margin)[0,1] for weights in nl_weights_list]\n",
    "plot_epochs = [report_every * i for i in range(len(nl_margin_weight_corr))]\n",
    "plt.plot(plot_epochs, nl_margin_weight_corr)\n",
    "plt.title(r\"Correlation between $\\gamma_i$ and $g(\\psi, x_i)$)\")\n",
    "plt.xlabel(\"epoch\")\n",
    "plt.ylabel(\"correlation\")\n",
    "plt.xlim([300, 2000])\n",
    "plt.ylim([0.44, 0.455])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
