{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Evolving Population: Fitness shift towards optimal"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "In this notebook we focus on reproducing the evolution of population fitness distribution. Our end goal is to visualize fitness distributions of multiple steps of TS-DE. With this plot, we show how TS-DE iteratively shifts the fitness distribution towards the maximum value."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 250 ms\n",
      "Wall time: 284 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "from tqdm import tqdm\n",
    "import sys\n",
    "import math\n",
    "from typing import List\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import PCA\n",
    "\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 right-hand side Figure 6.2.:**\n",
    "\n",
    "**Parameter setup:**\n",
    "- *d=40*\n",
    "- *M=20*\n",
    "- *T=60*\n",
    "- *mu=0.1*\n",
    "- *sigma=1*\n",
    "- *lambda_=1*\n",
    "\n",
    "**Claims we are testing:**\n",
    "(4) In TS-DE the population's fitness distribution shifts towards optimal during evolution."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 0 ns\n",
      "Wall time: 245 µs\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_evals = 100\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]\n",
    "max_fitness = linear_bayesian_utility_model(x=x_star, theta=theta_star)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:02<00:00,  1.61it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 1min 53s\n",
      "Wall time: 1min 2s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "data = []\n",
    "for _ in tqdm(range(n_evals)):\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)\n",
    "    for i in [1, 2, 5, 10, 20, 35]:\n",
    "        S = populations[i]\n",
    "        data.extend(\n",
    "            [\n",
    "                {'Time step': f't={i}', 'fitness f(x)': linear_bayesian_utility_model(x=x, theta=theta_star)} for x in S\n",
    "            ]\n",
    "        )\n",
    "\n",
    "plot = sns.kdeplot(data=pd.DataFrame(data), x='fitness f(x)', hue='Time step')\n",
    "plot.set_xlabel('Fitness', fontsize='15')\n",
    "plot.set_ylabel('Density', fontsize='15')\n",
    "\n",
    "plt.setp(plot.get_legend().get_texts(), fontsize='15')\n",
    "plt.setp(plot.get_legend().get_title(), fontsize='15')\n",
    "\n",
    "plt.axvline(x=max_fitness, label='Max fitness')\n",
    "plt.savefig('../plots/evolving_population_fitness.png')\n",
    "plt.show()"
   ],
   "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
}
