{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.collections import PatchCollection\n",
    "from matplotlib.patches import Rectangle\n",
    "%matplotlib inline\n",
    "%config InlineBackend.figure_format = 'retina'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from drtb import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Initialize a domain"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# setup a basic domain on [-1,1]^2\n",
    "dom = BoxDomain([-1,-1], [1,1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Random point, random direction parameter sweeps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pick a random point\n",
    "x = dom.sample()\n",
    "# pick a random direction\n",
    "p = np.random.randn(len(dom))\n",
    "p /= np.linalg.norm(p)\n",
    "\n",
    "# Find how far we can go in the direction p\n",
    "a1 = dom.extent(x, p)\n",
    "x1 = x + a1*p\n",
    "# Find how far we can go in the direction -p\n",
    "a2 = dom.extent(x, -p)\n",
    "x2 = x - a2*p\n",
    "\n",
    "# Sample uniformly on the line connecting x1, x2\n",
    "X = np.array([a*x1 + (1-a)*x2 for a in np.linspace(0,1,10)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x114fa40d0>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 304,
       "width": 332
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the sweep\n",
    "fig, ax = plt.subplots(figsize = (5,5))\n",
    "ax.plot(X[:,0], X[:,1],'k.')\n",
    "# plot the box domain\n",
    "rect = Rectangle(dom.lb, *(dom.ub - dom.lb), edgecolor = 'none', facecolor = 'b', alpha = 0.5)\n",
    "ax.add_patch(rect)\n",
    "ax.axis('equal');"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Random direction sweeps\n",
    "In high dimensional domains, the random point-random direction sweeps are apt to be relatively short because of the additional constraints.  Instead, we can find the point furthest along the direction $p$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pick a random direction\n",
    "p = np.random.randn(len(dom))\n",
    "p /= np.linalg.norm(p)\n",
    "\n",
    "# Find the point furthest along p\n",
    "x1 = dom.corner(p)\n",
    "x2 = dom.corner(-p)\n",
    "\n",
    "# Sample uniformly on the line connecting x1, x2\n",
    "X = np.array([a*x1 + (1-a)*x2 for a in np.linspace(0,1,10)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x114539e50>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 304,
       "width": 332
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the sweep\n",
    "fig, ax = plt.subplots(figsize = (5,5))\n",
    "ax.plot(X[:,0], X[:,1],'k.')\n",
    "# plot the box domain\n",
    "rect = Rectangle(dom.lb, *(dom.ub - dom.lb), edgecolor = 'none', facecolor = 'b', alpha = 0.5)\n",
    "ax.add_patch(rect)\n",
    "ax.axis('equal');"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Real-ish example\n",
    "Using an OTL circuit from https://www.sfu.ca/~ssurjano/otlcircuit.html"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Domain in application units\n",
    "dom = demos.build_otl_circuit_domain()\n",
    "# Domain in normalized units (-1,1)^6\n",
    "dom_norm = dom.normalized_domain()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x114539510>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 321,
       "width": 332
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# random-point, random-direction\n",
    "x_norm = dom_norm.sample()\n",
    "p = np.random.randn(len(dom_norm))\n",
    "p /= np.linalg.norm(p)\n",
    "\n",
    "# Find how far we can go in the direction p\n",
    "a1 = dom_norm.extent(x_norm, p)\n",
    "x1_norm = x_norm + a1*p\n",
    "# Find how far we can go in the direction -p\n",
    "a2 = dom_norm.extent(x_norm, -p)\n",
    "x2_norm = x_norm - a2*p\n",
    "\n",
    "# Sample uniformly on the line connecting x1, x2\n",
    "X_norm = np.array([a*x1_norm + (1-a)*x2_norm for a in np.linspace(0,1,50)])\n",
    "\n",
    "# Now convert back to application units\n",
    "X = dom.unnormalize(X_norm)\n",
    "\n",
    "# Evalute the function\n",
    "fX = demos.otl_circuit(X)\n",
    "\n",
    "fig, ax = plt.subplots(figsize = (5,5))\n",
    "ax.plot(np.dot(p, X_norm.T).T, fX, '.')\n",
    "ax.set_xlabel('normalized coordinates $p^Tx$')\n",
    "ax.set_ylabel('$f(x)$');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x114539690>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 321,
       "width": 323
      }
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# pick a random direction\n",
    "p = np.random.randn(len(dom_norm))\n",
    "p /= np.linalg.norm(p)\n",
    "\n",
    "# Find the point furthest along p\n",
    "x1_norm = dom_norm.corner(p)\n",
    "x2_norm = dom_norm.corner(-p)\n",
    "\n",
    "# Sample uniformly on the line connecting x1, x2\n",
    "X_norm = np.array([a*x1_norm + (1-a)*x2_norm for a in np.linspace(0,1,50)])\n",
    "\n",
    "# Now convert back to application units\n",
    "X = dom.unnormalize(X_norm)\n",
    "\n",
    "# Evalute the function\n",
    "fX = demos.otl_circuit(X)\n",
    "\n",
    "fig, ax = plt.subplots(figsize = (5,5))\n",
    "ax.plot(np.dot(p, X_norm.T).T, fX, '.')\n",
    "ax.set_xlabel('normalized coordinates $p^Tx$')\n",
    "ax.set_ylabel('$f(x)$');"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 2",
   "language": "python",
   "name": "python2"
  },
  "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.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
