{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Evolution_Baseline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import collections\n",
    "import random\n",
    "import design_bench\n",
    "import numpy as np\n",
    "\n",
    "def set_seed(seed):\n",
    "    \"\"\"Set the numpy, random, and torch random seeds.\"\"\"\n",
    "    np.random.seed(seed)\n",
    "    random.seed(seed)\n",
    "\n",
    "def mutate(parent, discrete=True):\n",
    "#     return parent + np.random.normal(loc=0.0, scale=1.0, size=parent.shape)\n",
    "    if discrete:\n",
    "        rng = np.random.default_rng()\n",
    "        return rng.permuted(parent)\n",
    "    else:\n",
    "        return max(1.0, parent + np.random.normal(loc=0.0, scale=0.1, size=parent.shape))\n",
    "\n",
    "#   seed 123,234,345; check main code for seed! Check data split\n",
    "def regularized_evolution(cycles, sample_size, taskname, seed=123):\n",
    "    \"\"\"Algorithm for regularized evolution (i.e. aging evolution).\n",
    "\n",
    "    Follows \"Algorithm 1\" in Real et al. \"Regularized Evolution for Image\n",
    "    Classifier Architecture Search\".\n",
    "\n",
    "    Args:\n",
    "    cycles: the number of cycles the algorithm should run for.\n",
    "    population_size: the number of individuals to keep in the population.\n",
    "    sample_size: the number of individuals that should participate in each\n",
    "        tournament.\n",
    "\n",
    "    Returns:\n",
    "    history: a list of `Model` instances,  representing all the models computed\n",
    "        during the evolution experiment.\n",
    "    \"\"\"\n",
    "    \n",
    "    set_seed(seed)\n",
    "    \n",
    "    #check \n",
    "    \n",
    "    TASKNAME2TASK = {\n",
    "    'dkitty': 'DKittyMorphology-Exact-v0',\n",
    "    'ant': 'AntMorphology-Exact-v0',\n",
    "    'tf-bind-8': 'TFBind8-Exact-v0',\n",
    "    'tf-bind-10': 'TFBind10-Exact-v0',\n",
    "    'superconductor': 'Superconductor-RandomForest-v0',\n",
    "    # 'hopper': 'HopperController-Exact-v0',\n",
    "    # 'nas': 'CIFARNAS-Exact-v0',\n",
    "    'chembl': 'ChEMBL_MCHC_CHEMBL3885882_MorganFingerprint-RandomForest-v0',\n",
    "    # 'gfp': 'GFP-Transformer-v0',\n",
    "    }\n",
    "    \n",
    "    if taskname != 'tf-bind-10':\n",
    "        task = design_bench.make(TASKNAME2TASK[taskname])\n",
    "    else:\n",
    "        task = design_bench.make(TASKNAME2TASK[taskname], dataset_kwargs={\"max_samples\": 10000})\n",
    "\n",
    "    normalise_x = True\n",
    "    normalise_y = True\n",
    "\n",
    "    if task.is_discrete:\n",
    "        print('discrete task')\n",
    "#         task.map_to_logits()\n",
    "        if taskname == 'tf-bind-10':\n",
    "            design_array = task.to_integers(np.load(f'/data/brooks/ddom_new/{taskname}_design_array_init.npy'))\n",
    "            obj_array = np.load(f'/data/brooks/ddom_new/{taskname}_obj_array_init.npy')\n",
    "        else:\n",
    "            design_array = task.x\n",
    "        \n",
    "    elif normalise_x:\n",
    "        task.map_normalize_x()\n",
    "        design_array = task.x\n",
    "    \n",
    "    \n",
    "    if normalise_y:\n",
    "        task.map_normalize_y()\n",
    "        if (taskname != 'tf-bind-10'):\n",
    "            obj_array = task.y\n",
    "        else:\n",
    "            obj_array = task.normalize_y(obj_array)\n",
    "    else:       \n",
    "        if (taskname != 'tf-bind-10'):\n",
    "            obj_array = task.y\n",
    "    \n",
    "    #check \n",
    "    indices = np.argsort(obj_array, axis=0).flatten()\n",
    "\n",
    "    # initialization\n",
    "    # Sorting x using the indices obtained from sorting y\n",
    "    # 25%~50% data\n",
    "    if taskname != 'tf-bind-10':\n",
    "        design_array = design_array[indices]\n",
    "        obj_array = obj_array[indices]\n",
    "        design_array = design_array[int(len(design_array)/4):int(len(design_array)/2)]\n",
    "        obj_array = obj_array[int(len(obj_array)/4):int(len(obj_array)/2)]\n",
    "    else:\n",
    "        print(f'loaded from npy for tf-bind-10')\n",
    "    # print(design_array[0], design_array[-1])\n",
    "    print(obj_array[0], obj_array[-1])\n",
    "    print('design_array', design_array.shape)\n",
    "    print('obj_array',  obj_array.shape)\n",
    "#     main_design = np.load(f'/data/brooks/ddom_new/{taskname}_design_array_init.npy')\n",
    "#     main_obj =  np.load(f'/data/brooks/ddom_new/{taskname}_obj_array_init.npy')\n",
    "    \n",
    "#     print(f'identical initiliaztions: {np.array_equal(main_design, design_array)}')\n",
    "\n",
    "#     population = collections.deque()\n",
    "#     history = []  # Not used by the algorithm, only used to report results.\n",
    "\n",
    "    # Initialize the population with random models.\n",
    "\n",
    "#     while len(population) < population_size:\n",
    "#     population_ind = np.random.choice(task.x.shape[0], size=population_size, replace=False)\n",
    "#     print(f'selected population indicies: {population_ind.shape}')\n",
    "#     population = collections.deque(task.x[population_ind])\n",
    "    population = collections.deque(design_array)\n",
    "#     print(task.x[population_ind].shape)\n",
    "    history = list(population)\n",
    "\n",
    "    # Carry out evolution in cycles. Each cycle produces a model and removes\n",
    "    # another.\n",
    "    for i in range(cycles):\n",
    "        print(f'at cycle {i}')\n",
    "        # Sample randomly chosen models from the current population.\n",
    "        sample = []\n",
    "        while len(sample) < sample_size:\n",
    "            # Inefficient, but written this way for clarity. In the case of neural\n",
    "            # nets, the efficiency of this line is irrelevant because training neural\n",
    "            # nets is the rate-determining step.\n",
    "            candidate = random.choice(list(population))\n",
    "#             print(f'shape of candidate: {candidate.shape}')\n",
    "            sample.append(candidate)\n",
    "\n",
    "        # The parent is the best model in the sample.\n",
    "        sample = np.array(sample)\n",
    "#         print(f'shape of sample: {sample.shape}')\n",
    "#         print(f'shape of prediction: {task.predict(sample).shape}')\n",
    "#         print(f'sample: {sample}')\n",
    "        parent_ind = np.argmax(task.predict(sample), axis=0)\n",
    "#         print(f'parent_ind: {parent_ind}')\n",
    "        parent = sample[parent_ind]\n",
    "\n",
    "        # Create the child model and store it.\n",
    "        child = mutate(parent).reshape(-1)\n",
    "#         print(f'child: {child}')\n",
    "        population.append(child)\n",
    "        history.append(child)\n",
    "\n",
    "        # Remove the oldest model.\n",
    "        population.popleft()\n",
    "\n",
    "        \n",
    "    history = np.array(history)\n",
    "    hist_scores = task.predict(history).reshape(-1)\n",
    "    return history, hist_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.6560762] [0.14245978]\n",
      "design_array (2501, 60)\n",
      "obj_array (2501, 1)\n",
      "at cycle 0\n",
      "at cycle 1\n",
      "at cycle 2\n",
      "at cycle 3\n",
      "at cycle 4\n",
      "at cycle 5\n",
      "at cycle 6\n",
      "at cycle 7\n",
      "at cycle 8\n",
      "at cycle 9\n",
      "at cycle 10\n",
      "at cycle 11\n",
      "at cycle 12\n",
      "at cycle 13\n",
      "at cycle 14\n",
      "at cycle 15\n"
     ]
    }
   ],
   "source": [
    "# add 100 points per iteratoin, 16 iterations\n",
    "history_x, hist_scores = regularized_evolution(cycles=16, sample_size=100, taskname='ant')\n",
    "np.save(f'ant_hist_scores.npy', hist_scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "history_x, hist_scores = regularized_evolution(cycles=16, sample_size=100, taskname='superconductor')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# task_list = ['ant', 'tf-bind-8', 'superconductor', 'tf-bind-10']\n",
    "# for t in task_list:\n",
    "#     print(f'running task {t}')\n",
    "#     history_x, hist_scores = regularized_evolution(cycles=1600, sample_size=20, taskname=t)\n",
    "#     np.save(f'{t}_hist_scores.npy', hist_scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5854,)"
      ]
     },
     "execution_count": 162,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hist_scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f7d9bd32350>]"
      ]
     },
     "execution_count": 167,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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t0qxsbFSx44dpTNnzkiSxDyzZ8eOHVJgYKD0wgsvSIcPH5Y+//xzKTQ0VPrss88s24hSDjCocdNbb70lde/eXQoKCpJGjx4tbd++XeskqWbDhg0SgGaP6dOnS5LUMJzvqaeekiIiIqTg4GDpuuuukzIzM232ce7cOenuu++WWrduLYWFhUkzZsyQSktLbbbZvXu3dOWVV0rBwcFS165dpUWLFqn1EWVlL68ASMuWLbNsU1lZKf3973+X2rVrJ4WGhkq33XablJuba7OfEydOSBMnTpRatWoldezYUXr44Yel2tpam202bNggDRs2TAoKCpJ69+5tcwy9+etf/yr16NFDCgoKkjp16iRdd911loBGkphn7mga1DDPmrvzzjulqKgoKSgoSOratat055132sy3wjyz78cff5QGDRokBQcHS/3795fee+89m9dFKQdMkiRJbtdBEREREQmKfWqIiIjIEBjUEBERkSEwqCEiIiJDYFBDREREhsCghoiIiAyBQQ0REREZAoMaIiIiMgQGNURERGQIDGqIiIjIEBjUEBERkSEwqCEiIiJDYFBDREREhvD/7zMANqYkimEAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.plot(hist_scores)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "K_6EyDK_B3fI"
   },
   "source": [
    "# Summary"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "eizp75WbBwaB"
   },
   "source": [
    "This document contains the code of the regularized evolution (i.e. aging evolution) algorithm used in:\n",
    "\n",
    "[E. Real, A. Aggarwal, Y. Huang, and Q. V. Le 2018. Regularized Evolution for Image Classifier Architecture Search](https://arxiv.org/abs/1802.01548).\n",
    "\n",
    "It demonstrates the application of the algorithm in a toy search space that can be run quickly in a single machine."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "VUdox1uMAMqF"
   },
   "source": [
    "# Toy Search Space"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "YtacawXFAQbg"
   },
   "source": [
    "For a simple problem to use for illustration purposes, we use the toy search space of appendix C. In it, toy models have a simulated architecture (bit-string) and a simulated accuracy (the number of 1s in the bit-string, with some additional random noise), as described below."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "d0uYu1WisqLa"
   },
   "outputs": [],
   "source": [
    "DIM = 100  # Number of bits in the bit strings (i.e. the \"models\").\n",
    "NOISE_STDEV = 0.01  # Standard deviation of the simulated training noise.\n",
    "\n",
    "class Model(object):\n",
    "  \"\"\"A class representing a model.\n",
    "\n",
    "  It holds two attributes: `arch` (the simulated architecture) and `accuracy`\n",
    "  (the simulated accuracy / fitness). See Appendix C for an introduction to\n",
    "  this toy problem.\n",
    "\n",
    "  In the real case of neural networks, `arch` would instead hold the\n",
    "  architecture of the normal and reduction cells of a neural network and\n",
    "  accuracy would be instead the result of training the neural net and\n",
    "  evaluating it on the validation set.\n",
    "\n",
    "  We do not include test accuracies here as they are not used by the algorithm\n",
    "  in any way. In the case of real neural networks, the test accuracy is only\n",
    "  used for the purpose of reporting / plotting final results.\n",
    "\n",
    "  In the context of evolutionary algorithms, a model is often referred to as\n",
    "  an \"individual\".\n",
    "\n",
    "  Attributes:\n",
    "    arch: the architecture as an int representing a bit-string of length `DIM`.\n",
    "        As a result, the integers are required to be less than `2**DIM`. They\n",
    "        can be visualized as strings of 0s and 1s by calling `print(model)`,\n",
    "        where `model` is an instance of this class.\n",
    "    accuracy:  the simulated validation accuracy. This is the sum of the\n",
    "        bits in the bit-string, divided by DIM to produce a value in the\n",
    "        interval [0.0, 1.0]. After that, a small amount of Gaussian noise is\n",
    "        added with mean 0.0 and standard deviation `NOISE_STDEV`. The resulting\n",
    "        number is clipped to within [0.0, 1.0] to produce the final validation\n",
    "        accuracy of the model. A given model will have a fixed validation\n",
    "        accuracy but two models that have the same architecture will generally\n",
    "        have different validation accuracies due to this noise. In the context\n",
    "        of evolutionary algorithms, this is often known as the \"fitness\".\n",
    "  \"\"\"\n",
    "  def __init__(self):\n",
    "    self.arch = None\n",
    "    self.accuracy = None\n",
    "\n",
    "  def __str__(self):\n",
    "    \"\"\"Prints a readable version of this bitstring.\"\"\"\n",
    "    return '{0:b}'.format(self.arch)\n",
    "\n",
    "def train_and_eval(arch):\n",
    "  \"\"\"Simulates training and evaluation.\n",
    "\n",
    "  Computes the simulated validation accuracy of the given architecture. See\n",
    "  the `accuracy` attribute in `Model` class for details.\n",
    "\n",
    "  Args:\n",
    "    arch: the architecture as an int representing a bit-string.\n",
    "  \"\"\"\n",
    "  accuracy =  float(_sum_bits(arch)) / float(DIM)\n",
    "  accuracy += random.gauss(mu=0.0, sigma=NOISE_STDEV)\n",
    "  accuracy = 0.0 if accuracy < 0.0 else accuracy\n",
    "  accuracy = 1.0 if accuracy > 1.0 else accuracy\n",
    "  return accuracy\n",
    "\n",
    "def _sum_bits(arch):\n",
    "  \"\"\"Returns the number of 1s in the bit string.\n",
    "\n",
    "  Args:\n",
    "    arch: an int representing the bit string.\n",
    "  \"\"\"\n",
    "  total = 0\n",
    "  for _ in range(DIM):\n",
    "    total += arch & 1\n",
    "    arch = (arch >> 1)\n",
    "  return total"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "f3SA6aWmArnW"
   },
   "source": [
    "# Search Space Traversal"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "jkNYKtGtAzUs"
   },
   "source": [
    "Below we define a function to generate random architectures in the basic search space and a function to mutate architectures within the search space."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "FXACEXwy201a"
   },
   "outputs": [],
   "source": [
    "import random\n",
    "\n",
    "def random_architecture():\n",
    "  \"\"\"Returns a random architecture (bit-string) represented as an int.\"\"\"\n",
    "  return random.randint(0, 2**DIM - 1)\n",
    "\n",
    "def mutate_arch(parent_arch):\n",
    "  \"\"\"Computes the architecture for a child of the given parent architecture.\n",
    "\n",
    "  The parent architecture is cloned and mutated to produce the child\n",
    "  architecture. The child architecture is mutated by flipping a randomly chosen\n",
    "  bit in its bit-string.\n",
    "\n",
    "  Args:\n",
    "    parent_arch: an int representing the architecture (bit-string) of the\n",
    "        parent.\n",
    "\n",
    "  Returns:\n",
    "    An int representing the architecture (bit-string) of the child.\n",
    "  \"\"\"\n",
    "  position = random.randint(0, DIM - 1)  # Index of the bit to flip.\n",
    "\n",
    "  # Flip the bit at position `position` in `child_arch`.\n",
    "  child_arch = parent_arch ^ (1 << position)\n",
    "\n",
    "  return child_arch"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "T2ciQCkqBSDe"
   },
   "source": [
    "# Regularized Evolution Algorithm"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "aHxYBucT-x5R"
   },
   "source": [
    "The regularized evolution (i.e. aging evolution) algorithm can be written as:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {
    "id": "6dr709ay2ahZ"
   },
   "outputs": [],
   "source": [
    "import collections\n",
    "import random\n",
    "import design_bench\n",
    "import numpy as np\n",
    "\n",
    "def set_seed(seed):\n",
    "    \"\"\"Set the numpy, random, and torch random seeds.\"\"\"\n",
    "    np.random.seed(seed)\n",
    "    random.seed(seed)\n",
    "\n",
    "def mutate(parent, discrete=True):\n",
    "#     return parent + np.random.normal(loc=0.0, scale=1.0, size=parent.shape)\n",
    "    if discrete:\n",
    "        rng = np.random.default_rng()\n",
    "        return rng.permuted(parent)\n",
    "    else:\n",
    "        return max(1.0, parent + np.random.normal(loc=0.0, scale=0.1, size=parent.shape))\n",
    "\n",
    "#   seed 123,234,345; check main code for seed! Check data split\n",
    "def regularized_evolution(cycles, population_size, sample_size, taskname, seed=0):\n",
    "    \"\"\"Algorithm for regularized evolution (i.e. aging evolution).\n",
    "\n",
    "    Follows \"Algorithm 1\" in Real et al. \"Regularized Evolution for Image\n",
    "    Classifier Architecture Search\".\n",
    "\n",
    "    Args:\n",
    "    cycles: the number of cycles the algorithm should run for.\n",
    "    population_size: the number of individuals to keep in the population.\n",
    "    sample_size: the number of individuals that should participate in each\n",
    "        tournament.\n",
    "\n",
    "    Returns:\n",
    "    history: a list of `Model` instances,  representing all the models computed\n",
    "        during the evolution experiment.\n",
    "    \"\"\"\n",
    "    \n",
    "    set_seed(seed)\n",
    "    \n",
    "    #check \n",
    "    \n",
    "    TASKNAME2TASK = {\n",
    "    'dkitty': 'DKittyMorphology-Exact-v0',\n",
    "    'ant': 'AntMorphology-Exact-v0',\n",
    "    'tf-bind-8': 'TFBind8-Exact-v0',\n",
    "    'tf-bind-10': 'TFBind10-Exact-v0',\n",
    "    'superconductor': 'Superconductor-RandomForest-v0',\n",
    "    # 'hopper': 'HopperController-Exact-v0',\n",
    "    # 'nas': 'CIFARNAS-Exact-v0',\n",
    "    'chembl': 'ChEMBL_MCHC_CHEMBL3885882_MorganFingerprint-RandomForest-v0',\n",
    "    # 'gfp': 'GFP-Transformer-v0',\n",
    "    }\n",
    "    \n",
    "    task = design_bench.make(TASKNAME2TASK[taskname])\n",
    "\n",
    "    normalise_x = True\n",
    "    normalise_y = True\n",
    "\n",
    "    if task.is_discrete:\n",
    "        print('discrete task')\n",
    "#         task.map_to_logits()\n",
    "    elif normalise_x:\n",
    "        task.map_normalize_x()\n",
    "\n",
    "    if normalise_y:\n",
    "        task.map_normalize_y()\n",
    "        \n",
    "    \n",
    "#     population = collections.deque()\n",
    "#     history = []  # Not used by the algorithm, only used to report results.\n",
    "\n",
    "    # Initialize the population with random models.\n",
    "\n",
    "#     while len(population) < population_size:\n",
    "    population_ind = np.random.choice(task.x.shape[0], size=population_size, replace=False)\n",
    "#     print(f'selected population indicies: {population_ind.shape}')\n",
    "    population = collections.deque(task.x[population_ind])\n",
    "#     print(task.x[population_ind].shape)\n",
    "    history = list(population)\n",
    "\n",
    "    # Carry out evolution in cycles. Each cycle produces a model and removes\n",
    "    # another.\n",
    "    i=0\n",
    "    while len(history) < cycles:\n",
    "#         print(f'at cycle {i}')\n",
    "        # Sample randomly chosen models from the current population.\n",
    "        sample = []\n",
    "        while len(sample) < sample_size:\n",
    "            # Inefficient, but written this way for clarity. In the case of neural\n",
    "            # nets, the efficiency of this line is irrelevant because training neural\n",
    "            # nets is the rate-determining step.\n",
    "            candidate = random.choice(list(population))\n",
    "#             print(f'shape of candidate: {candidate.shape}')\n",
    "            sample.append(candidate)\n",
    "\n",
    "        # The parent is the best model in the sample.\n",
    "        sample = np.array(sample)\n",
    "#         print(f'shape of sample: {sample.shape}')\n",
    "#         print(f'shape of prediction: {task.predict(sample).shape}')\n",
    "#         print(f'sample: {sample}')\n",
    "        parent_ind = np.argmax(task.predict(sample), axis=0)\n",
    "#         print(f'parent_ind: {parent_ind}')\n",
    "        parent = sample[parent_ind]\n",
    "\n",
    "        # Create the child model and store it.\n",
    "        child = mutate(parent).reshape(-1)\n",
    "#         print(f'child: {child}')\n",
    "        population.append(child)\n",
    "        history.append(child)\n",
    "\n",
    "        # Remove the oldest model.\n",
    "        population.popleft()\n",
    "        i+=1\n",
    "        \n",
    "    history = np.array(history)\n",
    "    hist_scores = task.predict(history).reshape(-1)\n",
    "    return history, hist_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "history_x, hist_scores = regularized_evolution(cycles=200, population_size=100, sample_size=10, taskname='ant')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [],
   "source": [
    "k=10\n",
    "top_scores = np.partition(hist_scores[100:200], -k)[-k:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f7dcf12e3d0>]"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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4O1vfzve+9734o477sCFF16Il770pTh06FC/D60jfPvb38bVV1+NW2+9FTfccANqtRouv/xyLC0tad9785vfjP3796v/3v/+9/fpiNvHueeeqx37d7/7XfW7P/zDP8R//Md/4F//9V/x7W9/G/v27cOrX/3qPh5t+/jBD36gnd8NN9wAAHjta1+rvjNs929paQkXXnghPvzhD1t///73vx9/+7d/i4985CO47bbbMDExgZe+9KVYXV1V33nDG96Ae++9FzfccAO++MUv4qabbsJv/dZv9eoUIhF1fsvLy7jjjjvw7ne/G3fccQc++9nP4sEHH8QrXvGKwHf//M//XLuvv/u7v9uLw4+FVvcQAK644grt+D/96U9rvx/kewi0Pkd+bvv378fHP/5xZDIZvOY1r9G+N6j3Mc780GoMbTQaeNnLXoZqtYqbb74Zn/zkJ3H99dfjPe95T3IH6owYnvOc5zhXX321+rnRaDjbt293rr322j4eVXI4dOiQA8D59re/rT77mZ/5Gef3f//3+3dQXeC9732vc+GFF1p/d+LECadQKDj/+q//qj67//77HQDOLbfc0qMjTB6///u/75x22mlOs9l0HGe475/jOA4A53Of+5z6udlsOlu3bnX+6q/+Sn124sQJp1QqOZ/+9Kcdx3Gc++67zwHg/OAHP1Df+fKXv+xkMhnnqaee6tmxx4F5fjZ8//vfdwA4TzzxhPps9+7dzgc/+MF0Dy4h2M7xTW96k/PKV74y9G+G6R46Trz7+MpXvtJ50YtepH02TPfRnB/ijKFf+tKXnGw26xw4cEB957rrrnOmp6edSqWSyHGNlCJSrVZx++2347LLLlOfZbNZXHbZZbjlllv6eGTJYW5uDgCwfv167fNPfepT2LhxI8477zxcc801WF5e7sfhdYSHH34Y27dvx6mnnoo3vOEN2LNnDwDg9ttvR61W0+7nWWedhV27dg3t/axWq/jHf/xH/Pqv/7rW6HGY75+Jxx57DAcOHNDu28zMDC6++GJ132655RbMzs7iWc96lvrOZZddhmw2i9tuu63nx9wt5ubmkMlkMDs7q33+vve9Dxs2bMAznvEM/NVf/VWicncvcOONN2Lz5s0488wz8da3vhVHjx5Vv1tr9/DgwYP4z//8T/zGb/xG4HfDch/N+SHOGHrLLbfg/PPPx5YtW9R3XvrSl2J+fh733ntvIsc10E3vksaRI0fQaDS0CwoAW7ZswQMPPNCno0oOzWYTf/AHf4DnPe95OO+889Tnv/zLv4zdu3dj+/btuPvuu/HOd74TDz74ID772c/28Wjj4eKLL8b111+PM888E/v378ef/dmf4fnPfz5+/OMf48CBAygWi4HBfcuWLThw4EB/DrhLfP7zn8eJEydw1VVXqc+G+f7ZQPfG9h7S7w4cOIDNmzdrv8/n81i/fv3Q3dvV1VW8853vxOtf/3qtmdjv/d7v4ZnPfCbWr1+Pm2++Gddccw3279+PD3zgA3082vi44oor8OpXvxqnnHIKHn30UfzxH/8xrrzyStxyyy3I5XJr6h4CwCc/+UlMTU0FQr/Dch9t80OcMfTAgQPWd5V+lwRGioisdVx99dX48Y9/rHkoAGgx2fPPPx/btm3Di1/8Yjz66KM47bTTen2YbeHKK69U/77gggtw8cUXY/fu3fjMZz6DsbGxPh5ZOvjYxz6GK6+8Etu3b1efDfP9G3XUajX84i/+IhzHwXXXXaf97u1vf7v69wUXXIBisYi3vOUtuPbaa4eilPgv/dIvqX+ff/75uOCCC3DaaafhxhtvxItf/OI+Hlk6+PjHP443vOENKJfL2ufDch/D5odBwEiFZjZu3IhcLhdwBB88eBBbt27t01Elg7e97W344he/iG9961vYsWNH5HcvvvhiAMAjjzzSi0NLFLOzszjjjDPwyCOPYOvWrahWqzhx4oT2nWG9n0888QS+/vWv4zd/8zcjvzfM9w+AujdR7+HWrVsDBvJ6vY5jx44Nzb0lEvLEE0/ghhtuaNla/eKLL0a9Xsfjjz/emwNMGKeeeio2btyonsu1cA8J3/nOd/Dggw+2fDeBwbyPYfNDnDF069at1neVfpcERoqIFItFXHTRRfjGN76hPms2m/jGN76BSy65pI9H1jkcx8Hb3vY2fO5zn8M3v/lNnHLKKS3/5q677gIAbNu2LeWjSx6Li4t49NFHsW3bNlx00UUoFAra/XzwwQexZ8+eobyfn/jEJ7B582a87GUvi/zeMN8/ADjllFOwdetW7b7Nz8/jtttuU/ftkksuwYkTJ3D77ber73zzm99Es9lURGyQQSTk4Ycfxte//nVs2LCh5d/cddddyGazgXDGsODJJ5/E0aNH1XM57PeQ42Mf+xguuugiXHjhhS2/O0j3sdX8EGcMveSSS3DPPfdopJKI9TnnnJPYgY4U/vmf/9kplUrO9ddf79x3333Ob/3Wbzmzs7OaI3iY8Na3vtWZmZlxbrzxRmf//v3qv+XlZcdxHOeRRx5x/vzP/9z54Q9/6Dz22GPOF77wBefUU091XvCCF/T5yOPhHe94h3PjjTc6jz32mPO9733Pueyyy5yNGzc6hw4dchzHcX77t3/b2bVrl/PNb37T+eEPf+hccsklziWXXNLno24fjUbD2bVrl/POd75T+3xY79/CwoJz5513OnfeeacDwPnABz7g3HnnnSpr5H3ve58zOzvrfOELX3Duvvtu55WvfKVzyimnOCsrK2obV1xxhfOMZzzDue2225zvfve7ztOe9jTn9a9/fb9OSUPU+VWrVecVr3iFs2PHDueuu+7S3kvKMrj55pudD37wg85dd93lPProo84//uM/Ops2bXLe+MY39vnMfESd48LCgvNf/st/cW655Rbnsccec77+9a87z3zmM52nPe1pzurqqtrGIN9Dx2n9nDqO48zNzTnj4+POddddF/j7Qb+PreYHx2k9htbrdee8885zLr/8cueuu+5yvvKVrzibNm1yrrnmmsSOc+SIiOM4zoc+9CFn165dTrFYdJ7znOc4t956a78PqWMAsP73iU98wnEcx9mzZ4/zghe8wFm/fr1TKpWc008/3fmjP/ojZ25urr8HHhOve93rnG3btjnFYtE56aSTnNe97nXOI488on6/srLi/M7v/I6zbt06Z3x83Pn5n/95Z//+/X084s7w1a9+1QHgPPjgg9rnw3r/vvWtb1mfyze96U2O47gpvO9+97udLVu2OKVSyXnxi18cOPejR486r3/9653JyUlnenra+bVf+zVnYWGhD2cTRNT5PfbYY6Hv5be+9S3HcRzn9ttvdy6++GJnZmbGKZfLztlnn+385V/+pTaJ9xtR57i8vOxcfvnlzqZNm5xCoeDs3r3befOb3xxY0A3yPXSc1s+p4zjORz/6UWdsbMw5ceJE4O8H/T62mh8cJ94Y+vjjjztXXnmlMzY25mzcuNF5xzve4dRqtcSOM+MdrEAgEAgEAkHPMVIeEYFAIBAIBIMFISICgUAgEAj6BiEiAoFAIBAI+gYhIgKBQCAQCPoGISICgUAgEAj6BiEiAoFAIBAI+gYhIgKBQCAQCPoGISICgUAgEAj6BiEiAoFAIBAI+gYhIgKBQCAQCPoGISICgUAgEAj6BiEiAoFAIBAI+ob/H+2Rg3vtfjsbAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.plot(hist_scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "0ptMGABxBV61"
   },
   "source": [
    "# Example Run on the Toy Search Space"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "ykQshJgS-1W1"
   },
   "source": [
    "We run the algorithm for 1000 samples, setting the population size and sample size parameters to reasonable values."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "1izV1iKqFSgS"
   },
   "outputs": [],
   "source": [
    "history = regularized_evolution(\n",
    "    cycles=1000, population_size=100, sample_size=10)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "5YUKkL0_-UMH"
   },
   "source": [
    "We plot the progress of the experiment, showing how the accuracy improved gradually:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 445
    },
    "id": "ZXKj2rddziLV",
    "outputId": "3ea1d3a6-134d-433a-d6a9-178d8f9f7d88"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAGsCAYAAAAxAchvAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvNQv5yAAAIABJREFUeJzs3Xd8FHX+P/DXJoDo0YLiKYET1B8JEHY3cgoqNkCKEJWQRD3hrAiciKJwSBCQFlDAwmHBcnJnIaQgGsCj2buQLQqoXytBEfEgYFQMZD+/P3T2Zmdndmd2Z7a+no8HjyO7Uz67cM6L96fZhBACRERERGkoI94NICIiIooXBiEiIiJKWwxCRERElLYYhIiIiChtMQgRERFR2mIQIiIiorTFIERERERpS1cQ2rNnD8aNG4c+ffrgggsuwJw5c9DY2Kh67NNPP40hQ4bA4XBgxIgRcLvd/vd8Ph8efvhhDBw4EPn5+SgsLMRrr73mf3/06NHo0aMHevXq5f81bNgw//s7d+7ENddcgzPPPBNnn302Jk6ciG+//TbSz05ERERpTlcQmjBhArKysrBp0yY899xzcLlcWLp0adBxa9aswX333Yc5c+bggw8+wOjRozF27FgcOnQIALBixQqUl5dj2bJleP/993H55ZfjlltuwXfffee/xvjx4/Hhhx/6f61btw4AcPToUYwZMwa9evXCW2+9hY0bNwIAJk+eHPWXQEREROkpbBD68MMPsWPHDkyZMgVt2rRBdnY2xo4di4qKCvh8voBjX375ZQwePBhnnXUWWrRogcLCQpx++unYsGHDbzfLyMDUqVORm5uL5s2bY/To0QAAr9cbtqF79uzBvn37MGLECLRo0QKtW7fGJZdcgp07d0byuYmIiIjCB6Ht27fj5JNPRvv27f2v9ezZEwcPHsSuXbuCjrfZbAE/t2nTxh9Wrr322oCurh9++AFHjhzBH//4R/9r7777Li699FLk5+fj6quvxueffw4AyM7ORm5uLsrLy9HQ0ICGhgasX78e/fv3V2330aNHsXv3bhw9ejTcRyQiIqI0FTYI1dfXo02bNgGvtW3bFgBw4MCBgNcvuugi/Oc//8EHH3yAxsZGvPLKK9i2bRvq6+uDrtvU1ITp06fjnHPOgcPhAACcdtppOO200/DUU0/h1VdfRXZ2NsaMGYNff/0VGRkZWLZsGV5++WX07t0bvXv3xrfffotZs2aptvu7777DgAEDArrdiIiIiOR0jRHSuy/r5ZdfjjFjxmDq1Kk499xzsWnTJgwbNgzNmjULOO6XX37BzTffjB9++AH33Xef//W7774bc+bMwfHHH4+2bdti5syZ2Lt3L95//300NjZi3LhxGDx4MLZu3YrXX38dJ554Iu644w4DH5eIiIjof5qFO6B9+/ZBFR3p5+OPPz7gdZvNhr/97W/429/+5n9t4sSJ6NKli//ngwcP4oYbbkDbtm3x73//G61atdK8d6tWrdC2bVt8//33eOedd/D1119j0qRJaN68OVq3bo2JEyfisssuw3//+9+gthARERGFE7YilJeXh71792Lfvn3+17xeL44//nh07tw54Ngvv/wSmzdv9v/c2NiIDz74AL179/b/PHbsWJxyyilYvnx5QAhqaGjA3Xffjb179/pf279/P/bv34/OnTujqakpqDLF8T9EREQUjbBBqEePHnA6nVi0aBF+/PFH1NXV4ZFHHsHVV18Nm82GIUOG4L333gMAfP/997j99tvhcrnQ2NiIe++9FyeccAL69esHAHjqqadw9OhR3HPPPUHdZa1atYLH48G8efNQX1+PgwcPYvbs2ejWrRv+/Oc/Iz8/H61atcIDDzyAn3/+GQcOHMCjjz6K/Px8VoOIiIgoIrrGCD344IM4dOgQzjvvPBQXF+P888/HuHHjAPxWBfr5558BAH369MFtt92GW265BWeddRa+/PJLPProo8jMzAQAVFZWYufOncjPzw9YNPHhhx8GADz00EMQQmDw4MG48MILceTIETz++OPIyMhAVlYWnnzySXi9XlxwwQUYNmwYMjMz8cADD1jxvRAREVEasAm9I6GTzO7duzFgwABs2bIFnTp1indziIiIKAFxrzEiIiJKWwxCRERElLYYhIiIiChtMQgRERFR2mIQIiIiorTFIERERERpi0GIiIiI0haDEBEREaUtBiEiIiJKWwxCRERElLYYhIiIiMgyQgi43W4k6o5eDEJERERkGY/Hg5EjR8Lj8cS7KaoYhIiIiMgyDocD1dXVcDgc8W6KKgYhIiIisozNZoPT6YTNZvO/lkjdZQxCREREFFOJ1F3GIEREREQxlUjdZc3i3QAiIiJKL1J3WSJgRYiIiIjSFoMQERER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bTEIqYjVFhjh7sOtOIiIiKzFIKQiVrO/wt2Hs9CIiIisxSCkIlazv5TbeCgrQJyFRkREZC0GIRWx2gLDZrPBZrP5t/FQVoC4FQcREZG10nr6fCKsBK2s+rACREREFDtpXRFKhDE48qoPK0BERESxldZBiGNwiIiI0ltad41xJWgiIqL0ltYVISO4pg8REVHqYRDSKRHGExEREZG5GIR04ngiIiKi1JPWY4SM4HgiIiKi1MOKEBEREaUtBiEiIiJKWwxCRERElLYYhIiIiChtMQgRERFR2mIQIiIiorTFIERERERpi0GIiIiI0haDEBEREaUtBqEocTNWIiKi5MUgFCVuxkpERJS8GISixM1YiYiIkhc3XY0SN2MlIiJKXqwIERERUdpiECIiIqK0xSBEREREaYtBiIiIiNIWgxARERGlLQah33FhRCIiovTDIPQ7LoxIRESUfhiEfseFEYmIiNIPg9DvpIURbTZbzO7J7jgiIqL4YhCKI3bHERERxReDUByxO46IiCi+uNdYHHGfMiIiovhiRYiIiIjSFoMQERERpS0GISIiIkpbDEJERESUthiEiIiIKG0xCBEREVHaYhAiIiKitMUgRERERGmLQYiIiIjSFoMQERERpS0GISIiIkpbuoLQnj17MG7cOPTp0wcXXHAB5syZg8bGRtVjn3zySQwcOBBOpxODBg3CP//5T9Xjtm/fjh49emD16tWq7//rX/9CTk4Odu/e7X/t1VdfRWFhIfLz83H++edj5syZaGho0PMRiIiIiILoCkITJkxAVlYWNm3ahOeeew4ulwtLly4NOq6yshIrVqzAsmXLUFtbi/nz5+OBBx7A5s2bA47z+XyYNWsWjjvuONX77d27F0899VTAa59//jkmTpyIMWPGYOvWrXj22WexdetWPPjgg3o/KxEREVGAsEHoww8/xI4dOzBlyhS0adMG2dnZGDt2LCoqKuDz+QKO7dq1K+677z7k5uYiIyMDZ555Jk477TR8/PHHAcetXLkSbdq0Qffu3VXvOX/+fFx55ZUBrzVr1gwLFy7E0KFDkZmZic6dO+O8884LujYRERGRXs3CHbB9+3acfPLJaN++vf+1nj174uDBg9i1axe6dOnif/3Pf/6z//eNjY3YvHkz6urq0L9/f//r+/btw0MPPYRnn30WM2fODLrfa6+9hk8//RSLFy/G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c+fipZdewsSJE/Hvf/8bS5YsAfBb4OrTpw/y8/Px5ptvBq0ML9eqVSv069cvaBudF198EYMHDw7qaly5ciXmz5+P0aNHY926dXjggQfg9XoxduxY//6Hs2fPxnvvvYcHH3wQ5eXlOOaYY4JCzqxZs1BZWYkJEyagpqYGJSUlmDFjBtavX6/azocffhgbN27EokWLsHHjRsyePRsvvPACHnvsMc3Ppscpp5yCnj17YtOmTQGvb9y4EZmZmRgyZAi++OIL3Hrrrejbty/Wr1+PlStX4rjjjsP48eOj+sfc5MmT8dVXX2HFihX4z3/+g2uvvRazZ8/G66+/DuC3P8cWLVrg+uuvx5tvvomTTz4Z7733HiZMmIDu3bujqqoK9913H959913cfvvt/usuXboUL774ImbNmoXq6mrk5uZi+fLlEbeT0sP69etx44034pRTTgl4fd++fRg3bhwuv/xyvP322ygrK8PixYv9f09fffVV3HfffZg7dy7eeecdFBYWYuzYsf5/HN1///1wuVx4+umnsXnzZmRlZWHixInhGyRSjNfrFbm5ueK///2v/7WXXnpJnHnmmaKpqSmOLaNkN2rUKLF06VIhhBDPP/+86Nmzp/jqq6+EEELU1dWJbt26ibq6OiGEEFOnThUDBw4MOH/t2rVBx+Tm5ooffvjBf8zw4cPFoEGD/D/7fD6Rn58vnnrqKSGEEEuXLhXdunUTb775pv+YPXv2iJycHPHMM88IIYQYMmSIGD9+fMC9n376adGjRw9x8OBB/2dxOp3i8OHDmp9Xuu6qVasCXl+yZInIz88XjY2NQgghrr/+ejFq1KhQX5246KKLRHV1taipqRE9evTwf+bvvvtO5Obmiq1bt4qlS5eKiy66yH/OoEGDxO233x5wnTfeeEN069ZNuFwu0dDQIHr27CmWL18ecExJSYno3r17wPWl709yyy23iBEjRvh/7tatm3jooYeEEELceOONYsyYMQHHf/bZZ/4/NzWjRo0S3bt3F06nU/XXN998I4QQ4rHHHhP5+fni119/9Z87evRoMXbsWCGEEIcPHxafffZZwPvvvvuu6Natm9i5c6cQQojq6mrRrVs3sWfPHv93W1paGtCeGTNmBHyXu3fvFnv37g045qKLLhJlZWX+n/Py8vx/v4UQ4oYbbhCXXnppwDkvv/yy6Natm/jkk0+E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",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f9b79548eb8>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "import seaborn as sns\n",
    "sns.set_style('white')\n",
    "xvalues = range(len(history))\n",
    "yvalues = [i.accuracy for i in history]\n",
    "ax = plt.gca()\n",
    "ax.scatter(\n",
    "    xvalues, yvalues, marker='.', facecolor=(0.0, 0.0, 0.0),\n",
    "    edgecolor=(0.0, 0.0, 0.0), linewidth=1, s=1)\n",
    "ax.xaxis.set_major_locator(ticker.LinearLocator(numticks=2))\n",
    "ax.xaxis.set_major_formatter(ticker.ScalarFormatter())\n",
    "ax.yaxis.set_major_locator(ticker.LinearLocator(numticks=2))\n",
    "ax.yaxis.set_major_formatter(ticker.ScalarFormatter())\n",
    "fig = plt.gcf()\n",
    "fig.set_size_inches(8, 6)\n",
    "fig.tight_layout()\n",
    "ax.tick_params(\n",
    "    axis='x', which='both', bottom='on', top='off', labelbottom='on',\n",
    "    labeltop='off', labelsize=14, pad=10)\n",
    "ax.tick_params(\n",
    "    axis='y', which='both', left='on', right='off', labelleft='on',\n",
    "    labelright='off', labelsize=14, pad=5)\n",
    "plt.xlabel('Number of Models Evaluated', labelpad=-16, fontsize=16)\n",
    "plt.ylabel('Accuracy', labelpad=-30, fontsize=16)\n",
    "plt.xlim(0, 1000)\n",
    "sns.despine()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "nWvlb_hnJt7U"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "name": "regularized_evolution_algorithm.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
