{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Evolving Population: Diversification & concentration around the optimal solution (2D)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "In this notebook we focus on reproducing the evolution trajectory of a population. Our end goal is to visualize multiple snapshots of high-dimensional populations and map them to 2D using KDE density contour plot. With this plot, we show how TS-DE balances the exploration-exploitation trade-off using initial diversification followed by approaching and concentrating around the optimal solution."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 0 ns\n",
      "Wall time: 0 ns\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "import sys\n",
    "import math\n",
    "from typing import List\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.lines as mlines\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import PCA\n",
    "sys.path.append('../')\n",
    "\n",
    "from util.common import zero_population, linear_bayesian_utility_model\n",
    "from util.TS_DE.TS_DE import TS_DE\n"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "**Reproducing left-hand side Figure 6.2.:**\n",
    "\n",
    "**Parameter setup:**\n",
    "- *d=10*\n",
    "- *M=40*\n",
    "- *T=100*\n",
    "- *mu=0.08*\n",
    "- *sigma=1*\n",
    "- *lambda_=1*\n",
    "\n",
    "**Claims we are testing:**\n",
    "(5) TS-DE first diversifies and then concentrates around the optimal solution."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 0 ns\n",
      "Wall time: 1 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "np.random.seed(seed=0)\n",
    "\n",
    "# Initial setting for TS-DE and DE\n",
    "d = 40\n",
    "M = 20\n",
    "T = 60\n",
    "mu = 0.1\n",
    "\n",
    "# Theta star - optimal theta - parametrization of the linear Bayesian utility model for\n",
    "# which we aim to optimize the protein design.\n",
    "theta_star = np.random.multivariate_normal(np.zeros(d), np.eye(d))\n",
    "\n",
    "# Sequence that maximizes the utility function (used for visualizations).\n",
    "x_star = [0 if theta_i < 0 else 1 for theta_i in theta_star]"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 1.44 s\n",
      "Wall time: 709 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "# Execute TS-DE\n",
    "populations, thetas = TS_DE(d=d,\n",
    "                            T=T,\n",
    "                            M=M,\n",
    "                            theta_star=theta_star,\n",
    "                            S_0=zero_population(d=d, M=M),\n",
    "                            mu=mu,\n",
    "                            sigma=1,\n",
    "                            lambda_=1,\n",
    "                            f=linear_bayesian_utility_model)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 0 ns\n",
      "Wall time: 0 ns\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "# Helper function to visualize the population evolution\n",
    "def visualize_population(populations: List[List[np.ndarray]],\n",
    "                         indices: List[int],\n",
    "                         pca_fit: PCA,\n",
    "                         x_star: list) -> None:\n",
    "    if len(indices) != 6:\n",
    "        raise RuntimeError('Population visualization supports exactly 6 populations')\n",
    "    nrows = 2\n",
    "    ncols = 3\n",
    "    fig, axes = plt.subplots(nrows=nrows, ncols=ncols)\n",
    "\n",
    "    for i in range(len(indices)):\n",
    "        ix_row = math.floor(i / ncols)\n",
    "        ix_col = i % ncols\n",
    "        ix_S = indices[i]\n",
    "        S = populations[ix_S]\n",
    "        # Perform PCA on the population\n",
    "        S_pca = pca_fit.transform(S)\n",
    "        x_star_pca = pca_fit.transform(np.array(x_star).reshape(1, -1))\n",
    "        df_S_pca = pd.DataFrame(data=S_pca,\n",
    "                                columns=['PC1', 'PC2'])\n",
    "\n",
    "        # Plot the population using KDE density contour plot\n",
    "        plot = sns.kdeplot(ax=axes[ix_row, ix_col],\n",
    "                           data=df_S_pca,\n",
    "                           x='PC1',\n",
    "                           y='PC2',\n",
    "                           fill=True,\n",
    "                           cmap='Blues')\n",
    "        plot.set_xlabel(\"PC1\",fontsize=15)\n",
    "        plot.set_ylabel(\"PC2\",fontsize=15)\n",
    "        axes[ix_row, ix_col].text(\n",
    "            3.3, 1.75, f't={indices[i]}',\n",
    "            horizontalalignment='center',\n",
    "            verticalalignment='center',\n",
    "            fontsize=15\n",
    "        )\n",
    "\n",
    "        axes[ix_row, ix_col].plot(x_star_pca[0][0], x_star_pca[0][1], marker='x', color='red')\n",
    "        axes[ix_row, ix_col].set_xlim([-2, 4])\n",
    "        axes[ix_row, ix_col].set_ylim([-2, 2])\n",
    "\n",
    "        if ix_col != 0:\n",
    "            plot.set(ylabel=None)\n",
    "\n",
    "        if ix_row != 1:\n",
    "            plot.set(xlabel=None)\n",
    "\n",
    "    red_marker = mlines.Line2D([], [], color='red', marker='x', linestyle='None',\n",
    "                              markersize=7, label='optimal solution')\n",
    "    plt.legend(handles=[red_marker], loc='lower center', bbox_to_anchor=(0.5, 0., 0., 0.5), prop={'size': 15})\n",
    "    plt.savefig('../plots/evolving_population_2d.png')\n",
    "    plt.show()"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 6 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 1.03 s\n",
      "Wall time: 982 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "# Fit PCA on all populations - this is done so that we have the same mapping for all steps in the visualization\n",
    "arr_populations = np.array([np.array(S) for S in populations]).reshape(M * (T + 1), d)\n",
    "pca = PCA(n_components=2)\n",
    "pca_fit = pca.fit(arr_populations)\n",
    "\n",
    "visualize_population(populations=populations,\n",
    "                     indices=[1, 2, 5, 10, 20, 35],\n",
    "                     pca_fit=pca_fit,\n",
    "                     x_star=x_star)"
   ],
   "metadata": {
    "collapsed": false
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
