{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3bd843e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from scipy.integrate import solve_ivp\n",
    "import numpy as np\n",
    "import random\n",
    "import pandas as pd\n",
    "import pickle\n",
    "from multiprocessing import Pool, cpu_count\n",
    "import tqdm\n",
    "import warnings\n",
    "import eventlet\n",
    "from func_timeout import func_timeout\n",
    "import networkx as nx\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d34ddbcc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func1(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ea0604e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func2(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, cat2 = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS + 2 * k31 * cat2 - ( k11 * S + k22 * P + 2 * k32 * cat ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * catS\n",
    "    dcat2dt = k32 * cat ** 2 - k31 * cat2\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dcat2dt]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c16dfca5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func3(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, cat2, cat2S = y\n",
    "    dSdt = k12 * cat2S - k11 * S * cat2\n",
    "    dPdt = k21 * cat2S - k22 * cat2 * P\n",
    "    dcatdt = 2 * k32 * cat2 - 2 * k31 * cat ** 2\n",
    "    dcat2dt = ( k12 + k21 ) * cat2S + k31 * cat ** 2 - ( k11 * S + k22 * P + k32 ) * cat2\n",
    "    dcat2Sdt = ( k11 * S + k22 * P ) * cat2 - ( k12 + k21 ) * cat2S\n",
    "    return [dSdt, dPdt, dcatdt, dcat2dt, dcat2Sdt]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1265f560",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func4(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, X = y\n",
    "    dSdt = k12 * X * catS - k11 * S * cat\n",
    "    dPdt = k21 * X * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * X * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * X * catS\n",
    "    dXdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * X * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dXdt]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f4abfc3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func5(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, catP = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k31 * catP - k32 * cat * P\n",
    "    dcatdt = k12 * catS + k31 * catP - ( k11 * S + k32 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * catP ) * cat - ( k12 + k21 * cat ) * catS\n",
    "    dcatPdt = k21 * catS * cat + k32 * P * cat - ( k31 + k22 * cat ) * catP\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dcatPdt]\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0cd1553",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func6(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catStar, catStarS = y\n",
    "    dSdt = k12 * catStarS - k11 * S * catStar\n",
    "    dPdt = k21 * catStarS - k22 * catStar * P\n",
    "    dcatdt = - k31 * cat\n",
    "    dcatStardt = k31 * cat + ( k12 + k21 ) * catStarS - ( k11 * S + k22 * P ) * catStar\n",
    "    dcatStarSdt = ( k11 * S + k22 * P ) * catStar - ( k12 + k21 ) * catStarS\n",
    "    return [dSdt, dPdt, dcatdt, dcatStardt, dcatStarSdt]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2650b619",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func7(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, catS2 = y\n",
    "    dSdt = k12 * catS2 - k11 * S * catS + k32 * catS - k31 * S * cat\n",
    "    dPdt = k21 * catS2 - k22 * catS * P\n",
    "    dcatdt = k32 * catS - k31 * S * cat\n",
    "    dcatSdt = k31 * S * cat - k32 * catS + ( k12 + k21 ) * catS2 - ( k11 * S + k22 * P ) * catS\n",
    "    dcatS2dt = ( k11 * S + k22 * P ) * catS - ( k12 + k21 ) * catS2\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dcatS2dt]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "62e89bdf",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func8(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catStar, catStarS, L = y\n",
    "    dSdt = k12 * catStarS - k11 * S * catStar\n",
    "    dPdt = k21 * catStarS - k22 * catStar * P\n",
    "    dcatdt = k32 * L * catStar - k31 * cat\n",
    "    dcatStardt = k31 * cat - k32 * L * catStar + ( k12 + k21 ) * catStarS - ( k11 * S + k22 * P ) * catStar\n",
    "    dcatStarSdt = ( k11 * S + k22 * P ) * catStar - ( k12 + k21 ) * catStarS\n",
    "    dLdt = k31 * cat - k32 * L * catStar\n",
    "    return [dSdt, dPdt, dcatdt, dcatStardt, dcatStarSdt, dLdt]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c47cb08b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func9(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Incat = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + k32 ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21) * catS\n",
    "    dIncatdt = k32 * cat\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatdt]\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f956e3f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func10(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Inhbt, IncatI = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + k32 * Inhbt ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * catS\n",
    "    dInhbtdt = - k32 * Inhbt * cat\n",
    "    dIncatIdt = k32 * Inhbt * cat\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dInhbtdt, dIncatIdt]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05312012",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func11(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, IncatS = y\n",
    "    dSdt = k12 * catS - ( k11 + k32 ) * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + k32 * S ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * catS\n",
    "    dIncatSdt = k32 * S * cat\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatSdt]\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7443ce1d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func12(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, IncatP = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - ( k22 + k32 ) * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + k32 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * catS\n",
    "    dIncatPdt = k32 * P * cat\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatPdt]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "037f8d83",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func13(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Incat2 = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + 2 * k32 * cat ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * catS\n",
    "    dIncat2dt = k32 * cat ** 2\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncat2dt]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5047865",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func14(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, IncatS = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 ) * catS\n",
    "    dIncatSdt = k32 * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatSdt]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eae83e38",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func15(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Inhbt, IncatSI = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * Inhbt ) * catS\n",
    "    dInhbtdt = - k32 * Inhbt * catS\n",
    "    dIncatSIdt = k32 * Inhbt * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dInhbtdt, dIncatSIdt]\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8564ed0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func16(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, IncatS2 = y\n",
    "    dSdt = k12 * catS - k11 * S * cat - k32 * S * catS\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * S ) * catS\n",
    "    dIncatS2dt = k32 * S * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatS2dt]\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c6f6227",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func17(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, IncatSP = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P - k32 * P * catS\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * P ) * catS\n",
    "    dIncatSPdt = k32 * P * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatSPdt]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "908b8107",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func18(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Incat2S2 = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * catS ) * catS\n",
    "    dIncat2S2dt = k32 * catS ** 2\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncat2S2dt]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27a52de0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func19(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Incat2S = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + k32 * catS ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * cat ) * catS\n",
    "    dIncat2Sdt = k32 * cat * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncat2Sdt]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f80c87a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def func20(t, y, k11, k12, k21, k22, k31, k32, k41, k42):\n",
    "    S, P, cat, catS, Incat, IncatS = y\n",
    "    dSdt = k12 * catS - k11 * S * cat\n",
    "    dPdt = k21 * catS - k22 * cat * P\n",
    "    dcatdt = ( k12 + k21 ) * catS - ( k11 * S + k22 * P + k32 ) * cat\n",
    "    dcatSdt = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k42 ) * catS\n",
    "    dIncatdt = k32 * cat\n",
    "    dIncatSdt = k42 * catS\n",
    "    return [dSdt, dPdt, dcatdt, dcatSdt, dIncatdt, dIncatSdt]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c9d0153",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f61df491",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e99e1527",
   "metadata": {},
   "outputs": [],
   "source": [
    "def data_gen(idx, sigma = 1e-4, t_span = (0,99), yd = [0.2, 0.9], inter_threshold = 0.2):\n",
    "    if idx in [1, 4]:\n",
    "        args = 10**np.random.uniform(-5,5,4)\n",
    "    elif idx in [2, 3, 5, 7, 8, 20]:\n",
    "        args = 10**np.random.uniform(-5,5,6)\n",
    "    elif idx in [6, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]:\n",
    "        args = 10**np.random.uniform(-5,5,5)\n",
    "        \n",
    "    if idx in [1, 4]:\n",
    "        args = args.tolist() + [0,0,0,0]\n",
    "    elif idx in [2, 3, 5, 7, 8]:\n",
    "        args = args.tolist() + [0,0]\n",
    "    elif idx in [6]:\n",
    "        args = args.tolist() + [0,0,0]\n",
    "    elif idx in [9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]:\n",
    "        args = args.tolist()\n",
    "        args.insert(-1,0)\n",
    "        args = args + [0,0]\n",
    "    elif idx in [20]:\n",
    "        args = args.tolist()\n",
    "        args.insert(-2,0)\n",
    "        args.insert(-1,0)\n",
    "    \n",
    "    cat1 = np.random.uniform(0.01, 0.99)\n",
    "    a = np.random.random()\n",
    "    if a <= 0.5:\n",
    "        r = 1\n",
    "    else:\n",
    "        r = np.random.uniform(0.5,1)\n",
    "    if idx in [1]:\n",
    "        y_1 = [1,0,cat1,0]\n",
    "    elif idx in [2, 3, 4, 5, 6, 7, 9, 11, 12, 13, 14, 16, 17, 18, 19]:\n",
    "        y_1 = [1,0,cat1,0,0]\n",
    "    elif idx in [8, 10, 15, 20]:\n",
    "        y_1 = [1,0,cat1,0,0,0]\n",
    "    solution1 = solve_ivp(eval(\"func\"+str(idx)), t_span, y_1, args=args, method = 'LSODA', t_eval=np.linspace(t_span[0], t_span[1], t_span[1]+1))\n",
    "    if sigma > 0:\n",
    "        solution1[\"y\"] += np.random.normal(0, sigma, solution1[\"y\"].shape[0]*solution1[\"y\"].shape[1]).reshape(solution1[\"y\"].shape)\n",
    "        solution1[\"y\"] = np.clip(solution1[\"y\"], a_min=0, a_max=1)\n",
    "        \n",
    "    idx_yd = False\n",
    "    for item in solution1.y[2:]:\n",
    "        if max(item)-min(item)>=inter_threshold:\n",
    "            idx_yd = True\n",
    "    \n",
    "    if solution1.y[1][-1] < yd[0] or solution1.y[1][-1] > yd[1]:\n",
    "        idx_yd = False\n",
    "    \n",
    "    \n",
    "    if idx == 1:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 2:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> + 2 * k31 * cat <2> - ( k11 * S + k22 * P + 2 * k32 * cat ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * cat <S> ,\n",
    "d cat <2> / d t = k32 * cat ** 2 - k31 * cat <2> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 3:\n",
    "        lb = '''d S / d t = k12 * cat <2> <S> - k11 * S * cat <2> ,\n",
    "d P / d t = k21 * cat <2> <S> - k22 * cat <2> * P ,\n",
    "d cat / d t = 2 * k32 * cat <2> - 2 * k31 * cat ** 2 ,\n",
    "d cat <2> / d t = ( k12 + k21 ) * cat <2> <S> + k31 * cat ** 2 - ( k11 * S + k22 * P + k32 ) * cat <2> ,\n",
    "d cat <2> <S> / d t = ( k11 * S + k22 * P ) * cat <2> - ( k12 + k21 ) * cat <2> <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 4:\n",
    "        lb = '''d S / d t = k12 * X * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * X * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * X * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * X * cat <S> ,\n",
    "d X / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * X * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 5:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k31 * cat <P> - k32 * cat * P ,\n",
    "d cat / d t = k12 * cat <S> + k31 * cat <P> - ( k11 * S + k32 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * cat <P> ) * cat - ( k12 + k21 * cat ) * cat <S> ,\n",
    "d cat <P> / d t = k21 * cat <S> * cat + k32 * P * cat - ( k31 + k22 * cat ) * cat <P> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 6:\n",
    "        lb = '''d S / d t = k12 * cat <Star> <S> - k11 * S * cat <Star> ,\n",
    "d P / d t = k21 * cat <Star> <S> - k22 * cat <Star> * P ,\n",
    "d cat / d t = - k31 * cat ,\n",
    "d cat <Star> / d t = k31 * cat + ( k12 + k21 ) * cat <Star> <S> - ( k11 * S + k22 * P ) * cat <Star> ,\n",
    "d cat <Star> <S> / d t = ( k11 * S + k22 * P ) * cat <Star> - ( k12 + k21 ) * cat <Star> <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 7:\n",
    "        lb = '''d S / d t = k12 * cat <S> <2> - k11 * S * cat <S> + k32 * cat <S> - k31 * S * cat ,\n",
    "d P / d t = k21 * cat <S> <2> - k22 * cat <S> * P ,\n",
    "d cat / d t = k32 * cat <S> - k31 * S * cat ,\n",
    "d cat <S> / d t = k31 * S * cat - k32 * cat <S> + ( k12 + k21 ) * cat <S> <2> - ( k11 * S + k22 * P ) * cat <S> ,\n",
    "d cat <S> <2> / d t = ( k11 * S + k22 * P ) * cat <S> - ( k12 + k21 ) * cat <S> <2> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 8:\n",
    "        lb = '''d S / d t = k12 * cat <Star> <S> - k11 * S * cat <Star> ,\n",
    "d P / d t = k21 * cat <Star> <S> - k22 * cat <Star> * P ,\n",
    "d cat / d t = k32 * L * cat <Star> - k31 * cat ,\n",
    "d cat <Star> / d t = k31 * cat - k32 * L * cat <Star> + ( k12 + k21 ) * cat <Star> <S> - ( k11 * S + k22 * P ) * cat <Star> ,\n",
    "d cat <Star> <S> / d t = ( k11 * S + k22 * P ) * cat <Star> - ( k12 + k21 ) * cat <Star> <S> ,\n",
    "d L / d t = k31 * cat - k32 * L * cat <Star> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 9:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + k32 ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21) * cat <S> ,\n",
    "d <In> cat / d t = k32 * cat .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 10:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + k32 * Inhbt ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * cat <S> ,\n",
    "d Inhbt / d t = - k32 * Inhbt * cat ,\n",
    "d <In> cat <I> / d t = k32 * Inhbt * cat .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 11:\n",
    "        lb = '''d S / d t = k12 * cat <S> - ( k11 + k32 ) * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + k32 * S ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * cat <S> ,\n",
    "d <In> cat <S> / d t = k32 * S * cat .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 12:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - ( k22 + k32 ) * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + k32 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * cat <S> ,\n",
    "d <In> cat <P> / d t = k32 * P * cat .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 13:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + 2 * k32 * cat ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 ) * cat <S> ,\n",
    "d <In> cat <2> / d t = k32 * cat ** 2 .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 14:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 ) * cat <S> ,\n",
    "d <In> cat <S> / d t = k32 * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 15:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * Inhbt ) * cat <S> ,\n",
    "d Inhbt / d t = - k32 * Inhbt * cat <S> ,\n",
    "d <In> cat <S> <I> / d t = k32 * Inhbt * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 16:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat - k32 * S * cat <S> ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * S ) * cat <S> ,\n",
    "d <In> cat <S> <2> / d t = k32 * S * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 17:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P - k32 * P * cat <S> ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * P ) * cat <S> ,\n",
    "d <In> cat <S> <P> / d t = k32 * P * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 18:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * cat <S> ) * cat <S> ,\n",
    "d <In> cat <2> <S> <2> / d t = k32 * cat <S> ** 2 .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 19:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + k32 * cat <S> ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k32 * cat ) * cat <S> ,\n",
    "d <In> cat <2> <S> / d t = k32 * cat * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    elif idx == 20:\n",
    "        lb = '''d S / d t = k12 * cat <S> - k11 * S * cat ,\n",
    "d P / d t = k21 * cat <S> - k22 * cat * P ,\n",
    "d cat / d t = ( k12 + k21 ) * cat <S> - ( k11 * S + k22 * P + k32 ) * cat ,\n",
    "d cat <S> / d t = ( k11 * S + k22 * P ) * cat - ( k12 + k21 + k42 ) * cat <S> ,\n",
    "d <In> cat / d t = k32 * cat ,\n",
    "d <In> cat <S> / d t = k42 * cat <S> .'''.replace(\" S \",\" [S] \").replace(\" P \",\" [P] \").replace(\" cat \",\" [cat] \").replace(\"**\",\"^\").replace(\" X \",\" [X] \").replace(\" L \",\" [L] \").replace(\" Inhbt \",\" [Inhbt] \")\n",
    "    \n",
    "    return solution1, y_1, idx, lb ,args, idx_yd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd2f2fc8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed14a801",
   "metadata": {},
   "outputs": [],
   "source": [
    "def num_encoder(num):\n",
    "    n_str = \"\"\n",
    "    if num >=0:\n",
    "        n_str += \"+;\"\n",
    "    else:\n",
    "        n_str += \"-;\"\n",
    "    num_norm = \"{:.3e}\".format(num)\n",
    "    n1,n2 = num_norm.split(\"e\")\n",
    "    if float(n1) != 0: \n",
    "        n_str += \"N\"+str(int(abs(float(n1)*1000)))+\";\"\n",
    "    else:\n",
    "        n_str += \"N0000;\"\n",
    "    n_str += \"E\" + str(int(n2)-3)\n",
    "    return n_str"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a73ea177",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen1(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,16),(9,10),(9,13),(10,11),(10,12),(13,14),(13,15)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "\n",
    "    seq = (seq1+seq2+seq3+seq4).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f9dcf74",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen2(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"add\",\"mul\",\"2\",\"mul\",\"k4\",\"x_4\",\"mul\",\"-1\",\n",
    "           \"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"add\",\"mul\",\"k3\",\"x_1\",\"mul\",\"2\",\"mul\",\"k5\",\"x_2\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,27),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,12),(7,8),(7,9),(9,10),(9,11),\n",
    "                      (12,13),(12,14),(14,15),(14,28),(15,16),(15,19),(16,17),(16,18),(19,20),(19,23),\n",
    "                      (20,21),(20,22),(23,24),(23,25),(25,26),(25,27)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"k5\",\"pow2\",\"x_2\",\"mul\",\"-1\",\"mul\",\"k4\",\"x_4\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,10),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,5),(1,2),(1,3),(3,4),(5,6),(5,7),(7,8),(7,9)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a326562",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen3(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_3\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_3\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"2\",\"mul\",\"k5\",\"x_3\",\"mul\",\"-2\",\"mul\",\"k4\",\"pow2\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,12),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,3),(3,4),(3,5),(6,7),(6,8),(8,9),(8,10),(10,11)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\").replace(\";-2;\",\";-;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"add\",\"mul\",\"k4\",\"pow2\",\"x_2\",\"mul\",\"-1\",\n",
    "           \"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"add\",\"mul\",\"k3\",\"x_1\",\"k5\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,24),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,11),(7,8),(7,9),\n",
    "                      (9,10),(11,12),(11,13),(13,14),(13,23),(14,15),(14,18),(15,16),(15,17),\n",
    "                      (18,19),(18,22),(19,20),(19,21)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_4\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),\n",
    "                      (10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef721f4c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen4(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"mul\",\"x_4\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,13),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,6),(1,2),(1,3),(3,4),(3,5),(6,7),(6,8),(8,9),(8,10),(10,11),(10,12)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"mul\",\"x_4\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,13),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,6),(1,2),(1,3),(3,4),(3,5),(6,7),(6,8),(8,9),(8,10),(10,11),(10,12)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"mul\",\"x_4\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\n",
    "           \"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,8),(1,2),(1,5),(2,3),(2,4),(5,6),(5,7),(8,9),(8,10),\n",
    "                      (10,11),(10,18),(11,12),(11,15),(12,13),(12,14),(15,16),(15,17)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\n",
    "           \"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"mul\",\"x_4\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15),\n",
    "                      (16,17),(16,18)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",'x_1',\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\n",
    "           \"mul\",\"x_4\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),\n",
    "                      (10,11),(10,12),(12,13),(12,16),(13,14),(13,15),(16,17),(16,18)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8b86813",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen5(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k4\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k5\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"k1\",\"x_3\",\"add\",\"mul\",\"k4\",\"x_4\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\n",
    "           \"k5\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,8),(5,6),(5,7),(8,9),(8,10),(10,11),(10,18),\n",
    "                      (11,12),(11,15),(12,13),(12,14),(15,16),(15,17)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_4\",\"x_2\",\"mul\",\n",
    "           \"-1\",\"mul\",\"add\",\"k1\",\"mul\",\"k2\",\"x_2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,18),(13,14),(13,15),\n",
    "                      (15,16),(15,17)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"k2\",\"mul\",\"x_3\",\"x_2\",\"add\",\"mul\",\"k5\",\"mul\",\"x_1\",\"x_2\",\"mul\",\"-1\",\n",
    "           \"mul\",\"add\",\"k4\",\"mul\",\"k3\",\"x_2\",\"x_4\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,6),(1,2),(1,3),(3,4),(3,5),(6,7),(6,12),(7,8),(7,9),(9,10),(9,11),\n",
    "                      (12,13),(12,14),(14,15),(14,20),(15,16),(15,17),(17,18),(17,19)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48b8a1d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen6(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_3\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_3\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"mul\",\"-1\",\"mul\",\"k4\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"k4\",\"x_2\",\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_4\",\"mul\",\n",
    "           \"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,10),(5,6),(5,9),(6,7),(6,8),\n",
    "                      (10,11),(10,12),(12,13),(12,20),(13,14),(13,17),(14,15),(14,16),(17,18),(17,19)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_3\",\"mul\",\"-1\",\"mul\",\n",
    "           \"add\",\"k1\",\"k2\",\"x_4\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),\n",
    "                      (12,13),(12,16),(13,14),(13,15)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa82ffde",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen7(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_4\",\"add\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_3\",\n",
    "           \"add\",\"mul\",\"k5\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k4\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,23),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,12),(5,6),(5,7),(7,8),(7,9),\n",
    "                      (9,10),(9,11),(12,13),(12,16),(13,14),(13,15),(16,17),(16,18),\n",
    "                      (18,19),(18,20),(20,21),(20,22)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_3\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"k5\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k4\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"k4\",\"mul\",\"x_0\",\"x_2\",\"add\",\"mul\",\"-1\",\"mul\",\"k5\",\"x_3\",\n",
    "           \"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_4\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"mul\",\"k3\",\"x_1\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,29),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,6),(1,2),(1,3),(3,4),(3,5),(6,7),(6,12),(7,8),(7,9),\n",
    "                      (9,10),(9,11),(12,13),(12,18),(13,14),(13,17),(14,15),(14,16),\n",
    "                      (18,19),(18,20),(20,21),(20,28),(21,22),(21,25),(22,23),(22,24),(25,26),(25,27)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_3\",\"mul\",\"-1\",\"mul\",\n",
    "           \"add\",\"k1\",\"k2\",\"x_4\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),\n",
    "                      (12,13),(12,16),(13,14),(13,15)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7088f6a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen8(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_3\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_4\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_3\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"k5\",\"mul\",\"x_5\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k4\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,3),(3,4),(3,5),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"k4\",\"x_2\",\"add\",\"mul\",\"-1\",\"mul\",\"k5\",\"mul\",\"x_5\",\"x_3\",\n",
    "           \"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_4\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"mul\",\"k3\",\"x_1\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,29),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,12),(5,6),(5,7),(7,8),(7,9),\n",
    "                      (9,10),(9,11),(12,13),(12,18),(13,14),(13,17),(14,15),(14,16),\n",
    "                      (18,19),(18,20),(20,21),(20,28),(21,22),(21,25),(22,23),(22,24),(25,26),(25,27)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_3\",\"mul\",\"-1\",\"mul\",\n",
    "           \"add\",\"k1\",\"k2\",\"x_4\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),\n",
    "                      (12,13),(12,16),(13,14),(13,15)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "    seq5 += \";|;\"\n",
    "    \n",
    "    G6 = nx.Graph()\n",
    "    seq6 = [\"add\",\"mul\",\"k4\",\"x_2\",\"mul\",\"-1\",\"mul\",\"k5\",\"mul\",\"x_5\",\"x_3\"]\n",
    "    G6.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq6)])\n",
    "    G6.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq6 = \";\".join(seq6).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq6 = seq6.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5+seq6).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5,G6],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1cc5a1a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen9(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"k5\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,18),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"x_2\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,3),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "24845e51",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen10(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"mul\",\"k5\",\"x_4\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,20),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16),(17,18),(17,19)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"-1\",\"mul\",\"k5\",\"mul\",\"x_4\",\"x_2\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,7),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4),(4,5),(4,6)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "    seq5 += \";|;\"\n",
    "    \n",
    "    G6 = nx.Graph()\n",
    "    seq6 = [\"mul\",\"k5\",\"mul\",\"x_4\",\"x_2\"]\n",
    "    G6.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq6)])\n",
    "    G6.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq6 = \";\".join(seq6).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq6 = seq6.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5+seq6).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5,G6],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8ba0301",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen11(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"k0\",\"k5\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,13),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,10),(7,8),(7,9),(10,11),(10,12)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"mul\",\"k5\",\"x_0\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,20),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16),(17,18),(17,19)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bc4357c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen12(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"k3\",\"k5\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,13),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,10),(7,8),(7,9),(10,11),(10,12)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"mul\",\"k5\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,20),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16),(17,18),(17,19)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"mul\",\"x_1\",\"x_2\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "70b02653",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen13(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"mul\",\"2\",\"mul\",\"k5\",\"x_2\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,23),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,22),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16),(17,18),(17,19),\n",
    "                      (19,20),(19,21)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "\n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,16),(13,14),(13,15)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"pow2\",\"x_2\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,4),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0a38009",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen14(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,16),(9,10),(9,13),(10,11),(10,12),(13,14),(13,15)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"k5\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,18),(13,14),(13,15),(15,16),(15,17)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,3),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d80604c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen15(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,16),(9,10),(9,13),(10,11),(10,12),(13,14),(13,15)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"mul\",\"k5\",\"x_4\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,20),(13,14),(13,15),(15,16),(15,17),\n",
    "                      (17,18),(17,19)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    \n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"-1\",\"mul\",\"k5\",\"mul\",\"x_4\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,7),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4),(4,5),(4,6)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "    seq5 += \";|;\"\n",
    "    \n",
    "    G6 = nx.Graph()\n",
    "    seq6 = [\"mul\",\"k5\",\"mul\",\"x_4\",\"x_3\"]\n",
    "    G6.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq6)])\n",
    "    G6.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq6 = \";\".join(seq6).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq6 = seq6.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5+seq6).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5,G6],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee555bb5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen16(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"add\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\",\n",
    "           \"mul\",\"-1\",\"mul\",\"k5\",\"mul\",\"x_0\",\"x_3\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,12),(5,6),(5,7),(7,8),(7,9),\n",
    "                      (9,10),(9,11),(12,13),(12,14),(14,15),(14,16),(16,17),(16,18)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,16),(9,10),(9,13),(10,11),(10,12),(13,14),(13,15)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"mul\",\"k5\",\"x_0\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,20),(13,14),(13,15),(15,16),(15,17),\n",
    "                      (17,18),(17,19)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"mul\",\"x_0\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a112af28",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen17(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"add\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\",\"mul\",\"-1\",\n",
    "           \"mul\",\"k5\",\"mul\",\"x_1\",\"x_3\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,12),(5,6),(5,7),(7,8),(7,9),\n",
    "                      (9,10),(9,11),(12,13),(12,14),(14,15),(14,16),(16,17),(16,18)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,16),(9,10),(9,13),(10,11),(10,12),(13,14),(13,15)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"mul\",\"k5\",\"x_1\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,20),(13,14),(13,15),(15,16),(15,17),\n",
    "                      (17,18),(17,19)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"mul\",\"x_1\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65fe2700",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen18(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,17),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,16),(9,10),(9,13),(10,11),(10,12),(13,14),(13,15)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"mul\",\"k5\",\"x_3\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,20),(13,14),(13,15),(15,16),(15,17),\n",
    "                      (17,18),(17,19)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"pow2\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,4),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dcf4d7af",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen19(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"mul\",\"k5\",\"x_3\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,20),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16),(17,18),(17,19)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"mul\",\"k5\",\"x_2\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,21),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,20),(13,14),(13,15),(15,16),(15,17),\n",
    "                      (17,18),(17,19)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"mul\",\"x_2\",\"x_3\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,5),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2),(2,3),(2,4)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ae059fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def graph_gen20(ks):\n",
    "    G1 = nx.Graph()\n",
    "    seq1 = [\"add\",\"mul\",\"k1\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k0\",\"mul\",\"x_0\",\"x_2\"]\n",
    "    G1.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq1)])\n",
    "    G1.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq1 = \";\".join(seq1).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq1 = seq1.replace(\"k\"+str(i),n_str)\n",
    "    seq1 += \";|;\"\n",
    "\n",
    "    G2 = nx.Graph()\n",
    "    seq2 = [\"add\",\"mul\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"k3\",\"mul\",\"x_2\",\"x_1\"]\n",
    "    G2.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,11),seq2)])\n",
    "    G2.add_edges_from([(0,1),(0,4),(1,2),(1,3),(4,5),(4,6),(6,7),(6,8),(8,9),(8,10)])\n",
    "    seq2 = \";\".join(seq2).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq2 = seq2.replace(\"k\"+str(i),n_str)\n",
    "    seq2 += \";|;\"\n",
    "\n",
    "    G3 = nx.Graph()\n",
    "    seq3 = [\"add\",\"mul\",\"add\",\"k1\",\"k2\",\"x_3\",\"mul\",\"-1\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\n",
    "           \"add\",\"mul\",\"k3\",\"x_1\",\"k5\",\"x_2\"]\n",
    "    G3.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq3)])\n",
    "    G3.add_edges_from([(0,1),(0,6),(1,2),(1,5),(2,3),(2,4),(6,7),(6,8),(8,9),(8,18),\n",
    "                      (9,10),(9,13),(10,11),(10,12),(13,14),(13,17),(14,15),(14,16)])\n",
    "    seq3 = \";\".join(seq3).replace(\";-1;\",\";-;N1000;E-3;\").replace(\";2;\",\";+;N2000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq3 = seq3.replace(\"k\"+str(i),n_str)\n",
    "    seq3 += \";|;\"\n",
    "    \n",
    "    G4 = nx.Graph()\n",
    "    seq4 = [\"add\",\"mul\",\"add\",\"mul\",\"k0\",\"x_0\",\"mul\",\"k3\",\"x_1\",\"x_2\",\"mul\",\"-1\",\"mul\",\"add\",\"k1\",\"add\",\"k2\",\"k7\",\"x_3\"]\n",
    "    G4.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,19),seq4)])\n",
    "    G4.add_edges_from([(0,1),(0,10),(1,2),(1,9),(2,3),(2,6),(3,4),(3,5),(6,7),(6,8),(10,11),(10,12),(12,13),(12,18),(13,14),(13,15),(15,16),(15,17)])\n",
    "    seq4 = \";\".join(seq4).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq4 = seq4.replace(\"k\"+str(i),n_str)\n",
    "    seq4 += \";|;\"\n",
    "\n",
    "    \n",
    "    G5 = nx.Graph()\n",
    "    seq5 = [\"mul\",\"k5\",\"x_2\"]\n",
    "    G5.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,3),seq5)])\n",
    "    G5.add_edges_from([(0,1),(0,2)])\n",
    "    seq5 = \";\".join(seq5).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq5 = seq5.replace(\"k\"+str(i),n_str)\n",
    "    seq5 += \";|;\"\n",
    "    \n",
    "    G6 = nx.Graph()\n",
    "    seq6 = [\"mul\",\"k7\",\"x_3\"]\n",
    "    G6.add_nodes_from([(i,{\"symbol\":j}) for i,j in zip(range(0,3),seq6)])\n",
    "    G6.add_edges_from([(0,1),(0,2)])\n",
    "    seq6 = \";\".join(seq6).replace(\";-1;\",\";-;N1000;E-3;\")\n",
    "    for i in range(len(ks)):\n",
    "        n_str = num_encoder(ks[i])\n",
    "        seq6 = seq6.replace(\"k\"+str(i),n_str)\n",
    "        \n",
    "    seq = (seq1+seq2+seq3+seq4+seq5+seq6).split(\";\")\n",
    "\n",
    "    return [G1,G2,G3,G4,G5,G6],seq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "196738bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0fa437a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6268107",
   "metadata": {},
   "outputs": [],
   "source": [
    "def batch_generate(batch_size, sigma = 0, i = None, i_li = None):\n",
    "    n = 0\n",
    "    batch = {}\n",
    "    batch[\"times\"] = []\n",
    "    batch[\"trajectory\"] = []\n",
    "    batch[\"tree_encoded\"] = []\n",
    "    batch[\"infos\"] = {}\n",
    "    batch[\"infos\"][\"dimension\"] = []\n",
    "    while True:\n",
    "        if n >= batch_size:\n",
    "            break    \n",
    "        if i_li:\n",
    "            i = np.random.choice(i_li)\n",
    "        else:\n",
    "            if not i:\n",
    "                i = np.random.choice(range(1,21))\n",
    "        x, cat, cls, y, ks, idx_yd = data_gen(i, sigma=sigma)\n",
    "        if idx_yd:\n",
    "            all_data = np.random.choice(x)\n",
    "            times = all_data[\"t\"]\n",
    "            trajectory = all_data[\"y\"].transpose(1,0)\n",
    "            dimension = trajectory.shape[1]\n",
    "            Gs, tree_encoded = eval(\"graph_gen\"+str(i))(ks)\n",
    "            n+=1\n",
    "            batch[\"times\"].append(times)\n",
    "            batch[\"trajectory\"].append(trajectory)\n",
    "            batch[\"tree_encoded\"].append(tree_encoded)\n",
    "            batch[\"infos\"][\"dimension\"].append(dimension)\n",
    "    return batch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "953f4389",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43256fd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_dir = \"\"\n",
    "sigma = 1e-4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a07efcbd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generator(idx, data_dir, num = 5000, infix = \"init\"):\n",
    "    dict_ = {\"class\":[],\"function\":[],\"coeff\":[], \"time\":[], \n",
    "            \"substrate\":[], \"product\":[], \"catalyst\":[], \"other\":[], \"differentiation\":[],\"tree_encoded\":[]}\n",
    "    n = 0\n",
    "    while True:\n",
    "        if n % 1 == 0:\n",
    "            print(n)\n",
    "        if n >= num:\n",
    "            break\n",
    "        try:\n",
    "            data = func_timeout(2,data_gen, args=(idx,))\n",
    "            x, cat, cls, y, args, idx_yd = data\n",
    "            d = eval(\"func\"+str(idx))(x.t, x.y, args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7])\n",
    "        except:\n",
    "            continue\n",
    "        if idx_yd:\n",
    "            Gs, tree_encoded = eval(\"graph_gen\"+str(idx))(args)\n",
    "            dict_[\"class\"] += [cls]\n",
    "            dict_[\"function\"] += [y.replace(\"\\n\",\" \").split(\" \")]\n",
    "            dict_[\"coeff\"] += [args]\n",
    "            dict_[\"time\"].append([x.t])\n",
    "            dict_[\"substrate\"].append(x.y[0])\n",
    "            dict_[\"product\"].append(x.y[1])\n",
    "            dict_[\"catalyst\"].append(x.y[2])\n",
    "            dict_['other'].append(x.y[3:])\n",
    "            dict_[\"differentiation\"].append(d)\n",
    "            dict_[\"tree_encoded\"].append(tree_encoded)\n",
    "            n += 1\n",
    "    df = pd.DataFrame(dict_)\n",
    "    with open(data_dir+\"mechanism_dsr_\"+str(idx)+\"_\"+infix+\".pkl\",\"wb\") as fin:\n",
    "        pickle.dump(df, fin)    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43ee9cd2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "966c9b3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "for idx in tqdm.tqdm(range(1,21)):\n",
    "    generator(idx, data_dir, num = 5000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddecf3db",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db0fb333",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "chem",
   "language": "python",
   "name": "chem"
  },
  "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
