{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6b3f03b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sympy import *"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "607e1dc7",
   "metadata": {},
   "source": [
    "### a scale-free model based on ratios\n",
    "\n",
    "we assume three points $a,b,c$ and look at $a-c$ and $b-c$.\n",
    "We split these vectors in a tangential part (parallel to $a-b$) and a normal part."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f7bb19de",
   "metadata": {},
   "outputs": [],
   "source": [
    "n, t_ac, t_bc = symbols(\"n t_ac t_bc\", positive=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b8367791",
   "metadata": {},
   "outputs": [],
   "source": [
    "d_ac = sqrt(t_ac**2 + n**2)\n",
    "d_bc = sqrt(t_bc**2 + n**2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0512c35a",
   "metadata": {},
   "source": [
    "the probability of a winning the comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "dca91ec9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "1/(sqrt(n**2 + t_ac**2)/sqrt(n**2 + t_bc**2) + 1)",
      "text/latex": "$\\displaystyle \\frac{1}{\\frac{\\sqrt{n^{2} + t_{ac}^{2}}}{\\sqrt{n^{2} + t_{bc}^{2}}} + 1}$"
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "expr1 = 1/(1 + d_ac/d_bc)\n",
    "expr1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "016d766c",
   "metadata": {},
   "source": [
    "the probability of $a$ winning the comparison, this is how we typically write down the $\\gamma$-CKL model."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "224697e3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "sqrt(n**2 + t_bc**2)/(sqrt(n**2 + t_ac**2) + sqrt(n**2 + t_bc**2))",
      "text/latex": "$\\displaystyle \\frac{\\sqrt{n^{2} + t_{bc}^{2}}}{\\sqrt{n^{2} + t_{ac}^{2}} + \\sqrt{n^{2} + t_{bc}^{2}}}$"
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "expr2 = d_bc/(d_ac + d_bc)\n",
    "expr2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "38da1196",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "0",
      "text/latex": "$\\displaystyle 0$"
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(expr1 - expr2).simplify()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "58c6a7e2",
   "metadata": {},
   "source": [
    "as long as $a$ is closer to $c$ than $b$, increasing the normal distance decreases the chance of $a$ winning."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e342f3fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "n*(t_ac**2 - t_bc**2)/(sqrt(n**2 + t_ac**2)*sqrt(n**2 + t_bc**2)*(sqrt(n**2 + t_ac**2) + sqrt(n**2 + t_bc**2))**2) > 0",
      "text/latex": "$\\displaystyle \\frac{n \\left(t_{ac}^{2} - t_{bc}^{2}\\right)}{\\sqrt{n^{2} + t_{ac}^{2}} \\sqrt{n^{2} + t_{bc}^{2}} \\left(\\sqrt{n^{2} + t_{ac}^{2}} + \\sqrt{n^{2} + t_{bc}^{2}}\\right)^{2}} > 0$"
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(diff(expr1, n) > 0).simplify()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9cd66719",
   "metadata": {},
   "source": [
    "### a more convenient notation, finding minima and maxima of probabilities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "629d4caf",
   "metadata": {},
   "outputs": [],
   "source": [
    "# distance of the outside query, dimensionality\n",
    "eps, D = symbols(\"eps d\")\n",
    "\n",
    "eps=D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9826717d",
   "metadata": {},
   "outputs": [],
   "source": [
    "d_vc = sqrt(D) # distance of x_v to corner (point with least favour for x_v)\n",
    "d_qc = sqrt(eps**2 + D-1) # distance of x_q to corner\n",
    "d_vq = eps + 1 # distance between x_v and x_q\n",
    "\n",
    "# this is important for the scale-free oracle, points with the same ratio have the same outcome probability\n",
    "ratio = d_vc / d_qc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2a0f5d3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "sqrt(d**2 + d - 1)",
      "text/latex": "$\\displaystyle \\sqrt{d^{2} + d - 1}$"
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d_qc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0d720c8f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# quick numerical check of these distances\n",
    "\n",
    "d=10\n",
    "\n",
    "# at the center of the current cube\n",
    "v = np.zeros((d,))\n",
    "\n",
    "# at the corner, all ones, assuming a side length of 2\n",
    "c = np.ones((d,))\n",
    "\n",
    "# the query point, at a distance of eps + 1, here eps=d\n",
    "q = np.zeros((d,))\n",
    "q[0]=1+d\n",
    "\n",
    "assert np.linalg.norm(v-c) == np.sqrt(d)\n",
    "assert np.linalg.norm(q-c) == np.sqrt(d**2 + d - 1)\n",
    "assert np.linalg.norm(v-q) == d+1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1ed2f566",
   "metadata": {},
   "outputs": [],
   "source": [
    "# x is along axis x_v - x_q, in the direction from x_q to x_v and 0 at x_v. \n",
    "# this means that a positive value of x means moving away from x_q\n",
    "# y is distance orthogonal\n",
    "x, y = symbols(\"x y\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "6ef9fb49",
   "metadata": {},
   "outputs": [],
   "source": [
    "d_vx = sqrt(x**2 + y**2)\n",
    "d_qx = sqrt((x+d_vq)**2 + y**2 )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "67ac351d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "[(d - sqrt(d**3 - d**2*y**2 + d**2 + 2*d*y**2 - d - y**2))/(d - 1),\n (d + sqrt(d**3 - d**2*y**2 + d**2 + 2*d*y**2 - d - y**2))/(d - 1)]"
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# for a given y, we solve for the x value, such that the point described by (x,y) has the same outcome probability as c\n",
    "x_solutions = solve(d_vx / d_qx - ratio, x)\n",
    "\n",
    "x_solutions"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72ca99d6",
   "metadata": {},
   "source": [
    "## we want to find the extreme, e.g. the closest and farthest points"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7dcf0888",
   "metadata": {},
   "source": [
    "## we analyze the first solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "5be4d891",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "(d - sqrt(d**3 - d**2*y**2 + d**2 + 2*d*y**2 - d - y**2))/(d - 1)",
      "text/latex": "$\\displaystyle \\frac{d - \\sqrt{d^{3} - d^{2} y^{2} + d^{2} + 2 d y^{2} - d - y^{2}}}{d - 1}$"
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_solutions[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "f14fff0c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "-(-d**2*y + 2*d*y - y)/((d - 1)*sqrt(d**3 - d**2*y**2 + d**2 + 2*d*y**2 - d - y**2))",
      "text/latex": "$\\displaystyle - \\frac{- d^{2} y + 2 d y - y}{\\left(d - 1\\right) \\sqrt{d^{3} - d^{2} y^{2} + d^{2} + 2 d y^{2} - d - y^{2}}}$"
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# take derivative\n",
    "dx_dy = diff(x_solutions[0], y)\n",
    "dx_dy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "8090a45c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "[0]"
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# necessary condition, first derivative must be 0\n",
    "solve(dx_dy, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "c3159b41",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "-(-d**2 + 2*d - 1)/((d - 1)*sqrt(d**3 + d**2 - d))",
      "text/latex": "$\\displaystyle - \\frac{- d^{2} + 2 d - 1}{\\left(d - 1\\right) \\sqrt{d^{3} + d^{2} - d}}$"
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# second derivative\n",
    "ddx_ddy = diff(dx_dy, y)\n",
    "\n",
    "#check sign\n",
    "ddx_ddy.subs({y:0})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "2ebff846",
   "metadata": {},
   "outputs": [],
   "source": [
    "# the above expression is positive for d>1\n",
    "# since d is the dimensionality, this must always be the case\n",
    "# we are looking at a minimum"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "55dd47ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "(d - sqrt(d**3 + d**2 - d))/(d - 1)",
      "text/latex": "$\\displaystyle \\frac{d - \\sqrt{d^{3} + d^{2} - d}}{d - 1}$"
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_solutions[0].subs({y:0}) # this is negative. Which means the point lies between x_v and x_q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "0c2fe7ee",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\frac{d - \\sqrt{d^{3} + d^{2} - d}}{d - 1}\n"
     ]
    }
   ],
   "source": [
    "print_latex(x_solutions[0].subs({y:0}))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb8c6332",
   "metadata": {},
   "source": [
    "## second solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "f4e7d4d3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "(d + sqrt(d**3 - d**2*y**2 + d**2 + 2*d*y**2 - d - y**2))/(d - 1)",
      "text/latex": "$\\displaystyle \\frac{d + \\sqrt{d^{3} - d^{2} y^{2} + d^{2} + 2 d y^{2} - d - y^{2}}}{d - 1}$"
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_solutions[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "476aa15a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "(-d**2*y + 2*d*y - y)/((d - 1)*sqrt(d**3 - d**2*y**2 + d**2 + 2*d*y**2 - d - y**2))",
      "text/latex": "$\\displaystyle \\frac{- d^{2} y + 2 d y - y}{\\left(d - 1\\right) \\sqrt{d^{3} - d^{2} y^{2} + d^{2} + 2 d y^{2} - d - y^{2}}}$"
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# take derivative\n",
    "dx_dy = diff(x_solutions[1], y)\n",
    "dx_dy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "cf8b1c4f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "[0]"
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# necessary condition, first derivative must be 0\n",
    "solve(dx_dy, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "85889674",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "(-d**2 + 2*d - 1)/((d - 1)*sqrt(d**3 + d**2 - d))",
      "text/latex": "$\\displaystyle \\frac{- d^{2} + 2 d - 1}{\\left(d - 1\\right) \\sqrt{d^{3} + d^{2} - d}}$"
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# second derivative\n",
    "ddx_ddy = diff(dx_dy, y)\n",
    "\n",
    "#check sign\n",
    "ddx_ddy.subs({y:0})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "db859617",
   "metadata": {},
   "outputs": [],
   "source": [
    "# the above expression is negative for d>1\n",
    "# since d is the dimensionality, this must always be the case\n",
    "# we are looking at a maximum"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "9457e7c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "(d + sqrt(d**3 + d**2 - d))/(d - 1)",
      "text/latex": "$\\displaystyle \\frac{d + \\sqrt{d^{3} + d^{2} - d}}{d - 1}$"
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_solutions[1].subs({y:0}) # this is negative. Which means the point lies on the far side of x_v (away from x_q)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "03e91578",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\frac{d + \\sqrt{d^{3} + d^{2} - d}}{d - 1}\n"
     ]
    }
   ],
   "source": [
    "# this is also the point with the highest distance to x_v\n",
    "print_latex(x_solutions[1].subs({y:0}))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "439980e3",
   "metadata": {},
   "source": [
    "## illustration of the construction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "69d324e1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 600x600 with 1 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmcAAAJRCAYAAAAAkRChAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAC4jAAAuIwF4pT92AABpOklEQVR4nO3dd3hUZd7G8XtSSIGE3hEUEKWICigqFhZBbFhQ17YqIEhzxbr2goqKLLqiooICoq7dRbALIoKASBEQVFSUTkBqgPTM+8fzJplzZtInc86ZfD/XNReeZybhZ8jM3PNUn9/v9wsAAACuEON0AQAAAChCOAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLxDldAKpGbm6u0tPTC69r1KihmBiyOAAApcnPz1d2dnbhdUpKiuLiIheZCGdRKj09XevXr3e6DAAAPK9169aqW7duxP4+ulIAAABchHAGAADgIgxrRqkaNWpYrlu3bq3ExESHqvGOzMxMy3AwPzdUFX7XECn8rpWf/Wdmf0+taoSzKGWf/J+YmKikpCSHqvEufm6IFH7XECn8rpVfpBfUMawJAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAF4lzugC38/v92rx5s9atW6ft27crPT1dNWrUUGpqqg4//HAdc8wxSkhIcLpMAAAQJQhnIezbt0+zZ8/W/PnztXjxYu3Zs6fYx8bHx+uMM87QddddpxNPPDGCVQIAgGhEOLMZPXq03n33XeXk5JTp8Tk5OZo9e7Zmz56tiy66SPfff79q1apVxVUCAIBoRTizWblyZchgFhsbq4YNG6p+/frKzc3V1q1blZ6ebnnMjBkztH79ek2bNk01a9aMVMkAACCKEM5KkJqaqvPPP189e/ZU165dLT1ieXl5Wrp0qSZMmKClS5cWtq9atUp33323JkyY4ETJAADA4whnITRv3lzDhw9Xv379lJiYGPIxsbGx6t69u6ZPn67Ro0fr7bffLrzv888/1+LFi3XSSSdFqmQAABAlCGc2N910k0455RTVqFGjTI+PjY3Vgw8+qDVr1ujHH38sbH/33XcJZwAAoNzY58ymZ8+eZQ5mBWJjYzV48GBL24IFC8JZFgAAqCYIZ2HSrVs3y/XevXuVkZHhUDUAAMCrCGdhUrt27aA2+2pOAACA0hDOwiQtLS2orU6dOpEvBAAAeBrhLEwCt9OQzIrP8s5dAwAAYLVmmLz//vuW69NPP92hSlBh+fnSzp2KCzyua+dOKSnJuZrgafn50qFD0sGD0oED5s/MTNOemZmlDRuy5fNJMTHSoQ27lJiYoMREqWZNqVYtc0tKknw+p/9P4GkZGdbXtfx852pBmRDOwmDevHn6/vvvLW39+/d3qJrQMjMznS7B/XbuVFKrVjrW6ToQNWIk1fr/W2OHa0H1lSRZXtf2rlsntWjhVDme4PR7JuGskvbu3asHHnjA0ta7d2917tzZoYpCW79+vdMluF7cnj0EMwBRb8OGDcrdv9/pMlAC5pxVQn5+vu644w5t3769sC0lJUX33Xefg1UBAAAvI5xVwpNPPqlvvvnG0vbwww+radOmDlUEAAC8jmHNCpo+fbqmTp1qaRs8eLDOPfdchyoqWevWrYs9JxT/b+fOoKZ9ixapRrNmDhSDcMjOlhYvjtFXX8Vq+fIY/fSTT1nZ4Zldn1DDryZN/Gra1K/Gjc2fTZqY/05JMZP5k5P9lj/j44sm92dlZWnDhg2F369Vq1ZKSEiQ3y9lZZkFBIcO+f5/IYFPBw9K+/b5tH27T2lpPm3fLm3bVnSdmxee/6+UWn517Jivbt3y1bt3vo49Nl+xsWH51nCAb9cuJXbpYmlr1aqVEphzVqLMzExHpwMRzipg1qxZeuyxxyxt/fv31+233+5QRaVLTExUEqsOSxbi51OjWTMltWzpQDGoqL/+kj75RJo1S/rsMxNyKqpFC6lrV+mYY6TDDjPXzZubP+vVq+QqyowMy7yfhBYtCp+jyZLqluNb5edLO3ZIW7ZImzebPzdskH74QVq2TNq1q+zf668D0h/fSR99Jz30vNSokXTeeVK/flKfPiZ0wkNCvK4lJCTwfuByhLNymjt3ru666y75/f7CtrPOOkuPPvqofKx3ByLO75d+/tmEsVmzpIULK7ZTQMuWJogV3Lp0McHEC2JipCZNzK1rV+t9fr+0aZMJaYG3EB3FIe3YIU2dam4JCVKvXiao9evHgj+gqhDOymHx4sUaNWqUcnNzC9t69Oih8ePHK5Z+fyBicnKkBQuKAtlvv5Xv6w8/PDiINWhQJaU6zuczwbNlS+nii02b32961wqC2vLl5s+AtU0hZWVJn35qbiNGSMcfXxTUunQxIRFA5RHOymjlypUaPny4srKyCtuOP/54Pffcc5wEAERAerr00UcmjH36qbR3b9m+zueTTjzRDM2dfLIJFPXrV2mprufzmV6vFi2kCy8sat+61YS0b781P+e1a0v+PitWmNvDD0vNmknnny9dcIEZ/uRlEag4wlkZ/PzzzxoyZIgOHTpU2NahQwdNnjxZycnJDlYGRL/Vq6UXXpBee63s88eSk01AuOACE8oaswNsmTRrZm79+klPPCGtX29C2syZ0jffSAGDBkG2bpUmTTK3xo2lwYOlG24wPXYAyodO6FKsX79egwYN0r59+wrb2rRpo1deeUUpKSkOVgZEr6ws6b//lU47Terc2YSz0oJZs2bS0KHSxx+bRQEzZkiDBhHMKqN1a2nUKGnOHDNH7a23pKuukuqWslohLU0aM0Y64gjTM/fZZ5wYBJQHPWcl2LJliwYOHKhdAUudWrRooalTp6pevXoOVgZEpz//lF56SXrllbJNWO/SxfTyXHCBGa5kTU7VqVNHuvxyc8vNNUOfM2eanrVffw39Nfn55jEzZ0pt2pjwPHBg9M7vA8KFnrNi7NixQwMGDLDs/t+4cWNNmzZNjfkoDoRNXp7p7Tr/fNNT88QTxQezmBjp7LOlF180W0YsWyY99JAJaQSzyImLk844Qxo/Xlq3zqyWffJJM6evOL//Lv3rX2ae27XXSosWmYUJAIIRzkLYu3evBg0apI0bNxa21atXT1OnTtVhhx3mYGVA9NixwwSxtm1NMPv44+LfrJs0ke67z/Ssffqp6YFp3jyi5aIERx0l3XGH2cZk9WqzkrO4WR9ZWWb+4CmnmFA9aVLl9qIDohHhzObAgQMaPHiwfg3op09NTdWUKVPUpk0bBysDosOyZdLVV5tNXe++2wSu4vTsKb3zjrRxo/TII+Zr4G6dOknPP2+26njhBTNnsDg//FAUtG+80SxAAMCcsyDDhw/X6tWrLW0DBgzQnj17tHDhwnJ9r44dO6p27drhLA/wrJ9/Nr1f779f8uNSU6XrrpOGDZM6dIhMbQi/lBTzbzh0qBnCnDhRevddc6SW3f79JtC99JJZ4Xn//aa3FKiuCGc2S5YsCWqbMGFChb7X9OnT1b1798qWBHjapk3S6NFmh/mSVuwdf7w0fLhZDVizZuTqQ9Xy+cwQ5imnSE8/LU2ZYkLYH38EPzY314S4adOkm282Q6V16kS4YMAFGNYEUCX++ku67TbpyCPN6stQwSwhwUwOX7zYDHcOGUIwi2YNG0p33mlOdPjkEzPXMNRCjkOHpMceMwtEnnzSXAPVCeEMQFilp5sd41u3lp56ykwAt6tb17z5btkivfqq1L07qy2rk5gY6ZxzzDYcf/wh3XKLCep2e/aYMHfkkWbhQE5O5GsFnMCwps0vv/zidAmAJ2VlmeGqRx8tfiuM5GTzRnz77QxXwWjVyoT4W24xoX7KlOBe1q1bzdy1cePM79dll3GOJ6Ibv94AKiUvz/R+HXWU2U0+VDCLj5dGjjR7XT36KMEMwQ47TJo8WVqzRrr00tCP+e036YorpG7dzKkD7JOGaEU4A1Ahfr/Z+b1zZ2nAAGnDhuDH+HzSP/5hVmo+9xwr8FC6o482qzq//96cjxrKihVmWPRvf5O++y6y9QGRQDgDUG7bt0v9+5tzE9euDf2Yfv2klSvNhqOtW0e2Pnhft27SF19Is2dLJ5wQ+jHz5plTCW66STp4MLL1AVWJcAagzPx+6Y03zP5jM2aEfsxpp0kLFphetWOOiWh5iEJnnml6xz74QGrfPvh+v1969lnTg/v11xEvD6gShDMAZbJ1q+kp+8c/zCo6u2OPNdsjzJsn9egR+foQvXw+6eKLpVWrzIKBUCdFrF9vhjlHjuQ4KHgf4QxAifx+afp0qWNHs/WBXcOGZuhy+XIzD4gtMVBV4uKkgQPNYetjx0qJicGPmTjR9Nh+9VXk6wPChXAGoFhbtpiNQq+7Ttq7N/j+yy83q+v+8Q+2NkDkJCZK//qXmdN46qnB9//5pxkOHTbMHA0FeA0vpwCC+P3muKWOHc1QpV2jRuaMzLfeMj1ngBPatTPD6M88IyUlBd//0kumF+3LLyNfG1AZhDMAFps2meHJQYOkffuC77/qKrNCs3//yNcG2MXEmNWaq1ZJp58efP/GjdJZZ5kD1UP9PgNuRDgDIMn0lr38sukt+/zz4PubNDErNN94Q6pfP+LlASVq21aaO9fspxfqfNbJk6VOnczmtYDbEc4AaPdu6bzzzMHj6enB9197rZlbduGFka8NKKuYGLNac/Vqs3LTbvNm0ys8fHjoM18BtyCcAdXcqlVmw89PPw2+r1kz6aOPzPFM9epFvjagIo44wmxe+8ILUq1awfe/+KIJb1u3Rr42oCwIZ0A19vbbZof1P/4Ivm/gQNNbdt55ka8LqKyYGLNa88cfpd69g+9ftEjq2lVauDDytQGlIZwB1VBentmK4IorpEOHrPc1aWJWaE6ZwgHl8L5WrcwxUJMmScnJ1vu2b5d69jT3AW5COAOqmd27zbybceOC7zv5ZGnZMnM/EC18PjOfctEiM+QZKCdHGjrUrOZkHhrcgnAGVCMF88tC7fs0ZIhZ7dasWeTrAiKhc2fp+++lPn2C75s8mXlocA/CGVBNvPNO6Pll8fFms85Jk6SEBGdqAyKlfn0zbH/HHcH3LVpkPrwsWhT5uoBAhDMgyuXnS3ffbY5aCjW/7OuvzZAOUF3ExUlPPmlOuLDPQ9u2TTrjDDPnEnAK4QyIYtnZZo+yJ54Ivu+kk8z8slNOiXxdgBtcfrlZrXn44db2nBzp+uulRx4xmzMDkUY4A6JUerrUr5/Z0d9u8GDTY8b8MlR3xx4rLV0aeruNBx6QRowwq5uBSCKcAVEoLc1Mbv7iC2t7bKzZmHPyZOaXAQXq1zebMN9+e/B9L74oXXqplJER+bpQfRHOgCjz++9Sjx5myDJQcrI0a5bZmBOAVVyc2V7muefM1huBZswwh6fv2eNIaaiGCGdAFFm+3Mwh+/13a3uDBmabDPYvA0o2cqRZ2VyjhrV9wQLptNPM+ZxAVSOcAVHiu++kXr2kHTus7YcfLn37rXTiiY6UBXjOpZdKn38upaZa29esMSs5N2xwpi5UH3FOFwCg8r791vSKpadb2487zsyladLEkbLw//x+82+TkyPl5po/DxzwadOmBPl8fsXGSrVrSykpZngtIUGqWTN4eA2R07OnNH++dPbZZnuNAuvXm4D21VdS69aOlYcoRzgDPG7+fBPMDh60tv/tb2aujP3TP8InP1/atcvsKr9tm7mF+u/t20MdDZQoqVOx3zs5WWra1Kyobdq0+P+uU4cQV1U6dzYb0vbtK/3yS1H7hg0moM2dK7Vt61x9iF6EM8DDFiwIHczOPlv63/+kxERn6opGWVnSjz+ahRbLlpn5fatXV915jIcOmbmD9vmDdrVqmR7Srl3NrUsX6eijzcpcVF6rVtK8edKZZ5phzQKbN5sPQF9/LbVp41h5iFKEM8CjCoYy7cGsXz/p3XfZKqMyMjNN8CoIYsuWmWCWk+N0ZcEOHDAhfcGCorbk5ODA1r69GTJF+TVubHrJ+vSRVq4sai8IaPPmBR+oDlQGT1XAg5YtM8HswAFr+4UXhl5phpL5/eZNd9Ys6aOPTK9Ybq7TVVXcoUNm5/uFC4vakpLM2ar9+pkbvT3l07ChmWfWu7e0YkVR+6ZNJqB9+63UvLlz9SG6EM4Aj/n119CT/y+4gGBWHllZpjdk5kwTyDZtqvj38vmkRo2K5oPZ54c1bWp6X5KSTO9VXJyUm5uhdet+kiTl5fnUtu3Rio9PUk6O6Q3dvj30PLaC6927y1djRoYJF199Jd1yi+lJu+ACE9ROOolh0LKoV0/68kszxBnYg7Zhg5lK8M03Ut26ztWH6EE4Azxk61azGebOndb2gqFMglnJdu6UPv7YBLIvvggeEi6LI480w4QFQ4ZHHWWCV3mHDDMypISEgoMb/apTx4S3AqVNNM/KMkFt7Vrr8GtZ9+H66SdzGzvW7IN33nnm9+iss8yqUYRWv740e7YJaKtWFbX/+KP5+X3xRfBh6kB5Ec4Aj9i713w6//NPa3uvXgSzkhw6JL35pjRlill5V56DrNu1KwphXbtKxx9vtrxwg4QEs4fd4YdL555b1L5jhzWsLVtWeq/gX39Jr75qbjVqmOAxZIgJG8xTC9aggQloPXqYnuwC335rDlP/3//4uaFy+PUBPCAjwwxBrV5tbe/SxWyXweT/YD//bM5FnDZN2revbF9zxBEmkJx/vtS9uze3IWnUyAx7B54GsXOn2XLlo4/Mzd7zGig72+yN9+mnZg7VDTdIgwebYVoUadjQ9JKdcop1H7SPPjI/s1deYYsTVBwnBAAul5srXXmleXMN1LateQNlCKpITo703numN7F9e+mZZ0oOZj6fmST/2GMm+P7+u/maPn28GcyK07Ch1L+/6T3cts0sFLj7bqljx5K/bssW6cEHpZYtza75X31Vvp7HaHf44dJnnwX3pk6dan6+QEXRcwa43L/+JX34obWtSRPzqb1RI2dqcpvNm6VJk6SXX7b2YoSSnGw2Fe3Xz8yzqm4/w9hYE0gLQun69aa3Z+ZMsyVEqFWqeXnS+++b21FHScOGSdddx+R3yWxUO2uWmauXmVnUPnas+QA1eLBztcG76DkDXOzVV6Wnn7a21a5tzv1jXyWz5UX//qYH45FHig9mPp8Z5psxw+zo/8EH0sCB1S+YhdK6tXTTTWYO1V9/mV6f7t2Lf/wvv5jVns2bm3lp9jmQ1dFpp0lvvx284nXECOt2JkBZEc4Al1qyRBo61NpWo4bp4ejc2Zma3GLdOjPxumtXM/k6Ly/04xo0MD2Pv/0mffKJ2QeOUxOKV7u2NGCAtHixWUgweHDxKw8zMkxPZbt2JtylpUW0VNe54ALTexsoJ8d8eCjrClqgAOEMcKFt26SLLw4+GujFF6XTT3emJjfYssUE1g4dzJ5uxTnlFOm118wqxbFjOaC6Irp0kSZPNj/zZ54xR0KFkpMjPfus2dT2/vvLvvgiGg0aJN16q7UtLc08lzMynKkJ3kQ4A1wmK8t82t661dp+001mKK462r3b9IC1bWt6J0L1lNWsaYLbDz+YLQ3+8Q96ycKhTh3zu7d2rdm097LLQm8TcfCg9OijJgiPH199w8jYsWZBSaClS83vJospUFaEM8BF/H4zT2XxYmt7r17Sv//tTE1OOnhQGjPGvOGPG2edcF2gTh0zsX3rVtOzeOyxES+zWvD5pJ49TY/lxo3SzTeH3ltv927p9tvNcOfLL3v7GKyKiIuT3nor+His116T/vMfR0qCBxHOABd5/nmz3UGgww83k43j4x0pyRH5+aaHrE0b6b77Qg+VJSVJd91lVhvefXd0bX3hdk2bmoUq69aZOWoxId5JNm82CwY6dTKnMlQn9eqZFda1alnbb7/dHP8ElIZwBrjE3LmmNyJQcrJ5kW/QwJGSHLF+vdmhfujQ0JPM4+LMVg6//SY9/jjbOTipVSuzunP1ajOvKpRffjGb+l5zTfnPA/Wyjh1Nb1mg/HyzkOX3352pCd5BOANc4I8/zFwe+1yqV1+tPisz8/Ol556TjjlG+vrr0I+58kpzHuQLL7BjvZt06GC2J1m8WPrb30I/5vXXzeNmzIhoaY666CLpoYesbXv2mFXD6elOVASvIJwBDsvLM5PXd+2ytt93n9mVvTr47Tfzpv7Pf5qzMO3OPVdasUL6739LPxAczuneXZozx2yQ3LVr8P0FKxevusrsqVYd3H9/cK/imjXBqzqBQIQzwGH/+U/wRpX9+kmjRztSTkTl55ttGjp3lr75Jvj+li3Nhrsffywdd1zEy0MF+HxmteL335v5k6EOin/zTTPs98EHka8v0mJiTA94p07W9pdfNkc/AaEQzgAH/fyzdO+91rY2bcwQUKhJ1tFk3TqzZ9vNN4fedmHYMOnHH82xOPAen89s/bJmjTkmy27HDumSS8wcrJIOYo8GKSlmONe+QGDwYGnvXicqgttF+cs/4F55eWalW+BGsz6fmWAdzSsP/X5pwgSz5cW33wbff/jhZmjshRc41D0aNG9uzp6cPt1se2L3zjtmLpr9/Nho06ZN8HY4W7aYo7AAO8IZ4JDx46XvvrO2jRplzumLVhkZZtXeqFGh9ywbOdKs/OvVK/K1oer4fObffe1ac8yR3V9/FU2ez8+PdHWRc8MNUu/e1rZp06rfViMoHeEMcMDatWaicKAjjzQbrkarzZtN8HzjjeD7Wrc2W4k891zw0A+iR9OmZnjvjTfMXmB2o0eboc5oXcno80mvvBLcIzxkiFnFCRQgnAERlpsrXXedlJ1d1ObzmU/QxR0y7XULF0rdupnDtO1GjZJWrTK7zyP6+XxmteaaNaH3RpsxQzr55OjdC6xlS7OBb6Bt28zzAChAOAMibNw4c9ZeoNtuM4d1R6NXXjHBy76hbEqKNHOmWa1as6YTlcFJTZpI779vVuvGxlrvW7NGOvFEM/cwGg0aJJ19trXttdeif94dyo5wBkTQ6tXSgw9a244+Wnr4YWfqqUo5OWbfssGDzX8HatvWbFjar58ztcEdfD5zqPrnnwef9LB7t9S3rwlv0XZguM8nTZ4cvM3I0KHB+x2ieiKcARGSk2NWZwYGlZgYM5yZlORUVVXjr7/MG+tzzwXfd9ZZ0pIlZoUeIJnjur7/3ux9Figvz2y1cv311lXN0aBFi+CD0NPSzAcagHAGRMgTT0jLl1vb7rjD7KoeTX75RTrhBDPB3+6228zKNM7DhF2bNtKiRWbVpt3UqWZoPNpOFbjuuuA94N58s3pszouSEc6ACFi5UnrkEWtbhw7B5+553apVZmPZP/+0tickmF3S//1vc3A5EEpKipmHZh/6l4rO7dy+PfJ1VRWfT5o0KXj/t2HDon9jXpSMcAZUsdzc4OHM2FgznJmY6FRV4bd0qXnz3LHD2t60qTma6dprnakL3hITYz60vPde8EKRH3+UzjjDbMsSLZo1k5591tq2cyfDm9Udn2GBKvbqq9IPP1jb7rrLDP15Xb4/X7sO7dKS76UrrpAOZEoK2A7k2OOk16ablXk7DzpVpTtlZGZoT1bR5lY7D+1UUn6UTT6shNPPlj6aK119tbR1S1H7us1Sjz7S+x9IXY6urxif9/sYrr7ahNHA1Zpvv2221zj5ZOfqgnN8fn+0rYOBJGVkZGjt2rWF1x06dFBStM06D7edO6VGjSxNGRs2KKllywp/y4wMs7nsloA3l06dTC9TQkKFv61r7Dy4U43+3aj0BwJV4LtLd+jEjg2dLiMstm83CyJ27y5qO+00ad48M/xZYVXwulYdOP0e6v2PHICLPfusNZhJZgPKaAhmkvT90tIfA1SV/v2lDRucriI8mjQJPjVk/nzpk0+cqQfOIpwBVWTPHunxx61tvXsHn63nVUuXSpdf7nQVqM62bDbzHKNlDtrw4VKrVta2u+4yW4qgeiGcAVXkiSekvXuD26LBDz9IffpIB6L0DER4xx9/SL16mSOQvC4hIXhV948/hj6PFtGNBQFAFdi0yexsHujyy6WuXZ2pJ5x+/90Es717ZZn8X2DtiLVqkNwg0mV5TkZmhtb9sq7wut1R7ZSUyLzQ4vx16C91mBh65+JffzU90gsXBu+67zVXXWWOeFu9uqjt/vulv/89ulZ3o2SEM6AKPPSQdUfzuDjp0UcdKyds9u83Ry6VtBlog+QGalgzOiZpV6WMmAztTCjazKphckMW7VTC2rXSlVdKs2YFn9XpJbGxpoc9cHPajRulF16QbrnFuboQWQxrAmG2dq3ZwyzQDTeY8yS9LC/PvPn99JPTlQDGEa2t159+Kt15pzO1hNM555jNnAM9+qi0b58z9SDyCGdAmN1zj5SfX3Rds2bwKiwvuvvu4JVjnI8JJ733ntTQ1kk7frzZW9DLfD5p7Fhr2+7dZrgT1QPhDAijhQutG0lK0q23mmXyXjZ9evAbQ4MG0vTXnKkHkKTDWphzKOPjre033GCei1520knSxRdb2556KjoWPqB0hDMgTPz+4CGVBg2k2293pp5wWbxYGjLE2hYfb94UWx7mTE1AgVNPNfOxAmVnmz3QNm1ypqZweewxc5xVgYwM6eGHnasHkUM4A8Lk44+lBQusbffdJ6WmOlNPOGzeLF10kXmzCzRxotm9HHCD66+Xbr7Z2paWJl14oXTQw8eGHX20NGiQtW3yZGndutCPR/QgnAFhkJdnNosMdPjh0rBhjpQTFocOmTe3tDRr+003SYMHO1MTUJxx46S+fa1tK1ZIAweaXm2veugh6xYaeXnmQx+iG+EMCIMZM6Q1a6xtjzzi3WOa/H7ziX35cmt7nz5mwjXgNnFx0ltvSe3aWdvffTd4Y1cvad7cHIAe6N13WTUd7QhnQBg8/7z1unNns5mkV736qvT229a2I480bXHsjgiXqlNHmjkzeCPa0aPN3EmvuvNOqW5da5t9nh2iC+EMqKS1a6W5c61t//qXdSKvl2zeHPxJvXZt86Znf4MA3Oaoo6R33rE+//LzpQEDzIR6L6pbVxo61Nr26qvSgQPO1IOq59G3D8A9Jk60XjdsKF16qTO1VJbfb1Zm7t9vbX/1VTM5GfCCs84KXtX4yy/e3m9w2DCz/1mB/ful1193rh5ULcIZUAnp6WYPsECDB3t3rtmUKdJnn1nbrr3WLAwAvOTOO6UTTrC2PfWU9O23ztRTWa1aSeefb217/nlvL3ZA8QhnQCW8/roJaAViYry7QnPjxuCz+5o1k/7zH0fKASolLs4coxb4QcnvN8Obhw45VVXljBxpvf7xx+DtexAdCGdABfn9wQsB+vWTWrZ0pp7K8PvNXlGBQVOSJk1inhm8q0OH4JWav/0m3XuvM/VUVp8+wWf02l+DEB0IZ0AFffNN8PYZI0Y4U0tlTZokzZ5tbRs4UDrvPGfqAcLl1lvNUUiBnnnGPH+9JiZGGj7c2vb++xzpFI0IZ0AF2T+xHnmk1Lu3M7VUxp9/Bh8x1aKFmZ8DeF1srBneDNzI1e83Hz68eHrAwIFSUlLRdW6uOTUA0YVwBlTA1q3S//5nbRsxwnvbZxQMZ9qX5L/8stkzCogGRx0ljRljbVu/Xrr7bmfqqYy6dYP3UHzpJSknx5l6UDU89lYCuMPkyeYTa4GkJDPR2Gs++ED66itr2+DBwcfgAF43apTUo4e17fnng6cmeIF9+sTWrWYfQkQPwhlQTjk55pNqoKuv9l5PU26udM891rbDDuN4JkSn2Fhp6lTrkGB+fvBzwAu6dAmeR8fCgOhCOAPKacaM4Am49iXuXjBlirRunbVt/HgpNdWZeoCqduSR5vSOQDNnenPvM/trzty55rQSRAfCGVBO9hMBTjlFOu44R0qpsEOHpIcesrZ16+bdkw2AsrrtNnOKR6A77/TeZq6XXSY1aGBt47zN6EE4A8rhjz+kr7+2tnlx+4xnngnu/Rs71no8DBCNUlKCj3H69ltp1ixn6qmohAQzPzTQa69J2dnO1IPwIpwB5WCfdFu/vvd6m3btkp54wtp21llSr17O1ANE2tCh0hFHWNvuvlvKy3Omnoqyn0ayb580f74ztSC8CGdAOdjDWb9+3jtH8/HHgw82t4c1IJrVqBF8csDatcHn5Lpdq1ZmOkIgVm1GB8IZUEZ79kjz5lnbvHYg+MaN0rPPWtuuuko6/nhn6gGccuWV0rHHWtseeEDKyHCmnoqyvwZ9+KH35s8hGOEMKKNPP7UOeyQkmLPuvOTBB61zUuLjg3sQgOogJia4x3jzZu9tSXHBBdbrDRuk1audqQXhQzgDysg+XNC7t1SzpjO1VMS6ddKrr1rbhg2TWrd2ph7AaX37Sn/7m7Xtsce8dazTMceY4c1ADG16H+EMKIPsbNNzFshrQ5oTJ1qHO2rVku67z7l6AKf5fMG9Z3v2SP/9rzP1VITPF3poE95GOAPKYN684En055/vTC0VcfCgOfw50PDhUqNGjpQDuMaJJ0rnnmtte/55b83bsg9tLl0qbdniTC0ID8IZUAb2YYITT5SaNnWmlop44w2zzL6Az2fCGYDg3fZXrpQWLXKmloo4/XSpdm1rm9f2bYMV4Qwohd8fHM68NKTp9wdPcj733OB9noDq6uyzg58PXloYEB8f3PvHvDNvI5wBpVi1ymxBEcg+jOBmCxea/4dAXjwLFKgqMTHBPcnvviulpTlTT0XYX5PmzJEOHHCmFlQe4QwohX1y7RFHSB07OlNLRdh7AFq3NqvUABQZNEhKTCy6zsmRXnnFuXrK6+yzpbi4ouvsbOnzz52rB5VDOANKEWpI0ytnUKalSe+9Z20bPtz0FAAoUr++dMUV1rYXX5Ryc52pp7zq1JF69rS2MbTpXbxEAyXYtk1atsza5qUhzcmTTQ9AgcRE00MAIJh9uH/TJumjj5yppSLsr00ff+ydcAkrwhlQgjlzYi3XdepIp57qTC3llZsrvfSSte3KK6V69ZypB3C7bt3MSuxAEyc6U0tF2MPZrl1mWw14D+EMKMHSpdanyLnnmpVRXvDZZ+Y4mkAsBABKNmKE9frLL6X1652ppbxatZI6d7a2ffedM7WgcghnQAlWrbI+RbzSayZJM2ZYr084Qera1ZFSAM+4/HIz/yyQl+Zu2V+jVq50pg5UDuEMKMHvv1tn/nsl3OTlBW9CaZ/sDCBYYqK3j0Oyv0YRzryJcAaUwK+icBYXFzxk4FZLlkg7dljbvLRxLuAk+3Nl/nxp925naimvbt2s1xs3OVMHKodwBpRRp07WfZDczP5Jv0MHqU0bZ2oBvKZ3b+tzPS9P+uQT5+opjw4dvPM6heIRzoAysn8idTMvHzcFOC05WerTx9rmlXlncXHSccc5XQUqi3AGlJFX5pv9+qv000/WNi/tzQa4gf0589lnUlaWM7WUl5c+SCI0whlQRl55wbN/wm/cOHjvJgAl69fPehJIerr09deOlVMuXvkgieIRzoAyiI+XjjnG6SrKxh7O+vXjuCagvBo3lrp3t7Z5ZWjTKx8kUTxesoEyOOYYKSHB6SpKt2uXtGCBtY0hTaBi7M+dmTMlv9+ZWsrj6KOlpCSnq0BlEM6AMvDKMMEnn0j5+UXXSUnSmWc6Vw/gZfaFNJs3SytWOFNLecTFSccf73QVqAzCGVAGXhkmsPea9eljVp4BKL/27aXWra1t337rTC3l5ZUPlAiNcAaUgVde6JYts1576bgpwG18vuDnkP055lZe+UCJ0AhnQClq1DAb0LpdVpa0apW1zSuhEnAr+3PIK+GM5763Ec6AUnhlMcCPP0o5Oda2Ll2cqQWIFvYeqLVrpYMHnamlPI4+mikNXkY4A0px7LFOV1A29k/0bdtKdeo4UgoQNY47zroVTX6+Nw4Tj431zvY/CEY4A0rRsqXTFZTN0qXWa+acAJWXnGzOqwxkf665lVdeuxCMcAaUokULpysoG3vPGeEMCA/7c8kr88688tqFYIQzoBReeIHLypJWr7a2MSEYCA/7c8krPWfNmztdASqKcAaUwgsvcKtXsxgAqCr2nrOff5YOHHCmlvLwwgdLhEY4A0rhhRc4+yf5du2k1FRnagGizbHHmgn2BfLzpR9+cKycMvPCaxdCI5wBJaiZ7Fft2k5XUTr76jHmmwHhk5QkdexobfPCik0v9PojtDinC/CajRs3atWqVdq+fbtycnKUmpqq1q1bq0uXLkrwwmZYKJcmTfzy+ZyuonSbN1uvjzrKmTqAaHX00dZNnu3POTdq1szpClBRhLMymj17tiZOnKg1a9aEvD85OVn9+/fXyJEjVa9evQhXh6rSpInf6RLKZOtW6zUvykB4NW1qvbY/59yoRg2pUUNJO52uBOXFsGYpsrOzdfvtt2vkyJHFBjNJOnTokF5//XWdd955+v777yNYIapS06beCGfbtlmvCWdAeNmfU/bnnFs1aeJ0BagIwlkJ8vPzdfPNN2vWrFmW9tjYWLVo0ULt27dXSkqK5b7du3dryJAhWrFiRSRLRRXxQs9ZXp6UlmZts3/KB1A59nDmhZ4ziQ9qXkU4K8HLL7+sOXPmWNquuOIKzZ07V3PmzNGMGTO0ZMkSPffcc2oW8AzIyMjQzTffrPT09EiXjDBr3Nj94WzHDrN6LBAvyEB42T/w0HOGqkQ4K8aePXv04osvWtpuu+02jR49Wo0bNy5si4mJUZ8+ffTWW2+pecDSmO3bt2vq1KkRqxdVwwvbUdg/wcfGSg0bOlMLEK3sH3h275YyM52ppTy88BqGYISzYrz88ss6ePBg4fUJJ5ygIUOGFPv4xo0ba8yYMZa2adOmac+ePVVWI6pezZru7zmzf4Jv0sR6UDOAygs1VWD79sjXUV61ajldASqCl/AQ8vPz9cEHH1jabrzxRvlK2VPh5JNPVreADaYOHjyoTz/9tEpqRGR44YXN3nPGfDMg/GrXNvudBfLCvDMvvIYhGOEshOXLl2v37t2F14cddpi6d+9epq+99NJLLdf2OWvwluRk9/ecsY0GUPV8Pm8uCqhZ0+kKUBGEsxDmzZtnuT7llFNK7TULfGyg7777TocOHQpbbag6ubnBbV741Gkf1qTnDKgaXlwUUNMDr2EIRjgL4aeffrJcdynHCdKNGze2LAzIycnRb7/9FrbaUHUCphgW8sKcs522DSYD1qsACCP7ykf7c8+NatFz5kmEsxDWr19vuW7Tpk25vr5t27Ylfj+404EDwW1eGBLIybFeJyY6UwcQ7ewn9Nmfe27khd5/BCOc2WRmZmqrbSJB03KOEzWxfbz6448/Kl0Xql5WVnCbF45LtQ/Hxsc7UwcQ7ezPrVBTIdyGD2veRDiz2bNnj/z+oqGs+Ph41a9fv1zfo7FtXGnXrl1hqQ1Vyx9iBDM2NvJ1lJf903scJ+YCVcL+3PJCzxnb6ngTL+M29sn7iYmJZV4MUCA5ObnE7+mETC/sluiwQ4eCf0Y5OVnKyMhwoJqyy86uIakoRfr92crIyIvI352RGfyzycjMUEaMu39mbmB/TvIcLZk7ftfiFfi2mZmZq4wMdye0nJzg36usrCzJ5a9rTnP6+Ug4szlomxWeUIFxLfvXuCGcMe+tdJvXH9IxtraNGzco78B+R+opq/37j5JUNLFkx45tWrv2r4j83XuygjdZXvfLOu1M8MBMaZfhOVoyN/yu7d9/mKRGhdc7duzR2rUbI/b3V8SmjYdkX9K2YcMG5e539+tadUeHp012drblOr4CE3hq1KhhuXY6gaOMytdB6ho+n/tXlALRwD71gSFDVBV+tWzswSqnApMK7AGvIr1viLyYECHHfqC4G8XFWevOzfVoygRczv7csj/33Cg/n9cDL2JY06ambe+ErFBL+Eph/xr7HDQntG7dWoks2ylR0oHgocDDDmulWke0cKCasqtd2/qBomHDJurQITInn+88tFP60trW7qh2apjMyeulyczMtAxl8hwtmRt+11JSrCMpjRrVU4cOKRH7+ysiPy34da1Vq1ZKaOHu1zWn2Z+fkUY4s7EHqczMTPn9/nItCrDPMXNDOEtMTFSS/WA4WCQlBb8xxsUluP7nZuvslVQj6AzAqpKUH/wXJSUmuf5n5kY8R0vmxt+1xMQ4JSW5+200Pj74dS0hwf2va9Udw5o2devWtQSxnJyccm+FkZaWZrku71YccEaoDO2FBU1e3HsJ8CIv7inogvVoqADCmU1iYqKa2U63tW9KW5pttgPXWrduXem6UPVCnQZw8KD752vYR8LS052pA4h29ueWF0ahQ518AvcjnIVwxBFHWK5///33cn29/fGEM28I1XPmhRc2+3l/XjiMGfAi+3PL/txzIy+8hiEY4SyE9u3bW65XrFhR5q/dsWOHtmzZUngdHx9f7rM54YxQy+K90HNm6+hVOTt6AZSR/bllf+65EeHMmwhnIfTs2dNyvXDhQsuRTiX59ttvLdfdu3cPWgEK7/DCC5v9DYKeMyD88vIk23RiwhmqDOEshC5duqhu3bqF15s2bdJ3331Xpq997733LNe9evUKa22ILC9Mpm3a1HpNzxkQfjt3moAWyP7ccyPboTfwCMJZCDExMbr44ostbc8//3ypvWeLFi3S0qVLC69r1qypc845p0pqRGQcOOC9Yc3du6UKbM8HoAT2Dz2xsVJDD2znR8+ZNxHOijFkyBDL/mRLlizR5MmTi318Wlqa7r33Xkvbtddeq3r16lVZjah6e/a4P5yF+vTO0CYQXvbnVOPGJqC53Z7gI0nhAYSzYtSrV0/Dhg2ztI0fP14PPfSQZR+z/Px8zZ49W1dccYVlIUCjRo00aNCgiNWLqpGW5v5wVqdO8JJ+whkQXl5cDCDxWuBV7t7a2GFDhgzRihUrNHfu3MK2N998U++8846aNWumlJQUbd68Wfv377d8XWJiov7zn/8oNTU10iUjzLzwwubzmd6zP/4oamPeGRBe9ueUF+abSbwWeBU9ZyWIiYnRM888o/POO8/SnpeXp02bNmnt2rVBwaxOnTqaNGmSunbtGslSUUW2bXN/z5nEik2gqtmfU17pOSOceRPhrBQJCQl66qmnNGHChKD9zwIlJyfrqquu0ieffKLu3btHsEJUJa+Gs82bnakDiFb255QXwtn+/dIBVmt6EsOaZdS3b1/17dtXGzZs0MqVK5WWlqacnBylpqaqTZs26tKlixISEpwuE2G2Y4dPeXnun/hrO9RCq1Y5UwcQrezPqcMPd6SMcgmYBg2PIZyVU6tWrdSqVSuny0CE5Ob5tGOH++eX2EfRly6V/H4zHw1A5aSlSZs2Wdu6dXOmlvKgB927GNYESuGFFzh7ONu5M/jNBEDFLFtmva5ZUzrqKGdqKQ96zryLcAaUwgvhrHVrs6VGIPsbCoCKsT+XjjvO/VMdJG+8diE0whlQCi98+vT5Qg9tAqg8+3PJC0OaEuHMywhnQCm88gJnD2f0nAHhYX8ueWWnJC98sERohDOgFL//7nQFZWP/NF+wKABAxW3fHhxyvNJztn690xWgoghnQCmWL3e6grKxf5rftUvauNGZWoBoEWoxQLt2ztRSHgcOSD//7HQVqCjCGVCK9eul3budrqJ0Rxwh1a1rbWPeGVA59udQly7eWAzwww9Sfr7TVaCiCGdAGXih94xFAUD4eXW+GXNOvY1wBpSBV0KOfS7M7NnO1AFEg+xsad48a5tXwplXXrMQGuEMKAOvfAo980zr9dKlrNgCKmrePHM+ZaBevZyppby88pqF0AhnQBl45VPoGWdItWtb2z76yJlaAK+bOdN6feKJ3jjwPD2dxQBeRzgDyuDPP83qR7eLj5fOOcfa9uGHztQCeJnfHxzOLrjAmVrK64cf2EbH6whnQBl5ZZjgwgut13PmmGX1AMpu5crgrWjszy238kpPP4pHOAPKyCvh7Oyzpbi4ouvsbOmLL5yrB/Aie6/ZEUdIHTs6U0t5Ec68j3AGlJFXwlmdOmbuWSCGNoHyCTWk6fM5U0t5eeW1CsUjnAFl5KVPo/bhl48/lnJznakF8JrNm4MDjleGNPfvl375xekqUFmEM6CMNmyQ/vrL6SrKpl8/6/WuXdKiRc7UAnjNrFnW6zp1pFNPdaSUcluxwnod54HTDBCMcAaUICnRuuTJK8MFhx8ude5sbWNoEygb+5DmueealdBeYO/hb9/emTpQOYQzoAQdOlgPp/Py0Obrr5vFAQCKt3mz9OWX1javDGlKwR8gjz3WmTpQOYQzoASdO1t7zrx0HNJll1mv09Kk//3PmVoAr5g0ScrLK7quWdOsgPaCvDyzdU4gwpk3Ec6AEvTokWe5nj9f2r3boWLK6ZhjgufJPP+8M7UAXpCdbcJZoGuukVJTnamnvJYskXbssLadfroztaByCGdACU47LV+JiUXXeXnSp586V095jRxpvZ4/X1q92plaALf74APTwxxoxAhnaqkI+1y5Dh2k1q2dqQWVQzgDSpCUJPXpY23z0sT6/v2lxo2tbRMnOlML4Hb2nuXTTjM90F5hf23yynFTCEY4A0phf4H77DMpK8uZWsqrRg1pyBBr22uvSfv2OVMP4FarVkkLFljb7D3Pbvbrr9JPP1nbvLSQAVaEM6AU/fpZdwZPT5fmzXOunvIaOlSKDdjr6OBBafp05+oB3Mjeo9ykiXTxxc7UUhH2vdkaNZJOPNGZWlB5hDOgFI0bS927W9u8NLTZokXwJ+iJEyW/P/Tjgepm3z6z1UygIUNMz7NX2F+T+vWTYniH9yz+6YAysA9tzpzprXBjH575+Wdp7lxnagHc5tVXTY9ygdhY0+PsFbt2BQ/JMqTpbYQzoAzsL3SbN0s//OBIKRXyt79JRx9tbXvmGWdqAdwkNzd4IcBFF0nNmztSToV88omUH7BfdlKSdOaZztWDyiOcAWXQvr3Upo21zUtDmz5f8JYAM2dKixc7Uw/gFtOnS+vWWdu8tH2GFPxa1KePlJzsTC0ID8IZUAY+X+ihTS+57jqpfn1r2513emt4FginjAzpgQesbccdZ3qavSIz06wgD8SQpvcRzoAysoezFSukTZucqaUiUlOle+6xtn3zjbc21QXC6bnnpC1brG1jx1pXZ7vd119b58v5fNJ55zlWDsKEcAaU0amnSnXrWtu81ns2YoTUsqW17a67rGcJAtXBnj3SY49Z23r1Ct502u3sQ5onnRS88TS8h3AGlFFcXPAnUq+Fs8RE6eGHrW2rV0v//a8z9QBOGTtW2rvX2vbEE97qNfP7g1+DGNKMDoQzoBzsQ5tffSVt3epMLRX1j39InTpZ2+6/3zunHgCVtXlz8Grlyy6TTjjBmXoqat684NcfjmyKDoQzoBzOPtssUy+Qmyu9/LJz9VREbKz0+OPWtg0bpBdecKYeINJGjzYT6QvExkpjxjhXT0XZTzU4+ujgLXPgTYQzoBxSUqSrr7a2vfSSlJPjTD0Vdd555lDnQI8+ypmbiH4//SRNmWJtu+EG6cgjnamnorZulf73P2vbsGHeGpZF8QhnQDnZ90DautVbe55J5gV87Fhr265d0pNPOlMPECl3323dsDU5OXg7DS+YNMn03BdITjbb5SA6EM6Acjr+eOnkk61t9uEFLzj5ZLMTeqBx46SVKx0pB6hy770X/EHq1lvNIedekpNjwlmgq6+W6tRxpBxUAcIZUAH2syrnzpXWrnWmlsp47DEz36ZATo40YICUne1YSUCV2LFDGj7c2taggXTHHc7UUxkzZkjbtlnb7K9J8DbCGVABl14qNWxobfNi71n79uaUgEA//BC8/xPgZX6/mY7w11/W9gkTzObMXmM/C7RHD+nYY52pBVWDcAZUQEKCNHiwtW36dCk93Zl6KuOBB4K31hgzxpyAAESDd96R3n/f2nbxxdIVVzhTT2WsWWO20AjktbNAUTrCGVBBw4ZJMQHPoPR06fXXnaunohISpGnTrMObublmcjHDm/C6tLTgIb/69c3WMV5c2WjvoW/USLrkEmdqQdUhnAEV1LKl1K+fte355715kHjXrsHnbq5eLT3yiDP1AOHg95t5Zrt2WdsnTvTmEUf795se+kBDhpgPWIguhDOgEuyfyNeskebPd6aWyrrvPqlzZ2vb449LS5c6Uw9QWW++GbwX2KWXSn//uzP1VNbrr0sHDhRdx8RIQ4c6Vw+qDuEMqIQzzwzevNI+WdcratSQXn3VnCFaIC/PrN7kaCd4zbZt0o03WtsaNvTmwh3J9ALaX1suuEA67DBn6kHVIpwBlRATEzwZ94MPgpe5e8Vxx5lzNgOtWWM27gS8Ii9PGjRI2rPH2v7CC8GrrL1i3rzg7XrYPiN6Ec6AShowwOzOXSA31xzp5FV332022g309NOmVw3wgrvvlj77zNp2xRXenjhv7zU76ijTc4/oRDgDKqlOneDzNp95JvhTu1fEx5vVm/Hx1vYbbpAWLXKkJKDMpk83J10EatRIevZZZ+oJh1WrgrcCGTHCm6tNUTaEMyAM7HNb9u6VnnjCkVLConNnMwQUKDvb7A21aZMzNQGlWbzYrF4MFBcnvfuuOQ3Aq+6+27oKPCVFuvZa5+pB1SOcAWHQubN0+eXWtgkTpM2bnaknHK6/Xho1ytqWliZdeKF08KAzNQHF2bzZnBVr35tv4kTp9NMdKSks5s2TPvnE2vavf3GOZrQjnAFh8uij1pWOmZnSQw85Vk5Y/PvfUp8+1rYVK6SBA725nxui06FD5kNDWpq1/Z//DO5J8xK/P/h4tcaNpVtucaYeRA7hDAiTtm3NvKxAU6d680D0AnFx0ttvS+3aWdvffZcNauEOfr9Zmbl8ubW9d2/pqaecqSlc/vc/6bvvrG0PPijVrOlMPYgcwhkQRvffb33hzM+X7r3XuXrCoW5daeZMqXZta/uDD0qzPnKmJqDAmDHmA0Sgtm1NW2BPttfk5gaf2tG2bfCZvohOhDMgjJo0kW691do2Y4a0cKEj5YTNUUeZN7sY2yvGjeyzBAfNnBm8L19qqjRrllSvnjM1hcvUqdIvv1jbxowJXkWN6EQ4A8Ls9tuDV4bddZf352j17SuNH29ty8hwphZAkoYNt17HxEhvvSUdfbQz9YTLoUPB81W7djVHT6F6IJwBYZaaas6pDDR/vvTxx87UE06jRpn5PYAb5OZYr8eNk845x5lawmnCBGnrVmvb2LHBPdeIXh4ekQfca9gw6T//kf78s6jt7rvNG0dsrFNVVZ7PZ7Ym2LhRmj079GP+OvRXZIvyqIzMDO3JKtqpeOehnUrKT3KwIncr7fdq2LDoWMW4e3fwHol9+nAaQHVDOAOqQEKCWc14zTVFbT/+KL3+unTddc7VFQ4JCdKHH5qg+c3S4Ps7TOwQ+aKiwZdOF+BdAwea442iYcf8xx+X9u2ztnl5Q2tUDJ2kQBW56irp2GOtbQ88YPY/87rkZOmjj6Ru3ZyuBNXd1VdLkydHx5Dfpk3Bx0xdcYXUpYsz9cA5UfDrDLhTTIz5FBxo48bgA4y9KiXFTL4GnHLBBeYcWC9PFQj04INSVlbRdVyc2dwa1Q/hDKhCZ58t9expbXvoIWnDBieqCb/UVKcrQHX2wgve3sss0Lx5ZvuMQEOHSm3aOFMPnBUlv9aAO/l8Zr7ISScVtR04YFY8fvml94di6ifX147bdyg93Qzj2nczT0oywzQXXOBMfW6WkZmhdb+sK7xud1Q7JSWyIKCA3y899/z/n0Rh24bmssukZ56RGqfWd6S2cDtwwMybC1SzZvAebqg+CGdAFeve3ezq/fLLRW1ffSW99JI0fHjxX+cFMb4YNazZUA1rSnNmmRD21VdF92cckgZfZbYWGT3a+2E0nDJiMrQzYWfhdcPkhkpKIpxJZp+vwUOkN98Mvu+GG0yPWTT9Lt15p/THH9a2Rx4x52iieoqiX2/AvcaPlw47zNp2xx3S+vXO1FMVatY0iwTOPTf4vkcflS66SNq/P+JlwWM2bpROOy10MBs1SnrxxegKZnPmmO1pAp12mvl/RfUVRb/igHulpkpTpljbDh40w5v5+c7UVBWSksxhzaHO/5s1Szr5ZOm33yJfF7xhwQLphBOCDzEvmB7w9NPRsV1Ggf37gzd1Tk42rxXRFEBRfvzzAxHSu7eZ4Bto3rzoWb1ZoEYNadIk6bnnglfRrV1r3ny/+MKZ2uBekydLvXpJO3ZY2wvOyrzzzugKZpLpPd+40do2dqw54BzVG+EMiKBx46RWraxtd90Vfb1JPp80cqRZ9FDfNmd7716zge3TT3v/vFFUXk6O+V254Qbz34HatTOLTM47z5naqtIXX5gPMYF69pRGjHCkHLgM4QyIoJSU4OHNQ4fMSq1oGt4s8Le/Sd9/Lx1zjLU9P1+69VZpwAAzvIvqaft2czSRfc6VZLah+e477x9iHsq+fcFD/zVrMpyJIvwaABHWq5fpKQi0YIE57DgaHXGEtHCh1L9/8H3Tp0udO5vhXVQffr/0xhtSx46h/+3vuMMsLqlTJ+KlRcRtt5nTAAKNG2eeK4BEOAMc8cQTUuvW1ra775bWrQv9eK+rVUt6913p4YeD71u/3gzn3Hij2e8J0W3bNrNy9x//MId8B0pMNOfPPvlk9Oz6b/fpp9Irr1jbzjwzeD4qqjfCGeCAWrWChzczM80wX16eIyVVuZgYs6nm//5n/v/tnn/eDH8G7pOG6OH3m57SDh2kmTOD72/eXJo/35yVGa327AkezqxVy4Q1hjMRiF8HwCFnnCHddJO1bdEiM1E+ml10kbRsmdSjR/B9f/5pehGGD5fS0yNdGarKli1Sv37SddeZBSF2f/+7tGKF1K1bxEuLqFtukbZutbY99VTwIiGAcAY46LHHgpfN33efCS/RrF07M9fo6afN3mh2L74odeokzZ4d+doQPn6/OS+yY0fp44+D72/USHrvPentt6WGDSNfXyS984706qvWtrPOCr0nIEA4AxxUs6Z58wrcvykry/QupaU5VlZExMZKN98srVpldkS327jRrOQbPNis6oO3/PyzOS1i0CCzOtHuyiulNWukSy6JfG2R9sMPwWdnpqaaI92ibe82hAfhDHDYqaeabSUCbd4sXXqplJ3tTE2R1Lat9PXX5oD05OTg+195RWrTxvQohnqTh7ts2mQCdceO0mefBd/fuLGZd/jf/0oNGkS+vkjbudN82Dp0yNr+n/8EH+kGFCCcAS7w2GPS6adb2xYsqD7n68XEmNWaq1ebvdHsDh2SxowxK1zHjZMyMiJfI0q2a5d0++3SkUeaQB1q375//MOcEnHRRREvzxE5OWY+3YYN1vYhQ8ziH6A4hDPABWrUMFtN2D9Jv/iiuVUXrVubeWYvvBB6Refu3dK//mUCwOTJUm5u5GuE1YED0iOPmH+78ePNsLxd06ZmheZrr0n16kW+RqfceqvpFQ50yinmaDOGM1ESwhngEo0aSTNmBE+Q/+c/zRYD1UVMjDRsmPTTT9L114feYmDLFnPcT8eOJtRG4+kKbpeVZYai27SRHnjAHOJtl5ws3XOP6S3r1y/yNTrplVdMCAvUvLn0/vvmwxhQEsIZ4CJdugTvf5abayZN2w9IjnYtWpgJ02vWmPl3oaxbZ4aNTjjBrPirDnP0nJaebno2jz7abAVjP6hckuLizBmRv/1mhqOjdaf/4ixcaLaDCZSQYD58NWniSEnwGMIZ4DJXXCHdeae1bedO6eKLgycVVwdHH216x5YskXr3Dv2Y5cvNz61lS7NwoLoF2UhYvdoErmbNzJ9//hn8GJ/PbCL7889mU+GmTSNepuM2bzZHldkPcZ88Ofr3cUP4EM4AFxozRjrnHGvb8uVmFZzf70xNTjvhBOnLL82tuDe5tDTzszviCOmCC8xqQYY8Ky4ry6yqPPVUcwbqCy8Uf8TWeeeZjWRff90MdVZHmZkmmNm3wbn1Vumaa5ypCd5EOANcKDbWvCm2a2dtf/NN6cEHnanJLXr3Nr1o770nHXVU6Mfk50uzZpmAe+SR5qzGv/6KbJ1e9scf0l13mQUqV18tfftt8Y/t0cPMifzoI+nYYyNXo9vk5ZnVqN9/b23v00caO9aZmuBdhDPAperUkT780GxWGeiRR8xE7OrM5zPz8H780YTYUJvYFli/3gwTt2hhgsYHH3DAeig7d5od7M87z/R8jR1r2kKJiZEuvFD64gsTzE49NbK1uo3fL40caSb7B2rdWnrrLTMHDygPwhngYkcfLb3xRvCKxVGjzAT46i4uzuw0/803RXOiUlJCP7ZgiO6SS6T69U2v2sSJZtPU6sjvN6sox4414apJE7P31iefFD903qSJmdP3559mcnufPmwJIUkPPSS99JK1LSXFfLiqTluHIHwIZ4DLnX++mesTyO83c1i+/NKZmtyoUyczCX3LFrM3XOfOxT82O9vMRxs50iwiOP54sx3E0qXRPUctJ0f66itzAPeRR5qtSO66ywxblvT//be/mbMhN240PbfsbF9k4kTp4YetbTVqmPDaqZMjJSEK0NkKeMANN5gtC+6/v6gtJ8es4Pz6a1aBBUpJkYYONT+zRYtMsH3nnZK32fjhB3N75BGzwvC886STT5a6dpU6dJDi4yNVfXhlZEgrV0rLlpkTJz79tOxHYNWuLV13ndlzrn37qq3Tq955x5xsEcjnM73dvXo5UxOiA+EM8Ih77zWrwAI3tjx40AzPzZ9vhkBRxOczu7Gfcor01FNmMcXMmdK8eSWfLLBtm9lf7eWXzXVCgpno3rVr0a1jR/cFtkOHioJYwW3tWjNRvaySk6WzzjLzyS67TKpZs+rq9bovvzQLAOxDwBMnFr8vH1BWhDPAI3w+6ZlnzKrDt94qav/rLzPs9PXXxa9erO4aNjQbpt50k+k5+uwzs5rzk0+kPXtK/tqsLLM6dMmSorYaNcywadeu5mfetKm5NWtm/gx19FRl+f3S3r0mPAbe1qwpCmIVGZJt3tzs3n/BBeb3KDEx7KVHnTlzzM/LvpfZ6NGmpxGoLMIZ4CExMWZF3a5d1vlm27cXBTT79huwql1buvxyc8vNNfOtZs0yt3XryvY9srPN/LSlS0PfX6tWUWArCG2NG5vgEx9vFjLk58dqx4568vul3FyfFi6MVUyMqengweAQtm2b2UcrHLp2LQpkxx3HpP7ymDvX/Ozs/xYjR1qnHQCVQTgDPKZGDbMdRJ8+0uLFRe3btpmA9tVX9KCVVVycdMYZ5vbvf0u//GL261q82PRG/fFHxb7vgQPSr7+aW/FqSDqiYn9BOfh8Zsi7a1ezKvP8801vGcpv7lzz88vIsLZfeaXp1SbkIlwIZ4AH1aplhubOOss63LZ1q9Szpxl26dDBsfI866ijrMF2925zMkPgPK71652rrzQxMWbyfsHcuC5dTM9YVQyzVjdffGHm4tl7zP7+d2n6dLNxNBAuhDPAo2rXlj7/3PSgBQ6vbd9eFNCOOcax8qJCvXrmRILAMz337DHHFC1bZibgb9liei23bjWHgkeqroIh08MOM1uBdO1qFi4wiT/8PvnEHMuUlWVtv+QSc1wVm8wi3PiVAjysTh3zib5vX+uxMTt3SqefboboevRwrLyoVLeu2SYh1FYJgXPFtm61zhfbscNMIM/NNbesrHylp2cqJsav2FgpJSVRCQmxioszK0QbNw5eaNC0qdkIlkn7kfPGG2ZzXvsK30suMSuA3bZqF9GBcAZ4XN26ZnHAOeeYfb0K7N1renzefFO66CKnqqteataU2rY1t9JkZGRp7dqfCq87dOigpKSkKqwO5TV+vHT77cHtV15phjLpMUNV4YQAIAoUDHHaz5jMzDSf8CdNcqYuwIvy86XbbgsdzK69VnrtNYIZqhbhDIgSKSlmkUC/ftb2/HyzY/7o0cWfmQjAyM42m8s+9VTwfTffLE2dyuR/VD3CGRBFkpPNNhuDBwff99BDZoPMknbHB6qz9HRzdNebbwbfN26cCWwxvGsiAvg1A6JMXJwZxgy1IeakSdK555otIgAU+e03c57q7NnW9rg4M4x5++3sY4bIIZwBUcjnkx5+2JzzZ39D+fJLc1D6qlXO1Aa4zaefSiecYI7CClSzplnx/I9/OFMXqi/CGRDFhg+X3nvPbM0Q6I8/TC/B2287UxfgBn6/9NhjZihz717rfQ0bmuPQ+vZ1ojJUd4QzIMr172+OnWna1Np+6JB0xRXSv/4l5eU5UxvglAMHpMsuk+69N3ihzDHHmCO8unVzpjaAcAZUAyefbE4ROPnk4PvGjTN7pDEPDdXFb79JJ50kvf9+8H1//7vZL7B168jXBRQgnAHVRLNmpgfthhuC72MeGqqL4uaXxcRIY8dKb73FEVhwHuEMqEYSEqSXXjI3+7EzzENDNPP7pccfDz2/rG5dE9r+9S9WZMIdCGdANXTDDWayc5Mm1vaCeWiDBgW/gQFetWGDdNZZ0j33hJ5f9v335n7ALQhnQDV1yinSsmVm7o3d1KlSx45mGwHAq/LzpRdekDp1Ct6/TDILAhYtktq0iXxtQEkIZ0A11qyZ6UELdaLA1q3mKKhrr2WxALznjz+k3r2lESPMysxAPp/0xBNmCJ/5ZXAjwhlQzSUkSJMnS6+8Ys7ntHvtNdOL9uGHka8NKK/8fOm558xw5dy5wfe3aCF9/rl0553ML4N7Ec4ASDLzzH78MfSmm9u3SxddJF19tbRrV8RLA8rk99+lv/1N+uc/pYMHg+8fPNj8jvfpE/nagPIgnAEo1LKlWbX2yitS7drB9//3v1KHDuZwdcAt8vOlZ54xvWXffBN8f8uWprds8uTQv9eA2xDOAFj4fEW9aOeeG3z/jh3SJZeYVZ07d0a+PiDQunXS6adLN98sZWQE3z9smLR6Nasx4S2EMwAhtWhhVmu++qpUp07w/W+/beaivftuxEsDlJcnPfWUdOyx0rffBt9/+OFmheYLL0ipqREvD6gUwhmAYvl8ZrXmmjVm5abdzp3muJsLLgjecR2oKvPmma1gbrtNyswMvn/kSNNbduaZka8NCAfCGYBSNWtmVmu+/rpUr17w/bNmmfk+AwZIf/4Z6epQXSxfLp19ttSzp7RkSfD9rVubFZrPPSfVqhXx8oCwIZwBKBOfz6zWXLPGrNy08/vNEGi7dtKoUWZuGhAOv/5q5jh27Wom9ody003mbNiePSNaGlAlCGcAyqVJE7Na8803pQYNgu/PyZEmTDC9GA8+KO3fH/kaER22bjUT+tu3L/7M1yOPNCs0n3mGDWURPQhnAMrN5zM9Gb//bgJYqCGkgwelhx82Ie2pp0LPDQJC2b3bbBLbpo300ktm8r9dkybSxIlmVfFpp0W+RqAqEc4AVFhqqvTQQyakjRol1agR/Jhdu8zE7XbtpClTpNzciJcJjzh4UHrsMRPon3wydKCvXds85rffpOHDQ//OAV5HOANQaY0aSf/5j9lzasAAKSbEK8umTdL115uFAx98YOaoAZKUnW16wdq0ke69V9q3L/gxiYmmN239eunuuxnCRHQjnAEIm1atpKlTzcTsUIsGJOnnn80mtt26SdOmhd44FNXD7t1myPvoo832F2lpwY+JjZWGDjU9ZU88EXq1MBBtCGcAwq5jR+l//5MWLSp+9dzy5dLAgVLz5tKtt5peN0Q/v99sgzFggPm3v+026Y8/Qj/2iiukn36SXnzRPBaoLuKcLsDN8vPztWHDBq1bt047d+7UgQMHlJiYqNq1a6tNmzZq37694uPjnS4TcK2TTpK++kr68kszFLV8efBj9uyRnn7a3Hr3lkaMMBvexvHqFFUOHjQrfF94IfTvQaCzzzbzyo4/PjK1AW7Dy5/Nzp079cUXX2jBggVasmSJDhw4UOxjExMT1bdvXw0YMEAdOnSIYJWAd/h85lzD3r2l996T7rvP7FsVyuzZ5ta8uTRkiLk1axbZehFeP/9sAtmrr4aeSxbo5JOlxx+XzjgjMrUBbsWwZoDhw4fr9NNP18MPP6yvvvqqxGAmSZmZmfrwww91ySWXaOzYscrOzo5QpYD3xMSYo57WrpVmzJD69i3+sVu2mFWgLVtKl14qzZnDAgIvyckxZ6726mX2KJswofhgFh9vhi/nzTNnZBLMAMKZxfLly5Wfnx/UHh8fr+bNm6tTp05q166dkpKSLPfn5+drypQpGjVqlHLZJwAoUVycdOGF0mefmR60228vfpJ3Xp70/vum1+3oo82K0N27I1ouymHTJumBB0yo/vvfzVFKxWnZ0gxdbtpkhjtPP930sgJgWLNYDRo00IUXXqjTTjtNXbp0UUJCQuF9OTk5mj9/vp5++mmtC5jF/NVXX2n8+PG68847nSgZ8Jy2baVx48xmte++a4a/Fi8O/dh166RbbjFh7vTTzby0fv3M94Az/H7phx/M2aozZ0rLlpX8eJ9POuccsz/ZOeeYlZgAgvn8fgYLCnTv3l2NGjXSyJEj1bt3b8WVMiM5KytLo0aN0tyAj4fx8fGaNWuWjjjiiKout0QZGRlau3Zt4XWHDh2Cevxgs3On2bArQMaGDUpq2dKhgqqnFStMSHvjDenQodIf3759UVA7+WTvvOF79TmamWl6xGbNMrfNm0v/mgYNzB53Q4dKDr80Vj+8rlWI089PhjUDjBkzRh9++KHOPvvsUoOZJCUkJOipp55SkyZNCttycnI0Y8aMKqwSiG7HHy9NmmTOVXz2WRO+SvLTT2Y3+dNOM0f6XHedWXiQnh6ZequDHTvM/nX9+5ugde65JkCXFsx69DAhe/Nms0cZwQwoG8JZgN69eysm1NbmJUhOTtY111xjaZs/f344ywKqpdq1pRtvlNaskb7+Wrr8cilgdkFIf/0lTZ8uXXaZVL++WXTw3HPShg0RKTlq+P3mzMrHH5dOOcWE3kGDzN51Bw+W/LW1a5thy5UrpQULpKuuKv3fDYAVc87CoFu3bpbrbdu2OVQJEH18PrOC74wzTDCYPbtoSG3HjuK/LidH+uILc/vnP6VOncy+a126SF27Sp07myOBYHoZV6wwc8aWLZMWLix+Y9hQWreWLrjADC2fdppZgQmg4ghnYZCammq5Tmc8BagSNWualZ4XXijl50vff180GX316pK/9scfza1AXJw5yaBr16Jb586SB6Z9Vcq+fdYgtny5WWxRntnHPp/pUSuY69e+PSstgXAinIVBmu1AuDp16jhTCFCNxMRI3bub26OPSn/+KX30kQlqX39tes5Kkptrht5WrpSmTDFtsbEmsBX0rnXtKh17rJScXNX/N1Vj714TvpYvLwpjxW0AXJpatcwwcb9+Zs5Zw4ZhLRVAAMJZGCyzrR93eqUmUB0dfriZo3bjjdL+/WY4c+ZM6ZNPpF27yvY98vLMoe2rVplD2SUT2Nq2lVq0MLfmzYv+LPjvhg1NWIyk3Fxp+3azYe/mzebPwP/esMEE1so47LCi4cqePZk7BkQK4ayS8vLyglZnnn766c4Ug7Dz7doV/eNcUShV0qVnmFvek0W9RgU9Zb//LpV5FC9P2vWLua0s5iHxcWbSfNOm5s+UFNPTVLNm8J+JiSbI5eZmaevWbPn9PuXnS3/9tEtxcQk6dMjMrTtwwPrnwYOmJ2zbNnPbsUPKL+V/okGZf2JSXKwZnuzc2dxOPNH0IhYOV+4vxzeDe/z1l9MVoAIIZ5X01ltvadOmTYXX8fHx6tevn4MVhZaZmel0Ce6XkSF7DEvs0sWRUhA+sZJO/P9blcmVtPn/b16VJ+nH/7/91+FaUKWysrKkjAyny3A1p98zCWeVsHHjRo0fP97SdtVVV1n2PXOL9evXO12C68Xt2aNjnS4CAKrYhg0blLufrlA3Y5+zCsrIyNBNN92kgwGb/jRv3lw33XSTg1UBAACvI5xVgN/v15133qmffvqpsC0uLk7jxo1TrVq1HKwMAAB4nWuGNceMGaPp06dX+d9z44036p///GelvscTTzyhzz//3NJ2zz33qGvXrpX6vlWpdevWSmTHzZLl52vvunXaELCdfKtWrSyH3gPhkpWVxe8aIsL+u9by+OOV6NX9YSIkMzPT0elArglnXjFp0iRNK1hj//9uvPFGXX311c4UVEaJiYmeOFTZcS1aWOZiJLRowc8NVSMjg981RIbtdy0xOZnfNZdjWLMc3nrrraAFANdcc02le+IAAAAKuKbnrGfPnqpbt26V/z0nnHBChb5u1qxZGj16tKXt4osv1r333huOsgAAACS5KJz16NFDPXr0cLqMkGbPnq277rpL+fn5hW19+/bVmDFj5ONAOQAAEEYMa5Zi4cKFuuWWW5Sbm1vYduqpp+rf//63YmNjHawMAABEI8JZCZYtW6YRI0YoOzu7sK1bt256/vnnVaNGDQcrAwAA0YpwVow1a9Zo6NChygg44qJTp0566aWX2JICAABUGcJZCL/99puuv/56paenF7a1a9dOL7/8MpvMAgCAKkU4s9m0aZMGDhyoPXv2FLa1atVKU6ZMichqUgAAUL0RzgKkpaVp4MCB2rFjR2Fbs2bNNG3aNDVs2NDBygAAQHXhmq00nJaRkaHrr79emzZtKmyLjY3VkCFD9Oeff+rPP/8s1/fr2rUrR7EAAIByI5z9v127dunXX3+1tOXl5QVtPFtWc+bMUYsWLcJRGgAAqEYY1gQAAHARwhkAAICLMKz5/1q0aKFffvnF6TIAAEA1R88ZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAixDOAAAAXIRwBgAA4CKEMwAAABchnAEAALgI4QwAAMBFCGcAAAAuQjgDAABwEcIZAACAi8Q5XQCqRn5+vuU6MzPToUq8xf5z4ueGqsLvGiKF37Xys/+M7O+pVc3n9/v9Ef0bERF79uzR+vXrnS4DAADPa926terWrRuxv49hTQAAABchnAEAALgIw5pRKjc3V+np6YXXNWrUUEwMWRwAgNLk5+crOzu78DolJUVxcZGbpk84AwAAcBG6UgAAAFyEcAYAAOAihDMAAAAXIZwBAAC4COEMAADARQhnAAAALkI4AwAAcBHCGQAAgIsQzgAAAFyEcAYAAOAihDMAAAAXIZwBAAC4COEMAADARQhnAAAALkI4AwAAcBHCGQAAgIsQzgAAAFyEcAYAAOAihDMAAAAXIZwBAAC4COEMAADARQhnAAAALkI4AwAAcBHCGQAAgIsQzgAAAFyEcAYAAOAicU4XAHhdfn6+NmzYoHXr1mnnzp06cOCAEhMTVbt2bbVp00bt27dXfHy802XCRTZu3KhVq1Zp+/btysnJUWpqqlq3bq0uXbooISHB6fLgcX6/X5s3b9a6deu0fft2paenq0aNGkpNTdXhhx+uY445ht8zlyOcARWwc+dOffHFF1qwYIGWLFmiAwcOFPvYxMRE9e3bVwMGDFCHDh0iWCXcZvbs2Zo4caLWrFkT8v7k5GT1799fI0eOVL169SJcHbxs3759mj17tubPn6/Fixdrz549xT42Pj5eZ5xxhq677jqdeOKJEawSZeXz+/1+p4sAvGT48OH6+uuvlZ+fX66vi4mJ0YABA3TLLbeoRo0aVVQd3Cg7O1v33HOPZs2aVabH16tXTxMmTNAJJ5xQxZUhGowePVrvvvuucnJyyv21F110ke6//37VqlWrCipDRRHOgHLq3r279u7dG9QeHx+vRo0aqW7dusrOztamTZuUkZER9LhevXrp2WefVVwcHdfVQX5+vm688UbNmTPH0h4bG6umTZsqJSVFmzdvVnp6uuX+pKQkTZ06Vccff3wky4UH9e/fP2RvbGxsrBo2bKj69esrNzdXW7duDfo9k6TOnTtr2rRpqlmzZiTKRRkQzoByCgxnDRo00IUXXqjTTjstaL5QTk6O5s+fr6efflrr1q2zfI9BgwbpzjvvjGTZcMikSZM0fvx4S9sVV1yhESNGqHHjxpJMgJszZ44ee+wxbd26tfBxTZo00UcffaSUlJSI1gxvCQxnqampOv/889WzZ0917drV0iOWl5enpUuXasKECVq6dKnle/Tt21cTJkyIaN0oHuEMKKfu3burUaNGGjlypHr37l1qD1hWVpZGjRqluXPnFrbFx8dr1qxZOuKII6q6XDhoz549OvPMM3Xw4MHCtttuu0033HBDyMenpaXpyiuv1JYtWwrbRo4cqZtuuqnKa4V39e/fX3v37tXw4cPVr18/JSYmlvj4vLw8jR49Wm+//bal/dVXX9VJJ51UlaWijAhnQDnNnj1bvXr1UkxM2XeiOXTokM455xxt3769sG3YsGG65ZZbqqJEuMS4ceP08ssvF16fcMIJeu211+Tz+Yr9mkWLFmnAgAGF1zVr1tScOXNUt27dqiwVHvb111/rlFNOKddc1ry8PP3973/Xjz/+WNh2/vnnB/XywhnscwaUU+/evcsVzCSzCu+aa66xtM2fPz+cZcFl8vPz9cEHH1jabrzxxhKDmSSdfPLJ6tatW+H1wYMH9emnn1ZJjYgOPXv2LPcio9jYWA0ePNjStmDBgnCWhUognAEREviGK0nbtm1zqBJEwvLly7V79+7C68MOO0zdu3cv09deeumllmv7YgIgHOyvSXv37g25iAmRRzgDIiQ1NdVyHWrVFKLHvHnzLNennHJKqb1mgY8N9N133+nQoUNhqw2QpNq1awe18brkDoQzIELS0tIs13Xq1HGmEETETz/9ZLnu0qVLmb+2cePGat68eeF1Tk6Ofvvtt7DVBkjBr0kSr0tuQTgDImTZsmWWa1ZqRrf169dbrtu0aVOur2/btm2J3w+oLPt2Gs2bN2eDbJcgnAERkJeXpxkzZljaTj/9dGeKQZXLzMy07FcmSU2bNi3X92jSpInl+o8//qh0XUCg999/33LNa5J7EM6ACHjrrbe0adOmwuv4+Hj169fPwYpQlfbs2aPAXYri4+NVv379cn2Pgg1qC+zatSsstQGSmRP5/fffW9r69+/vUDWwI5wBVWzjxo1BewddddVVQT0jiB72yfuJiYllXgxQIDk5ucTvCVTU3r179cADD1jaevfurc6dOztUEewIZ0AVysjI0E033WTZIb558+bs+B7lAv+9JVmO9Sor+9cQzhAO+fn5uuOOOywbYqekpOi+++5zsCrYEc6AKuL3+3XnnXdaVu3FxcVp3LhxlvPuEH2ys7Mt1/Hx8eX+HvaJ2ZmZmZWqCZCkJ598Ut98842l7eGHHy73nEhUrZIPBQRcZsyYMZo+fXqV/z033nij/vnPf1bqezzxxBP6/PPPLW333HOPunbtWqnvC/ezB6ucnJxyfw97wKtI7xsQaPr06Zo6daqlbfDgwTr33HMdqgjFoecMqAKTJk3StGnTLG033nijrr76amcKQkTVrFnTcp2VlVXu72H/GvscNKA8Zs2apccee8zS1r9/f91+++0OVYSSEM6AMHvrrbeCFgBcc801le6Jg3fYg1RmZqZl9WZZ2OeYEc5QUXPnztVdd91l+R0866yz9Oijj5Z7oQoig2FNeErPnj1Vt27dKv97TjjhhAp93axZszR69GhL28UXX6x77703HGXBI+rWrSufz1f4ZpiTk6Ndu3apQYMGZf4e9t3by7sVByBJixcv1qhRo5Sbm1vY1qNHD40fP16xsbEOVoaSEM7gKT169FCPHj2cLiOk2bNn66677lJ+fn5hW9++fTVmzBg+nVYziYmJatasmbZs2VLYtnXr1nKFs23btlmuW7duHbb6UD2sXLlSw4cPtwyRH3/88Xruuec4CcDlGNYEwmDhwoW65ZZbLJ9OTz31VP373//m02k1ZT+e6/fffy/X19sfTzhDefz8888aMmSIZXi8Q4cOmjx5MkPkHkA4Aypp2bJlGjFihGV1Xbdu3fT888/z6bQaa9++veV6xYoVZf7aHTt2WHrd4uPjy302J6qv9evXa9CgQdq3b19hW5s2bfTKK68oJSXFwcpQVoQzoBLWrFmjoUOHKiMjo7CtU6dOeumll5SYmOhgZXBaz549LdcLFy4s86KAb7/91nLdvXv3oBWgQChbtmzRwIEDLcd9tWjRQlOnTlW9evUcrAzlQTgDKui3337T9ddfr/T09MK2du3a6eWXX2aTWahLly6WxSubNm3Sd999V6avfe+99yzXvXr1CmttiE47duzQgAEDLLv/N27cWNOmTQs6qxXuRjgDKmDTpk0aOHCg9uzZU9jWqlUrTZkyJSKrSeF+MTExuvjiiy1tzz//fKm9Z4sWLdLSpUsLr2vWrKlzzjmnSmpE9Ni7d68GDRqkjRs3FrbVq1dPU6dO1WGHHeZgZagIwhlQTmlpaRo4cKB27NhR2NasWTNNmzZNDRs2dLAyuM2QIUMsk6+XLFmiyZMnF/v4tLS0oG1Xrr32WoajUKIDBw5o8ODB+vXXXwvbUlNTNWXKFOYqepTPX96dEYFqLCMjQ5dddpnlRTA2Nlb33XefDj/88HJ/v65du3IsT5R76aWX9NRTT1narrzySg0fPrxwqCk/P19fffWVxowZo61btxY+rlGjRvr444+Vmpoa0ZrhLddcc42WLFliabvpppt0/PHHl/t7dezYUbVr1w5XaaggwhlQDps3b9aZZ54Ztu83Z84ctWjRImzfD+6Tn5+vESNGaO7cuZb22NhYNWvWTCkpKdq8ebP2799vuT8xMVFTpkzhLFaU6qijjgrb95o+fbq6d+8etu+HimFYEwCqUExMjJ555hmdd955lva8vDxt2rRJa9euDQpmderU0aRJkwhmQDVFOAOAKpaQkKCnnnpKEyZMCNr/LFBycrKuuuoqffLJJ/ReANUYw5oAEGEbNmzQypUrlZaWppycHKWmpqpNmzbq0qULcxABEM4AAADchGFNAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHARwhkAAICLEM4AAABchHAGAADgIoQzAAAAFyGcAQAAuAjhDAAAwEUIZwAAAC5COAMAAHCR/wN3/t5mh7qvZgAAAABJRU5ErkJggg==\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(2,2), dpi=300)\n",
    "plt.xlim(-3,3)\n",
    "plt.ylim(-3,3)\n",
    "rect1 = plt.Rectangle((-1, -1), 2,2, color='g', fill=False)\n",
    "circle1 = plt.Circle((0, 0), np.sqrt(2), color='b', fill=False)\n",
    "circle2 = plt.Circle((0, 0), 2, color='b', fill=False)\n",
    "rect2 = plt.Rectangle((-2,-2), 2*2,2*2, color='r', fill=False)\n",
    "plt.gca().add_patch(circle1)\n",
    "plt.gca().add_patch(circle2)\n",
    "plt.gca().add_patch(rect1)\n",
    "plt.gca().add_patch(rect2)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "54eee515",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
