{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from PIL.ImageOps import scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1",
   "metadata": {
    "tags": [
     "parameters"
    ]
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = np.linspace(-2, 2, 20)\n",
    "y = np.linspace(-2, 2, 20)\n",
    "X, Y = np.meshgrid(x, y)\n",
    "\n",
    "R = np.sqrt(Y**2 + X**2)\n",
    "U = Y/R\n",
    "V = -X/R\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 8))\n",
    "ax.quiver(X, Y, U, V, alpha=.5)\n",
    "\n",
    "t = np.pi/2-np.linspace(0,.3*2*np.pi,100)\n",
    "\n",
    "\n",
    "trajectory = np.column_stack([np.cos(t), np.sin(t)]) * 1\n",
    "ax.plot(trajectory[:,0], trajectory[:,1], 'k', lw=3)\n",
    "ax.set_xlabel(\"X\")\n",
    "ax.set_ylabel(\"Y\")\n",
    "ax.axis('equal')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = np.linspace(-2, 2, int(1.5*20))\n",
    "y = np.linspace(-2, 2, int(1.5*40))\n",
    "X, Y = np.meshgrid(x, y)\n",
    "\n",
    "R = np.sqrt(Y**2 + X**2)\n",
    "U = -X/R + Y/R\n",
    "V = -Y/R - X/R\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 8))\n",
    "ax.quiver(X, Y, U, V, alpha=.25, pivot='middle', scale=49)\n",
    "# ax.streamplot(X, Y, U, V, density=2)\n",
    "\n",
    "points = [\n",
    "    (-2, 1.85),\n",
    "    (-.25, 1.81),\n",
    "    (0.8, 1.2),\n",
    "    (1.4, 1.5),\n",
    "]\n",
    "\n",
    "def connect(a,b, *args, **kwargs):\n",
    "    ax.plot([a[0], b[0]], [a[1], b[1]], *args, **kwargs)\n",
    "\n",
    "connect(points[2], points[3], '--r', lw=3, ms=15)\n",
    "connect(points[1], points[2], '.--k', lw=3, ms=15, color='#4d4d4dff')\n",
    "connect(points[1], points[3], '.-k', lw=3, ms=15, color = '#ca1469ff')\n",
    "connect(points[0], points[1], '.-k', lw=3, ms=15)\n",
    "\n",
    "# ax.plot([-2, -.25],[1.85, 1.77], '.-k', lw=3, ms=10 )\n",
    "# ax.plot([-.25, 0.5],[1.77, 1.4], '.--k', lw=2, ms=10 )\n",
    "# ax.plot([-.25, 1.0],[1.77, 1.5], '.-k', lw=3, ms=10 )\n",
    "# ax.plot([-.25, 1.0],[1.77, 1.5], '.-k', lw=3, ms=10 )\n",
    "\n",
    "# t = np.pi/2-np.linspace(0,.3*2*np.pi,100)\n",
    "#\n",
    "#\n",
    "# trajectory = np.column_stack([np.cos(t), np.sin(t)]) * 1\n",
    "# ax.plot(trajectory[:,0], trajectory[:,1], 'k', lw=3)\n",
    "ax.set_xlabel(\"X\")\n",
    "ax.set_ylabel(\"Y\")\n",
    "ax.set_ylim([1,2.1])\n",
    "ax.axis('off')\n",
    "\n",
    "fig.savefig('schematic.svg')\n"
   ]
  }
 ],
 "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": 5
}
