{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "939e45a7-e469-489e-a0a9-b9329909d6a4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy.stats\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import os\n",
    "import sys\n",
    "from tqdm import tqdm\n",
    "import matplotlib\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from scipy.stats import linregress\n",
    "sys.path.append(\"../\")\n",
    "\n",
    "import seq_models as smods\n",
    "import das\n",
    "import dl_utils.save_io as savio\n",
    "\n",
    "pd.set_option('display.max_rows', 500)\n",
    "pd.set_option('display.max_columns', 500)\n",
    "pd.set_option('display.width', 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0dea9e20-c9ea-4870-9aa1-1a0a10b407e0",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "rrm = das.RelaxedRotationMatrix(size=2)\n",
    "D = rrm.diag.data\n",
    "R = rrm.rot_module.weight.detach().data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "62e61dbb-2288-4c0f-a970-d7ffeec415b0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cond: tensor(1.0723)\n",
      "tensor([[0.9822, 0.0000],\n",
      "        [0.0000, 0.9160]])\n"
     ]
    }
   ],
   "source": [
    "sd = 1\n",
    "D = rrm.diag.data\n",
    "D[0] = sd*torch.rand(1)\n",
    "D[1] = sd*torch.rand(1)\n",
    "D = torch.diag(D)\n",
    "print(\"Cond:\", torch.linalg.cond(D))\n",
    "print(D)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d98de10c-10be-4810-b379-346bf01e1a1d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cond: tensor(1.0723)\n",
      "tensor([[1.0182, 0.0000],\n",
      "        [0.0000, 1.0917]])\n"
     ]
    }
   ],
   "source": [
    "D_inv = torch.diag(D.clone())\n",
    "D_inv = torch.diag(1/D_inv)\n",
    "print(\"Cond:\", torch.linalg.cond(D_inv))\n",
    "print(D_inv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7d009ce3-4836-4a0d-a882-09c6c41bed62",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cond: tensor(1.0000)\n",
      "tensor([[ 0.9899, -0.1415],\n",
      "        [ 0.1415,  0.9899]])\n"
     ]
    }
   ],
   "source": [
    "print(\"Cond:\", torch.linalg.cond(R))\n",
    "print(R)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "f1d60131-e6c4-493e-a0fc-ce817835a2a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Left Combo Cond: tensor(1.0723)\n",
      "Right Combo Cond: tensor(1.0723)\n"
     ]
    }
   ],
   "source": [
    "print(\"Left Combo Cond:\", torch.linalg.cond(torch.matmul(D,R)))\n",
    "print(\"Right Combo Cond:\", torch.linalg.cond(torch.matmul(R,D)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "16c474a4-70ff-4a50-8d99-bb98712f02b8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.5086, 0.0129],\n",
       "        [0.0904, 0.7678]])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "v = 0.5*torch.randn(2,2)\n",
    "v"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "99a1df44-086f-4790-a2f2-c7ae08bb41b9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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pGjBggV67LHHJEl1dXVKSkrS0qVL9cADD7QZU1dXp7q6uuC+3+/X4MGDVV1drfj4eGcmAgAAulQgEFBqaqpOnTolj8fTZa8b02Wv1AF+v18DBgy44POVlZXy+XzKzs4Otrndbt18883avn17yKCTn5+vJUuWtGlPTU3tmqIBAEC3OXHiRGQGnb///e/69a9/rWefffaCfXw+nyQpKSmpVXtSUpIOHz4cckxeXp5yc3OD+6dOndKQIUNUVVXVpf+ierqWJNzbjmQxb+bdGzBv5t0btHwj094BkUvR6aCzePHikEdQzrdz506NGTMmuH/06FFNmTJF06dP1/3333/R93C5XK32jTFt2lq43W653e427R6Pp1f9B9IiPj6eefcizLt3Yd69S2+dd1RU154+3OmgM3/+fM2cObPdPmlpacHHR48e1cSJE5WVlaXVq1e3Oy45OVlS85Edr9cbbK+trW1zlAcAAOBiOh10EhISlJCQ0KG+R44c0cSJE5WRkaG1a9deNKWlp6crOTlZxcXFGj16tCSpvr5epaWlWrp0aWdLBQAAvZxjl5cfPXpUEyZMUGpqqp555hkdO3ZMPp8veB5OixEjRqioqEhS81dWCxYs0C9+8QsVFRXpww8/1Jw5c9S/f3/de++9HXpft9utJ598MuTXWTZj3sy7N2DezLs3YN5dO2/HLi9/6aWX9MMf/jDkc+e/pcvl0tq1azVnzpzgc0uWLNGLL76okydPauzYsXrhhRc0atQoJ8oEAAAW69bf0QEAAOhO3OsKAABYi6ADAACsRdABAADWIugAAABrRXzQOXTokO677z6lp6erX79+uuqqq/Tkk0+qvr6+3XHGGC1evFgpKSnq16+fJkyYoN27d3dT1V3jqaee0rhx49S/f39dccUVHRozZ84cuVyuVltmZqazhXaxS5m3Det98uRJzZo1Sx6PRx6PR7NmzdKpU6faHROJ671y5Uqlp6crNjZWGRkZevvtt9vtX1paqoyMDMXGxmro0KEqKCjopkq7VmfmXVJS0mZdXS6X9u3b140VX75t27Zp2rRpSklJkcvl0uuvv37RMTasd2fnbcN65+fn6/rrr1dcXJwSExN15513av/+/Rcd1xXrHfFBZ9++fWpqatKLL76o3bt367nnnlNBQYEWLVrU7rinn35ay5Yt04oVK7Rz504lJyfrlltu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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_vec(vs,size=2,ax=None):\n",
    "    plt.scatter(0,0,color=\"k\")\n",
    "    if ax: plt.sca(ax)\n",
    "    for v in vs:\n",
    "        plt.plot([0,v[0]],[0,v[1]])\n",
    "        plt.scatter(v[0],v[1],s=50)\n",
    "    plt.xlim([-size,size])\n",
    "    plt.ylim([-size,size])\n",
    "plot_vec(v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "565fde86-9e69-456c-b8b2-07b3700fbd98",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def plot_vecs(vs,size=2,title=\"\"):\n",
    "    fig,axes = plt.subplots(1,len(vs),figsize=(5*len(vs),5))\n",
    "    for v,ax in zip(vs,axes):\n",
    "        plot_vec(v,size=size,ax=ax)\n",
    "    plt.suptitle(title)\n",
    "    plt.savefig(\"figs/\"+title+\".png\",bbox_inches=\"tight\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4402515-b344-4ce4-b6f5-29497e6579fb",
   "metadata": {},
   "source": [
    "# Rot Scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 526,
   "id": "0c2f7d2d-0e1b-43ee-9016-cd928b4d9401",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "#vecs = [v]\n",
    "#vecs.append(torch.matmul(vecs[-1], R))\n",
    "#vecs.append(torch.matmul(vecs[-1], D))\n",
    "#vecs.append(torch.matmul(vecs[-1], D_inv))\n",
    "#vecs.append(torch.matmul(vecs[-1], R.T))\n",
    "#plot_vecs(vecs, size=1.5, title=\"Rot then Scale then Project\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 527,
   "id": "6483c0ec-3281-48c4-9646-aeca98fab102",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACXEAAAHyCAYAAACnYB+XAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAByWUlEQVR4nOzdeZgdZZk34Of0kl4S0kkgYUtYBCIQBQSCBJDgJBBgAEFQZFGIy6AjijOo3xcHBJdPkHEExl1RUAGFAQRBWWVTQGBYRZYkCIEACZAd0un0Ut8fTZqc3quX1Fnu+7rqoqtOVfXTJ93nx6l6zvvmkiRJAgAAAAAAAAAAgExUZF0AAAAAAAAAAABAOdPEBQAAAAAAAAAAkCFNXAAAAAAAAAAAABnSxAUAAAAAAAAAAJAhTVwAAAAAAAAAAAAZ0sQFAAAAAAAAAACQIU1cAAAAAAAAAAAAGdLEBQAAAAAAAAAAkCFNXAAAAAAAAAAAABnSxAUAAACUnEsuuSRyuVzHUlVVFZtvvnl85CMfiXnz5g3onPfee2+cffbZsXz58n7t/8c//jHOPvvsbh/L5XJx6qmnDqiO4XL//ffHUUcdFVtttVXU1NTEpptuGtOmTYvTTz992L7nun+n559/fkjO9/LLL8fZZ58djz76aJfHTj755Bg1atSQfJ+hsv7vaC6Xi4aGhjjggAPiD3/4w5B+n7PPPjtyudyQnnN9af82AAAAAOhKExcAAABQsi6++OK477774rbbbotTTz01fv/738d+++0Xy5YtS32ue++9N772ta+lauL62te+lvr7ZOEPf/hD7LPPPrFy5co477zz4pZbbokLL7ww9t1337jiiiuyLq/fXn755fja177WbRNXoTrmmGPivvvui3vuuSd+8IMfxKJFi+Lwww8f0kauT37yk3HfffcN2fk6S/u3AQAAAEBXVVkXAAAAADBc3vWud8Wee+4ZEREHHHBAtLa2xllnnRXXXnttzJ49O+PqCsd5550X2267bdx8881RVfX25aKPfOQjcd5552VYWenbdNNNY++9946IiH322SemTZsW22+/fVxwwQXxz//8z90e09zc3DHCXH9MnDgxJk6cOGQ1AwAAADD0jMQFAAAAlI11DV2LFy/O2/773/8+pk2bFvX19bHRRhvFgQcemDdy0dlnnx1f+tKXIiJi22237Zj+7s477+z2+5x88snxgx/8ICLyp8zrPG3gr3/969hpp52ivr4+dt1117jhhhu6nGvevHlx/PHHx4QJE6KmpiZ22mmnjnOvc+edd0Yul4vf/OY38R//8R+xxRZbxOjRo2PmzJnxzDPP9Pm8LFmyJDbZZJNum4IqKrpePrr88stj2rRpMWrUqBg1alTstttu8fOf/7zj8VtvvTU+8IEPxMSJE6O2tja23377OOWUU+L111/vs5aIiNtuuy1mzJgRo0ePjvr6+th3333jT3/6U6/H3HnnnTF16tSIiJg9e3bHc955Ssv58+fHoYceGqNGjYpJkybF6aefHk1NTXn7rF27Nr75zW/GjjvuGDU1NTF+/PiYPXt2vPbaa3n7bbPNNnHYYYfFTTfdFLvvvnvU1dXFjjvuGL/4xS/69XN2Z7vttovx48fHggULOn6uXC4Xv/71r+P000+PLbfcMmpqamL+/PkREfGLX/widt1116itrY1x48bFUUcdFU899VTeOXuaTvGKK66IadOmxciRI2PUqFExa9aseOSRR7rsd//998fhhx8eG2+8cdTW1sZ2220XX/jCFzrOneZvAwAAAIDuaeICAAAAysZzzz0XERGTJ0/u2Hb55ZfHBz7wgRg9enT85je/iZ///OexbNmyOOCAA+Ivf/lLRLRPR/e5z30uIiKuueaauO++++K+++6L3Xffvdvvc+aZZ8YxxxwTEdGx73333Rebb755xz5/+MMf4vvf/358/etfj6uvvrqjAecf//hHxz5PPvlkTJ06NZ544on4r//6r7jhhhvin//5n+Pzn/98t1M1fuUrX4kFCxbERRddFD/96U9j3rx5cfjhh0dra2uvz8u0adPi/vvvj89//vNx//33R3Nzc4/7fvWrX40TTjghtthii7jkkkvid7/7XZx00kkdTUcREc8++2xMmzYtfvSjH8Utt9wSX/3qV+P++++P/fbbr9dzR0RceumlcdBBB8Xo0aPjl7/8ZVx55ZUxbty4mDVrVq+NXLvvvntcfPHFERFxxhlndDznn/zkJzv2aW5ujiOOOCJmzJgR1113XXz84x+P888/P7797W937NPW1hYf+MAH4txzz43jjz8+/vCHP8S5554bt956axxwwAHR2NiY930fe+yxOP300+Pf/u3f4rrrrotddtklPvGJT8Tdd9/d68/Zk2XLlsWSJUti/PjxedvnzJkTL7zwQvz4xz+O66+/PiZMmBDnnHNOfOITn4gpU6bENddcExdeeGE8/vjjMW3atJg3b16v3+db3/pWHHfccbHzzjvHlVdeGb/+9a9j1apV8b73vS+efPLJjv1uvvnmeN/73hcvvPBCfPe7340bb7wxzjjjjI5GyLR/GwAAAAD0IAEAAAAoMRdffHESEclf//rXpLm5OVm1alVy0003JZtttlmy//77J83NzUmSJElra2uyxRZbJO9+97uT1tbWjuNXrVqVTJgwIdlnn306tv3nf/5nEhHJc889168aPvvZzyY9XXqJiGTTTTdNVq5c2bFt0aJFSUVFRXLOOed0bJs1a1YyceLEZMWKFXnHn3rqqUltbW2ydOnSJEmS5I477kgiIjn00EPz9rvyyiuTiEjuu+++Xmt9/fXXk/322y+JiCQikurq6mSfffZJzjnnnGTVqlUd+/3jH/9IKisrkxNOOKFfz0GSJElbW1vS3NycLFiwIImI5Lrrrut4bN2/07rn9M0330zGjRuXHH744XnnaG1tTXbddddkr7326vV7Pfjgg0lEJBdffHGXx0466aQkIpIrr7wyb/uhhx6avPOd7+xY/81vfpNERHL11Vd3e+4f/vCHHdu23nrrpLa2NlmwYEHHtsbGxmTcuHHJKaec0mutSdL+e/Cv//qvSXNzc7J27drkqaeeSg455JAkIpIf/OAHSZK8/W+7//775x27bNmypK6ursu/+QsvvJDU1NQkxx9/fMe2s846K+938YUXXkiqqqqSz33uc3nHrlq1Ktlss82SD3/4wx3btttuu2S77bZLGhsbe/w50v5tAAAAANCVkbgAAACAkrX33ntHdXV1bLTRRnHwwQfH2LFj47rrruuYNvCZZ56Jl19+OT760Y/mTRs4atSoOProo+Ovf/1rrF69elhqe//73x8bbbRRx/qmm24aEyZM6BjRas2aNfGnP/0pjjrqqKivr4+WlpaO5dBDD401a9bEX//617xzHnHEEXnru+yyS0RE3ihZ3dl4443jz3/+czz44INx7rnnxgc+8IGYO3duzJkzJ9797nd3TIN46623Rmtra3z2s5/t9XyvvvpqfPrTn45JkyZFVVVVVFdXx9Zbbx0R0WWqv/Xde++9sXTp0jjppJPyft62trY4+OCD48EHH4w333yz1+/dm1wuF4cffnjetl122SXv+bnhhhtizJgxcfjhh+fVsNtuu8Vmm23WZZrA3XbbLbbaaquO9dra2pg8eXKfz/k6P/zhD6O6ujpGjBgRO+20U9x7773x9a9/Pf71X/81b7+jjz46b/2+++6LxsbGOPnkk/O2T5o0Kf7pn/6p11HLbr755mhpaYmPfexjeT9jbW1tTJ8+veNnnDt3bjz77LPxiU98Impra/v18wAAAAAwMFVZFwAAAAAwXH71q1/FTjvtFKtWrYorrrgifvKTn8Rxxx0XN954Y0RELFmyJCIib5rDdbbYYotoa2uLZcuWRX19/ZDXtvHGG3fZVlNT0zFd35IlS6KlpSW+973vxfe+971uz7Guuaqnc9bU1EREdJkCsCd77rln7LnnnhHRPvXg//k//yfOP//8OO+88+K8886L1157LSIiJk6c2OM52tra4qCDDoqXX345zjzzzHj3u98dI0eOjLa2tth77717rWXdFH3rpqLsztKlS2PkyJH9+nk6q6+v79KMVFNTE2vWrMmrYfny5TFixIhuz9HXc77unP19zj/84Q/Hl770pcjlcrHRRhvFdtttF5WVlV326/w72tfv7q233trj91z3PE+dOrXbx9c1NPbn3xsAAACAoaGJCwAAAChZO+20U0dT0vvf//5obW2Niy66KK666qo45phjOhpwXnnllS7Hvvzyy1FRURFjx47doDWvM3bs2KisrIyPfvSjPY58te222w7b96+uro6zzjorzj///HjiiSciImL8+PEREbFw4cKYNGlSt8c98cQT8dhjj8Ull1wSJ510Usf2+fPn9/k9N9lkk4iI+N73vhd77713t/tsuummqX6OtDbZZJPYeOON46abbur28fVHTxsK48eP7/gd7U0ul8tb7+t3d91z2Z11j1111VUdI6T1VFtE+783AAAAAMNLExcAAABQNs4777y4+uqr46tf/Wp88IMfjHe+852x5ZZbxuWXXx5f/OIXOxpl3nzzzbj66qtj2rRpHaNwpR3Vav396+rqUtdaX18f73//++ORRx6JXXbZpceRoYbCK6+80u2ITuumPtxiiy0iIuKggw6KysrK+NGPfhTTpk3r9lzrnsN1P/86P/nJT/qsY999940xY8bEk08+Gaeeemqqn2H979nff6PuHHbYYfHb3/42Wltb473vfe+AzzPcpk2bFnV1dXHppZfGhz70oY7tCxcujNtvv73X0cxmzZoVVVVV8eyzz3aZpnF9kydPju222y5+8YtfxL//+793+TddZyiedwAAAIByp4kLAAAAKBtjx46NOXPmxJe//OW4/PLL48QTT4zzzjsvTjjhhDjssMPilFNOiaampvjP//zPWL58eZx77rkdx7773e+OiIgLL7wwTjrppKiuro53vvOdPY7MtG7/b3/723HIIYdEZWVl6masCy+8MPbbb7943/veF5/5zGdim222iVWrVsX8+fPj+uuvj9tvv30Qz8bbZs2aFRMnTozDDz88dtxxx2hra4tHH300/uu//itGjRoVp512WkREbLPNNvGVr3wlvvGNb0RjY2Mcd9xx0dDQEE8++WS8/vrr8bWvfS123HHH2G677eL//t//G0mSxLhx4+L666/vdXq/dUaNGhXf+9734qSTToqlS5fGMcccExMmTIjXXnstHnvssXjttdfiRz/6UY/Hb7fddlFXVxeXXXZZ7LTTTjFq1KjYYostOprQ+uMjH/lIXHbZZXHooYfGaaedFnvttVdUV1fHwoUL44477ogPfOADcdRRR/X7fMNlzJgxceaZZ8ZXvvKV+NjHPhbHHXdcLFmyJL72ta9FbW1tnHXWWT0eu80228TXv/71+I//+I/4xz/+EQcffHCMHTs2Fi9eHA888ECMHDkyvva1r0VExA9+8IM4/PDDY++9945/+7d/i6222ipeeOGFuPnmm+Oyyy6LiPR/GwAAAAB0VZF1AQAAAAAb0uc+97nYaqut4utf/3q0trbG8ccfH9dee20sWbIkjj322Jg9e3aMHj067rjjjthvv/06jjvggANizpw5cf3118d+++0XU6dOjYceeqjH73P88cfHJz/5yfjhD38Y06ZNi6lTp8bLL7+cqtadd945Hn744XjXu94VZ5xxRhx00EHxiU98Iq666qqYMWPGgJ+Dzs4444wYO3ZsnH/++XHEEUfEIYccEv/93/8dM2fOjAceeKCjSSci4utf/3r86le/igULFsQJJ5wQRx55ZFx88cUdUztWV1fH9ddfH5MnT45TTjkljjvuuHj11Vfjtttu61ctJ554Ytxxxx3xxhtvxCmnnBIzZ86M0047LR5++OE+f+b6+vr4xS9+EUuWLImDDjoopk6dGj/96U9TPReVlZXx+9//Pr7yla/ENddcE0cddVQceeSRce6550ZtbW3ec5G1OXPmxEUXXRSPPfZYHHnkkXHqqafGlClT4t57740ddtihz2OvuuqqmDt3bpx00kkxa9as+PKXvxwLFiyI/fffv2O/WbNmxd133x2bb755fP7zn4+DDz44vv71r+dNa5n2bwMAAACArnJJkiRZFwEAAAAADI9/+7d/i1//+tfx+uuvZ10KAAAAAD0wnSIAAAAAlKBXX3017rvvvrjmmmti2rRpWZcDAAAAQC9MpwgAAAAAJeiPf/xjnHDCCbHDDjvEhRdemHU5AAAAAPTCdIoAAAAAAAAAAAAZMhIXAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGRIExcAAAAAAAAAAECGNHEBAAAAAAAAAABkSBMXAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGRIExcAAAAAAAAAAECGNHEBAAAAAAAAAABkSBMXAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGRIExcAAAAAAAAAAECGNHEBAAAAAAAAAABkSBMXAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIaqsi4greXLl8cdd9wRd9xxRzz66KMxd+7cWLZsWVRXV8e4ceNi1113jRkzZsRJJ50UY8eOzbpcADImNwBIS3YAkIbcACAt2QFAGnIDoHzkkiRJsi6iP55++un40pe+FLfcckusXbu2z/3r6+vj//2//xennXZa5HK5DVAhAIVEbgCQluwAIA25AUBasgOANOQGQPkpmiauq666Kj70oQ/lbausrIztt98+Nt1002htbY2nnnoqli5dmrfPJz/5yfjpT38qqADKjNwAIC3ZAUAacgOAtGQHAGnIDYDyU5F1AWlVVVXFkUceGddee20sXbo0nn766bjrrrviL3/5S7z++utx7bXXxpZbbtmx/0UXXRQ//vGPM6wYgCzJDQDSkh0ApCE3AEhLdgCQhtwAKB9FMxLXddddFzfccEOceeaZsdVWW/W674svvhh77bVXLFq0KCIiNtlkk3j55Zejurp6Q5QKQAGQGwCkJTsASENuAJCW7AAgDbkBUH6KpokrrZ/+9KdxyimndKzfdtttMWPGjAwrAqCQyQ0A0pIdAKQhNwBIS3YAkIbcACh+RTedYn8dfvjheetPP/10RpUAUAzkBgBpyQ4A0pAbAKQlOwBIQ24AFL+SbeIaN25c3vrKlSszqgSAYiA3AEhLdgCQhtwAIC3ZAUAacgOg+JVsE9eCBQvy1idMmJBRJQAUA7kBQFqyA4A05AYAackOANKQGwDFr2SbuK655pq89WnTpmVUCQDFQG4AkJbsACANuQFAWrIDgDTkBkDxyyVJkmRdxFBbsWJF7LjjjrFo0aKIiNhll13isccey7gqAAqV3AAgLdkBQBpyA4C0ZAcAacgNgNJQlXUBw+H000/vCKiIiG9+85t9HtPU1BRNTU0d621tbbF06dLYeOONI5fLDUudAKUgSZJYtWpVbLHFFlFRUZwDPA4kNyJkB8BAlWt2yA2AgSnX3IiQHQADVa7ZITcABqZccyNCdgAM1LBlR1JifvaznyUR0bEce+yx/TrurLPOyjvOYrFYLOmWF198cZhf4YfHQHMjSWSHxWKxDHYpt+yQGxaLxTK4pdxyI0lkh8VisQx2KbfskBsWi8UyuKXcciNJZIfFYrEMdhnq7Cip6RTvvvvuOPDAA2Pt2rUREbHtttvGI488Eg0NDX0e27nLeMWKFbHVVlvFiy++GKNHjx62mgGK3cqVK2PSpEmxfPnyfr3eFpLB5EaE7AAYqHLNDrkBMDDlmhsRsgNgoMo1O+QGwMCUa25EyA6AgRqu7CiZ6RQfffTROOKIIzoCasKECXHTTTf1+8mqqamJmpqaLttHjx4toAD6odiG1R1sbkTIDoDBKrfskBsAg1NuuREhOwAGq9yyQ24ADE655UaE7AAYrKHOjuKc1LeTZ555JmbNmhUrVqyIiIixY8fGLbfcEpMnT864MgAKkdwAIC3ZAUAacgOAtGQHAGnIDYDSVPRNXM8991zMnDkzXn311YiI2GijjeLGG2+MXXfdNePKAChEcgOAtGQHAGnIDQDSkh0ApCE3AEpXUTdxLVy4MGbMmBELFy6MiIj6+vq44YYb4r3vfW/GlQFQiOQGAGnJDgDSkBsApCU7AEhDbgCUtqJt4lq8eHHMnDkznnvuuYhon6/32muvjf333z/jygAoRHIDgLRkBwBpyA0A0pIdAKQhNwBKX1E2cS1ZsiRmzpwZzzzzTEREVFdXx1VXXRUHHnhgxpUBUIjkBgBpyQ4A0pAbAKQlOwBIQ24AlIeia+JasWJFzJo1K5544omIiKisrIzLL788DjvssIwrA6AQyQ0A0pIdAKQhNwBIS3YAkIbcACgfRdXE9eabb8Y///M/x0MPPRQRERUVFfHLX/4yjjnmmIwrA6AQyQ0A0pIdAKQhNwBIS3YAkIbcACgvRdPE1dTUFEceeWTcc889ERGRy+XiZz/7WZxwwgkZVwZAIZIbAKQlOwBIQ24AkJbsACANuQFQfqqyLqC/Lrzwwrjttts61seMGRNXXnllXHnllf06/sADD4zTTz99uMoDoMDIDQDSkh0ApCE3AEhLdgCQhtwAKD9F08S1evXqvPVly5bFzTff3O/jN9tss6EuCYACJjcASEt2AJCG3AAgLdkBQBpyA6D8FM10igAAAAAAAAAAAKUolyRJknURhWjlypXR0NAQK1asiNGjR2ddDkDB8nr5Ns8FQP94vWzneQDoH6+Xb/NcAPSP18t2ngeA/vF6+TbPBUD/DNfrpZG4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDRdnE9dprr8WNN94YX//61+OII46IzTffPHK5XMdyySWXZF0iAAVGdgCQhtwAIC3ZAUAacgOAtGQHQOmryrqANBYtWhR77713LFiwIOtSACgSsgOANOQGAGnJDgDSkBsApCU7AMpHUY3EtWbNGuEEQCqyA4A05AYAackOANKQGwCkJTsAykdRjcS1vvHjx8cee+wRe+65Z+y5555x5JFHZl0SAAVOdgCQhtwAIC3ZAUAacgOAtGQHQGkrqiaucePGxf/8z//E1KlTY+utt866HACKgOwAIA25AUBasgOANOQGAGnJDoDyUVRNXKNHj45jjjkm6zIAKCKyA4A05AYAackOANKQGwCkJTsAykdF1gUAAAAAAAAAAACUM01cAAAAAAAAAAAAGdLEBQAAAAAAAAAAkCFNXAAAAAAAAAAAABnSxAUAAAAAAAAAAJChqqwLKBRNTU3R1NTUsb5y5coMqwGgGMgOANKQGwCkJTsASENuAJCW7AAoLEbiess555wTDQ0NHcukSZOyLgmAAic7AEhDbgCQluwAIA25AUBasgOgsGjiesucOXNixYoVHcuLL76YdUkAFDjZAUAacgOAtGQHAGnIDQDSkh0AhcV0im+pqamJmpqarMsAoIjIDgDSkBsApCU7AEhDbgCQluwAKCxG4gIAAAAAAAAAAMiQJi4AAAAAAAAAAIAMaeICAAAAAAAAAADIkCYuAAAAAAAAAACADGniAgAAAAAAAAAAyJAmLgAAAAAAAAAAgAxp4gIAAAAAAAAAAMiQJi4AAAAAAAAAAIAMFV0T16c+9amora3tsqTdB4DyITsASENuAJCW7AAgDbkBQFqyA6A8VGVdQFrNzc3R1NTU6z4tLS3R0tKygSoCoNDJDgDSkBsApCU7AEhDbgCQluwAKA9FNxIXAAAAAAAAAABAKSm6Jq5LLrkkkiQZ0AJAeZIdAKQhNwBIS3YAkIbcACAt2QFQHoquiQsAAAAAAAAAAKCUaOICAAAAAAAAAADIkCYuAAAAAAAAAACADGniAgAAAAAAAAAAyJAmLgAAAAAAAAAAgAxp4gIAAAAAAAAAAMiQJi4AAAAAAAAAAIAMaeICAAAAAAAAAADIUFXWBQAAMASSJGL10oi1b0SMGBVRPy4il8u6KgAAAADKletVAACpaOICAChmjcsjHvtNxP0/iVj23Nvbx24b8d5TInY9LqJuTFbVAQAAAFBuXK8CABgQ0ykCABSr+bdFfHfniJvmRCx7Pv+xZc+3b//uzu37AQAAAMBwc70KAGDANHEBABSj+bdFXPbhiObGiEjeWtb31rbmxvb9XBgDAAAAYDi5XgUAMCiauAAAik3j8ogrPhaRJBHR1sfObe37XfGx9uMAAAAAYKi5XgUAMGiauAAAis1jv4loXh19XxBbp619/8d+O5xVAQAAAFCuXK8CABg0TVwAAMUkSSLu/8nAjr3/x299GhIAAAAAhojrVQAAQ0ITFwBAMVm9NGLZcxGR9uJW0n5c47LhqAoAAACAcuV6FQDAkNDEBQBQTNa+Mbjjm1YNTR0AAAAAEOF6FQDAENHEBQBQTEaMGtzxNRsNTR0AAAAAEOF6FQDAENHEBQBQTOrHRYzdNiJyKQ/MtR9XN3Y4qgIAAACgXLleBQAwJDRxAQAUk1wu4r2nDOzY9366/XgAAAAAGCquVwEADAlNXAAAxWbX4yKq66Pf/yuXq2jff9ePDGtZABSxJIl4c0nEsgXt/02SrCsCoNDJDgDW53oVAMCgVWVdAAAAKdWNiTj2VxGXfTgiqYiItl52roiIXMSxv24/DgDW17g84rHfRNz/k4hlz729fey27Z+k3/U4+QFAPtkBQHdcrwIAGDQjcQEAFKPtZ0accGVEdV1E9DTkfK798RP+J2L7GRuyOgCKwfzbIr67c8RNcyKWPZ//2LLn27d/d+f2/QAgQnYA0Lu861U9cb0KAKAnmrgAAIrV9jMj/v3JiIPPfWu4+vXUjmnffvpTLogB0NX829o/Id/cGBHJW8v63trW3Ni+n5vxAMgOAPqj43rVt6PLBw832tz1KgCAXmjiAgAoZnVjIvb+dMS7P5S//d0fat9e25BJWQAUsMblEVd8LCJJovcpTqL98SRp379x+fDXBkBhkh0ApLHuetXoLfK3H3aB61UAAL3QxAUAUArqx+WvNy7Npg4ACt9jv4loXh1934Rfp619/8d+O5xVAVDIZAcAA1HX+XrVsmzqAAAoEpq4AABKQeeLYqs1cQHQjSSJuP8nAzv2/h+/NQILAGVFdgAwUHVj8td96BAAoFeauAAASkHd2Px1F8UA6M7qpRHLnouItDfUk/bjfHIeoPzIDgAGqvPI8T50CADQK01cAACloMt0im6UANCNtW8M7vimVUNTBwDFQ3YAMFCmUwQASEUTFwBAKegynaKLYgB0Y8SowR1fs9HQ1AFA8ZAdAAxUlw8dGokLAKA3mrgAAEpB54tia1dFtKzNphYAClf9uIix20ZELuWBufbjOk/fC0Dpkx0ADFTnDDCdIgBArzRxAQCUgu5ujBiiHoDOcrmI954ysGPf++n24wEoL7IDgIHqMp2iJi4AgN5o4gIAKAWauADor12Pi6iuj35fEshVtO+/60eGtSwACpjsAGAgukynuDyTMgAAioUmLgCAUlBZHVEzOn+bTzcC0J26MRHH/uqtkVH6uixQERG5iGN/3X4cAOVJdgAwEJ1H4jKdIgBArzRxAQCUis6jcbkwBkBPtp8ZccKVEdV1EdHTNFe59sdP+J+I7WdsyOoAKER52dET2QHAejpfq2p+M6KlKZtaAACKgCYuAIBS0WWIek1cAPRi+5kR//5kxMHnvjVF1npqx7RvP/0pN+EBeNu67DhgTtfHxmwtOwDI1/laVYQPHQIA9EITFwBAqej86cbGZdnUAUDxqBsTsfenI3Y4MH/7Xv/Svr22IZOyAChgdWMi9pjddfun7pAdAOSrHdN1m+tVAAA90sQFAFAq6jp9utEnGwHor4rq/PWkNZs6ACgOldVdt8kOADqrrOra3GvkeACAHmniAgAoFaZTBGCgKqry11ubs6kDgOJQUdl1m+wAoDudR473oUMAgB5p4gIAKBVG4gJgoCo7NXG1GU0FgF50bv6NiGhr2fB1AFD4Ol+v8qFDAIAeaeICACgVnT/Z2Lg8kzIAKEKdb8a3GU0FgF50noY3QhMXAN3rMnL8smzqAAAoApq4AABKhekUARioLk1cbsQD0AsjcQHQX0aOBwDoN01cAAClwkUxAAaq84gqbsQD0JuKiohcp0vLrUZxBKAbPnQIANBvmrgAAEpFfefpFJdGJEk2tQBQXCoq89dbNXEB0AejOALQH3WdrletNp0iAEBPNHEBAJSKzhfFWtdGNK/OphYAikulkbgASEkTFwD90Xnk+EZNXAAAPanqexcAAIpC54tiEe1TKo4YueFrAaC4dLkRb0osAPpgKl4A+sN0igD0IEmSWLa6Od5saomRNVUxtr46crlc1mVBpjRxAQCUitqGiFxlRNL69rbGpRFjJmVXEwDFwY14ANLqPBWv7ACgO12mU9TEBVDuVjQ2x9UPLYxf3vt8LFj69mwiW4+rj5P22SaO3mNiNNRV93IGKF2auAAASkUu135hbPXrb29zYQyA/uhyI761+/0AYJ3OU/G2GsURgG50buJqXBqRJO3XsQAoO3fNfS0+c+lD0bi267WnF5aujm/c8GR855Zn4kcn7hHTJ4/PoELIVkXWBQAAMIS6DFG/LJs6ACgubsQDkFaXqXg1AAPQjc7XqtpaIta+kU0tAGTqrrmvxeyLH4jG5tZIIiLp9Pi6bY3NrTH74gfirrmvbfgiIWOauAAASkl3n24EgL50uRFvSiwA+tAlOzQAA9CNunFdtxk5HqDsrGhsjs9c+lB7o1bn7q1OkqS9meszlz4UKxq9z6C8aOICACglnS+MrTYSFwD9oIkLgLRkBwD9UbNR18zwoUOAsnP1QwujcW1rnw1c6yRJROPa1rjm4YXDWxgUGE1cAAClpMt0ii6KAdAPbsQDkFbn7DAVLwDdyeW6jhxvJC6AspIkSfzy3ucHdOwl9zwfSX87v6AEaOICACglXaZTNBIXAP3gRjwAaVVW56+3tWZTBwCFr/PI8a5XAZSVZaubY8HS1ZG2FSuJiAVLV8fy1a5TUT40cQEAlBKfbARgILrciDcSFwB9qKjMX29zYwWAHnQZOV4TF0A5ebNpcNeZ3hjk8VBMNHEBAJQS0ykCMBBdplM0mgoAfajQAAxAP3UeicuHDgHKysiaqr536sWoQR4PxUQTF0UtSZJY+ubaeHHp6lj65lrz4QKAi2IADESXJi6jqQDQhy7ZoYkLgB50Hjnehw4BysrY+urYelx95FIel4uIrcfVx5j66j73hVKhZZGitKKxOa5+aGH88t7nY8HS1R3btx5XHyfts00cvcfEaKjzYg5AGTI8PQAD4UY8AGl1noq3VXYA0IP6zk1crlcBlJNcLhcn7bNNfOOGJ1Mfe/K+20Qul7b9C4qXkbgoOnfNfS2mnfOn+MYNT8YL6zVwRUS8sHR1fOOGJ2PaOX+Ku+a+llGFAJChzp9sXLM8oq0tk1IAKCJdbsQbiQuAPlRU5q9rAAagJ0aOByh7R+8xMepGVEZ/+7EqchF1Iyrjg7tPHN7CoMBo4qKo3DX3tZh98QPR2NwaSUR0njxx3bbG5taYffEDGrkAKD+dL4olbe2NXADQmy4jcbVmUwcAxcNUvAD0V5eR4zVxAZSbhrrq+NGJe0Quot+NXD8+cQ+zb1F2NHFRNFY0NsdnLn2ovVGrc/dWJ0nS3sz1mUsfihWNLiABUEY6XxSLMEQ9AH3rMpqK91EA9KGi080UI3EB0JPOI8cbiQugLE2fPD4unr1X1FVXtjdz9bDfiKqKuGT2XrH/5PEbsjwoCJq4KBpXP7QwGte29tnAtU6SRDSubY1rHl44vIUBQCGprouoqsvfpokLgL64EQ9AWp0bgFtlBwA96DxyvGtVAGVr+uTxcd+cGfHVw3eOrcbVd7vPjB0naOCibGnioigkSRK/vPf5AR17yT3PR9Lfzi8AKAU+3QhAWl2mxHIjHoA+VGoABqCfOo8cv2aFKdwBylhDXXXM3nfbuPNLB8QjZx4Y/37g5LzH/zLv9Vjb0pZRdZAtTVwUhWWrm2PB0tWRthUriYgFS1fHa6uahqMsAChMnS+MNWriAqAPnW/EG00FgL5oAAagvzqPxBVJROPyLCoBoIDkcrkYO3JEHDt1Ut72VU0tce+zr2dUFWRLExdF4c2mwV0EOuA7d8ZnL384rnv0pVjR2DxEVQFAgTISFwBpdZ4Sy414APrSZSpe19wA6EHna1URPnQIQIdNR9fG7luNydt2898XZ1MMZKyq710geyNrBverunpta/zh8VfiD4+/ElUVuXjvO8bFgTttGjN33jQmju1+rl0AKFpG4gIgLTfiAUirSwOwabEA6EF1bUR1fUTz6re3+dAhAOuZNWWzePiF5R3rtz65KL555LuisiKXXVGQASNxURTG1lfH1uPqYyheolvakrhn/pI4+/onY79v3xGHXPjn+O6tc+OJl1ZEkqSdsBEAClDnIeobl2VTBwDFo/OUWElbRFtbNrUAUBw6Z0erBmAAeuF6FQC9mDVls7z1199YGw+/ICsoP5q4KAq5XC5O2mebYTn3U6+sjP/+07w47Ht/iX3PvT2+et0T8ed5r8XaFjcsAChSplMEIK3ON+IjTKkIQO8qO4/iKDcA6EV9p+tVRo4HYD3bbDIydtxso7xtNz+xKKNqIDuauCgaR+8xMepGVEaun8NxVeQi6kdUxm3/Pj2+ddS74/3vHB8jqnr/lX95xZr41X0L4qM/fyD2+MatcerlD8d1j74UKxp9khCAImI6RQDSqtTEBUBKnRuATcULQG986BCAPhzUaTSum/6+yExalJ1urtJCYWqoq44fnbhHzL74gYhcRG+v1+savX584h6x/YRRsf2EUXH8e7eKN5ta4u65r8WtTy2O259+NZav7vni0qqmlrjh8VfihsdfiaqKXLz3HePiwJ02jQOnbBZbjqkb4p8OAIZQ5+HpXRQDoC9G4gIgrS5NXK3Z1AFAcegynaLrVQDkmzVl0/jvP83rWF+4rDGefGVlTNmiIcOqYMMq2pG47r333jjllFNi5513joaGhhg9enTsvPPO8S//8i9xzz33ZF0ew2T65PFx8ey9oq66MnIR0XlQrnXb6qor45LZe8X+k8fnPT6ypioOeffm8d0P7xb/+x8z47f/snd8Yr9tY6tx9b1+35a2JO6ZvyTOvv7J2Pfc2+PQC/8c5986N554aYXuXygisoOy0WUkruWZlAGlQHZQNiqqu27TxAWpyQ3KSucmrlYjccFAyA7KRpfrVcuyqQOKnNyglO28+eiYODZ/MJWb/744o2ogG7mkyDpQ3nzzzfj85z8fv/jFL3rdb/bs2fG9730vRo4cOaDvs3LlymhoaIgVK1bE6NGjB3QOhs+Kxua45uGFcck9z8eCpas7tm89rj5O3nebOHqPiTG6tpubED1IkiTmLn4jbntqcdzy5OJ47MXl/T52i4bamLnzpnHgzpvGe7fduM8pG9NKkiQeeeSRePDBB+Pvf/97NDY2Rl1dXUyZMiWmTp0a73nPeyLX3zkmYRgUw+ul7KDcJAvui9zFB3esr2mrii8vP0F2UDCK4fVyQ2RHMTwPlIckSeLxv94Zu958ZN72X004M9619z/JDTJXDK+X3nNQbpIkiUW/+VxsPvfXHdseado6Htjms95zUBCK4fXSew7KSZIksejyU2PzeZd2bJMbFJJieL30noNy8c0bnoyL/vJcx/r46rUxbcUd7pFTcIbr9bKomrhaW1vj0EMPjVtuuaVj27o/1KqqqnjyySdj5cqVHY8ddNBB8cc//jEqKytTfy8BVRySJInlq5vjjaaWGFVTFWPqq4fkxXrxyjVx21OL47YnF8c9zy6JtS1t/Tpuo5qqOGDHCTFzpwlxwDsnRENd/xvJOmtubo6f/exnccEFF8S8efMil8tFVVVVJEkSuVwuWlpaIkmS2GGHHeILX/hCfOpTn4rq6oF/PxioQn+9lB2Uk3XZ8ftffCduOmxJ3mMjz22MxrWyg8JQ6K+XGyo7Cv15oPSt/55j8QvzYsX/zf89nHT+G7FwZZvcIHOF/nrpPQflZP3sOHbzBfGN99d2PHbtM63xwStWe89BQSj010vvOSgX6+fGYRsviO/Oejs3bn++NWb+Sm5QGAr99dJ7DsrJffNfjeMuejBv2+JffCZalr3iHjkFZbheL4tqOsUzzzwzL5w+9alPxcKFC+PBBx+M++67L15++eU488wzOx6/5ZZb4qtf/WoWpbKB5HK5GDtyREwaVx9jR44Ysm7bTUfXxgnv3Tounr1XPHLmgfGjE3aPD75nyxhT33sArGpqiesfezlO++2jscc3bo0TL7o/fnnv8/HS8sZU3/+JJ56IqVOnxqmnnhrz58+PiPaGtebm5mhpaYnm5uaOaRznz58fp556akydOjWeeOKJgf3AUMJkB+Vi/ex4+OkFXR4fXd0iO6CfZAfloPN7ju4+t1KZkxvQH3KDctFXdlRGm/cc0E+yg3LQOTeWNOaPKTGuNuQG9JPcoFw88cQT8eljZkXrm/lT7o7Ydqp75JSNohmJ6+WXX47tttsu1qxZExERH/3oR+NXv/pVt/ueeeaZ8c1vfjMiImpra+PZZ5+NLbbYItX302VMd1pa2+LB55fFbU8tjlufXBwvrDeVY1923nx0HPjWtItTthjdY8PZXXfdFYccckisXbs2Wltb+33+ysrKGDFiRNx4440xffr0fh8Hg1XIr5eyg3LROTsqcxEtX83/HZzywzfiydfy77LIDrJSyK+XGzI7Cvl5oLR1956juiJi7Zn5v4fb//eqeHbZ25cM5AZZKeTXS+85KBfdZcfp00bEdw56e0SVG+e1xKGX518rkx1kpZBfL73noBx0lxv/vENV3HB8fcc+L6xoi60veCPvOLlBVgr59dJ7DsrF+tnRMPPTsdFuh3Q8tualp2LxpV/q9jjZQVbKfiSuCy64oCOc6uvr44ILLuhx3zPPPDMmTZoUERFr1qyJCy+8cEOUSBmoqqyIadttHGcetnPc9aUD4uYv7B9fPGhy7Dqxoc9jn3xlZVz4p3lx2Pf+Evt9+44467on4s/zXsubqvGJJ56IQw45JJqamlI1cEW0D6Xa1NQUhxxyiG5jeIvsoBx0lx2tScTyNfl9+hvXdW0elh3Qleyg1PX0nqO7kbiqK/OzQ25AV3KDctDf7KjuZrYe2QFdyQ5KXU+50XkkLteqoH/kBuWgc3asnntf3uO1W+4UlSPHdnus7KDUFE0T1+9+97uOrz/84Q/HuHHjetx3xIgRMXv27I71a665Zlhrozzlcrl452Ybxan/tENcd+p+cf9XZsT/O+pdccA7x8eIyt7/tF5a3hi/vG9BfPTnD8Qe37w1PvebR+J3D70QJ5z8iVi7dm20tXVzB6Uf2traorm5OU488cRobm4e0DmglMgOSt261/zusmPJ6k4Xxuq7HwFSdkA+2UEp6y03koho6zRQd1U3b2vkBuSTG5S63rKjua3v3IiQHdCZ7KCU9ZYbSzs1cY0ckYuabhqA5QbkkxuUuu6yY82Cx6Ot6c28/ep22LvHc8gOSklRNHE988wzMX/+/I71gw8+uM9jDjnk7eH15s+fH88888yw1AbrbDq6Nk5479Zxyey94uGvHhg/PGH3+OB7toyGuupej1u1piWuf+zl+Lf/+Vssf/+c2Pjos2Kj3Q+Lyo3GD6iOlpaWePzxx+NnP/vZgI6HUiE7KAc/+9nP4vHHH+929Mb+fLpxHdkB7WQHpa633IiIaO60ubqHKwZyA9rJDcpBb9nRZSSuXq40yw5oJzsodb1eq+r0gcOInj90KDegndygHHSbHW0t0Tj/wbz96idP6/U8soNSURRNXI899lje+rRpvf+BRkTsvvvuMWLEiI71xx9/fMjrgp6MqqmKQ9+9eXz32N3ioTNmxm8+tXd8fN9tY9K4ul6Py1VWR922u8e4Az8dE//14tjspAuiYd/jonrCO1LXcOGFF0aSdH1TBOVCdlDqkiTpdejszhfGxvXSxLWO7KDcyQ5KWV+5EdH1ZnxPI6qsIzcod3KDUtdXdnTNDe85oC+yg1LWV24sW5N0Gf23r+tVcoNyJzcodb1lx+p5naZU3GqXqKgZ2ec5ZQfFriiauJ566qmOr0eMGNExl29vOu+3/jlgQ6qqrIhp220cXz1857j7S++Pm77wvvjiQZNj14kNfR5bs9n2MWa/E2Lb2d+Jfz71rDj6mCPiowdsF5+eWtPrcUmSxNy5c+PRRx8dop8Cio/soNQ98sgjMW/evB7fjCxpzL+j0tMnG9eRHSA7KG195UZERHNbflZUV/acHXID5Aalr6/saK2qz1sfUVvb6/lkB8gOSltfudGWRCxfmz9/4sb13cyn+Ba5AXKD0tdbdjT+46EY2bIi3pObFwdUPBpHVv81Tnr/dr2eT3ZQCoqiiev555/v+HrixImRy/X9qa6IiK222qrbc0BWcrlc7LjZ6Dj1n3aI607dL/46Z0Z888h3xTvq1kTS0vP8vBNyy+KGjc+Pq6bcGb+a/lr86NCamLD7zD6/14MPPtjrPlDKZAel7sEHH+zx9zpXXRNvNGyft23TTSf0eU7ZQbmTHZSy3nJjndaKEXnro3fct9f95QblTm5Q6vrMjo3y32PUjhnf5zllB+VOdlDK+vOeY3lbfgPwNvsd3uv+coNyJzcodb1lR9K8Jt712s3xu5qz4pIR58WFI34Y39r91T7PKTsodlVZF9Afq1at6vi6oaHv0YvWGT16dLfn6E5TU1M0NTV1rK9cuTJFhTAwmzXUxol7bx0PXP5fcc/PL4mqSbtE3fbvjbrtpkZl3UYd+61Iug4NObplafQWU1VVVfH3v/99GKqG4iA7KHV///vfo6qqKpqb12sCrqyKjXY7JBqmfTgaR98eES90PLTpFltExMKI6HkEFtlBuRvu7JAbZKnb3FhPrro2WqpqI2Jtx7bahk16PafcoNx5z0Gp6ys7mqM6b70yaenznLKDcuc9B6Wsr9yIiFgeG0XEGx3rDWte6fWccoNy5z0Hpa6v7Fj03DMR2769PqZqbeSqaiJpaep2/wjZQfEripG43njj7f+hq+1jWO711dXVdXuO7pxzzjnR0NDQsfRnOEoYKo2NjdG2tjFWP3NPLPnDd2Ph90+MRb+ZEysfvDaaly+KVVEfbUl+F3L960/2es4kSWL16tXDWTYUNNlBqWtsbHx7iOFcRYza5cDY8lM/jXEzT4nKkWNjWYzK239sTVuM2HyHXs8pOyh3w50dcoMs5eVGN0btcmC05vI/57V2/j29nlNuUO6856DU9ZUdbZ1GcKyK1j7PKTsod95zUMr6yo2IiOWVY/PWRze/1uv+coNy5z0Hpa6v7HhlXv798NpcS4zZftdezyk7KHZF0cTV0vL2p7iqqvo/eNj6+/bW+R8RMWfOnFixYkXH8uKLL6YvFAaorq4uf6jIttZoeuFvsez2i+Lln3wyXvr552JFS/7v/tjq3n+nc7lc1NfX97oPlDLZQalrz46KqN/xfbHFJ34YGx9yWlQ1vD2dyfJko3gjqY2FySbx2OpN4omn/hFrX5nb6zllB+VuuLNDbpClLu851periNF7fiBeSTaOhckm8VzbpvHMmrHxxrLXez2n3KDcec9Bqes1OyLijaiJl5KN44W28fFs2+bxQnPfo0PIDsqd9xyUsr5yo6J2VCyr3DiWJaPiubZN45G27WPxkhW9nlNuUO6856DU9ZUdS1Z0bUIctWJ+r+eUHRS7ophOcf0/sjVr1vT7uPX3HTmy63R066upqYmampr0xcEQmDJlSt7/iHXW/PqCWLJqVIwd93bf5di63ue9bmlpiSlTpgxZjVBsZAelLEmSGLHtHrHJCd+JEZu+o9t9ft82LX77ZHUsv/vX0fzqP/p1XtlBuRvu7JAbZKm39xz1k6dF1ZjN4ui1X+vYtuiy/xNNC3sfUUVuUO6856DU9XW96q5lm8a+TWd2rDe+8GhEPNrrOWUH5c57DkpZX7lRvfFWcXrzpyOi/d5G0tocL9xzdK/nlBuUO+85KHV9ZcfyNV1H6RrdsrzXc8oOil1RNHGNGvX2dECNjY39Pm79YfLWPwcUmqlTp/Y5zPCyxvzHx/XRxJUkSUydOnXQtUGxkh2UqvueXRL/efPT8fDiTWLEppt0u8+aF/4Wy+/+VTS99FSqc8sOyp3soJT19p5j9F75N06aXn4mmhb+vc9zyg3Kndyg1PV1vSpXnX+zL2lu6vOcsoNyJzsoZX3lRvUmk2JdA1dERPPSlyKStl7PKTcod3KDUtdXdrQl7Y1cY2rfzg/3yCl1RTGd4iabvH2D8pVXXun3cYsWLer4euONNx7SmmAovec974kddtih1+Eil3Zq4hpb2/O+uVwuJk+eHLvttttQlQhFR3ZQah59cXmceNH9cdzP/hoPv7C8232aXpkXi684Mxb/Zk7qBi7ZAbKD0tbTe46aiVOiZovJedtWPvi7Ps8nN0BuUPr6ul7VpYmrpfcmLtkBsoPS1lduVG+yVd568+sv9Ho+uQFyg9I3oHvkvTRxyQ5KQVE0cb3zne/s+HrJkiV53cO9WX/O3h133HHI64Khksvl4gtf+EKv+yxbk24krtNOO63XwINSJzsoFU8vWhmf+tX/xpE/uCf+Mv/1bvdZ+/qCePV3/y8W/erfYs3zjwz4e8kOyp3soJT19J5j9F5H5a23LF8Uq5+5t1/nlBuUO7lBqevrelVFVfqRuGQH5U52UMr6yo20TVwRcgPkBqWuX/fIU85WJTsodkXRxLXTTjvlrT/66KN9HvPSSy/Fa6+91uM5oNB86lOfil122SUqKyu7fbxzE1dPXcZVVVWxyy67xL/8y78MeY1QTGQHxe7519+ML/z2kTjkwj/HrU8u7nafiWProv7x/4lXf/mFaJx734C/l+yAdrKDUtf5PUfVuC2jfoe98/ZZ+b/X9TmlidyAdnKDctDb9arOI3G19dLEJTugneyg1PWWG9Ubd2riWvJil33WkRvQTm5QDvq6R97f2apkB6WiKJq49tprr6ipefuiwF/+8pc+j/nzn//c8XVtbW3stddew1IbDJXq6uq49NJLY8SIEVFR0fVPsz8BVVFR0XGeqqqqYasVioHsoFi9sqIx5lzzt5j53bvi2kdfju6mg5+wUU1888h3xe2nHxBXnvfFGFFd1W129IfsgLfJDkpd5/cco/c8Mu/x1jVvxBuP39rrOeQGvE1uUA56u16V6zwSVw/TKcoOeJvsoNT1lBu5mpFRtVH+lG49jcQlN+BtcoNy0Nc98v4MdCI7KCVF0cQ1atSomDFjRsf6ZZdd1ucx6+8zY8aMGDly5LDUBkPpXe96V9x4441RU1PTJWD6Giqyqqoqampq4sYbb4x3vetdw14rFDrZQbFZ8kZTfOOGJ2P6f94Zv3nghWhp69q9Nba+Or5y6I5x95ffHyfuvXWMqKroNTv6Ijsgn+ygHKzLjdox42PUu/4p77E3HvljJM1rejxWbkA+uUG56Ok9R+eRuLqbTlF2QD7ZQTnoLjeqN56Ut0/S2hLNy17pcqzcgHxyg3LR6z3yNe6RU16KookrIuLkk0/u+Prxxx+P66+/vsd9H3744bjxxhu7PRYK3fTp0+OBBx6IKVOmRC6X65izt6eRuNbtM2XKlHjggQdi+vTpG7xmKFSyg2Kwck1zfPeWZ2L/8+6In//luVjb0nUKq1E1VfGFmTvE3V9+f/zL/ttFbXX+sMI9ZUdPZAf0THZQDqZPnx6f/++r8m6+J63NserhG7rdX25Az+QG5aK79xy9NXHJDuiZ7KAcdM6NEeO3znu8edlLEW0tHetyA3omNygX7pFDu6Jp4jrmmGNi11137Vg/5ZRT4umnn+6y3yuvvBInnnhitLa2RkTEbrvtFkcfffQGqxOGwrve9a548MEH4/vf/35sv/32ERGxvNMH4td1Ge+www7x/e9/Px588EHdxdCJ7KCQNa5tjR/d+Wy879t3xH/fPj/eXNvaZZ+aqor4l/3fEXd/+f3xhZmTY6Pa6h7P11125HK5qK6ujqqqqqiuru540yM7oGeyg3LQuLY1bv5HY962N5+8M9reXCY3ICW5QTnp/J6jotN0irmkWXZAP8gOysX6uTF+u3fnPda6ZKH3HNBPcoNy4h45ROSSJOk6V0+BevDBB2P69OnR2Nh+sXn06NHxmc98Jvbff/+oqqqKBx54IL7//e/H4sWLIyKirq4u7rrrrpg6dWrq77Vy5cpoaGiIFStWxOjRo4f054A0kiSJRx99NBb+5bdx+JIfd2xfk6uLp464MXbbbbc+R1yB4VTor5eyg0KztqUtfvvgC/G92+fHa6u6TjcSEVFVkYuP7DUpPvdPO8Smo2tTf4912fHggw/G3//+91i9enXU19fHlClTYurUqbKDzBX66+WGyo5Cfx4oXZf+dUGcce0TedsumDU+Xp33qNygIBX666X3HJSjJEnioP+8NeYtbe7YttvaJ+LQHcfKDgpCob9ees9BufnYz++Pu+e93rH+jtVPx7tzL3jPQcEo9NdL7zkoR+vuc6y88/sxfcVVHdtfrZ4ULx36a9lB5obr9bKomrgiIq655po48cQTO0KqJ3V1dXHppZfGBz/4wQF9HwFFwVn0RMSP911vQy7iq0sjKopmQD1KVDG8XsoOCkFLa1v87pGX4oLb5sVLy7v/XczlIo56z5bxhRmTY6uN6zdwhbDhFMPr5YbIjmJ4Hig9bW1JzPjuXfHc6292bJs+eXz88uN7ZVgV9K4YXi+956AczTr/7nhm8aqO9f8+7j1xxK5bZFgRvK0YXi+956Cc7HPOn+LlFW8PpfK9494Th8sMCkgxvF56z0HZevK6iCs/9vb6uHdEfP6R7OqBtwzX62XRdX988IMfjIceeihmzpzZbWdlLpeLGTNmxP/+7/8OOJygINWN7bQhiWhakUkpUGxkB1lqa0viD4+/ErMuuDu+dNXjPTZwHTxls7j5C/vHdz+8mwYuKACyg1J121OL8xq4IiI+9b53ZFQNlA65QTlqbM6fEr6uujKjSqA4yQ7Kxao1zXkNXBERkzfdKKNqoHjJDcpW53vkjcszKQM2lKqsCxiInXbaKW699dZ48cUX45577omXXnopIiK23HLL2HfffWPSpEkZVwjDoG5M122Ny7pp7gK6IzvY0JIkiTvnvhbfufmZ+PvLK3vcb//J4+OLB02OXSaO2XDFAf0iOyhFP/vzP/LWd9p8dOy7/cYZVQOlRW5QbjRxweDJDsrB/FffyFuvrMjFNpv4ACMMhNygLNWOyV9fszyirc1sVZSsomziWmfSpEnxkY98JOsyYMOoro+oHBHRuvbtbTqNITXZwYZw/z+WxHdueSYefH5Zj/tM3WZsfPGgd8Z73+HGORQ62UGxS5Iklq1ujgeeW9Ilm/5l/227/QQvMHByg3KxZm1+E1dttZsoMFCyg1I2r1MT19Yb10dNlcZfGAy5QVnpPKBJ0haxdlVEbUM29cAwK+omLigruVx7p/Gbr769rbHn5gAANrzHFy6P79wyN+6e+1qP+0zZYnR8cdY744DJ4900B2BYrWhsjqsfWhi/vPf5WLB0dZfHJ2xUE4ftskUGlQFQzNbly6qmlrztn7v8kfjU/u+Io/eYGA111RlVB0Ch6TwS1w4TRmVUCQBFqafZqjRxUaI0cUExqRuT38S1ZnlWlQCwnnmLV8V/3TI3bvr7oh732W78yDj9oHfGwVM2i4oKzVsADK+75r4Wn7n0oWjsNErK+patXhv3Prskpk8evwErA6CYrcuX1d3kyysr18Q3bngyvnPLM/GjE/eQLwBERMTcxavy1idvulFGlQBQlEaMiqioimhb70MkjcsjxvZ4BBQ1TVxQTDoPF2kkLoBMvbBkdVxw29z43aMvRZJ0v8+WY+riCzN3iKPes2VUVZpeBIDhd9fc12L2xQ9EEhE9xFNERDS3JjH74gfi4tl7udEOQJ/Wz5eeJBHR2NwqXwDoMG9x/khc2xuJC4A01s1Wtfr1t7e5R04J08QFxaR2TP564/IsqgAoe4tXronv3T4vfvvAi9HS1v0tjPEb1cTn/mn7OHbqpKipqtzAFQJQrlY0NsdnLn2ovYGrt7vsb0ki4jOXPhT3zZlh6isAepQmX5IkInLyBYCIN5ta4qXljXnbdphgJC4AUqobm9/EZbYqSpgmLigmRuICyNTSN9fGj+96Nn557/PR1NLW7T4NddXxmQO2i5OmbRN1IzRvAbBhXf3Qwmhc29rrKCnrS5KIxrWtcc3DC2P2vtsOa20AFC/5AsBAPPta/ihcFbmId4wfmVE1ABStujH56+6RU8I0cUEx6RxQuowBBiVJkli2ujnebGqJkTVVMba+OnK5XJf9Vq1pjp//5bm46M/PxRtNLd2cKWLkiMr4xH7bxif3f0eMrvVJcwA2vCRJ4pf3Pj+gYy+55/k4eZ9tus1BAMqbfAFgoOYuWpW3vtW4+qit9qFHAFLqMtDJ8kzKgA1BExcUEwEFMCRWNDbH1Q8tjF/e+3wsWLq6Y/vW4+rjpH22iaP3mBgNddWxprk1fnXf8/GjO5+NZaubuz3XiKqK+NjeW8dnDtguNh5Vs6F+BADoYtnq5rxc668kIhYsXR3LVzfH2JEjhr4wAIqafAEgrXXX3i64bW7e9sUrm+IXf3mu49obAPRL7Zj8dSNxUcI0cUEx6RJQy7OoAqCo3TX3tfjMpQ9F49rWLo+9sHR1fOOGJ+M/b346PrTnpLj574ti8cqmbs9TVZGLD+05KT4/Y/vYvKFuuMsGgD692cNokf31RlOLm+wAdCFfAEhj/WtvnafhbWxujW/c8GR855Zn4kcn7hHTJ4/PpEYAikzngU7MVkUJ08QFxURAAQzKXXNfi9kXPxBJRJeLSLHetsbmtvjVfQu6PUcuF/GBXbeIL8ycHNtsMnK4SgWA1EbWDO4t/qhBHg9AaZIvAPRXX9fe4q3tjc2tMfviB+Li2Xtp5AKgb3Vj8tcNdEIJq8i6ACCFLgFlqEiA/lrR2ByfufSh9otIPV1F6sNBO28aN522f1zwkfdo4AKg4Iytr46tx9VHLuVxuWifUnhMvelMAOhKvgDQH2muvSVJezPXZy59KFY0Nm+I8gAoZp0HOnGPnBKmiQuKSZeAWp5JGQDF6OqHFrYP4z6ABq79tt8krv3svvHTj+0Z79xso6EvDgCGQC6Xi5P22WZAx5687zaRy6W9PQ9AOZAvAPRH2mtvSRLRuLY1rnl44fAWBkDxqx2Tv262KkqYJi4oJp0DqvnNiJa1mZQCUEySJIlf3vv8gI7ddKOa+PUn9ordJo0Z0poAYDgcvcfEqBtRGf29X16Ri6gbURkf3H3i8BYGQFGTLwD0ZjDX3i655/lIBjpsPgDlwXSKlBFNXFBMOgdUhE5jgH5Ytro5FixdHQO5HLR4VVMsX21YdwCKQ0NddfzoxD0iF9HnjfZ1j//4xD2ioc5UVwD0TL4A0JuBXntLImLB0tWuvQHQO7NVUUY0cUEx6TwSV4Q5fwH64c2mlkEd/8YgjweADWn65PFx8ey9oq66sv1me6fH122rq66MS2bvFftPHr/hiwSg6MgXAHri2hsAw6rzPfK1qyJaNQBTmqqyLgBIoWpERPXI9mkU19FpDNCnkTWD+1+eUYM8HgA2tOmTx8d9c2bENQ8vjEvueT4WLF3d8dhW4+rj5H23iaP3mBija42QAkD/yRcAuuPaGwDDqvNIXBERa1ZEjNxkw9cCw8z/FUGxqRvbqYnLSFwAfRlbXx1bj6uPF1IO656L9hsRY+rdgACg+DTUVcfsfbeNk/fZJpavbo43mlpiVE1VjKmvjlxfc2EBQA/kCwCdufYGwLCqG9N1W+MyTVyUJNMpQrHpHFJrlmdRBUBRyeVycdI+2wzo2JP33caNCACKWi6Xi7EjR8SkcfUxduQIuQbAkJAvAKzj2hsAw6qqJqK6Pn+b2aooUZq4oNh0Hi7SSFwA/XL0HhOjbkRl9PeaUEUuom5EZXxw94nDWxgAAAAAFDnX3gAYVrVj8tfdI6dEaeKCYlPbkL+uyxigXxrqquNHJ+4RuYg+Lyate/zHJ+4RDXWGcwcAAACA3rj2BsCw6jzQidmqKFGauKDYGIkLYMCmTx4fF8/eK+qqK9svKHV6fN22uurKuGT2XrH/5PEbvkgAAAAAKEKuvQEwbOrG5K+7R06Jqsq6ACClzgGlyxgglemTx8d9c2bENQ8vjEvueT4WLF3d8dhW4+rj5H23iaP3mBija30KEAAAAADScO0NgGHRZaCT5ZmUAcNNExcUGyNxAQxaQ111zN532zh5n21i+ermeKOpJUbVVMWY+urI9TXeOwAAAADQI9feABhytWPy190jp0Rp4oJi0yWglmdRBUBJyOVyMXbkiBg7ckTWpQAAAABASXHtDYAhY7YqykRF1gUAKRmJCwAAAAAAAIBy0bmJyz1ySpQmLig2uowBAAAAAAAAKBddBjpZnkkZMNw0cUGx6W6+3yTJpBQAAAAAAAAAGFbd3SOHEqSJC4pN5y7jtpaItW9mUwsAAAAAAAAADKfO98jNVkWJ0sQFxabzdIoRQgoAAAAAAACA0tT5HnnjcrNVUZI0cUGxqWmIiFz+NsNFAgAAAAAAAFCKOk+n2NoU0dyYSSkwnDRxQbGpqIiobcjf1rg8k1IAAAAAAAAAYFh1nk4xwmxVlCRNXFCMOoeUkbgAAAAAAAAAKEWdBzmJcI+ckqSJC4pR5zl/dRkDAAAAAAAAUIoqKs1WRVnQxAXFyEhcAAAAAAAAAJSL2jH56+6RU4I0cUEx6hJQy7OoAgAAAAAAAACGX+eBTsxWRQnSxAXFyEhcAAAAAAAAAJSLujH56+6RU4I0cUEx6hxQuowBAAAAAAAAKFVdBjpZnkkZMJw0cUExMt8vAAAAAAAAAOXCPXLKgCYuKEa6jAEAAAAAAAAoF53vkZutihKkiQuKkfl+AQAAAAAAACgX7pFTBjRxQTHSZQwAAAAAAABAuTBbFWVAExcUo87z/a5ZEdHWmkkpAAAAAAAAADCsOt8jNxIXJUgTFxSjzl3GEe2NXAAAAAAAAABQarqMxLUsIkmyqQWGiSYuKDaNyyP+dlXX7T9+X8Rff2TYSAAAAAAAAABKR+PyiHm35G9bszziwt3cI6ekaOKCYjL/tojv7hxx21e7PrZyYcRNc9ofn3/bhq8NAAAAAAAAAIbSunvk9/5318eWP+8eOSVFExcUi/m3RVz24Yjmxl52Stofv+zDQgoAAAAAAACA4uUeOWVGExcUg8blEVd87K05fdv62Lmtfb8rPmbYSAAAAAAAAACKj3vklCFNXFAMHvtNRPPq6Duc1mlr3/+x3w5nVQAAAAAAAAAw9Nwjpwxp4oJClyQR9/9kYMfe/+O3OpMBAAAAAAAAoAi4R06Z0sQFhW710ohlz0VE2qBJ2o9rXDYcVQEAAAAAAADA0HOPnDKliQsK3do3Bnd806qhqQMAAAAAAAAAhpt75JQpTVxQ6EaMGtzxNRsNTR0AAAAAAAAAMNzcI6dMaeKCQlc/LmLsthGRS3lgrv24urHDURUAAAAAAAAADD33yClTmrig0OVyEe89ZWDHvvfT7ccDAAAAAAAAQDFwj5wypYkLisGux0VU10e//2RzFe377/qRYS0LAAAAAAAAAIace+SUIU1cUAzqxkQc+6u3Oob7+rOtiIhcxLG/bj8OAAAAAAAAAIqJe+SUIU1cUCy2nxlxwpUR1XXRPvdv5yEg39pWXRdxwv9EbD9jw9cIAAAAAAAAAEPBPXLKTFXWBQApbD8z4t+fjHjstxH3/zhi2XNvPzZ2m/b5fXc7LqK2IbMSAQAAAAAAAGBIuEdOGdHEBcWmbkzE3p+OeO8pEY3LIppWRdRsFFE39q2hJAEAAAAAAACgRLhHTpnQxAXFKpeLqB/XvgAAAAAAAABAKXOPnBJXkXUBAAAAAAAAAAAA5UwTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGRIExcAAAAAAAAAAECGNHEBAAAAAAAAAABkSBMXAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGSo6Jq4li9fHn/605/i29/+dhxzzDGxzTbbRC6X61jOPvvsrEsEoIDIDQDSkh0ApCE3AEhLdgCQhtwAKB9VWReQxuTJk2P+/PmRJEnWpQBQBOQGAGnJDgDSkBsApCU7AEhDbgCUl6Jq4po3b17WJQBQROQGAGnJDgDSkBsApCU7AEhDbgCUl6Jq4lqnoaEhdt9995g6dWrsueeecdppp8Urr7ySdVkAFCi5AUBasgOANOQGAGnJDgDSkBsA5aGomrguu+yy2HPPPWOHHXaIXC7Xsf1LX/pShlUBUKjkBgBpyQ4A0pAbAKQlOwBIQ24AlJeiauI6/vjjsy4BgCIiNwBIS3YAkIbcACAt2QFAGnIDoLxUZF0AAAAAAAAAAABAOdPEBQAAAAAAAAAAkCFNXAAAAAAAAAAAABnSxAUAAAAAAAAAAJAhTVwAAAAAAAAAAAAZqsq6gELR1NQUTU1NHesrV67MsBoAioHsACANuQFAWrIDgDTkBgBpyQ6AwmIkrrecc8450dDQ0LFMmjQp65IAKHCyA4A05AYAackOANKQGwCkJTsACosmrrfMmTMnVqxY0bG8+OKLWZcEQIGTHQCkITcASEt2AJCG3AAgLdkBUFgG3MR16aWXRi6XG/LlkksuGcIfr/9qampi9OjReQsAQ6fUciNCdgAMt1LLDrkBMLxKLTciZAfAcCu17JAbAMOr1HIjQnYAFBojcQEAAAAAAAAAAGSoaqAHjhw5MrbccsuhrKXjvACUHrkBQFqyA4A05AYAackOANKQGwAMtwE3cR111FFx1FFHDWUtAJQwuQFAWrIDgDTkBgBpyQ4A0pAbAAw30ykCAAAAAAAAAABkSBMXAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGSoqJq4vvnNb0ZtbW2XZcGCBan2AaA8yA0A0pIdAKQhNwBIS3YAkIbcACgvVVkXkEZLS0s0NTX1uk9ra2u0trZ22Z4kyXCVBUCBkhsApCU7AEhDbgCQluwAIA25AVBeimokLgAAAAAAAAAAgFKTS7TgdmvlypXR0NAQK1asiNGjR2ddDkDB8nr5Ns8FQP94vWzneQDoH6+Xb/NcAPSP18t2ngeA/vF6+TbPBUD/DNfrpZG4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADKkiQsAAAAAAAAAACBDmrgAAAAAAAAAAAAypIkLAAAAAAAAAAAgQ5q4AAAAAAAAAAAAMqSJCwAAAAAAAAAAIEOauAAAAAAAAAAAADJUlXUBaaxevTruuuuuuP322+ORRx6Jp59+OpYsWRK5XC7Gjh0bU6ZMienTp8fs2bNjiy22yLpcADImNwBIS3YAkIbcACAt2QFAGnIDoLzkkiRJsi6iL4sXL47TTjstrr/++li9enWf+1dXV8cXv/jFOPvss2PEiBED+p4rV66MhoaGWLFiRYwePXpA5wAoB4X4eplFbkQU5nMBUIgK8fXSew6AwlWIr5fecwAUtkJ8vfSeA6BwFeLrpfccAIVtuF4vi2IkrhdffDGuuOKKvG25XC7e8Y53xGabbRaVlZUxb968eOWVVyIiorm5Oc4555x49NFH49prrx1UUAFQfOQGAGnJDgDSkBsApCU7AEhDbgCUp4qsC0gjl8vFjBkz4rLLLotXX3015s+fH3/5y1/irrvuipdffjnuvPPO2HnnnTv2v/HGG+PMM8/MsGIAsiQ3AEhLdgCQhtwAIC3ZAUAacgOgvBRFE1dFRUUcffTR8cQTT8Rtt90Wxx9/fGyyySZd9ps+fXrce++9eUF1wQUXxOLFizdkuQBkTG4AkJbsACANuQFAWrIDgDTkBkB5Koomrt133z2uuuqqvPDpSUNDQ5x//vkd62vXro0bbrhhOMsDoMDIDQDSkh0ApCE3AEhLdgCQhtwAKE9F0cSV1owZM6Kurq5j/emnn86wGgAKndwAIC3ZAUAacgOAtGQHAGnIDYDSUJJNXJWVldHQ0NCxvnLlygyrAaDQyQ0A0pIdAKQhNwBIS3YAkIbcACgNJdnE1djYGK+++mrH+oQJEzKsBoBCJzcASEt2AJCG3AAgLdkBQBpyA6A0lGQT13XXXRdtbW0d69OmTcuwGgAKndwAIC3ZAUAacgOAtGQHAGnIDYDSUHJNXC0tLfGtb32rY33ChAkxY8aMDCsCoJDJDQDSkh0ApCE3AEhLdgCQhtwAKB1VWRcw1M4999z429/+1rF+xhlnRE1NTZ/HNTU1RVNTU8f6ihUrIsJ8wQB9Wfc6mSRJxpUMzEBzI0J2AAxUuWaH3AAYmHLNjQjZATBQ5ZodcgNgYMo1NyJkB8BADVt2JCXkpptuSioqKpKISCIi2WeffZKWlpZ+HXvWWWd1HGexWCyW9Muzzz47zK/yQ28wuZEkssNisVgGu5RbdsgNi8ViGdxSbrmRJLLDYrFYBruUW3bIDYvFYhncUm65kSSyw2KxWAa7DHV25JKkSFuKO3nqqadi3333jWXLlkVExNixY+ORRx6Jrbfeul/Hd+4yXr58eWy99dbxwgsvRENDw7DUDGmtXLkyJk2aFC+++GKMHj0663IgIto/lbHVVlvFsmXLYsyYMVmX02+DzY0I2UFxkB0UonLNDrlBMZAbFKJyzY0I2UFxkB0UonLNDrlBMZAbFKJyzY0I2UFxkB0UouHKjgFPp3jppZfGRz/60SErZJ2LL744Tj755FTHvPjiizFr1qyOgKqvr48bbrghVUDV1NR0O6xkQ0ODFwIKzujRo/1eUnAqKip6fbzUciNCdlBcZAeFqNyyQ25QTOQGhajcciNCdlBcZAeFqNyyQ25QTOQGhajcciNCdlBcZAeFqK/sSH2+IT1bBhYvXhwzZ86MF198MSLag+baa6+NffbZJ+PKAChEcgOAtGQHAGnIDQDSkh0ApCE3AErXgEfiGjlyZGy55ZZDWUvHeftr6dKlceCBB8bcuXMjIqKqqiquuOKKOPDAA4e8LgAGR24AkJbsACANuQFAWrIDgDTkBgDDbcBNXEcddVQcddRRQ1lLKitXroxZs2bF3/72t4hoH6Ls0ksvjQ984ANDcv6ampo466yzuh0+ErLi95JC1N/fy1LPjQh/oxQmv5cUItnRzt8nhcjvJYVIbrzN3yiFyO8lhUh2tPP3SSHye0khkhtv8zdKIfJ7SSEart/LXJIkyZCecQN48803Y9asWXHPPfdEREQul4uLL744TjrppIwrA6AQyQ0A0pIdAKQhNwBIS3YAkIbcACgPFVkXkNaaNWviiCOO6AioiIgf/vCHAgqAbskNANKSHQCkITcASEt2AJCG3AAoH0XVxLV27do4+uij4/bbb+/Ydv7558enP/3pDKsCoFDJDQDSkh0ApCE3AEhLdgCQhtwAKC9F08TV2toaxx9/fPzxj3/s2Patb30rvvCFL2RXFAAFS24AkJbsACANuQFAWrIDgDTkBkD5KYomriRJ4uMf/3hcffXVHdu++tWvxpw5czKsCoBCJTcASEt2AJCG3AAgLdkBQBpyA6A85ZIkSbIuoi9XXnllHHvssR3rtbW1MX369H4fv8suu8R55503HKUBUIDkBgBpyQ4A0pAbAKQlOwBIQ24AlKeqrAvoj9WrV+etr1mzJm6++eZ+H79mzZqhLilWr14dd911V9x+++3xyCOPxNNPPx1LliyJXC4XY8eOjSlTpsT06dNj9uzZscUWWwz596d83HvvvfHLX/4y/vznP8dLL70USZLExIkTY7/99ouTTjop9t1336xLpIwsX7487rjjjrjjjjvi0Ucfjblz58ayZcuiuro6xo0bF7vuumvMmDEjTjrppBg7dmxmdRZibkTIDjYc2UGhKJbciCjM7JAbbChyg0JSLNlRiLkRITvYcGQHhaJYciOiMLNDbrAhyQ4KRbFkRyHmRoTsYMORGxSKDZ4bSRG4+OKLk4gY8DJ9+vQhq2XRokXJsccem9TX1/fre1dXVydz5sxJmpqahqwGysMbb7yRfPzjH+/zd2z27NnJG2+8kXW5lLinnnoqOeyww5IRI0b067Wvvr4+Of/885O2trZM6i2k3EgS2cGGIzsoFMWWG0lSWNkhN9hQ5AaFpNiyo5ByI0lkBxuO7KBQFFtuJElhZYfcYEOSHRSKYsuOQsqNJJEdbDhyg0KRVW4UxXSKheR///d/Y+rUqXnbcrlcvOMd74jNNtssKisrY968efHKK6/k7XPIIYfEtddeGyNGjNiQ5VKkWltb49BDD41bbrmlY1tdXV1MmTIlqqqq4sknn4yVK1d2PHbQQQfFH//4x6isrMyiXMrAVVddFR/60IfytlVWVsb2228fm266abS2tsZTTz0VS5cuzdvnk5/8ZPz0pz+NXC63IcstOLKDDUF2UEjkxuDIDTYEuUGhkR2DIzvYEGQHhURuDI7cYEORHRQS2TE4soMNQW5QSDLLjSFpQSsjDz74YBIRSS6XS2bMmJFcdtllyWuvvdZlvzvvvDPZeeed8zrvvvzlL2dQMcVozpw5eb87n/rUp5IlS5Z0PP7GG28kZ555Zt4+X/nKVzKsmFL3P//zP0lEJFVVVcmRRx6ZXHvttcmKFSvy9mlra0uuvfbaZMstt8z73fzhD3+YUdWFQ3awIcgOConcGBy5wYYgNyg0smNwZAcbguygkMiNwZEbbCiyg0IiOwZHdrAhyA0KSVa5oYkrpYceeig5+uijk7///e997rt8+fK8kBoxYkSyaNGiDVAlxeyll15KamtrO35vPvrRj/a47xlnnNGxX21tbfLSSy9twEopJ9dee23yyU9+MlmwYEGf+77wwgvJZptt1vG7uckmmyRr167dAFUWLtnBcJMdFBq5MThyg+EmNyhEsmNwZAfDTXZQaOTG4MgNNgTZQaGRHYMjOxhucoNCk1VuaOIaZjfffHNex91FF12UdUkUuC996Usdvy/19fV53cWdNTU1JZMmTdLJTsH5yU9+kvfad9ttt2VdUlGRHaQlOyh2cmNw5AZpyQ1KgewYHNlBWrKDYic3BkduMBCyg2InOwZHdpCW3KDYDVVuVATDasaMGVFXV9ex/vTTT2dYDcXgd7/7XcfXH/7wh2PcuHE97jtixIiYPXt2x/o111wzrLVBfx1++OF561770pEdpCU7KHZyY3DkBmnJDUqB7Bgc2UFasoNiJzcGR24wELKDYic7Bkd2kJbcoNgNVW5o4hpmlZWV0dDQ0LG+cuXKDKuh0D3zzDMxf/78jvWDDz64z2MOOeSQjq/nz58fzzzzzLDUBml0/h8rr33pyA7SkB2UArkxOHKDNOQGpUJ2DI7sIA3ZQSmQG4MjN0hLdlAKZMfgyA7SkBuUgqHKDU1cw6yxsTFeffXVjvUJEyZkWA2F7rHHHstbnzZtWp/H7L777jFixIiO9ccff3zI64K0FixYkLfutS8d2UEasoNSIDcGR26QhtygVMiOwZEdpCE7KAVyY3DkBmnJDkqB7Bgc2UEacoNSMFS5oYlrmF133XXR1tbWsd6fFxzK11NPPdXx9YgRI2LSpEl9HtN5v/XPAVnpPGyp1750ZAdpyA5KgdwYHLlBGnKDUiE7Bkd2kIbsoBTIjcGRG6QlOygFsmNwZAdpyA1KwVDlhiauYdTS0hLf+ta3OtYnTJgQM2bMyLAiCt3zzz/f8fXEiRMjl8v167itttqq23NAFlasWBEXXnhhx/ouu+wSO++8c4YVFRfZQVqyg2InNwZHbpCW3KAUyI7BkR2kJTsodnJjcOQGAyE7KHayY3BkB2nJDYrdUOaGJq5hdO6558bf/va3jvUzzjgjampqMqyIQrdq1aqOr9efJ7ovo0eP7vYckIXTTz89Fi1a1LH+zW9+M8Nqio/sIC3ZQbGTG4MjN0hLblAKZMfgyA7Skh0UO7kxOHKDgZAdFDvZMTiyg7TkBsVuKHNDE9cwufnmm+Oss87qWN9nn33iX//1XzOsiGLwxhtvdHxdW1vb7+Pq6uq6PQdsaBdddFH8/Oc/71g/9thj4/DDD8+wouIiOxgI2UExkxuDIzcYCLlBsZMdgyM7GAjZQTGTG4MjNxgo2UExkx2DIzsYCLlBMRvq3NDENQyeeuqpOO644zrm+R07dmxcfvnlUVlZmXFlFLqWlpaOr6uqqvp93Pr7Njc3D2lN0F933313fPazn+1Y33bbbeMnP/lJhhUVF9nBQMkOipXcGBy5wUDJDYqZ7Bgc2cFAyQ6KldwYHLnBYMgOipXsGBzZwUDJDYrVcORGSTRxXXrppZHL5YZ8ueSSS1LX8uKLL8asWbNi2bJlERFRX18fN9xwQ2y99dZD/FNTiurr6zu+XrNmTb+PW3/fkSNHDmlN0B+PPvpoHHHEEbF27dqIaJ/f/Kabbko15OmGJjsoFbKDYiQ35AbZkRsUK9khO8iO7KAYyQ25QbZkB8VIdsgOsiM3KEbDlRsl0cRVKBYvXhwzZ86MF198MSIiampq4tprr4199tkn48ooFqNGjer4urGxsd/HrV69uttzwIbwzDPPxKxZs2LFihUR0f7JiltuuSUmT56ccWXFQXYwWLKDYiM3BkduMFhyg2IkOwZHdjBYsoNiIzcGR24wFGQHxUZ2DI7sYLDkBsVmOHOj/2PRFbCRI0fGlltuOSzn7a+lS5fGgQceGHPnzo2I9qH7rrjiijjwwAOHvC5K1yabbNLx9SuvvNLv4xYtWtTx9cYbbzykNUFvnnvuuZg5c2a8+uqrERGx0UYbxY033hi77rprxpX1TXZQKmQHxURudH/e/pIbDAW5QbGRHd2ft79kB0NBdlBM5Eb35+0vucFQkR0UE9nR/Xn7S3YwFOQGxWS4c6MkmriOOuqoOOqoozL7/v+/vfsHjSINAzj8rn8wARHsFLHWNGqTWAhJsSsBFYUoBETUUjvBws5SSBobsVMQVguxExQbQTSNJiIqiJWFiSASxECSRXD3isO98zzRdXb2m4nPA8LOOl94i5Bf8zKzsLAQo6Oj8eLFi4iIWLVqVdTr9Th06FCymSinbdu2tT/Pz8/H0tLSN4+P/JGvm+0REdu3b89lNviv2dnZqFarMTs7GxH/PBp39+7diSf7NdrBSqEdlIVuZKMbdItuUCbakY120C3aQVnoRja6QTdpB2WhHdloB92iG5RFL7rhdYoZLS4uxr59+2J6ejoiIiqVSly9ejXGx8cTT0YZDQwMfHP97Nmzn56Zm5uLDx8+/PBnQB6+Phr3zZs3EfHPo3GHh4cTT1YO2kE3aQdloBvZ6AbdpBuUhXZkox10k3ZQBrqRjW7QbdpBGWhHNtpBN+kGZdCrbljiyqDRaMTBgwdjamqq/d3ly5fjxIkTCaeizIaGhmLdunXt60ePHv30zMOHD9uf+/r6YmhoKJfZ4Kv5+fmo1Wrx+vXriIhYu3Zt3Lp1y6Nxf5F20G3aQdHpRja6QbfpBmWgHdloB92mHRSdbmSjG+RBOyg67chGO+g23aDoetkNS1y/6fPnz3H48OG4f/9++7uLFy/GqVOnEk5F2a1fvz6q1Wr7+vr16z898+97qtVqR++phk59+vQpRkdH4+XLlxERsXr16rhx40YcOHAg8WTloB3kQTsoMt3IRjfIg25QdNqRjXaQB+2gyHQjG90gL9pBkWlHNtpBHnSDIut1Nyxx/YYvX77E0aNH486dO+3vLly4EGfOnEk3FCvGyZMn25+fP38et2/f/uG9T58+jbt37/7vWei2xcXF2L9/f8zMzETE3+82v3btWhw5ciTxZOWgHeRJOygi3chGN8iTblBU2pGNdpAn7aCIdCMb3SBv2kERaUc22kGedIMiStKNFh1pNput48ePtyKi/e/8+fOpx2IFaTabrZ07d7Z/vzZv3tx69erVd/e9e/euNTAw0L5v165drWazmWBi/gSNRqNVq9Xav2+VSqV15cqV1GOVhnaQN+2gaHQjG90gb7pBEWlHNtpB3rSDotGNbHSDXtAOikY7stEO8qYbFE2qblRarVarm0thK93NmzdjfHy8fd3X1xcjIyO/fH7Hjh0xOTmZx2isIE+ePImRkZFYXl6OiIgNGzbE6dOnY3h4ONasWROPHz+OS5cuxfv37yMior+/Px48eBCDg4Mpx2YFm5ycjHPnzrWvN27c2NG7pffu3Rtnz57NY7RS0A56QTsoEt3IRjfoBd2gaLQjG+2gF7SDItGNbHSDXtEOikQ7stEOekE3KJJU3VjT8Yk/3NLS0jfXjUYj7t2798vnG41Gt0diBRocHIx6vR7Hjh2L5eXlWFhYiImJiZiYmPju3v7+/qjX6+JErv77t+/jx48d/e3btGlTt0cqFe2gF7SDItGNbHSDXtANikY7stEOekE7KBLdyEY36BXtoEi0IxvtoBd0gyJJ1Y1Vv3UKyN3Y2FjMzMxErVaLSqXy3f9XKpWoVqsxPT0dY2NjCSYEoGi0A4BO6AYAndIOADqlHQB0Qjf403mdIpTA27dvY2pqKubm5iIiYsuWLbFnz57YunVr4skAKCrtAKATugFAp7QDgE5pBwCd0A3+RJa4AAAAAAAAAAAAEvI6RQAAAAAAAAAAgIQscQEAAAAAAAAAACRkiQsAAAAAAAAAACAhS1wAAAAAAAAAAAAJWeICAAAAAAAAAABIyBIXAAAAAAAAAABAQpa4AAAAAAAAAAAAErLEBQAAAAAAAAAAkJAlLgAAAAAAAAAAgIQscQEAAAAAAAAAACRkiQsAAAAAAAAAACAhS1wAAAAAAAAAAAAJWeICAAAAAAAAAABIyBIXAAAAAAAAAABAQn8B08hzID4T9P0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 3000x500 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-0.1055,  0.2865],\n",
      "        [ 0.0534, -0.6757]])\n"
     ]
    }
   ],
   "source": [
    "rs_vecs = [v]\n",
    "rs_vecs.append(torch.matmul(rs_vecs[-1], R))\n",
    "rs_vecs.append(torch.matmul(rs_vecs[-1], D))\n",
    "new_v = rs_vecs[-1].clone()\n",
    "#new_v[0,0], new_v[1,0] = rs_vecs[-1][1,0], rs_vecs[-1][0,0]\n",
    "new_v[0,0] = rs_vecs[-1][1,0]\n",
    "rs_vecs.append(new_v)\n",
    "rs_vecs.append(torch.matmul(rs_vecs[-1], D_inv))\n",
    "rs_vecs.append(torch.matmul(rs_vecs[-1], R.T))\n",
    "plot_vecs(rs_vecs, title=\"Rot then Scale then Project\")\n",
    "print(rs_vecs[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a196d38b-dfc2-4388-9d73-36db86a6b566",
   "metadata": {},
   "source": [
    "# Rot Only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 528,
   "id": "71336caf-5e0a-422a-b773-ae61cf857221",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABmoAAAHyCAYAAADr1pFOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABXuElEQVR4nO3deXhddZ0/8M9t9rRN2lLKUqCAUKRoQaCsSuHXFoQBRgRFWYQ6MriNMio6qIALA8osyOigggo4BQURqzLsW4WCUtmXUijD0rIU6JKWZmmW+/uj9rZJkyZNbnLuuff1ep7zPDnnnnPySUjvm3s+5/s9mWw2mw0AAAAAAACG3LCkCwAAAAAAAChVGjUAAAAAAAAJ0agBAAAAAABIiEYNAAAAAABAQjRqAAAAAAAAEqJRAwAAAAAAkBCNGgAAAAAAgIRo1AAAAAAAACREowYAAAAAACAhGjUAAJBSV111VWQymdxSXl4e22yzTXzsYx+L559/vl/nfOCBB+Jb3/pWrFixok/733zzzfGtb32r29cymUx8/vOf71cdg6G739d2220XM2fOjFdffTWv32vHHXeM008/Pa/n3NBll10WV1111aCdHwAAGDoaNQAAkHJXXnllPPjgg3HnnXfG5z//+fjDH/4Q73//+2P58uWbfa4HHnggvv3tb29Wo+bb3/72Zn+fJK37fd1xxx1xxhlnxK9+9av4wAc+EKtXr87b9/jd734X5557bt7O15VGDQAAFI/ypAsAAAAG5j3veU/su+++ERFx6KGHRnt7e5x//vkxe/bsmDlzZsLVFZ4Nf1+HHXZYtLe3x3e/+92YPXt2nHzyyd0e09jYGLW1tX3+Hu973/vyUisAAFD8jKgBAIAis64JsWTJkk7b//CHP8SBBx4YtbW1MXLkyJgxY0Y8+OCDude/9a1vxdlnnx0RETvttFNuirB777232+9z+umnx3//939HRHSaUuyll17qtN///M//xO677x61tbWx5557xk033bTRuZ5//vk46aSTYty4cVFVVRW777577tzr3HvvvZHJZOJXv/pVfOMb34htt9026urqYvr06bFgwYLN+h1t6IADDoiIiJdffjn3c40YMSKefPLJOPzww2PkyJExbdq0iIhYtmxZfPazn43x48dHZWVl7LzzzvGNb3wjWlpaOp2zu6nPVq5cGV/5yldip512isrKyhg/fnycddZZG43k6ejoiB/+8Iex1157RU1NTYwaNSoOOOCA+MMf/pA799NPPx1z5szJ/c533HHHfv/8AABAsoyoAQCAIvPiiy9GRMTEiRNz26699to4+eST4/DDD49f/epX0dLSEhdffHEceuihcdddd8X73//++NSnPhXLli2LH/7wh3HjjTfGNttsExERkyZN6vb7nHvuubF69eq44YYbOjV81h0XEfG///u/MW/evPjOd74TI0aMiIsvvjiOO+64WLBgQey8884REfHMM8/EQQcdFDvssEP8x3/8R2y99dZx2223xRe+8IV4++234/zzz+/0fb/+9a/HwQcfHD/72c9i5cqV8bWvfS2OOeaYmD9/fpSVlW3272vhwoUREbHlllvmtq1ZsyaOPfbYOPPMM+Nf/uVfoq2tLZqbm+Owww6LF154Ib797W/H5MmT47777ouLLrooHnvssfjf//3fHr9HY2NjTJ06NRYvXhxf//rXY/LkyfH000/HeeedF08++WTceeedkclkImJto2jWrFnxD//wD/Gd73wnKisr45FHHsk1wH73u9/FCSecEPX19XHZZZdFRERVVdVm/9wAAEBh0KgBAICUa29vzzUS5s6dGxdccEEccsghceyxx0bE2hEaZ599drz3ve+NW265JYYNWzuw/qijjop3vetd8bWvfS3mzp0b2223Xeywww4RsXbqrt5GabzrXe+KrbbaKiLWj0rpqqmpKe68884YOXJkRETsvffese2228b1118f//Iv/xIREV/60pdi5MiRcf/990ddXV1ERMyYMSNaWlrie9/7XnzhC1+I0aNH5845adKkmDVrVm69rKwsPvrRj8a8efN6rKOn39ecOXPiggsuiJEjR+Z+XxERra2tcd5553WaOu6nP/1pPPHEE3H99dfHRz7ykVydI0aMiK997Wtxxx13xIwZM7r9nv/1X/8VTzzxRPzlL3/JjXiaNm1ajB8/Pk444YS49dZb48gjj4z77rsv/ud//ie+8Y1vxAUXXJA7/oMf/GDu6/e9731RU1MTdXV1ffp5AQCAwmbqMwAASLkDDjggKioqYuTIkfHBD34wRo8eHb///e+jvHztfVkLFiyI1157LU499dRckyYiYsSIEXH88cfHn//852hsbByU2g477LBckyYiYquttopx48blphlrbm6Ou+66K4477riora2Ntra23HLUUUdFc3Nz/PnPf+50zg0bKhERkydPjoj1U5f1ZsPf19FHHx1bb7113HLLLbmm0zrHH398p/W77747hg8fHieccEKn7eumOLvrrrt6/J433XRTvOc974m99tqr0894xBFHdJpe7pZbbomIiM997nN9+lkAAID0M6IGAABS7pe//GXsvvvusWrVqrjuuuvipz/9aXz84x/PXfRfunRpRHSekmydbbfdNjo6OmL58uVRW1ub99q22GKLjbZVVVVFU1NTrra2trb44Q9/GD/84Q+7Pcfbb7+9yXOum/Zr3Tl7s+73VV5eHltttVW3v5fa2trc6J51li5dGltvvXVuirJ1xo0bF+Xl5bnfc3eWLFkSCxcujIqKim5fX/czvvXWW1FWVhZbb711n34WAAAg/TRqAAAg5XbffffcdFqHHXZYtLe3x89+9rO44YYb4oQTTsg1Nl5//fWNjn3ttddi2LBhnaYWG0qjR4+OsrKyOPXUU3scRbLTTjvl9Xtu+PvqSddmTMTaBtFf/vKXyGaznV5/8803o62tLcaOHdvj+caOHRs1NTXxi1/8osfXI9Y+J6e9vT3eeOONbhtIAABA8TH1GQAAFJmLL744Ro8eHeedd150dHTEbrvtFuPHj49rr702stlsbr/Vq1fHb3/72zjwwANzo2k2d3TK5u7fVW1tbRx22GHx6KOPxuTJk2PffffdaOluVE4Spk2bFu+8807Mnj270/Zf/vKXudd7cvTRR8cLL7wQW2yxRbc/47rnAR155JEREfHjH/94k7VsOCoJAABINyNqAACgyIwePTrOOeec+OpXvxrXXnttnHLKKXHxxRfHySefHEcffXSceeaZ0dLSEv/2b/8WK1asiO9973u5Y9/73vdGRMSll14ap512WlRUVMRuu+3W6TkzG1q3//e///048sgjo6ysLCZPnhyVlZV9rvfSSy+N97///fGBD3wgPvOZz8SOO+4Yq1atioULF8Yf//jHuPvuuwfw28ifT3ziE/Hf//3fcdppp8VLL70U733ve+P++++PCy+8MI466qiYPn16j8eeddZZ8dvf/jYOOeSQ+Od//ueYPHlydHR0xCuvvBK33357fPnLX479998/PvCBD8Spp54aF1xwQSxZsiSOPvroqKqqikcffTRqa2vjn/7pnyJi7e/917/+dVx33XWx8847R3V1de6/BQAAkC4aNQAAUIT+6Z/+KX70ox/Fd77znfj4xz8eJ510UgwfPjwuuuiiOPHEE6OsrCwOOOCAuOeee+Kggw7KHXfooYfGOeecE1dffXVcccUV0dHREffcc08ceuih3X6fk046KebOnRuXXXZZfOc734lsNhsvvvhiboRIX0yaNCkeeeSR+O53vxvf/OY3480334xRo0bFrrvuGkcdddQAfxP5U11dHffcc0984xvfiH/7t3+Lt956K8aPHx9f+cpX4vzzz99o/w2nRxs+fHjcd9998b3vfS8uv/zyePHFF6OmpiZ22GGHmD59eqff11VXXRV77713/PznP4+rrroqampqYtKkSfH1r389t8+3v/3teP311+OMM86IVatWxYQJE+Kll14azB8fAAAYJJnshnMfAAAAMGBjxoyJT37yk/Hv//7vSZcCAAAUOCNqAAAA8uSJJ56Im2++OZYvXx4HHnhg0uUAAAApYEQNAABAnhx22GHx7LPP5p4LtOH0ZwAAAN3RqAEAAAAAAEjIsKQLAAAAAAAAKFUaNQAAAAAAAAnRqAEAAAAAAEiIRg0AAAAAAEBCNGoAAAAAAAASolEDAAAAAACQEI0aAAAAAACAhGjUAAAAAAAAJESjBgAAAAAAICEaNQAAAAAAAAnRqAEAAAAAAEiIRg0AAAAAAEBCNGoAAAAAAAASolEDAAAAAACQEI0aAAAAAACAhGjUAAAAAAAAJESjBgAAAAAAICEaNQAAAAAAAAnRqAEAAAAAAEiIRg0AAAAAAEBCNGoAAAAAAAASUp50AZtrxYoVcc8998Q999wTjz32WDz33HOxfPnyqKioiDFjxsSee+4Z06ZNi9NOOy1Gjx6ddLkAFCh5AkA+yBMA8kWmAJSuTDabzSZdRF88++yzcfbZZ8ftt98ea9as6XX/2tra+Nd//df44he/GJlMZggqBCAN5AkA+SBPAMgXmQJAaho1N9xwQ3zkIx/ptK2srCx22WWX2GqrraK9vT3mz58fy5Yt67TPpz71qbj88ssFFwARIU8AyA95AkC+yBQAUveMmvLy8vjQhz4Us2fPjmXLlsWzzz4bc+bMifvvvz/efvvtmD17dowfPz63/89+9rP4yU9+kmDFABQieQJAPsgTAPJFpgCUrtSMqPn9738fN910U5x77rmxww47bHLf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+awld96+WrZsWcyYMSOee+65iIgoLy+P6667LmbMmJH3ugAYHPIEgHyQJwDki0wBYKj1u1Fz3HHHxXHHHZfPWjbLypUr44gjjognn3wyItYONZo1a1b8/d//fV7OX1VVFeeff363Q0Mhaf4+KXSb8zcqTyBZ/kYpZPKkM/9eKWT+Pil0MmU9/14pZP4+KXSD9TeayWaz2byecQisXr06jjjiiJg7d25ERGQymbjyyivjtNNOS7gyANJEngCQD/IEgHyRKQClKXXPqGlubo5jjz02F1gREZdddpnAAmCzyBMA8kGeAJAvMgWgdKWqUbNmzZo4/vjj4+67785tu+SSS+LTn/50glUBkDbyBIB8kCcA5ItMAShtqWnUtLe3x0knnRQ333xzbtuFF14YZ511VnJFAZA68gSAfJAnAOSLTAEgFY2abDYbn/zkJ+O3v/1tbtt5550X55xzToJVAZA28gSAfJAnAOSLTAEgIiKTzWazSRfRm+uvvz5OPPHE3Hp1dXVMnTq1z8dPnjw5Lr744sEoDYAUkScA5IM8ASBfZAoAERHlSRfQF42NjZ3Wm5ub47bbbuvz8c3NzfkuKRobG2POnDlx9913x6OPPhrPPvtsLF26NDKZTIwePTr22GOPmDp1asycOTO23XbbvH9/StMDDzwQV199ddx3333x6quvRjabje222y7e//73x2mnnRYHH3xw0iVSYlasWBH33HNP3HPPPfHYY4/Fc889F8uXL4+KiooYM2ZM7LnnnjFt2rQ47bTTYvTo0UmXK0/gb+QJhShNmVKIeRIhUxh68oRClKY8iSjMTJEnJEGmUGiGPE+yKXDllVdmI6Lfy9SpU/NWyxtvvJE98cQTs7W1tX363hUVFdlzzjkn29LSkrcaKD3vvPNO9pOf/GSvf28zZ87MvvPOO0mXSwmYP39+9uijj85WVlb26b2wtrY2e8kll2Q7OjoSrVueUOrkCYUojZlSSHmSzcoUhp48oRClMU+y2cLKFHlCEmQKhSapPEnF1GeF5K9//WtMmTKl07ZMJhM777xzbL311lFWVhbPP/98vP766532OfLII2P27NlRWVk5lOVSBNrb2+Ooo46K22+/PbetpqYm9thjjygvL49nnnkmVq5cmXvt8MMPj5tvvjnKysqSKJcSccMNN8RHPvKRTtvKyspil112ia222ira29tj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",
      "text/plain": [
       "<Figure size 2000x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-0.1055,  0.2865],\n",
      "        [ 0.0534, -0.6757]])\n"
     ]
    }
   ],
   "source": [
    "r_vecs = [v]\n",
    "r_vecs.append(torch.matmul(r_vecs[-1], R))\n",
    "new_v = r_vecs[-1].clone()\n",
    "#new_v[0,0], new_v[1,0] = r_vecs[-1][1,0], r_vecs[-1][0,0]\n",
    "new_v[0,0] = r_vecs[-1][1,0]\n",
    "r_vecs.append(new_v)\n",
    "r_vecs.append(torch.matmul(r_vecs[-1], R.T))\n",
    "plot_vecs(r_vecs, title=\"Rot then Project\")\n",
    "print(r_vecs[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c7deb02-2bfd-4bd2-9143-e0be253898b5",
   "metadata": {},
   "source": [
    "# Scale then Rot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 529,
   "id": "1847fb68-8ca2-405a-9e0f-b1293065a033",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACXEAAAHyCAYAAACnYB+XAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABq60lEQVR4nOzdeXgddb0/8M/J0iwt3YCytRQEKlAELligoFRtoYisgiKLlipe1IuiF/XeelnVK8v9XZHrvoJYUBARBGWVRQUEZN8LCF1YSumSbmmbNPP7IzT0JG2SyTZneb2eZx4yc2Ymn5wnnTdn5pPvN5ckSRIAAAAAAAAAAABkoiLrAgAAAAAAAAAAAMqZJi4AAAAAAAAAAIAMaeICAAAAAAAAAADIkCYuAAAAAAAAAACADGniAgAAAAAAAAAAyJAmLgAAAAAAAAAAgAxp4gIAAAAAAAAAAMiQJi4AAAAAAAAAAIAMaeICAAAAAAAAAADIkCYuAAAAoCTdf//9cfTRR8e2224bNTU1scUWW8TEiRPjjDPO6Lfvedlll0Uul4uXX365T8736quvxrnnnhuPPvpoh9dOPvnkGDJkSJ98n76Sy+XylqFDh8b+++8fv/71r3t0vpUrV8a5554bd911V7f2L/b3a9iwYfG+970v/vjHP/bp9zn33HMjl8v16TnXd++998a5554bS5Ys6bfvAQAAAFDqNHEBAAAAJeePf/xj7L///rF06dK46KKL4tZbb41LLrkkDjjggLjqqquyLq/bXn311TjvvPM22JRUqI499ti477774t57740f/ehHsXTp0jjhhBPiyiuvTH2ulStXxnnnnZeqiatY36977rknvv/978frr78ehx9+eJ82cp1yyilx33339dn52rv33nvjvPPO08QFAAAA0AtVWRcAAAAA0Ncuuuii2H777eOWW26Jqqq3b3987GMfi4suuijDykrfFltsEfvtt19EREycODEOOOCA2G677eLHP/5xnHDCCRlXV3jWf7/233//mDhxYuy4447xne98Jz70oQ9t8JimpqbI5XJ5v9udGT16dIwePbrPagYAAACg7xmJCwAAACg5CxcujM0222yDTS4VFR1vh1x55ZUxceLEGDJkSAwZMiT23HPP+PnPf972+m233RZHHnlkjB49Ompra2PHHXeMU089Nd58881u1XP77bfH5MmTY+jQoVFfXx8HHHBA/PnPf+70mLvuuismTJgQERHTp09vm3Lv3HPPzdvvhRdeiEMPPTSGDBkSY8aMiTPOOCNWr16dt8+aNWvim9/8Zuy8885RU1MTm2++eUyfPj0WLFiQt992220Xhx12WNx8882x1157RV1dXey8887xi1/8ols/54aMHTs2Nt9885g/f37e9jlz5sRJJ50Uo0aNipqamthll13if//3f6OlpSUiIl5++eXYfPPNIyLivPPOa/v5Tz755A1+n1J5v3bYYYfYfPPNY/bs2W0/Vy6Xi1/96ldxxhlnxDbbbBM1NTXxwgsvRETEL37xi9hjjz2itrY2Ro4cGUcffXQ888wzeefc2HSKV111VUycODEGDx4cQ4YMialTp8YjjzzSYb/7778/Dj/88Nh0002jtrY2dthhh/jiF7/Ydu6vfOUrERGx/fbbt73v3R09DQAAAIBWmrgAAACAkjNx4sS4//774wtf+ELcf//90dTUtNF9zz777DjxxBNj6623jssuuyx+//vfx7Rp09qaaCIiXnzxxZg4cWL88Ic/jFtvvTXOPvvsuP/+++M973lPp+eOiJg5c2YcfPDBMXTo0PjlL38ZV199dYwcOTKmTp3aaSPXXnvtFZdeemlERJx55plx3333xX333RennHJK2z5NTU1xxBFHxOTJk+P666+PT37yk3HxxRfHhRde2LZPS0tLHHnkkXHBBRfECSecEH/84x/jggsuiNtuuy3e9773RWNjY973feyxx+KMM86IL33pS3H99dfH7rvvHp/61KfiL3/5S6c/58Y0NDTEokWLYty4cW3bFixYEPvvv3/ceuut8Y1vfCP+8Ic/xJQpU+LLX/5ynHbaaRERsdVWW8XNN98cERGf+tSn2n7+s846q6Tfr8WLF8fChQvbGtjWmTFjRsyZMyd+9KMfxQ033BCjRo2K888/Pz71qU/F+PHj49prr41LLrkkHn/88Zg4cWI8//zznX6fb33rW3H88cfHrrvuGldffXX86le/imXLlsV73/veePrpp9v2u+WWW+K9731vzJkzJ7797W/HTTfdFGeeeWZbU94pp5wSn//85yMi4tprr2173/faa68e/fwAAAAAZSsBAAAAKDFvvvlm8p73vCeJiCQikurq6mT//fdPzj///GTZsmVt+/3zn/9MKisrkxNPPLHb525paUmampqS2bNnJxGRXH/99W2vXXrppUlEJC+99FKSJEmyYsWKZOTIkcnhhx+ed461a9cme+yxR7LPPvt0+r0efPDBJCKSSy+9tMNr06ZNSyIiufrqq/O2H3roock73/nOtvVf//rXSUQkv/vd7zZ47h/84Adt28aOHZvU1tYms2fPbtvW2NiYjBw5Mjn11FM7rTVJkiQiks997nNJU1NTsmbNmmTWrFnJEUcckWyyySbJP/7xj7b9/vM//zOJiOT+++/PO/6zn/1sksvlkueeey5JkiRZsGBBEhHJOeec0+X3Xv9nKtb365lnnkk++MEPJhGRfP/730+SJEnuvPPOJCKSAw88MO/YxYsXJ3V1dcmhhx6at33OnDlJTU1NcsIJJ7RtO+ecc5L1bwPOmTMnqaqqSj7/+c/nHbts2bJkyy23TD760Y+2bdthhx2SHXbYIWlsbNzoz/E///M/eb/3AAAAAKRnJC4AAACg5Gy66abx17/+NR588MG44IIL4sgjj4xZs2bFjBkz4l3velfbNIi33XZbrF27Nv7t3/6t0/O98cYb8ZnPfCbGjBkTVVVVUV1dHWPHjo2I6DB13fruvffeWLRoUUybNi2am5vblpaWljjkkEPiwQcfjBUrVvT458zlcnH44Yfnbdt9993zRhG78cYbY/jw4XH44Yfn1bDnnnvGlltu2WHauz333DO23XbbtvXa2toYN25c3jk784Mf/CCqq6tj0KBBMW7cuLjpppvi17/+dey9995t+9xxxx2x6667xj777JN37MknnxxJksQdd9zR3bcglUJ/v3bZZZe499574+tf/3p87nOfy9vvmGOOyVu/7777orGxscP0kmPGjIkPfOADnY7ydsstt0Rzc3N84hOfyPsZa2trY9KkSW0/46xZs+LFF1+MT33qU1FbW9utnwcAAACAnqnKugAAAACA/vLud7873v3ud0dE61R6//Ef/xEXX3xxXHTRRXHRRRfFggULIiJi9OjRGz1HS0tLHHzwwfHqq6/GWWedFe9617ti8ODB0dLSEvvtt1+H6fXWt27KuWOPPXaj+yxatCgGDx7ckx8v6uvrOzTX1NTUxKpVq/JqWLJkSQwaNGiD51jX0LbOpptu2mGfmpqaTn/O9X30ox+Nr3zlK9HU1BRPPPFEzJgxIz72sY/Fww8/HDvttFNERCxcuDC22267DsduvfXWba/3h0J+v3K5XGyyySaxww47RGVlZYf9ttpqq7z1de9R++0Rre/jbbfdttHvue73csKECRt8vaKi9e8+u/PvAwAAAIC+oYkLAAAAKAvV1dVxzjnnxMUXXxxPPvlkRERsvvnmERExb968GDNmzAaPe/LJJ+Oxxx6Lyy67LKZNm9a2/YUXXujye2622WYREfHd73439ttvvw3us8UWW6T6OdLabLPNYtNNN42bb755g69vsskmffr9Nt9887bGuYkTJ8Yuu+wSkyZNii996Utx4403RkRr49Nrr73W4dhXX321reasZPl+dSaXy+Wtr2se29j72Nl7uO61a665pm1EuY3VFtH67wMAAACA/qWJCwAAACg5r7322gZHKFo39eG6EZ8OPvjgqKysjB/+8IcxceLEDZ5rXfNMTU1N3vYf//jHXdZxwAEHxPDhw+Ppp5+O0047LdXPsP737O6oThty2GGHxW9+85tYu3Zt7Lvvvj0+T0+9973vjU984hPxy1/+Mu67776YOHFiTJ48Oc4///x4+OGHY6+99mrb9/LLL49cLhfvf//7IyL9z18K71d3TZw4Merq6mLmzJnxkY98pG37vHnz4o477uh09LepU6dGVVVVvPjiix2maVzfuHHjYocddohf/OIX8e///u8d/g2s0xfvOwAAAEC508QFAAAAlJypU6fG6NGj4/DDD4+dd945Wlpa4tFHH43//d//jSFDhsTpp58eERHbbbddfO1rX4tvfOMb0djYGMcff3wMGzYsnn766XjzzTfjvPPOi5133jl22GGH+M///M9IkiRGjhwZN9xwQ6fT1a0zZMiQ+O53vxvTpk2LRYsWxbHHHhujRo2KBQsWxGOPPRYLFiyIH/7whxs9focddoi6urq44oorYpdddokhQ4bE1ltv3daE1h0f+9jH4oorrohDDz00Tj/99Nhnn32iuro65s2bF3feeWcceeSRcfTRR3f7fD3xjW98I6666qo466yz4vbbb48vfelLcfnll8eHPvSh+PrXvx5jx46NP/7xj/GDH/wgPvvZz8a4ceMionXUq7Fjx8b1118fkydPjpEjR8Zmm222wakYI0rn/eqO4cOHx1lnnRVf+9rX4hOf+EQcf/zxsXDhwjjvvPOitrY2zjnnnI0eu91228XXv/71+K//+q/45z//GYccckiM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G7Q3b968mDx5csybNy8i3h4ad9999824su6RHZQK2UGxkBu9IzfoK3KDYiI7ekd20FdkB8VCbvSO3KAvyQ6KhezoHdlBX5EbFIuByA3TKfbSihUr4tBDD41//OMfERGRy+XiF7/4RRx33HEZV0Yx2mWXXfLWH3300S6PeeWVV2LBggUbPQf0h3VD47700ksR8fbQuAceeGDGlRUH2UFfkh0UA7nRO3KDviQ3KBayo3dkB31JdlAM5EbvyA36muygGMiO3pEd9CW5QTEYqNzQxNULq1atiiOOOCLuueeetm0/+MEPYtq0aRlWRTHbZ599oqampm39b3/7W5fH/PWvf237ura2NvbZZ59+qQ3WWbhwYUyZMiWee+65iIiorq6Oa665xtC43SQ76Guyg0InN3pHbtDX5AbFQHb0juygr8kOCp3c6B25QX+QHRQ62dE7soO+JjcodAOZG5q4emjNmjVxzDHHxB133NG27eKLL47PfOYzGVZFsRsyZEhMnjy5bf2KK67o8pj195k8eXKqeaohrYaGhpg6dWo8+eSTERFRWVkZV155ZRx22GEZV1YcZAf9QXZQyORG78gN+oPcoNDJjt6RHfQH2UEhkxu9IzfoL7KDQiY7ekd20B/kBoVsoHNDE1cPrF27Nk444YT405/+1LbtW9/6Vnzxi1/MrihKxsknn9z29eOPPx433HDDRvd9+OGH46abbtrgsdDXVqxYER/60IfioYceiojWuc1/+ctfxrHHHptxZcVBdtCfZAeFSG70jtygP8kNCpXs6B3ZQX+SHRQiudE7coP+JjsoRLKjd2QH/UluUIgyyY2EVFpaWpJPfOITSUS0LWeffXbWZVFCWlpakj322KPt92urrbZKnnnmmQ77vfrqq8kuu+zStt+ee+6ZtLS0ZFAx5WDVqlXJlClT2n7fcrlc8vOf/zzrsoqG7KC/yQ4KjdzoHblBf5MbFCLZ0Tuyg/4mOyg0cqN35AYDQXZQaGRH78gO+pvcoNBklRu5JEmSvmwKK3VXX311HHfccW3rtbW1MWnSpG4fv/vuu8dFF13UH6VRQh588MGYNGlSNDY2RkTE0KFD47Of/WwceOCBUVVVFQ888EB873vfi/nz50dERF1dXdx9990xYcKELMumhF100UXxH//xH23rI0aMSDW39EEHHRRnnHFGf5RWFGQHA0F2UEjkRu/IDQaC3KDQyI7ekR0MBNlBIZEbvSM3GCiyg0IiO3pHdjAQ5AaFJKvcqEp9RJlbuXJl3vqqVavilltu6fbxq1at6uuSKEETJkyImTNnxkknnRSNjY2xdOnSuPDCC+PCCy/ssG9dXV3MnDlTONGv2l/7Fi9enOrat+WWW/Z1SUVFdjAQZAeFRG70jtxgIMgNCo3s6B3ZwUCQHRQSudE7coOBIjsoJLKjd2QHA0FuUEiyyo2KHh0F9LsPf/jD8dBDD8WUKVMil8t1eD2Xy8XkyZPjH//4R3z4wx/OoEIACo3sACANuQFAWrIDgLRkBwBpyA3KnekUoQjMnTs37rnnnnjllVciImKbbbaJAw44IMaMGZNxZQAUKtkBQBpyA4C0ZAcAackOANKQG5QjTVwAAAAAAAAAAAAZMp0iAAAAAAAAAABAhjRxAQAAAAAAAAAAZEgTFwAAAAAAAAAAQIY0cQEAAAAAAAAAAGRIExcAAAAAAAAAAECGNHEBAAAAAAAAAABkSBMXAAAAAADA/2/XjgUAAAAABvlbD2NPcQQAADCSuAAAAAAAAAAAAEYSFwAAAAAAAAAAwEjiAgAAAAAAAAAAGElcAAAAAAAAAAAAI4kLAAAAAAAAAABgJHEBAAAAAAAAAACMJC4AAAAAAAAAAIBRQXgA5WsJ9WgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 3000x500 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[-0.5541,  0.1933],\n",
      "        [ 0.0534, -0.6757]])\n"
     ]
    }
   ],
   "source": [
    "sr_vecs = [v]\n",
    "sr_vecs.append(torch.matmul(sr_vecs[-1], D))\n",
    "sr_vecs.append(torch.matmul(sr_vecs[-1], R))\n",
    "new_v = sr_vecs[-1].clone()\n",
    "#new_v[0,0], new_v[1,0] = sr_vecs[-1][1,0], sr_vecs[-1][0,0]\n",
    "new_v[0,0] = sr_vecs[-1][1,0]\n",
    "sr_vecs.append(new_v)\n",
    "sr_vecs.append(torch.matmul(sr_vecs[-1], R.T))\n",
    "sr_vecs.append(torch.matmul(sr_vecs[-1], D_inv))\n",
    "plot_vecs(sr_vecs, title=\"Scale then Rot then Project\")\n",
    "print(sr_vecs[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a798df50-0292-40ee-8d6d-c96d8d721f37",
   "metadata": {},
   "source": [
    "# Scale Only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 530,
   "id": "46d2c9a5-da44-4060-8cb7-2727b2958eb2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "#vecs = [v]\n",
    "#vecs.append(torch.matmul(D,vecs[-1]))\n",
    "#vecs.append(torch.matmul(D_inv, vecs[-1]))\n",
    "#plot_vecs(vecs,title=\"Scale Only\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 531,
   "id": "969f75ac-9b7e-4fc5-a091-df8047a074bf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABmoAAAHyCAYAAADr1pFOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABRUUlEQVR4nO3deXwfdZ0/8Pe3SZqkLU0PKGc5LCCHAiIFCi7190uhgJyCIocWFBZ1XcFlcX91uWUB2QNZFRWUYy3ugoggyC0ICCxUpJzlKEIPCgV6QpumOeb3R+23zdHmmmQy+T6fj8c8+M58ZybvhHRe+c575jOFJEmSAAAAAAAAoM8NyroAAAAAAACAUqVRAwAAAAAAkBGNGgAAAAAAgIxo1AAAAAAAAGREowYAAAAAACAjGjUAAAAAAAAZ0agBAAAAAADIiEYNAAAAAABARjRqAAAAAAAAMqJRAwAA/diTTz4ZRx99dGy99dZRWVkZm266aUyYMCHOOuusXvua119/fRQKhXjzzTdT2d/8+fPjggsuiBkzZrR57+STT45hw4al8nXSUigUWkw1NTXx6U9/On73u9+l+nUuuOCCKBQKqe5zXY8//nhccMEFsWTJkl77GgAAQM9p1AAAQD/1u9/9Lvbbb79YtmxZXH755XHffffFlVdeGfvvv3/cdNNNWZfXafPnz48LL7yw3UZNf3XsscfGE088EY899lj86Ec/infeeScOP/zwVJs1p556ajzxxBOp7a+1xx9/PC688EKNGgAA6OfKsy4AAABo3+WXXx7bbbdd3HvvvVFevvZP9y984Qtx+eWXZ1jZwLfpppvGvvvuGxER++23X0yYMCG23377+P73vx+f+cxn2t2moaEhCoVCi/9XG7LVVlvFVlttlVrNAABAPrmjBgAA+qmFCxfGxhtv3O6J/0GD2v4p/8tf/jImTJgQw4YNi2HDhsUee+wRP//5z4vv33///XHkkUfGVlttFVVVVbH99tvH6aefHu+//36n6nnggQeitrY2hg8fHkOGDIn9998/fv/7329wmz/84Q8xfvz4iIg45ZRTisOJXXDBBS3WmzVrVhx66KExbNiwGDt2bJx11llRX1/fYp1Vq1bFxRdfHDvttFNUVlbGJptsEqecckq89957Ldbbdttt47DDDot77rkn9txzz6iuro6ddtoprr322k59n+0ZN25cbLLJJjF79uzi91UoFOIXv/hFnHXWWbHllltGZWVlzJo1KyIirr322th9992jqqoqRo0aFUcffXTMnDmzxT7XN/TZTTfdFBMmTIihQ4fGsGHDYvLkyfHMM8+0We/JJ5+Mww8/PEaPHh1VVVUxbty4OPPMM4v7PvvssyMiYrvttiv+3P/whz90+2cAAAD0Do0aAADopyZMmBBPPvlkfPOb34wnn3wyGhoa1rvueeedFyeeeGJsscUWcf3118dvfvObmDJlSrGxEBHx+uuvx4QJE+LHP/5x3HfffXHeeefFk08+GZ/61Kc2uO+IiGnTpsVBBx0Uw4cPjxtuuCFuvvnmGDVqVEyePHmDzZo999wzrrvuuoiIOOecc+KJJ56IJ554Ik499dTiOg0NDXHEEUdEbW1t3H777fHlL385rrjiivje975XXKe5uTmOPPLIuOyyy+KEE06I3/3ud3HZZZfF/fffH5/+9Kejrq6uxdd99tln46yzzopvfetbcfvtt8duu+0WX/nKV+KRRx7Z4Pe5PosXL46FCxfGJpts0mL51KlTY86cOfGTn/wk7rjjjhgzZkxceuml8ZWvfCV23XXXuPXWW+PKK6+M5557LiZMmBCvvfbaBr/OJZdcEscff3zssssucfPNN8cvfvGL+OCDD+Jv/uZv4qWXXiqud++998bf/M3fxJw5c+I//uM/4u67745zzjknFixYEBGrh1X7+7//+4iIuPXWW4s/9z333LNb3z8AANCLEgAAoF96//33k0996lNJRCQRkVRUVCT77bdfcumllyYffPBBcb2//OUvSVlZWXLiiSd2et/Nzc1JQ0NDMnv27CQikttvv7343nXXXZdERPLGG28kSZIky5cvT0aNGpUcfvjhLfbR1NSU7L777snee++9wa81ffr0JCKS6667rs17U6ZMSSIiufnmm1ssP/TQQ5OPfvSjxfn//u//TiIi+fWvf93uvq+66qrism222SapqqpKZs+eXVxWV1eXjBo1Kjn99NM3WGuSJElEJF//+teThoaGZNWqVcnMmTOTQw45JImI5Ec/+lGSJEny0EMPJRGRHHDAAS22Xbx4cVJdXZ0ceuihLZbPmTMnqaysTE444YTisvPPPz9Z9yPZnDlzkvLy8uTv//7vW2z7wQcfJJtttlny+c9/vrhs3Lhxybhx45K6urr1fh//+q//2uL/IwAA0D+5owYAAPqp0aNHx6OPPhrTp0+Pyy67LI488sh49dVXY+rUqfHxj3+8OGTZ/fffH01NTfF3f/d3G9zfu+++G1/96ldj7NixUV5eHhUVFbHNNttERLQZlmtdjz/+eCxatCimTJkSjY2Nxam5uTkOPvjgmD59eixfvrzb32ehUIjDDz+8xbLddtutxd1Ad955Z4wYMSIOP/zwFjXssccesdlmm7UZ0muPPfaIrbfeujhfVVUVO+64Y4t9bshVV10VFRUVMXjw4Nh5553j8ccfj4suuii+/vWvt1jvmGOOaTH/xBNPRF1dXZx88sktlo8dOzb+7//9vxu8++jee++NxsbG+NKXvtTie6yqqoqJEycWv8dXX301Xn/99fjKV74SVVVVnfp+AACA/qtzT7kEAAAys9dee8Vee+0VEauHCfunf/qnuOKKK+Lyyy+Pyy+/vPiMlg09mL65uTkOOuigmD9/fpx77rnx8Y9/PIYOHRrNzc2x7777thk6bF1rhtM69thj17vOokWLYujQod359mLIkCFtGg6VlZWxcuXKFjUsWbIkBg8e3O4+Wj9nZ/To0W3Wqays3OD3ua7Pf/7zcfbZZ0ehUIiNNtooxo0bF2VlZW3W23zzzVvML1y4sN3lERFbbLFF3H///ev9mmt+zmue6dPamucSdeb/NwAAkB8aNQAAkCMVFRVx/vnnxxVXXBEvvPBCRETxuSnz5s2LsWPHtrvdCy+8EM8++2xcf/31MWXKlOLyWbNmdfg1N95444iI+MEPfhD77rtvu+tsuummXfo+umrjjTeO0aNHxz333NPu+xtttFGqX2+TTTYpNsc2pFAotJhf0yB6++2326w7f/784s+yPWveu+WWW4p3Oq2vtojV/78BAID806gBAIB+6u233273zow1w5RtscUWERFx0EEHRVlZWfz4xz+OCRMmtLuvNQ2FysrKFst/+tOfdljH/vvvHyNGjIiXXnopvvGNb3Tpe1j3a3b2bpb2HHbYYfE///M/0dTUFPvss0+399PbJkyYENXV1TFt2rT43Oc+V1w+b968ePDBBzd4V9LkyZOjvLw8Xn/99TZDqq1rxx13jHHjxsW1114b//AP/9Dm/+kaafzcAQCA3qdRAwAA/dTkyZNjq622isMPPzx22mmnaG5ujhkzZsS///u/x7Bhw+KMM86I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",
      "text/plain": [
       "<Figure size 2000x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[ 0.0534,  0.1874],\n",
      "        [ 0.0534, -0.6757]])\n"
     ]
    }
   ],
   "source": [
    "s_vecs = [v]\n",
    "s_vecs.append(torch.matmul(s_vecs[-1], D))\n",
    "new_v = s_vecs[-1].clone()\n",
    "#new_v[0,0], new_v[1,0] = s_vecs[-1][1,0], s_vecs[-1][0,0]\n",
    "new_v[0,0] = s_vecs[-1][1,0]\n",
    "s_vecs.append(new_v)\n",
    "s_vecs.append(torch.matmul(s_vecs[-1], D_inv))\n",
    "plot_vecs(s_vecs, title=\"Scale then Project\")\n",
    "print(s_vecs[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bf1a0a24-519d-4ca9-bd67-60a558e38df6",
   "metadata": {},
   "source": [
    "# MSEs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 533,
   "id": "6ab78214-7235-4bef-b77c-5b3e08782e89",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rs r tensor(0.)\n",
      "rs sr tensor(0.4583)\n",
      "rs s tensor(0.1873)\n",
      "r sr tensor(0.4583)\n",
      "r s tensor(0.1873)\n",
      "sr s tensor(0.6076)\n"
     ]
    }
   ],
   "source": [
    "def mse(v, u):\n",
    "    return torch.norm(v-u)\n",
    "vectors = [rs_vecs,r_vecs, sr_vecs, s_vecs]\n",
    "names = [\"rs\", \"r\", \"sr\", \"s\"]\n",
    "for i in range(len(vectors)):\n",
    "    for j in range(i+1,len(vectors)):\n",
    "        print(names[i],names[j],mse(vectors[i][-1][0],vectors[j][-1][0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 536,
   "id": "7d93a2e2-3cee-4a8f-b9d4-211454d058cc",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rs r tensor(1.0000)\n",
      "rs sr tensor(0.6352)\n",
      "rs s tensor(0.8077)\n",
      "r sr tensor(0.6352)\n",
      "r s tensor(0.8077)\n",
      "sr s tensor(0.0577)\n"
     ]
    }
   ],
   "source": [
    "def cosine(v, u):\n",
    "    return torch.dot(v,u)/(torch.norm(v)*torch.norm(u))\n",
    "vectors = [rs_vecs,r_vecs, sr_vecs, s_vecs]\n",
    "names = [\"rs\", \"r\", \"sr\", \"s\"]\n",
    "for i in range(len(vectors)):\n",
    "    for j in range(i+1,len(vectors)):\n",
    "        print(names[i],names[j], cosine(vectors[i][-1][0],vectors[j][-1][0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec141383-f4b6-4447-bb93-1128011cda1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dfdaa7a8-4f78-497f-9b14-36ad763a2457",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "39b0b2fd-85bb-43e5-aa75-f86d0635e953",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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peoL11fd/tDgrbArD/Mv1Rmvuu0BW2LXONtiMMTY2FgdOXKkqgYhudTF788884zD/Evd/WhVf5XD/KrB/bsf3Zx5GBlxgVUcPHiwjh07VjfddNNl16enp+vYsWN18ODBEU22Rd18d9WDT1dVM3hCuVRnfHD9wae9KfY50LRtu+YG6dLSUu3evbs++OCDmpyc3Iy5YEvp9Xo1Pz9fZ86cqb1799bs7KwnltW8fXLwuvHrz3/yC/3bHxo8sQjLtrbeHogLsHGWPx68FbZzwhnLNWK9PXCgD2ycHdeJyueUMxcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBOXACIExcA4sQFgDhxASBufD2L2ratqqqlpaUNHQaAre1iBy52YZh1xaXb7VZV1czMzP85FgDXgm63W7t37x56v2nXyk9V9fv9WlxcrImJiWqaJjogANtH27bV7XZramqqOp3hJyvrigsAfBYO9AGIExcA4sQFgDhxASBOXACIExcA4sQFgLj/Ah3+eANhqAw1AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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TlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKE5cAChOXAAoru+yXFRVVZJk9uzZK3QYAJrbgg4s6MKSLFNc2tvbkyTDhg1bzrEA6Ana29szcODAJX6+pVpafpLUarVMnTo1bW1taWlpKTogAN1HVVVpb2/PkCFD0tq65JOVZYoLALwRDvQBKE5cAChOXAAoTlwAKE5cAChOXAAoTlwAKO5/AWNs6GJSWBuFAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "v1 = np.array([\n",
    "    [np.sqrt(2)/2,np.sqrt(2)/2],\n",
    "    [-np.sqrt(2)/2,np.sqrt(2)/2],\n",
    "])\n",
    "fig = plt.figure(figsize=(5,5))\n",
    "ax = plt.gca()\n",
    "plot_vec(v1, size=2.5, ax=ax)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "\n",
    "v1_rot = np.array([\n",
    "    [0,1],\n",
    "    [-1,0],\n",
    "])\n",
    "fig = plt.figure(figsize=(5,5))\n",
    "ax = plt.gca()\n",
    "plot_vec(v1_rot, size=2.5, ax=ax)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "\n",
    "v2 = np.array([\n",
    "    [np.sqrt(2),np.sqrt(2)],\n",
    "    [np.sqrt(2)/2,-np.sqrt(2)/2],\n",
    "])\n",
    "fig = plt.figure(figsize=(5,5))\n",
    "ax = plt.gca()\n",
    "plot_vec(v2, size=2.5, ax=ax)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "\n",
    "v2_rot = np.array([\n",
    "    [0,2],\n",
    "    [1,0],\n",
    "])\n",
    "fig = plt.figure(figsize=(5,5))\n",
    "ax = plt.gca()\n",
    "plot_vec(v2_rot, size=2.5, ax=ax)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "\n",
    "v3_rot = np.array([\n",
    "    [0,2],\n",
    "    [-1,0],\n",
    "])\n",
    "fig = plt.figure(figsize=(5,5))\n",
    "ax = plt.gca()\n",
    "plot_vec(v3_rot, size=2.5, ax=ax)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "\n",
    "v3 = np.array([\n",
    "    [np.sqrt(2),np.sqrt(2)],\n",
    "    [-np.sqrt(2)/2,np.sqrt(2)/2],\n",
    "])\n",
    "fig = plt.figure(figsize=(5,5))\n",
    "ax = plt.gca()\n",
    "plot_vec(v3, size=2.5, ax=ax)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "64542612-f767-4857-be16-55f86a68563d",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
