{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Population Diversity Evolution"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "In this notebook we test claims on how the TS-DE approach converges. More specifically, we test if the TS-DE approach first diversifies and then focuses on optimization to the optimal solution. And additionally, we test whether the population first diversifies and then focuses and converges to the optimal solution. While the experiments in `EvolvingPopulation2D.ipynb` try to support the same claim, we aim to remove the randomness from the equation in this experiment, since the aforementioned notebooks draw conclusions on a single evaluation. In this experiment we run multiple evaluations and include uncertainty in the results."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 15.6 ms\n",
      "Wall time: 14.7 ms\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "import sys\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\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": [
    "**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",
    "(5) TS-DE first diversifies and then concentrates around the optimal solution."
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 46.9 ms\n",
      "Wall time: 46.3 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 = 100\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]\n",
    "max_fitness = linear_bayesian_utility_model(x=x_star, theta=theta_star)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 0 ns\n",
      "Wall time: 0 ns\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "def nucleotide_diversity(S, M):\n",
    "    unique_rows, n_duplicates = np.unique(S, axis=0, return_counts=True)\n",
    "    pi_sum = 0\n",
    "    for unique_row_i, n_duplicate_i in zip(unique_rows, n_duplicates):\n",
    "        for unique_row_j, n_duplicate_j in zip(unique_rows, n_duplicates):\n",
    "            pi_sum += n_duplicate_i * n_duplicate_j * np.sum(unique_row_i != unique_row_j)\n",
    "\n",
    "    return pi_sum * M / (M - 1)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:43<00:00,  1.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 2min 51s\n",
      "Wall time: 1min 43s\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "data = []\n",
    "for i in tqdm(range(100)):\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 t, S in enumerate(populations):\n",
    "        if t == 0:\n",
    "            # Diversity is always 0\n",
    "            continue\n",
    "        data.append({\n",
    "            'T': t,\n",
    "            'nucleotide diversity': nucleotide_diversity(S=S, M=M)\n",
    "        })"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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RjFdMKR2dnYvsva58bhH9yLr3ZV63RxelV9o/3ZTlEzOIZrKDHGrRERktCjqifruu+9y4okn4nbn68T8+c9/xjAMTj755MJ7pk+ffsCLmGfPns2sWbO47rrr2LRpEy+88AK33HILX/rSlzjuuOMYP3481157LRs3buT2229n7dq1XHDBBQAsXryYVatWcfvtt7Nx40auvfZaJk2axIIFCwD4zGc+w5133snTTz/N2rVrueGGG7jwwgtH5Hb8XeHukSKfe9Qe77Enfttkek0QgHW7wlgug3BCoUhERPpHUU/UnjDUY8WKFZim2WtLfGdnZ69t/H1hmia33XYbPp+PT33qU3zjG9/goosu4uKLLy5ca25u5vzzz+eRRx5h2bJlTJgwAYBJkybxs5/9jOXLl3PBBRfQ0dHBsmXLCnVszjrrLC6//HKuv/56Lr30Uo455hi++tWvFvPlD7nCdny/G7drLIUii5m1QVwGNEdShFMZOuJpMjmNaYuIyMErak3RYYcdxooVK8jlcmzYsIG33nqL+fPnEwzm/xXf1tbG008/XVi/cyBqa2u59dZb93htypQp+6yQffLJJ/carXq/yy67jMsuu+yA2zTcNEbyoagqYGON8sKNu7NcBrUlHiaX+9jaFmdLS5TQBIt4av/rikRERPanqGGG8847j7fffpvTTz+diy66CIALL7wQgN/97necd955tLe39/k4EOk7x3FoieR30VUH7VFfuPH98uuK8uegrde6IhER6UdFPVE/9alPcdVVVxEOh3G5XPzzP/8zH//4x4H8oa0dHR185Stf4fTTT+/Xxgq0x9OksvnpoqqAjXsMjRRB97qi6vyI5Fu7wrgMR+uKRESkXxQ157Bjxw6uvPJKrrzyyg9c+9SnPsWll15amEqT/lXfnl9kHfKYBD1uXGOszKrftphWE8BtGnQmMrTHM/jd+XVF1igvYCkiIgOrqJGiiy++mP/3//7fHq/V1tYqEA2gHZ35Apblfje+MbQdv4flMqgOephakd+av6U1SjKTI57KDnHLRERkpCvqqdrU1FTY9SWDa2fne9vxvWP0MNQSr8Vh3euK3m6Kks45xNIKRSIicnCKCkXTp09n7dq1/d0W6YOdXT2FG+0xO12UX1fUvdi6MYKhdUUiItIPilpTdN1113H11Vfz2c9+lo997GMccsghhTPI3m/h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5/D4449zyimn9FPzREamyoCNxzI59cgqAF58pxUciKVz+VEjEREZdoqurvjcc89x/fXX09zcTE1NDTfddJPCkEi3oMeiKuAmlfEysdTLjs4EL77TxvFTy9nVlaAm5MFyacG1iMhwcsAjRT2jQ1dccQXNzc2ce+65Gh0S2YOaoBfDZfB30/KjRX98uxmf2ySczNCV0GiRiMhwc0AjRbuPDlVXV/Od73xHYUhkL0p8FpU+m1njQwQ9Ji3RFGsauji03EdrJEWF3x7qJoqIyG76NFIUDoe55pprCqND5513Hk888YQCkcg+uAyD2hIPBganHpEfLXryrSYCHovWWEoLrkVEhpk+jRSdeeaZtLS0AHD00Uczbtw4fvWrX+338wzD4Oqrry6qYalUivPPP59vfetbLFiwAID6+nq+9a1vsXr1aiZMmMB1113HiSeeWPicFStW8O///u/U19dTV1fH9773PQ455JDC9bvvvps777yTSCTCGWecwbe+9S18Pp1HJQOn3OemxGuxYEoZT7zVxIbmKLu6Evhti854WofEiogMI30KRc3NzYX//cYbbxSKM+5PsaEomUzy5S9/mY0bNxZecxyHK6+8kmnTprF8+XKefvpplixZwhNPPMGECRNoaGjgyiuv5KqrruKkk05i2bJlXHHFFTzyyCMYhsGTTz7Jrbfeyi233EJlZSXXXnstt9xyC9dff/0Bt0+kryzTxfgSL52JDAsml7FiaztPrW/mUx+aSGM4SU3Ig0sVrkVEhoU+haKlS5cOdDsKNm3axJe//GUcx+n1+l/+8hfq6+u5//778fv9HH744bz88sssX76cq666igcffJCjjz6aSy+9tNDmE044gVdeeYUFCxZw7733cskll3DqqacCcOONN/KFL3yBr371qxotkgFV4XcTsF185IhKVmxt55V3O7jwQxPoTGToSmQoUzFHEZFhoU+h6LzzzhvodhT0hJj/9//+H3PmzCm8vmbNGo466ij8fn/htXnz5rF69erC9fnz5xeu+Xw+Zs2axerVq5k/fz6vv/46S5YsKVyfM2cO6XSa9evXM3fu3D6372D/Ud/z+RocGHjDpa99tkltyEM8nWNqhZ8tbTH+srWdeYeU0R5LUe4f+aFouPT1WKH+Hjzq68EzUH19IPcruk7RQPnMZz6zx9d76iHtrrKykl27du33eldX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9COmTZuGx+P5wEhcKpVSnxfp1ltv5eijj+41Mtdjbz/j6uviWJZFJBLhhz/8IRMnTgTyi05/85vfMGXKFPV1P3r55Zd56KGHeOGFF/B6vcyePZvGxkZ+/vOfc8ghh6ivB9D+fkfv7fdKSUnJgLRH02eDpLa2lvb2djKZTOG15uZmvF7vgH1zx5rvfOc73HXXXdxyyy187GMfA/L93tLS0ut9LS0tHxiOlb55/PHHefrpp5k7dy5z587l0Ucf5dFHH2Xu3Lnq635WXV2Nx+MpBCKAqVOnsnPnTvV1P3vjjTeYMmVKr6Bz1FFH0dDQoL4eYPvr371dr66uHpD2KBQNkpkzZ2JZVq/FYStXrmT27Nm4XPo2HKxbb72V+++/n//8z//krLPOKrxeV1fHm2++SSKRKLy2cuVK6urqhqKZI95///d/8+ijj/Lwww/z8MMPs2jRIhYtWsTDDz9MXV0dr732WmGrrOM4rFq1Sn1dpLq6OpLJJFu2bCm8tnnzZiZOnKi+7mc1NTVs27at14jE5s2bmTRpkvp6gO3vd3RdXR0rV64sXIvH46xbt27A+l9P40Hi8/k499xzueGGG1i7di1PP/00v/rVr7j44ouHumkj3jvvvMNtt93GP/3TPzFv3jyam5sLf4477jjGjx/Ptddey8aNG7n99ttZu3YtF1xwwVA3e0SaOHEiU6ZMKfwJBAIEAgGmTJnC6aefTldXF9/73vfYtGkT3/ve94jH45xxxhlD3ewR6bDDDuOUU07h2muvZf369fzpT3/i9ttv59Of/rT6up8tWrQIt9vNN7/5TbZs2cKzzz7LL37xCy666CL19QDb3+/oxYsXs2rVKm6//XY2btzItddey6RJk1iwYMHANGhANvrLHsViMedrX/uaM2fOHOfEE0907rrrrqFu0qjwy1/+0pk2bdoe/ziO42zdutX57Gc/6xx99NHOWWed5fz5z38e4haPHtdcc02hTpHjOM6aNWucc88915k9e7ZzwQUXOG+++eYQtm7k6+rqcr761a86c+bMcRYuXOj87Gc/K9TLUV/3r40bNzqf+9znnA996EPORz/6Ueeuu+5SXw+Q3esUOc7+f0c///zzzmmnneYcc8wxziWXXOK8++67A9Y2w3EGqiykiIiIyMih6TMRERERFIpEREREAIUiEREREUChSERERARQKBIREREBFIpEREREAIUiEREREUChSERERAQAa6gbICIymH72s59x66239vn9S5cu5fzzzx/AFonIcKFQJCJjynHHHceSJUt6vfb000+zfv16/u7v/o6ZM2f2uvb+j0Vk9FIoEpExZcGCBR84THLHjh2sX7+ej370oxoVEhnDtKZIREREBIUiEREREUChSERERARQKBIREREBFIpEREREAIUiEREREUChSERERARQKBIREREBFIpEREREAIUiEREREUChSERERARQKBIREREBwHAcxxnqRoiIiIgMNY0UiYiIiKBQJCIiIgIoFImIiIgACkUiIiIigEKRiIiICKBQJCIiIgIoFImIiIgACkUiIiIigEKRiIiICKBQJCIiIgIoFImIiIgACkUiIiIiAPx/AZ8w3t3XiHYAAAAASUVORK5CYII=\n"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CPU times: total: 2.92 s\n",
      "Wall time: 2.94 s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "plot = sns.lineplot(data=pd.DataFrame(data),\n",
    "             x='T',\n",
    "             y='nucleotide diversity',\n",
    "             errorbar=('ci', 95))\n",
    "plot.set_xlabel('T', fontsize='15')\n",
    "plot.set_ylabel('Nucleotide diversity', fontsize='15')\n",
    "\n",
    "plt.savefig('../plots/population_diversity_evolution.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
}
