{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c678a29",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pickle\n",
    "from src import roc_mc_general as roc\n",
    "from matplotlib import pyplot as plt\n",
    "import scipy as sp\n",
    "from src import process_periodic_raw_data as pro"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b665da5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def preprocess_data(data, loc=1):\n",
    "    r = []\n",
    "    for x in data['result']:\n",
    "        r += x\n",
    "    r = np.array([x[loc] for x in r])\n",
    "    return r\n",
    "\n",
    "def clr(d):\n",
    "    s = d.shape\n",
    "    d = d.reshape(-1,s[-1])\n",
    "    f = np.log(d)\n",
    "    r = f - np.sum(f, axis=1).reshape(-1,1)/s[-1]\n",
    "    return r.reshape(s)\n",
    "\n",
    "def inv_clr(d):\n",
    "    s = d.shape\n",
    "    d = d.reshape(-1,s[-1])\n",
    "    f = np.exp(d)\n",
    "    r = f / (np.sum(f, axis=1).reshape(-1,1))\n",
    "    return r.reshape(s)\n",
    "\n",
    "def sigmoid(x):\n",
    "    return 1/(1+np.exp(-x))\n",
    "\n",
    "trans_mat = np.array([[np.sqrt(3), np.sqrt(0.75)],\n",
    "                      [0,          1.5]])\n",
    "trans_inv = np.array([[np.sqrt(1/3), -1/3], \n",
    "                      [0,            2/3]])\n",
    "def plane2space2(v: np.ndarray):\n",
    "    \"\"\"v.shape=(n,2)\"\"\"\n",
    "    v = np.array(v).reshape(-1,2)\n",
    "    A = np.einsum(\"ij,kj->ki\", trans_inv, v)\n",
    "    return A"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fee86eb1",
   "metadata": {},
   "source": [
    "# Period 20 Circle / Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e2c566d9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_circle_path(radius, center):\n",
    "    alpha =  np.linspace(0, 2*np.pi, period, endpoint=False)\n",
    "    circle2d = np.concatenate([np.cos(alpha).reshape(-1,1), \n",
    "                               np.sin(alpha).reshape(-1,1)], axis=1)\n",
    "    circle3d2 = plane2space2(circle2d)\n",
    "    path = center + radius * (np.concatenate([circle3d2, \n",
    "                                              -np.sum(circle3d2, axis=1).reshape(-1,1)], \n",
    "                                             axis=1))\n",
    "    return path\n",
    "\n",
    "def dim2todim3centric(path_2d):\n",
    "    path_3d = np.concatenate([path_2d, \n",
    "                              -np.sum(path_2d, axis=1).reshape(-1,1)],\n",
    "                             axis=1)\n",
    "    return path_3d\n",
    "\n",
    "\n",
    "def transform(x, y):\n",
    "    trans = np.array([[np.sqrt(3), np.sqrt(3)/2], [0,1.5]])\n",
    "    x = np.array(x).reshape(-1,1)\n",
    "    y = np.array(y).reshape(-1,1)\n",
    "    coord = np.concatenate([x,y], axis=1)\n",
    "    t = np.einsum(\"ij,kj->ki\", trans, coord)\n",
    "    return t[:, 0], t[:, 1]\n",
    "\n",
    "def path_close(a,b):\n",
    "    return (np.concatenate([a, a[:1]]),\n",
    "            np.concatenate([b, b[:1]]),)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "721bdc0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "n, m = 3,3\n",
    "period = 20\n",
    "radii = np.linspace(0.3, 0, 10, endpoint=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3bfe50a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[0.26693435, 0.54268186, 0.18634553],\n",
       "        [0.40621228, 0.27822368, 0.00562658],\n",
       "        [0.32685337, 0.17909446, 0.80802789]]),\n",
       " array([0.33198725, 0.23002084, 0.43799191]))"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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br31Vh5++GFSU1N54IEHuPzyy1vvXUjQcNhtDDpq39NvIiIi+2Kz9pxNGsRKS0uJjY2lpKQEl8tlOo6IiIg0Q3N/f+uL8kRERMQolRERERExSmVEREREjFIZEREREaNURkRERMQolRERERExSmVEREREjFIZEREREaNURkRERMSogG8Hb8Kem8SWlpYaTiIiIiLNtef39sFu9h4SZaSsrAyAHj16GE4iIiIigSorKyM2Nna/fx4S303j9/vJzc0lJiYGm631vgG2tLSUHj16sG3btk77nTfaBg20HbQNQNsAtA1A2wBabxtYlkVZWRmpqanY7fs/MyQkjozY7XYOP/zwNnt+l8vVaT9we2gbNNB20DYAbQPQNgBtA2idbXCgIyJ76ARWERERMUplRERERIzq1GUkIiKCjIwMIiIiTEcxRtuggbaDtgFoG4C2AWgbQPtvg5A4gVVEREQ6rk59ZERERETMUxkRERERo1RGRERExCiVERERETGqw5WRhQsX0qtXLyIjIxkwYADvv//+Ace/9957DBgwgMjISHr37s0jjzyy15iXX36Z448/noiICI4//niWL1/eVvFbRSDb4JVXXmHo0KEkJibicrkYNGgQ//73v5uMefLJJ7HZbHs9qqur2/qttFgg2+Ddd9/d5/v73//+12RcR/4cXHvttfvcBieccELjmFD7HKxevZqRI0eSmpqKzWbj1VdfPeg6HW1/EOg26Ij7g0C3QUfcHwS6DUzsDzpUGVm2bBmTJk0iPT2dnJwchgwZwogRI9i6des+x2/ZsoULLriAIUOGkJOTQ1paGhMnTuTll19uHLNmzRpGjRrF6NGj+fzzzxk9ejRXXHEFn3zySXu9rYAEug1Wr17N0KFDWbFiBevWrePss89m5MiR5OTkNBnncrnwer1NHpGRke3xlgIW6DbY45tvvmny/o4++ujGP+von4P777+/yXvftm0b8fHx/OEPf2gyLpQ+BxUVFfTr14+HHnqoWeM74v4g0G3QEfcHgW6DPTrS/iDQbWBkf2B1IKeeeqo1YcKEJsuOO+44a8qUKfscf+edd1rHHXdck2XXXXeddfrppzf+fMUVV1jDhw9vMub888+3rrzyylZK3boC3Qb7cvzxx1uZmZmNPy9ZssSKjY1trYhtLtBt8M4771iAtXPnzv0+Z2f7HCxfvtyy2WzWDz/80Lgs1D4HPwdYy5cvP+CYjrg/+LnmbIN9CfX9wc81Zxt0xP3Bz7Xkc9Ae+4MOc2SktraWdevWMWzYsCbLhw0bxkcffbTPddasWbPX+PPPP5+1a9dSV1d3wDH7e06TWrINfsnv91NWVkZ8fHyT5eXl5fTs2ZPDDz+ciy66aK9/KQWLQ9kG/fv3x+12c+655/LOO+80+bPO9jlYvHgx5513Hj179myyPFQ+By3R0fYHrSHU9weHoqPsD1pDe+wPOkwZKSoqwufzkZyc3GR5cnIyeXl5+1wnLy9vn+Pr6+spKio64Jj9PadJLdkGvzRv3jwqKiq44oorGpcdd9xxPPnkk7z++ussXbqUyMhIzjjjDL777rtWzd8aWrIN3G43jz32GC+//DKvvPIKxx57LOeeey6rV69uHNOZPgder5c333yT8ePHN1keSp+Dluho+4PWEOr7g5boaPuDQ9Ve+4OQ+NbeQNhstiY/W5a117KDjf/l8kCf07SW5l26dCkzZszgtddeIykpqXH56aefzumnn9748xlnnMEpp5zCgw8+yAMPPNB6wVtRINvg2GOP5dhjj238edCgQWzbto17772X3/zmNy16zmDQ0rxPPvkk3bp145JLLmmyPBQ/B4HqiPuDlupI+4NAdNT9QUu11/6gwxwZSUhIwOFw7NVMCwoK9mqwe6SkpOxzvNPppHv37gccs7/nNKkl22CPZcuWMW7cOF544QXOO++8A4612+38+te/Dsp/CR3KNvi5008/vcn76yyfA8uyeOKJJxg9ejTh4eEHHBvMn4OW6Gj7g0PRUfYHrSWU9weHoj33Bx2mjISHhzNgwABWrVrVZPmqVasYPHjwPtcZNGjQXuPfeustBg4cSFhY2AHH7O85TWrJNoCGfwFde+21PPfcc1x44YUHfR3Lsli/fj1ut/uQM7e2lm6DX8rJyWny/jrD5wAaLm39/vvvGTdu3EFfJ5g/By3R0fYHLdWR9getJZT3B4eiXfcHrXYqbBB4/vnnrbCwMGvx4sXWhg0brEmTJlnR0dGNZwBPmTLFGj16dOP4zZs3W1FRUdatt95qbdiwwVq8eLEVFhZmvfTSS41jPvzwQ8vhcFhz5861Nm7caM2dO9dyOp3Wxx9/3O7vrzkC3QbPPfec5XQ6rYcfftjyer2Nj127djWOmTFjhrVy5Upr06ZNVk5OjjV27FjL6XRan3zySbu/v+YIdBvcd9991vLly61vv/3W+uqrr6wpU6ZYgPXyyy83junon4M9rrnmGuu0007b53OG2uegrKzMysnJsXJycizAmj9/vpWTk2P9+OOPlmV1jv1BoNugI+4PAt0GHXF/EOg22KM99wcdqoxYlmU9/PDDVs+ePa3w8HDrlFNOsd57773GP/vTn/5knXXWWU3Gv/vuu1b//v2t8PBw68gjj7QWLVq013O++OKL1rHHHmuFhYVZxx13XJMPZTAKZBucddZZFrDX409/+lPjmEmTJllHHHGEFR4ebiUmJlrDhg2zPvroo3Z8R4ELZBvcfffd1lFHHWVFRkZacXFx1plnnmn961//2us5O/LnwLIsa9euXVaXLl2sxx57bJ/PF2qfgz2XaO7vs90Z9geBboOOuD8IdBt0xP1BS/4utPf+wGZZu8/QEhERETGgw5wzIiIiIqFJZURERESMUhkRERERo1RGRERExCiVERERETFKZURERESMUhkRERERo1RGRERExCiVERERETFKZURERESMUhkRERERo1RGRERExKj/B7A8Q40i01xtAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "M = np.random.dirichlet([0.5,] * n, m).T\n",
    "theta = np.random.dirichlet([1,] * m)\n",
    "eta = np.random.dirichlet([1,] * n)\n",
    "center = np.mean(M, axis=1)\n",
    "plt.plot(*transform([0,1,0,0], [0,0,1,0]), c='tab:red')\n",
    "plt.scatter(*transform(M[0], M[1]))\n",
    "plt.scatter(*transform(center[0], center[1]))\n",
    "M, center"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7e50b1b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = np.linspace(-2,9,12)\n",
    "X = np.exp(X*np.log(10))\n",
    "gX, gY = np.meshgrid(X, X)\n",
    "params = [(1, gX.reshape(-1)[i], gY.reshape(-1)[i]) for i in range(144)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "252eb878",
   "metadata": {},
   "outputs": [],
   "source": [
    "params = [(1,10,10)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b03e5ffe",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Generating curve of different shapes.\n",
    "def gen_polygon():\n",
    "    delta_angle = np.random.dirichlet([10,]*period)*np.pi*2\n",
    "    angle = [np.sum(delta_angle[:i]) for i in range(period)]\n",
    "\n",
    "    r_thres = 0.5\n",
    "    rad = np.random.uniform(r_thres/5, r_thres, period)\n",
    "\n",
    "    path_2d = np.concatenate([(rad * np.cos(angle)).reshape(-1,1),\n",
    "                              (rad * np.sin(angle)).reshape(-1,1),\n",
    "                             ], axis=1)\n",
    "    return path_2d\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "767cd9d1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f94d742b820>]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_2d = gen_polygon()\n",
    "plt.plot(*path_close(path_2d[:,0], path_2d[:,1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1ffa348f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.47660641, 0.23002084, 0.29337275],\n",
       "       [0.38898901, 0.24633372, 0.36467727],\n",
       "       [0.44964826, 0.30598192, 0.24436981],\n",
       "       [0.38878179, 0.28912996, 0.32208825],\n",
       "       [0.36217602, 0.29389886, 0.34392512],\n",
       "       [0.3351691 , 0.30879968, 0.35603123],\n",
       "       [0.29985281, 0.3402946 , 0.35985259],\n",
       "       [0.29265062, 0.2766351 , 0.43071428],\n",
       "       [0.30582323, 0.24750032, 0.44667645],\n",
       "       [0.2359508 , 0.25011383, 0.51393537],\n",
       "       [0.24952864, 0.22296777, 0.5275036 ],\n",
       "       [0.26628523, 0.20671866, 0.52699611],\n",
       "       [0.23218984, 0.15995968, 0.60785048],\n",
       "       [0.29340032, 0.177315  , 0.52928469],\n",
       "       [0.29626192, 0.1063613 , 0.59737677],\n",
       "       [0.34237264, 0.18173649, 0.47589087],\n",
       "       [0.36872968, 0.14197411, 0.48929621],\n",
       "       [0.39872346, 0.16997836, 0.43129818],\n",
       "       [0.40438235, 0.1920113 , 0.40360635],\n",
       "       [0.39216287, 0.21376887, 0.39406826]])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "center+dim2todim3centric(path_2d)*0.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7436574a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "955944fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "_path_gen = gen_circle_path\n",
    "_path_gen = lambda *r: r[1]+dim2todim3centric(path_2d)*r[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8369cc45",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RADIUS: 0.3\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.27\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.24\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.21\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.18\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.15\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.12\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.09\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.06\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n",
      "RADIUS: 0.02999999999999997\n",
      "================================================================================ \n",
      "PARAM:  (1, 10, 10)\n",
      "process 0: 0.0% completed\n"
     ]
    }
   ],
   "source": [
    "# BEWARE: multiple for loops, use only necessary loops!\n",
    "\n",
    "prefix = \"vary_xxx\"\n",
    "for radius in radii:\n",
    "    path = _path_gen(radius, center)\n",
    "    print(\"RADIUS:\", radius)\n",
    "    for param in params:\n",
    "        print(\"=\"*80, \"\\nPARAM: \", param)\n",
    "        # path = gen_path(radius)\n",
    "        suffix = prefix+\"/300steps_350epi30_centric_cicle_r_%.3f_p_%d_%.3f_%.3f\"%tuple([radius]+list(param))\n",
    "        result = roc.mp_test(M, eta, theta, 3, 6, 1, method=\"uot\",\n",
    "                         param = param,\n",
    "                         teacherClass=roc.TeacherPeriod,\n",
    "                         teacher_args = [path], \n",
    "                         suffix=suffix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "97812ff3",
   "metadata": {},
   "outputs": [],
   "source": [
    "prefix = \"vary_xxx\"\n",
    "for radius in radii:\n",
    "    path = _path_gen(radius, center)\n",
    "    print(\"RADIUS:\", radius)\n",
    "    for param in params:\n",
    "        print(\"=\"*80, \"\\nPARAM: \", param)\n",
    "        # path = gen_path(radius)\n",
    "        suffix = prefix+\"/300steps_350epi30_centric_cicle_r_%.3f_p_%d_%.3f_%.3f\"%tuple([radius]+list(param))\n",
    "        result = roc.mp_test(M, eta, theta, 300, 640, 16, method=\"uot\",\n",
    "                         param = param,\n",
    "                         teacherClass=roc.TeacherPeriod,\n",
    "                         teacher_args = [path], \n",
    "                         suffix=suffix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "48e2f2f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['./data/vary_xxx/300steps_350epi30_centric_cicle_r_0.270_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.150_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.240_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.090_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.180_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.030_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.120_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.210_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.060_p_1_10.000_10.000.dat',\n",
       " './data/vary_xxx/300steps_350epi30_centric_cicle_r_0.300_p_1_10.000_10.000.dat']"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pro.process('./data/vary_xxx/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c1106f5",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
