{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "db8514fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import numpy as np\n",
    "\n",
    "sys.path.append('lib/')\n",
    "import ph_simple"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ce02ba4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "1339804f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def draw_graph(n_nodes, edges, w):\n",
    "    edges = [list(x) for x in edges.T]\n",
    "    \n",
    "    #---directed graph---\n",
    "    G = nx.DiGraph(directed=True)\n",
    "    G.add_nodes_from(list(range(8)))\n",
    "    G.add_edges_from(edges)\n",
    "    \n",
    "    # set layout\n",
    "    pos = nx.circular_layout(G)\n",
    "\n",
    "    # draw graph\n",
    "    nx.draw(G, pos, with_labels = True)\n",
    "    \n",
    "    wmap = {}\n",
    "\n",
    "    for k, v in zip(edges, list(w)):\n",
    "        ks = tuple(sorted(k))\n",
    "        if ks not in wmap:\n",
    "            wmap[ks] = v\n",
    "        else:\n",
    "            wmap[ks] = [wmap[ks], v]\n",
    "\n",
    "    # draw edge labels\n",
    "    nx.draw_networkx_edge_labels(\n",
    "        G, pos,\n",
    "        edge_labels= wmap,\n",
    "        font_color='red'\n",
    "    )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "29447e38",
   "metadata": {},
   "source": [
    "### Two graphs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "dd705d49",
   "metadata": {},
   "outputs": [],
   "source": [
    "batch_size = 2\n",
    "n_nodes = 8\n",
    "edges = np.array([[0, 1, 2, 4, 5, 6, 4], [1, 2, 3, 5, 6, 7, 7]], dtype = np.int32)\n",
    "w = np.array([0.1, 0.2, 0.3, 0.9, 0.8, 0.7, 1.0], dtype = np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "9515145c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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d999N/Ly8nDixAl4eHioXQ6piD2URERE1Cl//OMfceHCBfz5z39WuxRSGXsoiYiIqNN+9atf4V//+heKiorQv39/tcshlbCHkoiIiDrtxRdfBAC8+uqrKldCamKgJCIiok4LCAjAypUr8f7776OgoEDtckglHPImIiIim9TX12Ps2LGYOXMm/vOf/6hdDqmAPZRERERkEw8PD6xatQrffPMNcnJy1C6HVMAeSiIiIrKZ1WrFzJkz4erqip07d0Kj0ahdEvUg9lASERGRzbRaLd566y3s2rULGzZsULsc6mHsoSQiIqIuExcXh/z8fOTn58PV1VXtcqiHsIeSiIiIuszq1atRXFyM9957T+1SqAexh5KIiIi61JNPPokNGzagqKgI/fr1U7sc6gHsoSQiIqIu9fLLL6OxsRGrVq1SuxTqIQyURERE1KUGDhyI5557Dn/+859RXFysdjnUAzjkTURERF2urq4Oo0ePRmRkJNatW6d2OdTN2ENJREREXc7LywuvvPIK/v3vf2PPnj1ql0PdjD2URERE1C0sFgsmT56MgIAAZGZmcrNzB8YeSiIiIuoWOp0Ob731FrKyspCcnKx2OdSN2ENJRERE3UaSJCxZsgTnzp3D4cOHodfr1S6JugF7KImIiKjbaDQarFmzBidOnMA///lPtcuhbsIeSiIiIup2jz76KDZt2oSioiJ4e3urXQ51MfZQEhERUbd77bXXUF1djdWrV6tdCnUDBkoiIiLqdkFBQVixYgXefvttnDt3Tu1yqItxyJuIiIh6xJUrVxAcHIz4+Hh89NFHapdDXYg9lERERNQj+vbti5deegmffPIJDh06pHY51IXYQ0lEREQ9prm5GaGhoRg5ciQ2bdqkdjnURdhDSURERD3GxcUFb775JtLS0pCenq52OdRF2ENJREREPUqSJCxYsADV1dXYt28fdDqd2iWRjdhDSURERD2qZbPzQ4cO4dNPP1W7HOoC7KEkIiIiVdx3333YsWMHCgsL4enpqXY5ZAP2UBIREZEq3njjDZSXl2Pt2rVql0I2Yg8lERERqeY3v/kN/vGPf6CoqAgDBgxQuxzqJPZQEhERkWr+8Ic/QK/XIzExUe1SyAbsoSQiIiJVXbhwAYMGDYIkSdBoNGqXQ53AQElERESqYpDs/TjkTURERKpimOz9GCiJiIiIyCYMlERERGTfTCZg506gqAioq1O7GroFBkoiIiKyTxcvAitWAEOHAj/5CTB5MvDoo8CxY2pXRjfgohwiIiKyP++9B/z+90BgIPDUU8CUKXLv5IYNwJEjwJ49aldI19CrXQARERGRoqkJWLkS+PBDuXfy5z+XQ2XLwp0JE4BZs4Ddu+V/kl1goCQiIiL7kZ8PfPkl8OqrwOOPAzee8V1WBvj6An5+qpRHt8Y5lERERGQ/cnOBAQOA//qvm8Pk/v3AM88AAwcCgwerUx/dEnsoiYiIyH40Ncl/rg2T588D27cDX38t/7x69c1hk1TFRTlERERkXwYNApYtA8LDgdJSoKAAyMmRV3u/9BIQEaF2hXQDBkoiIiKyL1u3Ap9/LvdITpwIBAQAy5cDP/7x1cdI0tWFOqQ6BkoiIiKyP83NQEOD/E9vb8DFRb7dYgF0OnVro5twUQ4RERHZHxcXOUhWVt4+TJrNcvAk1TBQEhERkX0yGoH77wc++UT++VZh8uJF4I03gDVrerIyugEDJREREdmnSZPk/SaHDm39MX37Al5ewL/+BWzZ0nO10XU4h5KIiIjsl9UKaLU336bRXF2Uk54OPPYYEBwsby9EPY77UBIREZH9ulWYbLmtqAh4/30gK0s+63vWLKCmRp57ST2KPZRERERkvyQJKC8H/vd/gXffBVxd5YU6H3wAJCbKP4eFAQYDz/ZWEQMlERER2TeLRV7p/Ze/AB4ewGefASaTHCATEoDISED/w6DrrYbIqdsxUBIREZH9++tfgV/9Sh7anjQJiIsDoqIAHx/5fm50rioGSiIiIuodxo0Dhg0D1q0D+veXb2OQtAvsEyYiIqLe4bXX5DO9WzYxZ5i0GwyURERE1Dvccw+wcCFw/Lj8M8Ok3eCQNxEREfUeXHRjl/h/hIiIiHoPrVYOldewWCwqFUMtGCiJiIiod7mhh3Lfvn24dOmSSsUQwEBJREREvVhdXR2io6OxcuVKtUtxagyURERE1Gt5eXnhxRdfxIcffoijR4+qXY7T4qIcIiIi6tWampoQEhKCsWPHIiUlRe1ynBJ7KImIiKhXc3V1xR//+EekpqZiy5YtapfjlNhDSURERL2eJEmYP38+GhoasGfPHmi5tVCP4n9tIiIi6vU0Gg3WrFmD/fv3Y926dWqX43TYQ0lEREQO45577sHu3btx4sQJeHh4qF2O02APJRERETmMN954AxcuXMCf/vQntUtxKuyhJCIiIofy61//Gp988gmKiorQv39/tctxCuyhJCIiIofywgsvAABeeeUVlStxHgyURERE5FACAgKwcuVKfPDBBygoKFC7HKfAIW8iIiJyOPX19Rg3bhxmzJiB//znP2qX4/DYQ0lEREQOx8PDA6+//jq++eYb7NixQ+1yHB57KImIiMghWa1WzJw5Ey4uLvjuu++g0WjULslhsYeSiIiIHJJWq8WaNWuQm5uLr7/+Wu1yHBp7KImIiMihxcXFIT8/H8eOHYObm5va5Tgk9lASERGRQ1u9ejWKi4vx/vvvq12Kw2IPJRERETm8J598El9//TVOnjyJfv36qV2Ow2EPJRERETm8l19+GU1NTVi1apXapTgkBkoiIiJyeAMHDsRvf/tb/PnPf0ZxcbHa5TgcDnkTERGRU6irq8Po0aMRERGBf//732qX41DYQ0lEREROwcvLC6+++iq++OIL5OXlqV2OQ2EPJRERETkNi8WCKVOmwM/PD9u2beNm512EPZRERETkNHQ6HVavXo3t27cjKSlJ7XIcBnsoiYiIyKlIkoSoqCiUlpbi8OHDcHFxUbukXo89lERERORUNBoN3nrrLRQUFOCf//yn2uU4BPZQEhERkVN67LHHsHHjRhQWFsLHx0ftcno19lASERGRU3rttddQXV2N1atXq11Kr8dASURERE5p6NChWLFiBd555x2cO3dO7XJ6NQ55ExERkdOqrq5GcHAw4uLi8NFHH6ldTq/FHkoiIiJyWj4+PnjppZfwySef4ODBg2qX02uxh5KIiIicWnNzMyZMmIDhw4cjLS1N7XJ6JfZQEhERkVNzcXHBm2++ifT0dAbKTmIPJRERETk9SZKwYMECXLlyBfv374dOp1O7pF6FPZRERETk9DQaDdasWYPDhw/j008/VbucXoc9lEREREQ/uP/++5GdnY2CggJ4eXmpXU6vwR5KIiIioh+88cYbuHTpEtauXat2Kb0KeyiJiIiIrvHMM8/g73//O4qKijBgwAC1y+kVGCiJiIiIrlFZWYlRo0bh/vvvx/vvv692Ob0Ch7yJiIiIruHn54cXXngB//jHP5Cfn692Ob0CeyiJiIiIbtDY2Ijx48djwoQJSExMVLscu8ceSiIiIqIbuLm5YdWqVUhKSkJWVpba5dg99lASERER3YIkSZgzZw6sVityc3Oh1bIfrjVOHyjrGs0orqhDk9kKV70Ww/294OWmV7ssIiIisgPZ2dlYsGAB1q1bhwcffFC5nfnhek4ZKAvLarAutwSZJy6ipNKEa/8DaAAM8/NE5NhAPDR7GEYP8FarTCIiIrIDy5cvx/79+5GcvQcb9pcxP9yCUwXK0koTVn57GNlFl6DTamCxtv6rt9wfFhyAVcsnIsjPswcrJSIiInuRtecI7n8nEW53TGZ+aIXTBMr1eSV4KfEozFapzTfCjXRaDfRaDV5OCMX9M4d1Y4VERERkb5T8YLHC0oHE5Gz5wSkC5V8zC7EmvcDm6zwbNQZPR47ugoqIiIjI3jE/tJ/DL1dan1fSJW8GAFiTXoAv80q65FpERERkv5gfOsaheyhLK01YvDYLjWZrl13TTa9Fxopwp5kTQURE5Gxulx+sTfWo2v4ZTMd3wFJfAxf/oeg75x54hYS3ek1Hzw8O3UO58tvDMLdzvmTNwTSc+WMcSt6+p83Hma0SVn57uCvKIyIiIjt0u/xQ/s0q1B3egr7zH8CAe1+G26DRuJT4FuqObmv1OY6eHxw2UBaW1SC76FK7FuCYay7h8taPoOvjd9vHWqwSsosuoehiTVeUSURERHbkdvmh/mQeGor3w2/pU/CeGgP3OybBP+ZXcB8+FZczP4JktdzyeY6eHxw2UK7LLYFOq2nXYys3/R/cg0LhPnxqux6v02rw+S7HngtBRETkjG6XH0wF30Hj6gHPcXded3ufSYthqa1E4/nW5106cn5w2ECZeeJiu3ona49koqH0CPyinmr3tS1WCZkFF20pj4iIiOzQ7fJDU/kZuPgPhUaru+52l/7DAQDNl860+lxHzg8OGShrG80oqTTd9nGWuipc3vIP9It4DHqfgA69RkmFCXWN5s6WSERERHamPfnBWl8DrfvNp+BoPbx/uL+6zec7an5wyEB5pqIO7VmKU5n+Hlz8hqDP1NgOv4YEoLiirsPPIyIiIvvU3vwATVtT6tqebueo+cEhA2VTO7YJqjueA1PRbvjF/BKaNt8Ytr0OERER9Q7t+VzXenjfshfSWl+j3N8Vr9PbOGSgdNW3/WtZm+pRufl9+EyPh76PH6wNtbA21EKyyl3Q1oZaWJsabH4dIiIi6j3a87nu2n84mivO3rSau7m8GADgEnBHl7xOb6NXu4DuMNzfCxqg1W5rq6ka1roqVO/+FtW7v73p/tJ374fH6DkIvPsPrb6G5ofXISIiIsdwu/wAAJ5j5qL2YBpMJ3LgNX6Bcnvtka3Q9fGD2+Axbb6Go+YHhwyUXm56DPPzxJlWJtbq+vTDgAdW3XT7lV0b0Fh6BIE/+l9oPX3afA2Xxip88dkniI+Px4ABA7qkbiIiIlLP7fIDAHiMmgH34VNRmfYerI0muPQbjLpjWWg4tRf+8c/ctPr7RsP8PeHl5njxy/H6XH8QOTaw1X2kNHpXuN8x6aY/Oq9+gEYL9zsmwfWH5f+3fD4kuFWexJNPPolBgwZh/vz5WL16NQoKuubMTyIiIlJHW/mhRf+7VsIrNBJXsteh7KsX0Xj+BAISnkOf0Mg2n6fTahA5JrAry7UbDnuWd2FZDZa8u71Dz7mUvBamEzkY9syG2z42Y8UC+GobkZycDFEUkZaWhvr6eowfPx4GgwGCIGDmzJnQah02sxMRETmczuSHjshYsQDBgbdfuNPbOGygBIBHPszFzlMV7drgvL10Wg3mjfTHZ0/Mvu52k8mEjIwMGI1GJCUl4dKlSxg0aBASEhJgMBiwcOFCuLm5dVkdRERE1D16Mj84CocOlKWVJixem4XGLlye76bXImNFOIL8PFt9jMViwc6dOyGKIoxGI06ePIk+ffogJiYGgiAgNjYWvr6+XVYTERERdR218kNv5tCBEgDW55Xgd98c7rLrvXnXRNw3c1i7Hy9JEo4ePaqEyz179kCv1yMiIgIGgwEGgwFBQUFdVh8RERHZTu380Ns4fKAEgL9mFmJNuu0LZp6LGotfRAbbdI2zZ88iMTERoihi69atMJvNmDZtGgRBgCAImDBhQqc3WiciIqKuY0/5wd45RaAE5G8aLyUehdkqdWhOhE4D6HVavJIQ2uXfLK5cuYKNGzfCaDQiNTUVNTU1GDFiBARBgMFgwPz586HXO97WAkRERL1Fp/ODVgO9VtMt+cEeOU2gBOQ5ESu/PYzsokvQaTVtvjFa7veuO4vU/32k2+c8NDY2Ytu2bRBFEaIo4vz58/D390dcXBwEQUBUVBQ8PR1z3gUREZE960x+CAsOwKrlEx12zuSNnCpQtigsq8G63BJkFlxESYXpuh3xNZA3HY0cE4i+5Yfwm/9+ENu3b0dYWFiP1We1WrF3714YjUYYjUYcO3YM7u7uiIqKgsFgQHx8PPr3799j9RAREVH788PDc4Y55NZAbXHKQHmtukYziivq0GS2wlWvxXB/L2UHe6vVilmzZkGn02HXrl2qzW0sLCxUei5zcnKg0Wgwb948ZWg8ONix52UQERHZm7bygzNy+kB5O9u2bUNkZCTWr1+P++67T+1ycPHiRSQnJ8NoNGLz5s1oaGhAaGioEi6nT5/OzdSJiIioRzFQtkN8fDyOHj2K/Px8u9qcvK6uDunp6RBFEUlJSaisrMSQIUOQkJAAQRAQEREBV1dXtcskIiIiB8dA2Q75+fmYOHEi3nrrLaxYsULtcm7JbDYjJydHmXdZXFwMHx8fxMbGwmAwICYmBn379lW7TCIiInJADJTt9LOf/QxfffUVTp48iX79+qldTpskScLhw4dhNBohiiL27dsHFxcXREZGQhAEJCQkYMiQIWqXSURERA6CgbKdvv/+e4wePRpPPvkk1qxZo3Y5HVJSUoLExEQYjUZkZWXBbDZj5syZMBgMEAQBISEh3EydiIiIOo2BsgNeffVVvPbaazh+/DhGjBihdjmdcvnyZaSmpkIURWzcuBG1tbUYNWqUsqhn3rx50Ol0apdJREREvQgDZQfU1dVh9OjRCA8PxxdffKF2OTZraGhAZmYmjEYjEhMT8f3336N///7KZupLliyBh4eH2mUSERGRnWOg7KCPPvoITzzxBHJzczFr1iy1y+kyVqsVu3fvhiiKMBqNOH78ODw8PLB06VIIgoBly5YhICBA7TKJiIjIDjFQdpDFYsHUqVPh6+uLrKwsh517eOLECWUz9e+++w4ajQZhYWEwGAwwGAwYOXKk2iUSERGRnWCg7IRNmzYhJiYGRqMRBoNB7XK6XVlZGZKSkmA0GpGRkYHGxkZMnDhRmXc5bdo0hw3WREREdHsMlJ0gSRKWLl2KkpISHD58GC4uLmqX1GNqa2uRlpYGo9GIlJQUXL58GUFBQcpm6uHh4U7134OIiIgYKDvt4MGDmDp1Kv7617/iqaeeUrscVTQ3NyM7O1uZd1lSUoK+ffti2bJlMBgMiI6Oho+Pj9plEhERUTdjoLTBj3/8Y6SkpKCoqMjpg5MkSTh48KCymfqBAwfg6uqKRYsWwWAwICEhAYMGDVK7TCIiIuoGDJQ2OHv2LMaMGYMVK1bg9ddfV7scu1JcXKxspr59+3ZYLBbMnj1bmXc5btw4zrskIiJyEAyUNnr++efxzjvvoLCwEEOHDlW7HLtUWVmJlJQUiKKITZs2oa6uDmPGjFFO6pk9ezY3UyciIurFGChtVF1djeDgYCxbtgwff/yx2uXYvfr6emzZsgWiKCIxMREXL15EYGAgEhISYDAYsHjxYri7u6tdJhEREXUAA2UXeO+99/D0009j//79mDx5strl9BoWiwW5ubkwGo0wGo0oLCyEl5fXdZup+/n5qV0mERER3QYDZRdobm7GxIkTERQUhPT0dM4N7ARJknD8+HFlxXhubi50Oh0WLFigzLu844471C6TiIiIboGBsouIoghBELBx40ZER0erXU6vd/78eSQlJUEURWzZsgVNTU2YMmWKMu9y8uTJDO5ERER2goGyi0iShPDwcFy+fBkHDhzgIpMuVF1dfd1m6leuXMEdd9yhHAMZFhbGzdSJiIhUxEDZhXbv3o3Zs2fjww8/xOOPP652OQ6pqakJ27dvV/a7PHv2LPr164dly5ZBEAQsXboUffr0UbtMIiIip8JA2cUeeOABZGVlKQtMqPtIkoR9+/Yp8y4PHz4MNzc3LF68GIIgID4+HgMGDFC7TCIiIofHQNnFTp8+jXHjxuEPf/gDXnjhBbXLcSqnTp2CKIoQRRHZ2dmQJAlz585V5l2OGTNG7RKJiIgcEgNlN3j22WfxwQcfoKioCAMHDlS7HKd06dIlpKSkwGg0Ii0tDfX19Rg3bpyyYnzWrFnQarVql0lEROQQGCi7weXLlzFq1Cjce++9+OCDD9Qux+mZTCZkZGTAaDQiKSkJly5dwsCBA5GQkABBELBw4UK4ubmpXSYREVGvxUDZTdauXYvnnnsOhw4dQkhIiNrl0A8sFgt27typzLs8efIk+vTpg5iYGBgMBsTGxqJfv35ql0lERNSrMFB2k8bGRowfPx6hoaFISkpSuxy6BUmScOzYMSVc5uXlQa/XIzw8XBkaDwoKUrtMIiIiu8dA2Y2+/PJL3H///cjMzERERITa5dBtnDt3DomJiTAajcjMzERzczOmTZumLOqZOHEiN1MnIiK6BQbKbtSyythsNmP37t1cBNKLXLlyBRs3boQoikhNTUV1dTWGDx8OQRAgCALmz58PvV6vdplERER2gYGym+3YsQNhYWH4/PPP8dBDD6ldDnVCU1MTtm3bpmymfv78efj5+SE+Ph4GgwFRUVHcc5SIiJwaA2UPuOuuu7B3716cOHEC7u7uapdDNrBardi7d68y7/Lo0aNwd3fHkiVLIAgC4uLiEBgYqHaZREREPYqBsgcUFBQgNDQUr7/+On7729+qXQ51oaKiIiVc5uTkAADmz5+vzLsMDg5WuUIiIqLux0DZQ55++ml8/vnnOHnyJPz9/dUuh7rBxYsXkZycDFEUkZ6ejoaGBoSEhCgrxmfMmMF5tERE5JAYKHtIeXk5Ro0ahccffxzvvvuu2uVQN6urq8PmzZthNBqRnJyMiooKDB48GAaDAQaDAZGRkXB1dVW7TCIioi7BQNmD3njjDbz44ovIz8/nUKgTMZvNyMnJUYbGT58+DR8fH8TExEAQBMTExKBv375ql0lERNRpDJQ9qL6+HmPGjMGcOXPw9ddfq10OqUCSJBw5ckRZMb537164uLggMjISBoMBCQkJGDp0qNplEhERdQgDZQ/79NNP8eijjyInJwfz5s1TuxxSWUlJCRITEyGKIrZt2waz2YwZM2Yo8y5DQ0O5mToREdk9BsoeZrVaMX36dHh4eCAnJ4dhgRRVVVVITU2F0WjExo0bUVtbi1GjRikrxufNmwedTqd2mURERDdhoFTBli1bsHjxYmzYsAF333232uWQHWpsbMTWrVshiiJEUcT333+PgIAAxMfHQxAELF68GJ6enmqXSUREBICBUjWxsbEoKCjAsWPHuNqX2mS1WpGXl6fMu8zPz4eHhweWLl0Kg8GAuLg4BAQEqF0mERE5MQZKlRw5cgSTJ0/G2rVr8atf/UrtcqgXKSgoUFaMf/fdd9BoNLjzzjuVeZcjR45Uu0QiInIyDJQq+slPfoJvvvkGJSUlPAuaOqWsrAxJSUkwGo3IyMhAY2MjJk6cqMy7nDZtGufpEhFRt2OgVNGlS5dw+vRpzJw5U+1SyAHU1tYiLS0NoigiOTkZly9fxtChQ5VwGR4eDhcXF7XLJCIiB8RAqTKr1crj+KjLNTc3Y8eOHcq8yzNnzqBv375YtmwZDAYDoqOj4ePjo3aZRETkIBgoiRycJEk4ePCgMu/ywIEDcHV1xcKFCyEIAhISEjBo0CC1yyQiol6MgZLIyZw5c0bZjigrKwsWiwWzZ89WhsbHjRvHeZdERNQhDJT2zGQCDhwAAgOBQYMALtyhLlZZWalspr5p0ybU1dVh9OjRyorxOXPmcDN1IiK6LQZKe3TxIvDGG8C//iUHyeJiICYGeOUVICRE7erIQTU0NGDLli1K7+XFixcRGBiobKa+aNEieHh4qF0mERHZIQZKe/Pee8Dvfy/3Sj71FDBlClBXB2zYABw5AuzZo3aF5AQsFgtyc3OVeZcFBQXw9PREdHQ0DAYDli1bBn9//45fuL4eaG4GuCCIiMihMFDai6YmYOVK4MMPgV//Gvj5z+VQ2TKXrbgYmDULSE6W/0nUg44fP66sGN+1axd0Oh3CwsKUofHhw4e370JGI/DBB8CVK8CiRcAzzwD9+nVn6URE1AMYKO3FwYNAXBzwP/8DPP44cOM5zbm5wCOPAKmpQHCwOjUSAbhw4YKymfqWLVvQ1NSEyZMnQxAE/PrXv4avr++tF/VYrcDWrcCpU8COHcDnnwNZWUBYWM//EkRE1KUYKO3F3/8u/9m69ebhwP37gV/+EtBqgU2bbg6bRCqpqanBpk2bIIoi0tPTcfr06fad+vSzn8lTOL75Ru6JJyKiXk2vdgH0g6Ym+c+1YfH8eWD7duDrr+WfV69mmCS74u3tjR/96Ef40Y9+BLPZDL3+Nk2KxQLodEBiIvDf/w34+d3+Rc6dA9zdgc7M2SQioh7BHkp7MmgQsGwZEB4OlJYCBQVATg4wdCjw0ktARITaFRJ1niTJc4ILCoBx44AtW4DIyLaf87vfAdnZwOHDwB13AG+9BURH90y9RETUbjzzz56sWyfPM3vqKXnxTWWlvFAnM/NqmGT+p97KYpH/+fnnwOjRwNixrT/WbJa/RP3pT8CDDwK7dgGxsfLWWRcu9Ey9RETUbuyhtDfNzUBDg/xPb2/AxUW+vWWo0GqVe3l4kgn1NlarPA943DhgyRJgzRrAze3Wj9myBXj2WeCee4Dnn5fvKygA5s0D/vY34O67e75+IiJqFXso7Y2LixwkKytvHSa1WjlMNjSoWydRR1gs8nu3vFwOhtHRN4dJ4GoP/BdfAAEBgCBcvS8gQN6X9bvvrn8sERGpjoty7JHRCLz2GvD008Bjj8lhEpA/kKuqgDffBEpK5AUNd9/NuZVk3xoa5OFrT0+guhoICgImTbr1Y1ve67m58jZa126R1dwMHDsGPPBA99dMREQdwh5KezRpkhwWhwy5/vbaWjlkZmUBffoA+fnyz5s2qVMnUXu4uAAjRshzJ999V15w9sILwM6d8v0XLlw/L/LwYTlYjhp1fS9mYSFQVgYsWCD/zGkfRER2g4HSHo0cKYfEJUuuv/3ECSAjQ974/IMP5H9/6CH5ZB0ie6XTyftOFhbKX4o+/VTe3PyNN+TFN3/7G5CQABw/Lj/eapV7I319r16jsVHeszI4WF7QcwNOBSciUhcDpb3SauUP27Nn5bO8ATlQennJ+/e19M7813/Jtx09ql6tRO3l4QE8/LC8v2pSEqDXyz3xw4cDY8bIjwkNlecQHzt29Xk5OVf3rgSumz/Z3NyMzz//HCtWrMC2bdtgNpt77vchIiIADJT2raQEePXVqx+sd98tDxdu23b1MevWyeciDxigSolENvvJT+TN+7U/NEd6vTyHeP16eYj844+Be+8FZsy4GiivGe52cXHBlStX8PXXXyMyMhIDBgzAo48+im+//RZ1LV/GiIioW3HbIHtmtcq9N2+/Le/FB8gB88sv5Z5Jq1U+2zsmBvj979WtlagrmUzAe+8BH30kD30vWgT8v//X5mk5kiRh7969MBqNEEURR44cgbu7O5YsWQKDwYD4+HgE8phHIqJuwUBp795+G3j/feDDD+UTdEwm+czv556Tt2JZuhT45z9vXsBD5CgaGuSjF4Grp+20w8mTJyGKIoxGI3JyciBJEubNmwdBEGAwGDD6FnMxiYiocxgoe4MHH5RXvjY2ysfP7dsn71X5xhvcQoWoHcrLy5GcnAyj0Yj09HQ0NDQgJCRECZczZsyAVssZQEREncVA2RvU1wMHDgA7dgAXL8qLFh599GpPTQd6bYicXV1dHTZv3gxRFJGUlISKigoMHjwYCQkJEAQBkZGRcHV1VbtMIqJehYGyN2OQJLKJ2WzGzp07lXmXp06dgre3N2JjY2EwGBAbG4u+ffuqXSYRkd1joOyNGCSJupwkSThy5Igy73Lv3r1wcXFBREQEBEFAQkIChg4dqnaZRER2iYGyl5MkCRqGS6IuV1paisTERIiiiMzMTJjNZsyYMQMGgwGCICA0NJR/94iIfsBA2Uu1BMkLFy5g0KBBapdD5NCqqqqQmpoKURSRmpqK2tpajBw5UlnUM3/+fOhaziEnInJCDJS92N/+9jf87ne/w8mTJ+Hn56d2OUROobGxEZmZmTAajUhMTMSFCxcQEBCAuLg4CIKAJUuWwNPTU+0yiYh6FANlL1ZWVobg4GD89Kc/xdtvv612OUROx2q1Ii8vT5l3mZ+fDw8PD0RFRUEQBMTFxSEgIEDtMomIuh0DZS/32muv4dVXX0V+fj5GjhypdjlETq2goACiKEIURezcuRMajQZ33nknDAYDDAYDRo0apXaJRETdgoGylzOZTBg9ejTCwsKwfv16tcshoh+UlZUpm6lv3rwZjY2NmDBhgjLvcvr06VzUQ0QOg4HSAXz00Ud44oknkJubi1mzZqldDhHdoLa2Funp6TAajUhOTsbly5cxdOhQZTP18PBwbqZORL0aA6UDsFgsmDp1Knx9fZGVlcVeDyI7ZjabkZ2drcy7PHPmDPr27YvY2FgIgoDo6Gj4+PioXSYRUYcwUDqItLQ0REdH49tvv4UgCGqXQ0TtIEkSDh06pJzUs3//fri4uGDRokUwGAxISEjA4MGD1S6TiOi2GCgdyNKlS1FcXIwjR47AxcVF7XKIqIPOnDmDxMREGI1GZGVlwWKxYNasWcq8y/Hjx3MEgojsEgOlAzl06BCmTJmCv/zlL/jFL36hdjlEZIPKykqkpqbCaDRi06ZNqKurw+jRo5WTeubMmcPN1InIbjBQOpgf//jHSElJQVFREedhETmIhoYGbNmyBaIoIjExEWVlZejfvz8SEhJgMBiwePFieHh4qF0mETkxBkoHc/bsWYwZMwYrVqzA66+/rnY5RNTFrFYrcnNzlXmXJ06cgKenJ6Kjo2EwGLBs2TL4+/urXSYRORkGSgf0hz/8AW+//TYKCgoQFBSkdjlE1I2OHz+urBjftWsXdDodwsLClHmXw4cPV7tEInICDJQOqLq6GsHBwYiNjcUnn3yidjlE1EMuXLiApKQkiKKIjIwMNDU1YfLkycq8yylTpnBRDxF1CwZKB/X+++/jF7/4Bfbt24cpU6aoXQ4R9bCamhqkpaXBaDQiJSUFVVVVGDZsmHIM5IIFC7gbBBF1GQZKB9Xc3IyJEyciKCgI6enp7JUgcmLNzc3Yvn27MjReWloKX19fLFu2DIIgYOnSpfD29la7TCLqxRgoHVhiYiIMBgM2btyI6OhotcshIjsgSRIOHDgAo9EIo9GIQ4cOwc3NDYsWLYIgCIiPj8fAgQPVLpOIehkGSgcmSRIiIiJQWVmJAwcOcM86IrrJ6dOnIYoiRFHE9u3bIUkS5syZo8y7HDt2rNolElEvwEDp4PLy8jBr1iz885//xBNPPKF2OURkxyoqKpCSkgKj0Yi0tDSYTCaMHTtWWTE+e/ZsaLVatcskIjvEQOkEHnzwQWzbtg2FhYXw8vJSuxwi6gXq6+uRkZGhbKZeXl6OgQMHIj4+HoIgYOHChXB3d1e7TCKyEwyUTqC4uBhjx47F888/jxdffFHtcoiol7FYLNi1a5cy77KoqAh9+vS5bjP1fv36qV0mEamIgdJJPPvss/jggw9QVFTECfdE1GmSJCE/P185qWf37t3Q6XQIDw9XhsaHDRumdplE1MMYKJ3E5cuXMWrUKNx777344IMP1C6HiBzE+fPnkZiYCKPRiK1bt6K5uRlTp05VFvVMmjSJ25YROQEGSieydu1aPPvsszh8+DBCQkLULoeIHEx1dTU2btwIURSRkpKC6upqDB8+XAmXd955J/R6vdplElE3YKB0Io2NjQgJCUFISAiSkpLULoeIHFhTUxOysrKUofFz587Bz88PcXFxMBgMWLp0KRcJEjkQBkon89VXX+G+++7D1q1bERkZqXY5ROQEJEnC3r17lZN6jhw5And3dyxevFjZTD0wMFDtMonIBgyUTkaSJMydOxfNzc3Iy8vjnnJE1ONOnjyphMucnBxIkoR58+YpQ+OjR49Wu0Qi6iAGSie0Y8cOhIWF4fPPP8dDDz2kdjlE5MTKy8uRnJwMURSRnp6O+vp6jB8/HoIgQBAEzJgxg198iXoBBkonddddd2Hv3r04ceIENycmIrtgMpmwefNmGI1GJCUloaKiAoMGDYLBYIDBYEBkZCTc3NzULpOIboGB0kkVFBQgNDQUr7/+On7729+qXQ4R0XXMZjN27typDI2fOnUK3t7eiImJgSAIiImJga+vr9plEtEPGCid2C9/+Ut89tlnKCoqQkBAgNrlEBHdkiRJOHr0qLJifM+ePdDr9YiMjFR6L4cOHap2mUROjYHSiZWXlyM4OBiPPfYY/vSnP6ldDhFRu5w9e1bZTD0zMxNmsxnTp09XTuqZMGECN1Mn6mEMlE7uj3/8I1544QUcO3aMKyuJqNepqqpSNlNPTU1FTU0NRo4cqYTL+fPnQ6fTqV0mkcNjoHRy9fX1GDt2LGbNmoUNGzaoXQ4RUac1NjYiMzMToihCFEVcuHABAQEBiIuLgyAIWLJkCTw9PdUuk8ghMVASPv30Uzz66KPIycnBvHnz1C6HiMhmVqsVe/bsUeZdHjt2DB4eHoiKioLBYEBcXBz69++vdplEDoOBkmC1WjF9+nR4eHggJyeHc4+IyOEUFhYqK8Z37twJjUaD+fPnK0Pjo0aNUrtEol6NgZIAAFu2bMHixYvx9ddf45577lG7HCKiblNWVnbdZuqNjY2YMGGCclLP9OnT+cWaqIMYKEkRGxuLgoICHDt2DK6urmqXQ0TU7erq6pCeng6j0Yjk5GRUVlZi6NChSEhIgCAICA8PZ3tI1A4MlKQ4cuQIJk+ejLVr1+JXv/oVMjMzYTKZsGzZMrVLIyLqdmazGTt27FDmXRYXF8PHxwfLli2DwWBATEwMfHx81C6TyC4xUNJ1fvKTn+Crr77CjBkzsHXrVgwaNAjnz59Xuywioh4lSRIOHTqkzLvcv38/XFxcsHDhQgiCgISEBAwePFjtMonsBgMlKS5cuIBnnnkGX3zxBTQaDSRJgo+PD65cuaJ2aUREqjpz5gwSExMhiiK2bdsGi8WCWbNmKfMux48fz3mX5NQYKAkAcOjQIcyePRvNzc2wWCzK7S4uLmhqalKxMiIi+3L58mWkpqbCaDRi06ZNqK2tRXBwsLJifO7cudxMnZwOAyUBkI9hXLJkCQ4dOoQb3xJms5mNIxHRLTQ0NGDr1q0wGo1ITExEWVkZ+vfvj/j4eAiCgMWLF8PDw0PtMom6HQMlKZqbm/Hqq6/i9ddfByDvTwkANTU16NOnj5qlERHZPavVitzcXGXe5YkTJ+Dp6YmlS5cqm6n7+/urXSZRt2CgpJvs3r0bDzzwAE6dOgVAnls5cOBA5f66RjOKK+rQZLbCVa/FcH8veLnp1SqXiMguHT9+XDkGcteuXdBqtQgLC4PBYIDBYMCIESPULlHBdp1sxUBJt2QymfDggw8qQzhVVnesyy1B5omLKKk04do3jQbAMD9PRI4NxEOzh2H0AG+1yiYiskvff/89kpKSYDQakZGRgaamJkyaNEmZdzl16tQeX9RTWFbDdp26DAMltenMpVr8QTyK7KJL0Gk1sFhbf7u03B8WHIBVyyciyM+zByslIuodampqkJaWBlEUkZycjKqqKgQFBSkrxhcsWAAXF5due/3SShNWfnuY7Tp1KQZKatX6vBK8lHgUZqvUZoNzI51WA71Wg5cTQnH/zGHdWCERUe/W3NyM7OxsZTP1kpIS+Pr6KpupR0dHw9u763oH2a5Td2GgpFv6a2Yh1qQX2HydZ6PG4OnI0V1QERGRY5MkCQcOHFAW9Rw8eBCurq5YtGiRspn6tfPZW9TU1OCpp57CihUrMG3atFavz3aduhMDJd1kfV4JfvfN4S673pt3TcR9/EZLRNQhxcXFyqKe7du3w2q1Yvbs2cq8y3HjxgEA1q1bh4cffhh9+vRBeno65s6de9O12K5Td2OgpOuUVpqweG0WGs3WLrumm16LjBXhnHtDRNRJFRUVSElJgSiK2LRpE0wmE8aOHQuDwYC8vDxs374dkiTB1dUVqampiIyMVJ7Ldp16AgMlXeeRD3Ox81TFLefWNJw5hLIvVt7yeQMfWQO3IeNueZ9Oq8G8kf747InZXVorEZEzqq+vx5YtW5TN1MvLy5X7NBoNXFxcIIoioqOjAbTdrl9KXou6I1tafa3W2na263QjBkpSFJbVYMm721u9vyVQ+ob/F9yHTbruPpf+d0Dr2vZpEBkrFiA4kFtPEBF1leTkZMTHx990u0ajwdq1axF7/+NttuvNly/Aarpy0+0XN7wCjd4FQ37+ETTa1k9KY7tOLbRqF0D2Y11uCXTa2++Dpu83GG5Dxl3353ZhUqfV4PNdJV1VKhERAUhKSgIAaLVa6PVXNyKXJAmJiYm3bddd+g26qT2XLM2w1lejz8TFbYZJtut0LW6DT4rMExc7tI1ER1isEjILLuJ/Edot1ycickbe3t4IDg7G5MmTERoaivHjxyMkJARjxoyBu7s7wt/K7HC7XnswHYAGXpOWtPk4tut0LQZKAgDUNppRUmlq12Mr0z/AJXE1NC5ucBsyDn3n3Q/3oNs3KCUVJtQ1mnmcFxFRF1mzZg3WrFlzy/s60q63sDbUwXRiJ9yHT4aL781bFN2I7Tq14JA3AQDOVNThdt9htW5e8J6RAP/oX2DAg6vgt/insFRfQtm/f4/6U3tv+xoSgOKKui6pl4iI2taedv1GdflZkMyN6HOb3skWbNepBb9SEACgqR3bSbgOHAW/gaOu3hA0AZ5j5uL8h0/jcubH8Bg5vUteh4iIbNeZ9rb24GZoPXzgOWZet74OOR72UBIAwFXfubeC1r0PPIJnorm8GNbmxm57HSIi6piOtrdNF0+j6ftCeIVGQKNv/1nibNcJYA8l/WC4vxc0QIeHRwAAP+w8pdG0vUJc88PrEBFR1zhw4ACKiooQEhKC4OBguLq6Kvd1tF2XF+MAfSZHtfv12a5TCwZKAgB4uekxzM8TZzo4gdvSUIv6k3lwCRwJjd61zcd6WGqxfetmLFy4EG5ubraUS0REAF544QUkJycDAHQ6HYYPH46JEyfCw8MDjzzySLvbdcncjLqj2+A6aAxc+w9v9+sP8/fkghwCwEBJ14gcG4jPcs+0usVEeeJb0Pv0h+vAYOg8fNB8+TyqdxthqauC/7IVbV5bAwn1p/Yi9q234O3tjZiYGBgMBsTGxsLX17cbfhsiIscXGRmpBEqLxYKTJ0/i5MmTAICCggLEvfivNtv1FqbC72BtqEGfyY+2+7V1Wg0ixwR2vnhyKAyUpHho9jB88l1xq/e79h+Ouvxs1OzfCKmpHloPb7gNDUFA/G/gNmhMm9eWoMHm/3sBDS89AlEUYTQa8dBDD0Gv1yMiIgKCICAhIQFBQUFd/FsRETmm0tJSXLly8yk3Go0Gs2bNwpYtW3C+1tpmu96i9uBmaFzc4TV+Qbtf32KV8PCcYR0pmRwYj16k67R15mtntXbma2lpKRITEyGKIjIzM2E2mzF9+nQYDAYIgoAJEybcdl4mEZGzkCQJR44cgdFohNFoxL59+6DX6+Hq6gqTSR7W1mg0iI2NxYYNG+Du7g6gZ9t1cl4MlHSd0koTFq/NQmMXbgPhptciY0U4gvw8W31MVVUVNm7cCKPRiI0bN6KmpgYjRoyAIAgwGAyYP3/+dceKERE5A7PZjJycHGVk5/Tp0/D29kZsbCwMBgNiYmLw9ttvY9WqVZAkCXfddRe++OILuLhcXaWtVrtOzoWBkm6yPq8Ev/vmcJdd7827JuK+me0fFmlsbERmZiZEUYQoirhw4QL8/f0RHx8Pg8GAqKgoeHqyESMix2QymZCeng6j0Yjk5GRUVFRg0KBBMBgMMBgMiIyMvG5h4/79+zFt2jQ88sgj+Oijj2755Vvtdp0cHwMl3dJfMwuxJr3A5us8FzUWv4gM7vTzrVYr9uzZA6PRCFEUcezYMXh4eGDJkiUQBAFxcXHo37+/zXUSEampvLwcSUlJEEUR6enpaGhoQEhIiDIFaMaMGdBqW9/vsbCwEKNGjWrzMfbSrpNjYqCkVq3PK8FLiUdhtkodmnuj02qg12rwSkJol3+DLSgoUHoud+7cCY1Gg/nz5yvf3IOD2cgRUe9QVFSktGc5OTmQJAnz5s1TpvqMHj26y1/THtt1cgwMlNSm0koTVn57GNlFl6DTatpsgFruDwsOwKrlE7t9bk1ZWRmSk5NhNBqxefNmNDY2IjQ0VGmMZ8yYwUU9RGQ3JEnCnj17lPmQR48ehZubG6KiomAwGBAXF4cBAwZ0ex323K5T78VASe1SWFaDdbklyCy4iJIK03UnL2ggb24bOSYQD88ZhuBA7x6vr7a2Funp6RBFEUlJSbh8+TKGDBmChIQECIKAiIiI606QICLqCU1NTdi2bRuMRiMSExNx7tw5+Pn5IS4uDoIgICoqCl5e6pw0Y+/tOvUuDJTUYXWNZhRX1KHJbIWrXovh/l52dVKC2WzGjh07lHmXxcXF8PHxQWxsLARBQExMDHx8fNQuk4gcVHV1tbJrRWpqKqqrqzF8+HBlPuSdd95pd7tW2Hu7TvaPgZIcmiRJOHTokDLEtH//fri4uGDhwoUwGAxISEjAkCFD1C6TiHq5c+fOKfvqbt26Fc3NzZg6daoyBWfSpEmcgkMOjYGSnMqZM2eQmJgIo9GIrKwsWCwWzJw5U+k5CAkJYaNPRLclSRKOHTumfFnNy8uDTqdDRESE8mX1jjvuULtMoh7DQElOq7KyEqmpqRBFERs3bkRdXR2Cg4OVcDl37lzodDq1yyQiO2GxWPDdd98p02mKiorQp08fREdHQxAExMbGol+/fmqXSaQKBkoiAA0NDdi6dasycb6srAz9+/dXNlNfsmQJPDw81C6TiHpYfX09MjIyYDQakZSUhPLycgwYMEBZ8Ldw4ULliEMiZ8ZASXQDq9WK3NxcZSjrxIkT8PT0RFRUlLKZur+/v9plElE3qaioQHJyMkRRRFpaGkwmE8aOHavMh5w9e3abG4gTOSMGSqLbOH78uBIud+3aBa1Wi7CwMGUz9ZEjR6pdIhHZ6PTp08rf8+zsbEiShDlz5ih/z8eNG6d2iUR2jYGSqAMuXLigHI+WkZGBpqYmTJw4EYIgQBAETJ06lYt6iHqCJAE2/F2TJAn79+9X5kMeOnQIbm5uWLRoEQRBQHx8PAYOHNiFBRM5NgZKok6qqalBWloajEYjUlJSUFVVhaCgIKVHIzw8HC4uLmqXSeRYGhuBvXuBefM6HCqbm5uRlZWlHHdYWloKX19fxMXFwWAwYOnSpfD25gbeRJ3BQEnUBZqbm7F9+3ZlyKzlg6plM/Xo6OiOfVBZrcC2bcCBA0BEBDBtWjdVTtQLXLgAfPop8PnnwNGjQGAgcPw44Ot726fW1NRg06ZNEEVR+eI3bNgwZTeHsLAwfvEj6gIMlERdTJIkHDhwQBlKO3jwIFxdXbFo0SIYDAbcd9998G3rg/DcOeCNN4ANG4CxY4GDB4HFi+UPVE+eo0tOJDkZWLECOHlS/lL19NPy3wu9HvjqK6CV41Srqqrw1VdfwWg0YsuWLWhqasLkyZOVRTVTpkzh1BSiLsZASdTNTp8+rWymnp2djf/85z+Ii4trfY/Ln/8c2LMH+MUvgMcekwPlffcBv/ylfBuRo7NaAa0WyM4GysqAyEigZWeFn/1M7qXMzr76uGuYzWYkJyfjnnvuwYIFC5QpKMOHD+/534PIiTBQEvWgiooK+Pr6th4m6+sBPz9g9Wo5QLaIigLuuAP4xz9av3hTU6s9NkR2SZKA8nJ5CLs9GhqABx8E3N2Bf/+71YdZLBZUVVVxey+iHsSNtIh6kL+/f9un73zzDeDmBiQkXL1NkoCgIKCiQv5AvZHFAvz978BDDwHTpwMvvgiUll59LpG92btXnsbh6wvccw/wwgu3f47VKgfJkyflvw9Aq+9vnU7HMEnUwxgoieyJ0SivXh0y5OptFy4ANTVy0HR3v/lD9F//kofJQ0KAH/8YyM0F7r0XOH3apm1ViLpFbS3w0kvAoEHAxo3ye3X1avmLkMnU+vO0WrkH38fn6hcrq7Vnaiai22KgJLInBw4As2ZdHwQLC4H8fCAsTP752g9RiwXIywPmzgVeflletPDxx/IH8//9X4+WTtQuu3fL8x9/9jP5y9PTTwN//KO8ACctTX6MxXLr59bUAJWVwNCh8s9t9fYTUY9ioCSyFzU1wOjRwJUr139Qbtsm90q2DIO3LEKQJPlxd94JeHld/RDWauXrnDwp/8xeHLIne/YA48YB1y6SiY8Hhg0DvvhC/rm1nnU/P6CkBBg1qtvLJKKO0atdABFBDofe3sCUKfKwd02N/POWLfKHbFyc3CsjSVc3c9Zo5KG/c+eAoiKgXz958Y7FAly6BPz+92r/VkQ3GzdO3kOyufnqbSNGyPN/162T39Pu7rdcwY3Tp+XpINXV8s+3egwRqYKBksgetPTIPPGEPBw4YwYwYQKwcyewcKE8v6zlcS2PPXNGXsywdy+wdi1gNsuLc5qa5LlpffrIj+MHLtmTuXPlKRnHjl3tpdTp5F51d3d5CkdYmPy+bW4GXFzkL0k6HXD2rDwFZNAg+Xl8bxPZDf5tJLIno0YB6ely7+KAAcAnnwDvvScvRPjLX4Cf/EQOkoAcPE+cAP78Z3k4/K67gLfekvft+/JLVX8Nolb17w9MnSpvUH7trgUDB179ubERePVV4He/k39u+RI1dSrwzjvAggU9WzMR3RYDJZG98fCQNzR/7z1g6VKgb1+5h6agQF7B3bJnn6+vPNR97XyziRPl248ckX++ZkV4WVkZVq9ejYKCgp76TchJFRQU4K233sLFixdv/YAnn5R70bOzr95WXCzPj5w6Vd7R4MgR+f1eW3u1J9LXF/j1r+W/I0RkV7ixOVFvcv48MHiw/O9VVcDy5fKctP/5H/nD9uuv5VWzSUnyfMofWK1WJCUl4YEHHkB9fT3Gjx+vnGU8c+ZMaDl0SDawWq3Iy8tTjhvNz8+Hh4cH1q9fj7i4uJvfX42NwMMPAzt2AG++KR8p+uab8uKclSvloxXPnpXnS3LrK6JegYGSqDfLzpaHxw8cAIKD5SHDWbPkc79vwWQyYfPmzRBFEYmJiaioqMCgQYOQkJAAg8GAhQsXws3NrWd/B+qVGhsbkZmZCaPRiMTERFy4cAEBAQGIj4+HwWDAkiVL4NnW2fMXLwJr1gBZWXLP5L33As8/3/5Tc4jIrjBQEjmCigogJ0feemXKFPm2ltXgrTCbzdi5cydEUYTRaMSpU6fQp08fxMTEQBAExMbGwtfXt0fKp96hqqoKqampEEURGzduRE1NDUaNGgVBEGAwGDBv3ry2T4K6lcpKeTsgIurVGCiJCJIk4ejRo8qQ5Z49e6DX6xEREQGDwQCDwYCgluPuyKmUlpYiMTERRqMR27Ztg9lsxowZM5QQGRoaCg2HpYmcHgMlEd3k7NmzSojIzMyE2WzGtGnTIAgCBEHAhAkTGCIclCRJOHLkiPLlYu/evdDr9Vi4cCEMBgMSEhIwtOWkGiKiHzBQElGbqqqqsHHjRoiiiNTUVNTU1GDEiBFKD9X8+fOh13NL297MbDYjJydHmf5w+vRpeHt7IzY2FoIgICYmBn379lW7TCKyYwyURNRujY2N2LZtm7IQ4/z58/D390dcXBwEQUBUVFTbCzHIbphMJqSnp8NoNCI5ORkVFRUYPHiwMsUhIiKCC7SIqN0YKImoU6xWK/bs2aP0ah07dgzu7u6IioqCwWBAfHw8+vfvr3aZdI3y8nIkJSVBFEWkp6ejoaEBISEhylSG6dOncwspIuoUBkoi6hKFhYUQRRGiKCInJwcajQbz589XeryCg4PVLtEpFRUVKaF/586dkCTpuv8vo0ePVrtEInIADJRE1OUuXryo9IRt3rwZDQ0NCA0NVeZdzpgxg4t6uonVasXevXuVEHn06FG4u7tjyZIlEAQBcXFxCORej0TUxRgoiahb1dXVXTdXr7KyEkOGDEFCQgIEQUBERARcXV3VLrNXa2pqum5u67lz5+Dn56dsMh4VFQUvLy+1yyQiB8ZASUQ9xmw2Y8eOHUrvWXFxMXx8fK5bTezj46N2mYq6RjOKK+rQZLbCVa/FcH8veLnZx4r2K1euXLf6vrq6GsOHD1fmQ3L1PRH1JAZKIlKFJEk4fPiwst/hvn374OLict1+h0OGDOnxugrLarAutwSZJy6ipNKEaxtIDYBhfp6IHBuIh2YPw+gB3j1a27lz567bH7S5uRnTpk1TzmWfOHEipxIQkSoYKInILpSUlFx3IovFYsHMmTOVeZchISHdGpZKK01Y+e1hZBddgk6rgcXaetPYcn9YcABWLZ+IIL/u2SpJkiQcO3ZMCd15eXnQ6/UIDw+HIAhISEjAsGHDuuW1iYg6goGSiOzO5cuXkZqaCqPRiE2bNqG2thbBwcFKT9zcuXM7fmZ0G9bnleClxKMwW6U2g+SNdFoN9FoNXk4Ixf0zuybYWSwWfPfdd0qILCoqUs5YNxgMiI2NRb9+/brktYiIugoDJRHZtYaGBmzdulXZkqisrAz9+/dHfHw8BEHA4sWL4eHhcdPz6uvr8dJLL+GnP/1pm1sW/TWzEGvSC2yu89moMXg6snNb8NTX12Pz5s0QRRFJSUkoLy/HwIEDlYVLkZGRcHd3t7lGIqLuwkBJRL2G1WrF7t27ld6748ePw9PTE0uXLoXBYEBcXBz8/f0BABs2bMCPfvQj9O/fH1lZWRg/fvxN11ufV4LffXO4y+p7866JuK+dPZWXLl1CSkoKjEYj0tLSUF9fj3Hjxim9sLNmzeIm40TUazBQElGvdeLECWXF+K5du6DRaBAWFgZBEJCZmYmUlBQAgI+PDzIzMzF58mTluaWVJixem4VGs7XL6nHTa5GxIrzVOZWnTp1Selqzs7MhSRLmzp2rbDI+duzYLquFiKgnMVASkUP4/vvvkZSUBKPRiIyMDDQ1NSn3abVaeHl5ISMjA7NmzQIAPPJhLnaeqmhzzmRD6VFc+e4rNJ07DsnSDJ23P7wmLITv/Adu+XidVoN5I/3x2ROzAciLavbt26eE3sOHD8PNzQ2LFy+GIAiIj4/HgAEDuvC/AhGROhgoicjhJCUlISEh4abb9Xo9Pv/8c0yLiMWSd7e3eY26o9twKfkdeI67E14h4dC6eqC56gIsNZXwvfPWgbLFK3NcsHtzIhITE1FaWop+/fph2bJlEAQBS5cuRZ8+fWz6/YiI7A13vSUih5Oenq78u16vh8VigSRJMJvNeOeddxDjMaHNrYHMNZdQsemv6DMlGv5Ln1Jud79j0m1fW7Ja8P/+mgjvgk1Yvnw5DAYDwsLC4OLiYvsvRkRkpxgoicjh1NTUwNvbG6GhoZg0aRJCQkIQEhKC8ePHY8iQIYhYs63Noe7ag+mQmhvQd849HX5tjVaHsRHLsTP9A24yTkROg4GSiBzOxx9/jI8//viWga620YySSlObz28sPQKtuzeaK0px8T+vorn8DLQe3vAcMxf9Ih+H1q3tjcy/r7XA1GSxm2MaiYi6G/ekICKHo9FoWu0dPFNRh9tNHDfXVEIyN6Lc+Ed4jQ/DgPtfg8/su1B3JBMXv/5f3G7quQSguKKuc8UTEfVC/PpMRE6lqT3bBElWSOYm+IY/ir5zfwRAnj+p0epxecs/0HDmIDyGT7H9dYiIHAR7KInIqbjqb9/saT28AQAeI6Zdd7vHqBkAgKbvi7rkdYiIHAVbPCJyKsP9vXC7pTKugSNufUfLULem7aZT88PrEBE5CwZKInIqXm56DGvlJJsWnmPnAQDqT+297vb6k3sAAG6D2z7RZpi/JxfkEJFTYYtHRE4ncmwgPss90+rWQR4jpsEjeBaqcr6AJFnhNmQcmi4U4krOF/AYNRPuQaGtXlun1SByTGB3lU5EZJd4Ug4ROZ3CsprbnpRjbW7ElZwvUHcsC5baSuj6+MErNAK+8x+ERt/2JuUZKxYgONC7K0smIrJrDJRE5JTac5Z3R914ljcRkbPgHEoickqrlk+EXtu1J9notRqsWj6xS69JRNQbMFASkVMK8vPEywmtz4XsjFcSQhF0mwU/RESOiIGSiJzW/TOH4dmoMV1yreeixuK+mcO65FpERL0N51ASkdNbn1eClxKPwmyVOjSnUqfVQK/V4JWEUIZJInJqDJRERABKK01Y+e1hZBddgk6raTNYttwfFhyAVcsncpibiJweAyUR0TUKy2qwLrcEmQUXUVJhwrUNpAbypuWRYwLx8Jxh3BqIiOgHDJRERK2oazSjuKIOTWYrXPVaDPf34gk4RES3wEBJRERERDbhKm8iIiIisgkDJRERERHZhIGSiIiIiGzCQElERERENmGgJCIiIiKbMFASERERkU0YKImIiIjIJgyURERERGQTBkoiIiIisgkDJRERERHZhIGSiIiIiGzCQElERERENmGgJCIiIiKbMFASERERkU0YKImIiIjIJgyURERERGQTBkoiIiIisgkDJRERERHZhIGSiIiIiGzCQElERERENmGgJCIiIiKbMFASERERkU0YKImIiIjIJgyURERERGQTBkoiIiIisgkDJRERERHZhIGSiIiIiGzCQElERERENmGgJCIiIiKbMFASERERkU0YKImIiIjIJgyURERERGQTBkoiIiIisgkDJRERERHZhIGSiIiIiGzCQElERERENmGgJCIiIiKb/H9WgZLQHgUWsgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_graph(n_nodes, edges, w)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "dc3fba6e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0  1  2 -1  5  4  3 -1]\n",
      "[ 0  0  0  1  1  1 -1 -1]\n",
      "[-1 -1 -1 -1 -1 -1  1 -1]\n"
     ]
    }
   ],
   "source": [
    "edge_ptr = np.array([0, 3, 7], dtype = np.int32)\n",
    "node_ptr = np.array([0, 4, 8], dtype = np.int32)\n",
    "h0 = np.full(n_nodes, -1, dtype = np.int32)\n",
    "h0_e = np.full(w.shape, -1, dtype = np.int32)\n",
    "h1_e = np.full(w.shape, -1, dtype = np.int32)\n",
    "multiprocessing = 1\n",
    "filter_cycles = 0\n",
    "\n",
    "ph_simple.calc_barcodes_batch_cycles(batch_size, edges, w, edge_ptr, node_ptr, h0, h0_e, h1_e, filter_cycles, multiprocessing)\n",
    "\n",
    "# result: indexes of edges\n",
    "\n",
    "# must be [ 0,  1,  2, -1,  5,  4,  3, -1]\n",
    "print(h0)\n",
    "\n",
    "# must be [ 0,  1,  2, -1,  5,  4,  3, -1]\n",
    "print(h0_e)\n",
    "\n",
    "# must be [-1 -1 -1 -1 -1 -1  1 -1]\n",
    "print(h1_e)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bdb4c714",
   "metadata": {},
   "source": [
    "### Check doubled edges\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "338d0d7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "batch_size = 2\n",
    "n_nodes = 8\n",
    "edges = np.array([[0, 1, 2, 1, 2, 3, 4, 5, 6, 4, 5], [1, 2, 3, 0, 1, 2, 5, 6, 7, 7, 7]], dtype = np.int32)\n",
    "w = np.array([0.1, 0.2, 0.3, 0.11, 0.21, 0.31, 0.9, 0.8, 0.7, 1.0, 0.85], dtype = np.float32)\n",
    "edge_ptr = np.array([0, 6, 11], dtype = np.int32)\n",
    "node_ptr = np.array([0, 4, 8], dtype = np.int32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "991c6e15",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0  1  2 -1  8  7  6 -1]\n",
      "[ 0  0  0 -1 -1 -1  1  1  1 -1 -1]\n",
      "[-1 -1 -1 -1 -1 -1 -1 -1 -1  1  1]\n"
     ]
    }
   ],
   "source": [
    "h0 = np.full(n_nodes, -1, dtype = np.int32)\n",
    "h0_e = np.full(w.shape, -1, dtype = np.int32)\n",
    "h1_e = np.full(w.shape, -1, dtype = np.int32)\n",
    "multiprocessing = 1\n",
    "filter_cycles = 0\n",
    "\n",
    "ph_simple.calc_barcodes_batch_cycles(batch_size, edges, w, edge_ptr, node_ptr, h0, h0_e, h1_e, filter_cycles, multiprocessing)\n",
    "\n",
    "# result: indexes of edges\n",
    "\n",
    "# must be [ 0  1  2 -1  8  7  6 -1]\n",
    "print(h0)\n",
    "\n",
    "# must be [ 0  0  0 -1 -1 -1  1  1  1 -1 -1]\n",
    "print(h0_e)\n",
    "\n",
    "# must be [-1 -1 -1 -1 -1 -1 -1 -1 -1  1  1]\n",
    "print(h1_e)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "5a922f51",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_graph(n_nodes, edges, w)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb3fd418",
   "metadata": {},
   "source": [
    "### Check filter cycles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "51e16125",
   "metadata": {},
   "outputs": [],
   "source": [
    "batch_size = 2\n",
    "n_nodes = 8\n",
    "edges = np.array([[0, 1, 2, 1, 2, 3, 4, 5, 6, 4, 5], [1, 2, 3, 0, 1, 2, 5, 6, 7, 7, 7]], dtype = np.int32)\n",
    "w = np.array([0.1, 0.2, 0.3, 0.11, 0.21, 0.31, 0.9, 0.8, 0.7, 1.0, 0.85], dtype = np.float32)\n",
    "edge_ptr = np.array([0, 6, 11], dtype = np.int32)\n",
    "node_ptr = np.array([0, 4, 8], dtype = np.int32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "94f4c466",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0  1  2 -1  8  7  6 -1]\n",
      "[ 0  0  0 -1 -1 -1  1  1  1 -1 -1]\n",
      "[-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1]\n"
     ]
    }
   ],
   "source": [
    "h0 = np.full(n_nodes, -1, dtype = np.int32)\n",
    "h0_e = np.full(w.shape, -1, dtype = np.int32)\n",
    "h1_e = np.full(w.shape, -1, dtype = np.int32)\n",
    "multiprocessing = 1\n",
    "filter_cycles = 1\n",
    "\n",
    "ph_simple.calc_barcodes_batch_cycles(batch_size, edges, w, edge_ptr, node_ptr, h0, h0_e, h1_e, filter_cycles, multiprocessing)\n",
    "\n",
    "# result: indexes of edges\n",
    "\n",
    "# must be [ 0  1  2 -1  8  7  6 -1]\n",
    "print(h0)\n",
    "\n",
    "# must be [ 0  0  0 -1 -1 -1  1  1  1 -1 -1]\n",
    "print(h0_e)\n",
    "\n",
    "# must be [-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1]\n",
    "print(h1_e)"
   ]
  }
 ],
 "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
}
