{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import sys\n",
    "\n",
    "sys.path.append(\"..\")\n",
    "import copy\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# setup sympy\n",
    "from sympy import symbols, init_printing, simplify, collect, factor, flatten\n",
    "import sympy as sp\n",
    "\n",
    "init_printing(use_unicode=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# mLSTM Cell FLOP and Memory Operation counts\n",
    "\n",
    "We perform all of this computation for the mLSTMsig and mLSTMexp."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define symbols"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# dimensions\n",
    "N_batch, N_head, N_chunk = symbols(\n",
    "    \"N_batch N_head N_chunk\", integer=True, positive=True\n",
    ")\n",
    "T, L, d_qk, d_hv = symbols(\"T L d_qk d_hv\", real=True, positive=True)\n",
    "# flop factors\n",
    "F_exp, F_log, F_sig, F_max, F_mask, F_abs = symbols(\n",
    "    \"F_exp F_log F_sig F_max F_mask F_abs\", real=True, positive=True\n",
    ")\n",
    "# causal factor\n",
    "F_causal = symbols(\"F_causal\", real=True, positive=True)\n",
    "# number of bytes\n",
    "btytes_qkv, bytes_Cmn, bytes_if = symbols(\n",
    "    \"btytes_qkv bytes_Cmn bytes_if\", real=True, positive=True\n",
    ")\n",
    "\n",
    "N_chunk = T / L"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Chunkwise Parallel Formulation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### FLOP counts"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mLSTMexp:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# recurrent computation of the inter chunk states\n",
    "flop_cwp_exp_gates = (\n",
    "    2 * L + 0.5 * L * (L + 1) + L * (1 + F_exp + F_log + F_sig) + 3 + F_max + F_exp\n",
    ")\n",
    "flop_cwp_exp_numerator = 2 * d_qk * d_hv + 2 * L * d_qk * d_hv + L * d_qk\n",
    "flop_cwp_exp_denominator = 2 * d_qk + 2 * L * d_qk\n",
    "flop_cwp_exp_reccomp_inter = (\n",
    "    flop_cwp_exp_gates + flop_cwp_exp_numerator + flop_cwp_exp_denominator\n",
    ")\n",
    "\n",
    "# parallel computation of the intra chunk outputs\n",
    "flop_cwp_exp_cum_fgates = 0.5 * L * (L + 1) + L * (F_log + F_sig)\n",
    "flop_cwp_exp_gate_matrix = F_causal * (L**2 * (3 + F_exp + F_max) + L * (1 + F_max))\n",
    "flop_cwp_exp_intra_outputs = F_causal * (2 * L**2 * (d_qk + d_hv) + 3 * L**2)\n",
    "flop_cwp_exp_parcomp_intra = (\n",
    "    flop_cwp_exp_cum_fgates + flop_cwp_exp_gate_matrix + flop_cwp_exp_intra_outputs\n",
    ")\n",
    "\n",
    "# parallel computation of the inter chunk outputs\n",
    "flop_cwp_exp_inter_outputs = 2 * L * d_qk * d_hv + 3 * L * d_qk\n",
    "\n",
    "# combination of inter and intra chunk outputs\n",
    "flop_cwp_exp_output_comb = 2 * L * d_hv + L * (1 + F_max + F_abs + F_exp)\n",
    "\n",
    "flop_cwp_exp_expr_dict = {\n",
    "    \"flop_cwp_exp_gates\": flop_cwp_exp_gates,\n",
    "    \"flop_cwp_exp_numerator\": flop_cwp_exp_numerator,\n",
    "    \"flop_cwp_exp_denominator\": flop_cwp_exp_denominator,\n",
    "    \"flop_cwp_exp_reccomp_inter\": flop_cwp_exp_reccomp_inter,\n",
    "    \"flop_cwp_exp_cum_fgates\": flop_cwp_exp_cum_fgates,\n",
    "    \"flop_cwp_exp_gate_matrix\": flop_cwp_exp_gate_matrix,\n",
    "    \"flop_cwp_exp_intra_outputs\": flop_cwp_exp_intra_outputs,\n",
    "    \"flop_cwp_exp_parcomp_intra\": flop_cwp_exp_parcomp_intra,\n",
    "    \"flop_cwp_exp_inter_outputs\": flop_cwp_exp_inter_outputs,\n",
    "    \"flop_cwp_exp_output_comb\": flop_cwp_exp_output_comb,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# total flops mLSTMexp\n",
    "flop_cwp_exp_recurrent = flop_cwp_exp_reccomp_inter\n",
    "flop_cwp_exp_parallel = (\n",
    "    flop_cwp_exp_parcomp_intra + flop_cwp_exp_inter_outputs + flop_cwp_exp_output_comb\n",
    ")\n",
    "flop_cwp_exp_total = (\n",
    "    flop_cwp_exp_reccomp_inter\n",
    "    + flop_cwp_exp_parcomp_intra\n",
    "    + flop_cwp_exp_inter_outputs\n",
    "    + flop_cwp_exp_output_comb\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle F_{causal} L^{2} \\left(2 d_{hv} + 2 d_{qk} + 3\\right) + F_{causal} \\left(L^{2} \\left(F_{exp} + F_{max} + 3\\right) + L \\left(F_{max} + 1\\right)\\right) + F_{exp} + F_{max} + L \\left(F_{abs} + 2 F_{exp} + 2 F_{log} + F_{max} + 2 F_{sig} + 1.0 L + 4 d_{hv} d_{qk} + 2 d_{hv} + 6 d_{qk} + 5.0\\right) + 2 d_{hv} d_{qk} + 2 d_{qk} + 3$"
      ],
      "text/plain": [
       "          2                                 ⎛ 2                                ↪\n",
       "F_causal⋅L ⋅(2⋅dₕᵥ + 2⋅d_qk + 3) + F_causal⋅⎝L ⋅(Fₑₓₚ + Fₘₐₓ + 3) + L⋅(Fₘₐₓ +  ↪\n",
       "\n",
       "↪   ⎞                                                                          ↪\n",
       "↪ 1)⎠ + Fₑₓₚ + Fₘₐₓ + L⋅(F_abs + 2⋅Fₑₓₚ + 2⋅F_log + Fₘₐₓ + 2⋅F_sig + 1.0⋅L + 4 ↪\n",
       "\n",
       "↪                                                            \n",
       "↪ ⋅dₕᵥ⋅d_qk + 2⋅dₕᵥ + 6⋅d_qk + 5.0) + 2⋅dₕᵥ⋅d_qk + 2⋅d_qk + 3"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(flop_cwp_exp_total, L)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mLSTMsig:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# recurrent computation of the inter chunk states\n",
    "flop_cwp_sig_gates = (\n",
    "    2 * L + 0.5 * L * (L + 1) + L * F_exp + F_exp + 2 * L * (F_log + F_sig)\n",
    ")\n",
    "flop_cwp_sig_numerator = 2 * d_qk * d_hv + 2 * L * d_qk * d_hv + L * d_qk\n",
    "flop_cwp_sig_reccomp_inter = flop_cwp_exp_gates + flop_cwp_sig_numerator\n",
    "\n",
    "# parallel computation of the intra chunk outputs\n",
    "flop_cwp_sig_cum_fgates = 0.5 * L * (L + 1) + 2 * L * (F_log + F_sig)\n",
    "flop_cwp_sig_gate_matrix = F_causal * (L**2 * (2 + F_exp))\n",
    "flop_cwp_sig_intra_outputs = F_causal * (2 * L**2 * (d_qk + d_hv) + 3 * L**2)\n",
    "flop_cwp_sig_parcomp_intra = (\n",
    "    flop_cwp_sig_cum_fgates + flop_cwp_sig_gate_matrix + flop_cwp_sig_intra_outputs\n",
    ")\n",
    "\n",
    "# parallel computation of the inter chunk outputs\n",
    "flop_cwp_sig_inter_outputs = 2 * L * d_qk * d_hv + L * d_qk\n",
    "\n",
    "# combination of inter and intra chunk outputs\n",
    "flop_cwp_sig_output_comb = L * d_hv\n",
    "\n",
    "flop_cwp_sig_expr_dict = {\n",
    "    \"flop_cwp_sig_gates\": flop_cwp_sig_gates,\n",
    "    \"flop_cwp_sig_numerator\": flop_cwp_sig_numerator,\n",
    "    \"flop_cwp_sig_reccomp_inter\": flop_cwp_sig_reccomp_inter,\n",
    "    \"flop_cwp_sig_cum_fgates\": flop_cwp_sig_cum_fgates,\n",
    "    \"flop_cwp_sig_gate_matrix\": flop_cwp_sig_gate_matrix,\n",
    "    \"flop_cwp_sig_intra_outputs\": flop_cwp_sig_intra_outputs,\n",
    "    \"flop_cwp_sig_parcomp_intra\": flop_cwp_sig_parcomp_intra,\n",
    "    \"flop_cwp_sig_inter_outputs\": flop_cwp_sig_inter_outputs,\n",
    "    \"flop_cwp_sig_output_comb\": flop_cwp_sig_output_comb,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "flop_cwp_sig_recurrent = flop_cwp_sig_reccomp_inter\n",
    "flop_cwp_sig_parallel = (\n",
    "    flop_cwp_sig_parcomp_intra + flop_cwp_sig_inter_outputs + flop_cwp_sig_output_comb\n",
    ")\n",
    "flop_cwp_sig_total = (\n",
    "    flop_cwp_sig_reccomp_inter\n",
    "    + flop_cwp_sig_parcomp_intra\n",
    "    + flop_cwp_sig_inter_outputs\n",
    "    + flop_cwp_sig_output_comb\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle F_{exp} + F_{max} + L^{2} \\left(F_{causal} \\left(F_{exp} + 2\\right) + F_{causal} \\left(2 d_{hv} + 2 d_{qk} + 3\\right)\\right) + L \\left(F_{exp} + 3 F_{log} + 3 F_{sig} + 1.0 L + 4 d_{hv} d_{qk} + d_{hv} + 2 d_{qk} + 4.0\\right) + 2 d_{hv} d_{qk} + 3$"
      ],
      "text/plain": [
       "               2                                                               ↪\n",
       "Fₑₓₚ + Fₘₐₓ + L ⋅(F_causal⋅(Fₑₓₚ + 2) + F_causal⋅(2⋅dₕᵥ + 2⋅d_qk + 3)) + L⋅(Fₑ ↪\n",
       "\n",
       "↪                                                                              ↪\n",
       "↪ ₓₚ + 3⋅F_log + 3⋅F_sig + 1.0⋅L + 4⋅dₕᵥ⋅d_qk + dₕᵥ + 2⋅d_qk + 4.0) + 2⋅dₕᵥ⋅d_ ↪\n",
       "\n",
       "↪       \n",
       "↪ qk + 3"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(flop_cwp_sig_total, L)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Compare mLSTMsig and mLSTMexp:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle L^{2} \\left(1.0 d_{hv} + 1.0 d_{qk} + 3.0\\right) + L \\left(1.0 L + 4 d_{hv} d_{qk} + d_{hv} + 2 d_{qk} + 11.0\\right) + 2 d_{hv} d_{qk} + 5$"
      ],
      "text/plain": [
       " 2                                                                             ↪\n",
       "L ⋅(1.0⋅dₕᵥ + 1.0⋅d_qk + 3.0) + L⋅(1.0⋅L + 4⋅dₕᵥ⋅d_qk + dₕᵥ + 2⋅d_qk + 11.0) + ↪\n",
       "\n",
       "↪                \n",
       "↪  2⋅dₕᵥ⋅d_qk + 5"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(\n",
    "    flop_cwp_sig_total.subs(\n",
    "        {F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1, F_causal: 0.5}\n",
    "    ),\n",
    "    L,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle L^{2} \\left(1.0 d_{hv} + 1.0 d_{qk} + 4.0\\right) + L \\left(1.0 L + 4 d_{hv} d_{qk} + 2 d_{hv} + 6 d_{qk} + 14.0\\right) + 2 d_{hv} d_{qk} + 2 d_{qk} + 5$"
      ],
      "text/plain": [
       " 2                                                                             ↪\n",
       "L ⋅(1.0⋅dₕᵥ + 1.0⋅d_qk + 4.0) + L⋅(1.0⋅L + 4⋅dₕᵥ⋅d_qk + 2⋅dₕᵥ + 6⋅d_qk + 14.0) ↪\n",
       "\n",
       "↪                           \n",
       "↪  + 2⋅dₕᵥ⋅d_qk + 2⋅d_qk + 5"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(\n",
    "    flop_cwp_exp_total.subs(\n",
    "        {F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1, F_causal: 0.5}\n",
    "    ),\n",
    "    L,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Substitute and simplify:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "simplified_flop_cwp_exp_dict = copy.deepcopy(flop_cwp_exp_expr_dict)\n",
    "for k, v in simplified_flop_cwp_exp_dict.items():\n",
    "    simplified_flop_cwp_exp_dict[k] = collect(\n",
    "        v.subs({F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1}), L\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'flop_cwp_exp_gates': L*(0.5*L + 6.5) + 5,\n",
       " 'flop_cwp_exp_numerator': L*(2*d_hv*d_qk + d_qk) + 2*d_hv*d_qk,\n",
       " 'flop_cwp_exp_denominator': 2*L*d_qk + 2*d_qk,\n",
       " 'flop_cwp_exp_reccomp_inter': L*(0.5*L + 2*d_hv*d_qk + 3*d_qk + 6.5) + 2*d_hv*d_qk + 2*d_qk + 5,\n",
       " 'flop_cwp_exp_cum_fgates': L*(0.5*L + 2.5),\n",
       " 'flop_cwp_exp_gate_matrix': F_causal*(5*L**2 + 2*L),\n",
       " 'flop_cwp_exp_intra_outputs': F_causal*L**2*(2*d_hv + 2*d_qk + 3),\n",
       " 'flop_cwp_exp_parcomp_intra': F_causal*L**2*(2*d_hv + 2*d_qk + 3) + F_causal*(5*L**2 + 2*L) + L*(0.5*L + 2.5),\n",
       " 'flop_cwp_exp_inter_outputs': L*(2*d_hv*d_qk + 3*d_qk),\n",
       " 'flop_cwp_exp_output_comb': L*(2*d_hv + 4)}"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simplified_flop_cwp_exp_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "simplified_flop_cwp_sig_dict = copy.deepcopy(flop_cwp_sig_expr_dict)\n",
    "for k, v in simplified_flop_cwp_sig_dict.items():\n",
    "    simplified_flop_cwp_sig_dict[k] = collect(\n",
    "        v.subs({F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1}), L\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'flop_cwp_sig_gates': L*(0.5*L + 7.5) + 1,\n",
       " 'flop_cwp_sig_numerator': L*(2*d_hv*d_qk + d_qk) + 2*d_hv*d_qk,\n",
       " 'flop_cwp_sig_reccomp_inter': L*(0.5*L + 2*d_hv*d_qk + d_qk + 6.5) + 2*d_hv*d_qk + 5,\n",
       " 'flop_cwp_sig_cum_fgates': L*(0.5*L + 4.5),\n",
       " 'flop_cwp_sig_gate_matrix': 3*F_causal*L**2,\n",
       " 'flop_cwp_sig_intra_outputs': F_causal*L**2*(2*d_hv + 2*d_qk + 3),\n",
       " 'flop_cwp_sig_parcomp_intra': L**2*(F_causal*(2*d_hv + 2*d_qk + 3) + 3*F_causal) + L*(0.5*L + 4.5),\n",
       " 'flop_cwp_sig_inter_outputs': L*(2*d_hv*d_qk + d_qk),\n",
       " 'flop_cwp_sig_output_comb': L*d_hv}"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simplified_flop_cwp_sig_dict"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Recurrent Formulation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### FLOP counts"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mLSTMexp:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "flop_rec_exp_gates = 4 + 2 * F_exp + F_log + F_sig + F_max\n",
    "flop_rec_exp_cell_update = 4 * d_qk * d_hv\n",
    "flop_rec_exp_denom = 6 * d_qk + d_hv + 1 + F_abs + F_max\n",
    "flop_rec_exp_output = 2 * d_hv * d_qk + d_qk\n",
    "\n",
    "flop_rec_exp_total = (\n",
    "    flop_rec_exp_gates\n",
    "    + flop_rec_exp_cell_update\n",
    "    + flop_rec_exp_denom\n",
    "    + flop_rec_exp_output\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle F_{abs} + 2 F_{exp} + F_{log} + 2 F_{max} + F_{sig} + 6 d_{hv} d_{qk} + d_{hv} + 7 d_{qk} + 5$"
      ],
      "text/plain": [
       "F_abs + 2⋅Fₑₓₚ + F_log + 2⋅Fₘₐₓ + F_sig + 6⋅dₕᵥ⋅d_qk + dₕᵥ + 7⋅d_qk + 5"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flop_rec_exp_total"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mLSTMsig:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "flop_rec_sig_gates = 2 * F_sig\n",
    "flop_rec_sig_cell_update = 4 * d_qk * d_hv\n",
    "flop_rec_sig_output = 2 * d_hv * d_qk + d_qk\n",
    "\n",
    "flop_rec_sig_total = flop_rec_sig_gates + flop_rec_sig_cell_update + flop_rec_sig_output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAMMAAAAVCAYAAAD7GFqYAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAHQklEQVR4Ae2b63EUORCAF8oBcCYDyMBABEAGcI4AyACKX/CPggyACAxkABcBHBlABmecge/7ZPWU5rG7s7Mzs2uKrtLq1VI/1N16jH3l/Px88fLlyxuLxeIZSbhNOiU9o/27DU2g/Slt90niCt9IZ6l08XONLPqc513Rd2mLyPG6wfzJMh0FHv1HlN+T1PEH6k+ib+p8l7Qvo2xXXrx44SK9RXEadwLKLnoyeMpfcnMro++cxu/kt1qdNND+L5lzX2pngH919JGkYyd9kFs/Ir9JvhbAU1cPyT+tRR4ZYZe0RxalNd2Ysl1ldg2/Fq0g4C5hpHfBOwEcI56w1Fnoe0v6KdKuAX7vkR4P5EM9uAuUsrr79ZJN2pluOX4gK5sN2yXt4FQeSEN1H9O08rFl0xlcqB9M7OKW4MJdo/1G2ViUY4E/F23NosetXgbTHDhBXfmaMq4lg/wPQNLxa7sb7fdNaye4QBDvJ/hnPfHHRNsl7ZBjkO5j8Ip8VNl0Bo1+1UItM6BkCCxwLdpRjx0jyUB9X5xhhU5Xdrlrnm1pyAaOmp5WUhy3c5e0x5WkPduosh2wyA/bNFJLMmr6Oy/RYMhIrQ9cx3hxTu3UZz8fQ3tsUB6DhbIdk/4jeU/4SFvLwGlzJ/XoaRAQVxzHviJNCrukPalgTD6HbAddQkDYxXNR44Wphpb7bauMITPrq8ky56rNcYkqsTPeRsZKH5R/kR6RKoenbIDwfnGLctoRyeMYWelqCtl3SXsKeco555Kt0xlgxAX9BBNvSqaKshFS8DUlLtk60CH1jY9FjNHgBo2Viakg8+X0ylm7M9D2gfSe9i8kj1HKoC58cSp1YNkXtzPySWCXtCcRqJh0TtlazgDx9AJEvirCGwEFnwqrRc5jL3o2+30OukeKZc7Xe7bMQ/BXjju0Qn/t5SwjaKyr5C2NO+b02dgXEo9RRn2PRj44NJ1GXqrdg3IC8BzrTuPT87Zyb0T7goPlv0N5Y5y2M7buZ5PtoFRJVoIROl2Oy75G2V2gFu0YY2SMI0EDfXWVsdXxYzXm+l7m6jL2Be2+Ct0g72144BrxJVo5vJUGxGvb37TXjkKMVSf2t/RC3zuSC10bQ30IbER7HYGCt9qdsMe40XRf0JpNtsoZUIDGcpO8ipCU00KTV5GRcnh+bRFp12BaEbAQ6rIWlTMMvksGL9cavalp9C7kgv6arnJb6HYjg3NsCUNol+O7yswpb+5yLb678Kdqm1u25AwQNdLfIW9GaB2kue3HrnHSVwnMawT8kfFPqSenIdexgnblhDEv/R4lNDJBZ3OBekf2NGr7H7f+uBeVs/nV3Z3DO0PwWAWNjKiu4mVNXbqbBo6yOzY+Ril/7U9g6GvphzZ1uSBvrlXMa7ewlDZj5dejqWtiWd3q1GH8iTfapKNjyPt1yk2aoswBs8h2NQvrYmtonl+rRNsT6iqqBBW1oL1XRHM+0P16q1N9Ix2THO8ieDHVuB/kul0JqD+l4KvMm4yjsdy56J3vF9o6rkabjFDKlOXdqP8o19VRbQcBRwPS0ZVZ8CNduagaq8c2j0vqxl1FA01A2zL9fAWh2qnA24h2ntf7TvyZjHy7Rk3ePoMrHWWQv8e5TnEemFu2A8RyERQ6IlQpaUQ1F+Y9KS2QCDAa0bL5emJ3Cc7tq4sK9w/VYgc4pK4haDS1j360OUbj+4sUIH7QjLZZcvjRkF+TlEGQl7vUy4CgXMqpE18nnZA0eMfZFmMpJjCo3M1lM79dlAbZqR/m8pWvGRQ2oa1ede6SljtcWZc3nc5gFbu48pY4dM8Cs8l2gIBr/9AMHKOPTA0Bt9Z/SBqDhpHe4EOx5F66ugyldkEH54gU2zjFeQE+Vx4R6F+mo5bewNXZF+SlM2mAFQ36kuGRu5Mmg8xj1EPtbgJOb9qMdUcreZJupVfmkjeDnnbhHdJA5VqUvNI1D0B3NtmuTikSgqhYlWmEV7mnJHeCBLSrdBfDHcJFDhA3jheL3NeMXoHbN1eppn0AZS7lU08emYz6pR7kVdzS+O+BUxmvCH2BcerbVEZ4dy93gYDkHOAapNyJ025MXR6HwuS6H0O2SZ0BzbmIt9UgzLoARrhyIVV87ADls5yLc0gKeE6hHBftvXPoezRoPgb0Hj8yogZYM3DqEf3dCUowgJjUoQY5OEIzvmaU1HW8ZPzOn6HkLdHN7eX6BG6vHDqT634M2aZ2Bs+nXsy9fHkn+UpeLqYG7s7hmVrcBNQ1jFPbc59GUEavC8TL+2t0DuNXiuToyKoOXtlQgEZ4TJ/6G7wrFPN5RPKe53zJwCmXa1LxltsNVuKeFHPsa3Er2a74n277DizGL3hsXlj3ne295y8buS+Gnf+ctfcCrGBwiGxT7wwr2O3uQghfMOKbxIKyu0a6xHWP+NO6hQZ0gq2On1vQnnroxrLtnTOgIc+1Gr9HK48NXqbvkv7AiBrIuvVlyeDjMfS3gaGy/Q+wPb2242v2GwAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle 2 F_{sig} + 6 d_{hv} d_{qk} + d_{qk}$"
      ],
      "text/plain": [
       "2⋅F_sig + 6⋅dₕᵥ⋅d_qk + d_qk"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flop_rec_sig_total"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Parallel Formulation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### FLOP counts"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mLSTMexp:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "flop_par_exp_cum_fgates = 0.5 * T * (T + 1) + T * (F_log + F_sig)\n",
    "flop_par_exp_gate_matrix = T**2 * (3 + F_exp + F_max + F_mask)\n",
    "flop_par_exp_attn_logits = F_causal * (2 * T**2 * d_qk + 2 * T**2)\n",
    "flop_par_exp_normalization = F_causal * (T**2 * (3 + F_abs) + T * (F_exp + F_max))\n",
    "flop_par_exp_outputs = F_causal * 2 * T**2 * d_hv\n",
    "\n",
    "flop_par_exp_total = (\n",
    "    flop_par_exp_cum_fgates\n",
    "    + flop_par_exp_gate_matrix\n",
    "    + flop_par_exp_attn_logits\n",
    "    + flop_par_exp_normalization\n",
    "    + flop_par_exp_outputs\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle F_{causal} \\left(T^{2} \\left(F_{abs} + 3\\right) + T \\left(F_{exp} + F_{max}\\right)\\right) + T^{2} \\left(2 F_{causal} d_{hv} + F_{causal} \\left(2 d_{qk} + 2\\right) + F_{exp} + F_{mask} + F_{max} + 3\\right) + T \\left(F_{log} + F_{sig} + 0.5 T + 0.5\\right)$"
      ],
      "text/plain": [
       "         ⎛ 2                              ⎞    2                               ↪\n",
       "F_causal⋅⎝T ⋅(F_abs + 3) + T⋅(Fₑₓₚ + Fₘₐₓ)⎠ + T ⋅(2⋅F_causal⋅dₕᵥ + F_causal⋅(2 ↪\n",
       "\n",
       "↪                                                                        \n",
       "↪ ⋅d_qk + 2) + Fₑₓₚ + Fₘₐₛₖ + Fₘₐₓ + 3) + T⋅(F_log + F_sig + 0.5⋅T + 0.5)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(flop_par_exp_total, T)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "mLSTMsig:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "flop_par_sig_cum_fgates = 0.5 * T * (T + 1) + 2 * T * (F_log + F_sig)\n",
    "flop_par_sig_gate_matrix = T**2 * (3 + F_exp + F_max + F_mask)\n",
    "flop_par_sig_attn_logits = F_causal * (2 * T**2 * d_qk + 2 * T**2)\n",
    "\n",
    "flop_par_sig_outputs = F_causal * 2 * T**2 * d_hv\n",
    "\n",
    "flop_par_sig_total = (\n",
    "    flop_par_sig_cum_fgates\n",
    "    + flop_par_sig_gate_matrix\n",
    "    + flop_par_sig_attn_logits\n",
    "    + flop_par_sig_outputs\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle T^{2} \\left(2 F_{causal} d_{hv} + F_{causal} \\left(2 d_{qk} + 2\\right) + F_{exp} + F_{mask} + F_{max} + 3\\right) + T \\left(2 F_{log} + 2 F_{sig} + 0.5 T + 0.5\\right)$"
      ],
      "text/plain": [
       " 2                                                                             ↪\n",
       "T ⋅(2⋅F_causal⋅dₕᵥ + F_causal⋅(2⋅d_qk + 2) + Fₑₓₚ + Fₘₐₛₖ + Fₘₐₓ + 3) + T⋅(2⋅F ↪\n",
       "\n",
       "↪                              \n",
       "↪ _log + 2⋅F_sig + 0.5⋅T + 0.5)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(flop_par_sig_total, T)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Compare mLSTMsig and mLSTMexp:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle T^{2} \\left(1.0 d_{hv} + 1.0 d_{qk} + 9.0\\right) + T \\left(0.5 T + 3.5\\right)$"
      ],
      "text/plain": [
       " 2                                             \n",
       "T ⋅(1.0⋅dₕᵥ + 1.0⋅d_qk + 9.0) + T⋅(0.5⋅T + 3.5)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(\n",
    "    flop_par_exp_total.subs(\n",
    "        {F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1, F_causal: 0.5}\n",
    "    ),\n",
    "    T,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYEAAAAZCAYAAADXG5K+AAAACXBIWXMAAA7EAAAOxAGVKw4bAAALTUlEQVR4Ae2d2XUVORCGLz4OgIEIxmRghgjGZGAgAkwGcHiCtzmQARABSwYmA5YMTAYYZ+D5P1klS93qvfvevtdd58jaS6VfpdLWtm9dXl6uhtDr169vq/5Lz+PA+0+VfjGE71J3QWBBYEFgQWB6BPZHaOKNDP4z46PwO4V/yN2ztMVfEFgQWBBYEJgnAnsjiHUiw38U8Xmj8IHSDqO0JbggsCCwILAgMEMExlgEOAV8H9o3LRp2lTSU1VJ/QWDrELgp+n9T+jlXBczhP3gRENP3cvH9P4vCL6X9bAuEyj5X2eXk0BawpdzaEJBucqrltMvb15REO8yDnSXfv1HnuXiW+DFWcjduU9kSi5Ke3eJhGNCkedzjQ7/kzKgbwHEa4FL+neq9lR/IC/FZCfcVNh4hPxdQuWOlP5D/oiIfGTrxND7iydUU9FuONwreL+hLLakMbX6Qo6+fFA9vHrUVZ5zp+7Tg2HGMhBv6CW5VdKEyf1VlWrrKNOqiyrAIwO+91Vu3r7ZHsQVFucW3cp4rrxGbIj+Lq+4fhZHZNp2EoWCDpurTVTPT/ZTc2KFn8lvZnzZYIK3KJXpmD8MnygPE5Ksez/Rc/kMqGynOpEiMvNIwmAxmAN/KV/mqw4C9lH8/LuPTMcLncv/IdV7VxYNF7T/5X+SvPM8f8h/K1S4EygcL+sGnU6fU30aS/OC74Dhs8B6o+le5nM7wFpbdvMRNahxa6aLKvaWsHBuPZH7F/CYOD7YFRfnUl+w8p5zyWmFT5BnFsREQBpMxYr4z72P8Ru+T2lgHYWexRW2pDRZgnuiZLQLsxB/FLSluO/5PcboPf5QfQPZlX8h3i4WPr+TnJk7MjkWDr4kSUj14O3kU7nxVpDoMOkdCtwDAXGF2WMRpL1nUyC+SytpjNwZgY+Tl4AjXeXeoOguOGrkhGDLwql/SF6W5jYn8oGM5JVF+V11EP5kXrXZ/FW2iu710RvUG2YKcPEqrmuddscmx/ymME9uVKTRFn0rNSI4huCf8xKvP1WAbLKydoGd7agxlzu12zQjm8qjzHW6+Pgy5HjrEKczuyFYlBSvpscp3Nm6V3K4zUIrcCvpN6Udq8/Z10coQE5+3jbDYVZacNgNZ28g7hRS7guMQDNGZHCWfRucK+LROGPr5wLwYMua9+qs2B9mCGgyq5nknbGr4V2ZN2Kdcm71wLzKSzNjQC++K2aPE1QZ21+nZngJVOwbb/eR2wqw4CAlxnGPBwDfHQ5rlK7lMyueOsOmkUK7YLgV5couQtWcLXB03yuT6Xldn1/JuPI7S09JOX2nsbP9rOdh9MERPH7fkP2axobagJEvDPO+DTamNhoTR+9TQ3hjZT4TbFJvjomxOz/bVWJWhY4CyO+G4jsKNj2LFln2cRaaq7YoqzcmSh9W4ie7EBVSHHRATG1B+yyEXq3Hbia6iu0ULjvnx9LrCibfNW0BnXfSton/Mj3UYgtBR9alqPrayBYFRGsjO8z76lbK9jomXu1ZSyl055jJvAu4mYKI+XTc+ckjycg3EzUovqsMiw9Dp2X4mYyVGAIkC594DclX6pPHg27uzNQ2aga87iYTJqb6i4DzA8BDsTgry7QqsalLUNL8zWQuO+aFks4BrQ50wjBieKYxebpxGsAVV87wvNkVMnJ2SnG6+e3nP5PMBSHb++jKuXpHZJuNeLt4unR3qIUtXLJyeZRcBNW4KaMawhzyNVRA4d2XTWHGEAuwYVgIbGVgAeNSOgSccX3kp6sqz42AHWPo8lvwbSL1wbIOTxmN2WEsmNke8KXGXPRY5DAvMmBe0NQcaaguGzPMcNgkmGgu7tnbpinN7gfFng1n1p2uG9imRYcQIn4M2njCr2uuBhdOzqkXAgM2upFVCdExnJ3DRsU6b4nULi+0+uPKB2NHxFVHx2I2S5O6C+cU46oyOi/iitKacCgZyMis/97VIl68BAsOWgclwbNM+Y+Kx/tmmPGVUfmoMGYN4s9AkWhcMY160gfGspTX0l/aH2oKqed4Xm1pMfCb4sVjzHpAbr0F9mgJ38WTTM8XNSB0WTs+qFgGMUfY9wIM8W09gcpxCvtwksjRTDB7fEoOuupRhF1Y6BSnP7c7ktzZM4tOKxDNn5FdK5wEdZU5+Ma8V0wGF1N5kOLYRS+2DNQt0Mj51dVV2agw7fczQEcO4a1WGMy6zWkN/aW8SWzAAm4CBeDBH78i/HxLTgM33NHVgn8bGXfxM180uFeVtjPfEwulZaREwgdTqlO8BdIqdQNUgkT+EMBzOYBeYuF210r6qn7SNKxp791WG8nPGhwlBXVZtiGsBrpLCoqAwZQ7lwrfJSnN3yPJ7H/XEbxM0CY7CAdxfynEnSfhCzo7xCjpyWBNSecYSA3x3Uxh6mZEjjLXCbagRwwwTMGF+bJQ87sgyxBbUzfM+2MSY8N6Qw8nNc8lfGquR+hTLMEYYvcJecDUdE3aEDSDpzI86+9EZC/F0erYXt+jDTD6oaByvUsf7yapH56cgQAOUIrFjKN71F1dfjopOeQT6sVwsI3nukzOlc4UERhgzR0oDVL4cYddOXeLQN7mYj0vcgh+j4+gx4VNi3lXAEEPAMTg3DqcqA25MBsqe+LiCayfTp5zRqROmC4bGByNWxMPy1umPYQvq5nkfbOL+c2WYu/cPG4i4sA+P0acM2/5J6gMby0dFJ44XcpZXtwDQeB8snJ7tUbtAdqRmck5JGNoHLRqwxyEETkigcV1wKYdRCaQ4BuNc/rElKoxBZpf/lDTFHcAKBuPsy2Nw3C/CyS/+iQkUyNWXD6GA8WRFRgaDdsN1muK8L8TlFF07zQVH96YiTGI8uHqK44Bjk5VF9Ysc4/Vvpty6gER/IOQokeTqrYslZvpSTWmlXWym3NRJY9iCynkuzBrnKR2swlZZbCSSe3TF+cQSqnq8H6NPVy1M/xOdM71zrY2MhdOzfTiLMRMTY0iDGEHos9JR+G/yp7iP/kgbNJQjtWl5ZgyQB0PB7hDlWck342FGO2ZFB/mtThYaHoLxMSLx5EJRPigNxcFIIhO7feqRFhRMcbdYFOojW1ihlecMmfwnSg8Py4qD6dQnKzVRJrU9KxwlIQtxPEHBMNlwSGbTRRbZe4qzoHKCi8dOWWsl2nbzIdeqZBuqizFbMDFjFadPHlY/xrYFtfNcHWqcp1XYKh29YK7aPGUTdi73N3UMLMoobDq1LvtmzXf2fX+cvVHlI8WZw84O0y857Exi80iTa8SiIMyVnvFXRDflXr16dSZ3uKn2u7QrOU/kTq2Owgdyil6u5Cd9UPyP3FFU9rmFu/ricyzXu37X9qYsr37clruUO7B2FD6VS/qneMBa4SO5M8rLD/Wsfhtf9bYGQ/po/W3Tt1yZufWX/sglcyQn97anzQ33Ojwla9CzvcLKsO4oK/RGdjw9OsoJId7Ns4rabp+df0zsRnArrc6s6Owi+xI7mrCr6ctkDvWERdIXxdmVlU4CSouxdjh6+fvqStLuHLCokYGTJfNiCM2tv9s0z3cJ97q+BD1z/0+gruTUeTIEGFZ+SaJ4Jzx10534F+VUHOOOciN38qdrlYdhw5Dx9ctKcXd9Rfimk8eG6yDecbgK4LH3VoyL4olOKM5xmLTvCg9ZUONmZhdW39Ap7rnRnZ0i9SkZ053q3JZ1pqhn+zOQH4PAJJ+14hcnpuIY//huO0CpPO64k3vukHnDAzE2CvOpbcmoKz3RBcWzOO8glNxt9z3tzB2OrZjncwdxJPkSPdv0ddBKE5yjKycBe9UfqZ8Lmy1AgJPAslgKBK//sz8R99WpZZ73RW7cejk92/h10LhdXLhtCwJSRq7SOAnwlcPOGr9tGY9FzpuLwP8TYwzQxRHyAQAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle T^{2} \\left(1.0 d_{hv} + 1.0 d_{qk} + 7.0\\right) + T \\left(0.5 T + 4.5\\right)$"
      ],
      "text/plain": [
       " 2                                             \n",
       "T ⋅(1.0⋅dₕᵥ + 1.0⋅d_qk + 7.0) + T⋅(0.5⋅T + 4.5)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "collect(\n",
    "    flop_par_sig_total.subs(\n",
    "        {F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1, F_causal: 0.5}\n",
    "    ),\n",
    "    T,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Compare the Total FLOP counts\n",
    "\n",
    "We compare the flop counts for a single head for one sequence of length $T$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "subs_dict = {F_exp: 1, F_log: 1, F_sig: 1, F_max: 1, F_mask: 1, F_abs: 1}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### mLSTMexp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "comp_flop_rec_exp_total = T * flop_rec_exp_total\n",
    "comp_flop_cwp_exp_total = N_chunk * flop_cwp_exp_total\n",
    "comp_flop_par_exp_total = flop_par_exp_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQwAAAAWCAYAAAA1tqLaAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAI1ElEQVR4Ae2c6XUUORDHe/0cgJfNwGTAEcGaDHZNBEAG7OMTfONBBiwRGMgAZ8CRAWSwZjLw/n8aSS6ppXb3TPfcek+WVCrVJVXpmIbm+vq6mTK/fPnydEr6B9rTzt/Bvvtr35LvHjUTplevXj0X+XsTsjiQPlggWkDr7VT5qfJJBB4qy1gAe+LDMf3GDuIN/M1Df6qc+Xpwdgs7VR8T8k7j3nq8VqG+vwR8qPKfVqcHqO9N1nch2PcMljTVj0zvlZHjg9rPEoSJGuviO5E6Cdld0U16sOY+JsqljZlwfk9BN61dsQMaeV2wxX3Vgz9HZQXDf4JvPlD9irbgif+pTcDAbv+qbI75o/RUGcQn6ojEVf8l2JXKRypjUhtBIl7s8BX1E1BeqLyf99EWHGGhgYCXHkabfJd2LQkfOTHCtcrPNbyx4eviO7YeJXo7pNtD6cd6YoPL05kAwUHyPtfedjtIfvyOzRTnJwjgZ60kPOBs+NGvVWfz/gZM2fkkA1V/qwyczXkWAgYngb9BCEltiCLAhwAz5YXq1YChPpi/M/h5lcDAaSIKpja8ShOdj200jskn2fFzyIR/18XXquRl4KjoIr7tW6a+Cboh/7L6aXx0gmAPwZzjqPwUYLXS86d7pWvLyuNlGDzHGodPOj9Wves5AP9MTubCZ/Pm4IBv5qcwfNmNORISxizt1MEpS32M+apcS+eiW1zQgnNs5FqR9AtOZGtNdoUBeD+F3xW0KkOXAq+LrxWawEoeO22Cbui0jH5fKkZ5o7WSOEgFD/Am2GEZG3SoFrvw7R+ySb6OCJIngrsAG7DVxlfx6ZMjVWqRDMORSpH2uwbP5t3pX8EJCF0nBSaOO1FxfEqt2kLhklzVASN1rIvvSOJ3ktl63bSmWicIwdgZX3dqnnZuvR1SdYotfKdrw80DCUTw6fNjGbTmeBiuSLRjDIQJNDWa9HO3gi6njMfK/ynzbvGxRFcwoh2TjsDgQpuxQxaB0IeldfEdJuVi2Lusm7WI1/OeyuLbxb7YwdqEuvROnh9MP35Ff/Lw6fvxu0fHvpEUGoCTEmVK7xcJbqFBQOh6vwjR64H4xIlU/Zcyj65xl1CdoMWdikdOd2pRGa5IXUGpIFZ/0Lr49pdwccxd1q1gFTYacivtmR1a+ucA2YNggd9Hn8xwfqh9VgwYdHjk4JzZ2M4mAYFX2laSUCFYEPWTNwwhE5zeC36pzJUFXIIFjzH2ikO9dSUSDg82KNv5c6/6O9NQvp3E1DmWXLfx6dM/VLdNkr2PfhZHsrP4z1S2dtOhdrB0S/VttpPRB1/7JF1qn0rg06e1gNH1fmF4FKt3BJ0Ve26ANgAEKN+B4PScUDg9sDPwAJMHFoJZPIWo7hJ4yoxZ9uQxiK9nXy2MXKVjXtc4TmkhcFs87NuIbukRj0DachAzeJBuRvZlbWpEmFdFewr9LB/sU1pn4AyygyVaqhs7bcIcl0TshPm54Jmga+1gy5NawGChFt8vOjnf0imBODmA1RVQ2BlI58rJQtVYTh30t04+6nPjVA6aNNHK0yC++eC87eUi8CW65Hh5W/ilgNAIzqMyD9W1nSAnZduDdBOPsWxqZXB10Z5CP8sHO9UCxiA7WKKlurfTpsxxScQqTLKzSd9RGQ4JNVx3EGgFjKC8Ri3yfgEzji44di3hOCEolHAIVIwn54GBiW7UX3I+ghzXGQxAIlomX66pDxzuavG7E8HYbRqV4A7m68e8EAnueIyfKaNDkNHJJVgjGHqzkP9QvXZXBHX0JH6DdZMQS9t0dEV6EPS6YuvW5rGIHfyYjZ/jHqZJUKQXa/GuyniyUD1sEnmwZf1cHSUU5g0WCSl31jn09r8wckwrqBxFS/18FcoJJDgaw3OhiYJuEaBsUA5EJfrcT8SCc41BfibZJcFQmLcTdmbG0ibx230uTy++ngZXKd5N4Ins6GfHI9dn9cODYAXeU99WdeXJygbzVdl0lYo+8MzYvGqplx22dI5rOke49AobZ75xEURKduOE8fMoUriphKOiddyb3ttrOPTDGpoE5f2Bk4Db2cFTHefl9PDEt2cq4R8dWTgogpJflUl86GUnnUDnxrve+U+1th+FeeeATrxuqY08Dk/1oXzRAV0sH4KebYcATLDiUQkef2Y4Ak2bPN+V23RararUWU8kbJ2kBeywNXOcKKpTrG+z7pMkG+BXPHJyjWKzi1mwZ95GyRg12NC/HwMVAkaBCIbGKUl8F4HBv6gccl++YCwEakn0cHa+vmM3JqEUTuRODw4yv1Lwq8lztVEeuuyGjAMWxjZqu8Ci0o7HUWP0VF8ICo8Fj4+mgqOvPU1xPOvFV3gEuXicUx2eMdB6ubAp35lw9CNQ8TBp5VTXylJv3bzsTSbrojZdmYKeEfZ1a7fCuLcdNH6r5ljzFXyPuSLhx6x9TrnhBwTWOz4Tru+qxlRbm9B7dgyaCEXHisMWrIgWDgFNdtQac/o7eaqfCbfOGCQqwVAmnDygjTG4nrCj53KAa2mcCScGRNV78RUegYBsTxMENBt84MUJhKhNnckkcCCbHSfw9Ek8e+nmJRnNptNrlnLwts3/PURE6msH4W3jHNu1HXW2FenV+Q88LS514YcN+fIo7xypzYklXG1GItlJpuSo4RTBicKmKzXIwRDVoGYH5XUZEecju6Q2JxUXIDyIwsrlePq+ZWyT8DW8xq5a2aGNbpPa1CuwKv08u3qxB3NcVz7tYXPHp5vjFD5OS4bmrcA99KlcxU56IsnDYkYJrgXu2qPyNQCTcNbHkss9jCGr6RtaJZrz6woPn9zxGtVtAIpyAfeZYyDXq4WSaMQrz0IE+g+KsvshK7HpCvXra4ldnuNbbaD5CKd1t8m5/0Dn1lELIIgRC477EzvVzifpSSDg6uECx84rvIcK7uMcS2eu2Kxrt/FPdSVpxGDmGfFAuQ+JQLGq3X8f7LmJOu7VHMuH8d0YLJiQyU4YmzjbU8kkw3K/44TBw2ti4Kl4Huiu1gKHOZ7b+38UaL1aScO52wAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle T \\left(6 d_{hv} d_{qk} + d_{hv} + 7 d_{qk} + 12\\right)$"
      ],
      "text/plain": [
       "T⋅(6⋅dₕᵥ⋅d_qk + dₕᵥ + 7⋅d_qk + 12)"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpl_comp_flop_rec_exp_total = collect(comp_flop_rec_exp_total.subs(subs_dict), T)\n",
    "simpl_comp_flop_rec_exp_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'T \\\\left(6 d_{hv} d_{qk} + d_{hv} + 7 d_{qk} + 12\\\\right)'"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sp.latex(simpl_comp_flop_rec_exp_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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KR1hAiZgAiZgAiZgAiZgAiZgAiZgAiZgAiZgAiZgAiawOwJ7+wbz7gBZIBMwARMwARMwARMwARMwARMwARMwARMwARMwARMwgTyBB9999919PsmxJmACJmACJmACJmACJmACJmACJmACJmACJmACJmACJtBMwJ/IaGbjFBMwARMwARMwARMwARMwARMwARMwARMwARMwARMwgRYC/kRGCxwnmYAJmIAJmIAJmIAJmIAJmIAJmIAJmIAJmIAJmIAJNBOwg7mZjVNMwARMwARMwARMwARMwARMwARMwARMwARMwARMwARaCNjB3ALHSSZgAiZgAiZgAiZgAiZgAiZgAiZgAiZgAiZgAiZgAs0E7GBuZuMUEzABEzABEzABEzABEzABEzABEzABEzABEzABEzCBFgKPWtKcZAImYAImYAImYAImYAI3SeDVq1cv1fBn2r4IAN5q/07bL0r7d4jzzgRMwARMwARMwARMwARunsCD+/v7m4dgACZgAiZgAiZgAiZgAiaQIyBnMsbyO+0/yaU7zgRMwARMwARMwARMwARunYA/kXHrGuD2m4AJmIAJmIAJmIAJZAnIqfxpSPg5m8GRJmACJmACJmACJmACJmACJzuYrQQmYAImYAImYAImYAImkCfwPET/kk92rAmYgAmYgAmYgAmYgAmYgB3M1gETMAETMAETMAETMAETyBN4QbTeZP41n+xYEzABEzABEzABEzABEzABO5itAyZgAiZgAiZgAiZgAiaQJ8AnMvjnfg4mYAImYAImYAImYAImYAINBOxgbgDjaBMwARMwARMwARMwgdsloLeW4+cx/Pby7aqBW24CJmACJmACJmACJtCDgB3MPSA5iwmYgAmYgAmYgAmYwM0R+Dy02N9fvrmud4NNwARMwARMwARMwASGELCDeQgt5zUBEzABEzABEzABE7gVAsUbzG3fX1ba41uB4XaagAmYgAmYgAmYgAmYQBMBO5ibyDjeBEzABEzABEzABEzglgm0fn9ZzuWvBefJLQNy203ABEzABEzABEzABEwAAnYwWw9MwARMwARMwARMwARMICGQfH/5TRJdP/xc+d7VI31uAiZgAiZgAiZgAiZgArdGwA7mW+txt9cETMAETMAETMAETKCLQPz+cvYf/Mmx/FIF+NvMXRSdbgImYAImYAImYAImcBMEHt1EK91IEzABEzABEzABEzABE+hP4AuyypH8tn6J4n5QHA7mj+ppPjcBEzABEzABEzABEzCBWyTw4P7+/hbb7TabgAmYgAmYgAmYgAmYQElAjmP+Yd9rbR9r4/vLhJ/Pu+JvJV75v0zSfGgCJmACJmACJmACJmACN0vg/wHOvUcZRkRjPgAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle \\frac{1.0 \\left(L^{2} \\left(2.0 F_{causal} T d_{hv} + 2.0 F_{causal} T d_{qk} + 8.0 F_{causal} T + 1.0 T\\right) + L \\left(2.0 F_{causal} T + 4.0 T d_{hv} d_{qk} + 2.0 T d_{hv} + 6.0 T d_{qk} + 13.0 T\\right) + 2.0 T d_{hv} d_{qk} + 2.0 T d_{qk} + 5.0 T\\right)}{L}$"
      ],
      "text/plain": [
       "    ⎛ 2                                                                        ↪\n",
       "1.0⋅⎝L ⋅(2.0⋅F_causal⋅T⋅dₕᵥ + 2.0⋅F_causal⋅T⋅d_qk + 8.0⋅F_causal⋅T + 1.0⋅T) +  ↪\n",
       "────────────────────────────────────────────────────────────────────────────── ↪\n",
       "                                                                               ↪\n",
       "\n",
       "↪                                                                              ↪\n",
       "↪ L⋅(2.0⋅F_causal⋅T + 4.0⋅T⋅dₕᵥ⋅d_qk + 2.0⋅T⋅dₕᵥ + 6.0⋅T⋅d_qk + 13.0⋅T) + 2.0⋅ ↪\n",
       "↪ ──────────────────────────────────────────────────────────────────────────── ↪\n",
       "↪               L                                                              ↪\n",
       "\n",
       "↪                                ⎞\n",
       "↪ T⋅dₕᵥ⋅d_qk + 2.0⋅T⋅d_qk + 5.0⋅T⎠\n",
       "↪ ────────────────────────────────\n",
       "↪                                 "
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpl_comp_flop_cwp_exp_total = collect(\n",
    "    sp.cancel(collect(comp_flop_cwp_exp_total.subs(subs_dict), L)), L\n",
    ")\n",
    "simpl_comp_flop_cwp_exp_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAskAAAAaCAYAAABFAMFFAAAACXBIWXMAAA7EAAAOxAGVKw4bAAATBklEQVR4Ae2d7bHktBKGZ7dOAAtEcCGDZYkAyICPCFgyuNT+4x8FGXCJYIEMgAh22QwgAw4ng73vo1GrZFm25Y+xx2OpykffUverVqsly3MevX379lTd9SHw7bffPhFVLzxl73v/K6U/XB+1lSJDoI6bIVH9ikBFoCJQEagI7BuBu32Tvw71Mnyeq6e/5f++To+ul+/V39fWn8I/Kvynng8s7ZZ8+Iv53TFvhxq3HY9TJb0iUBGoCFQEKgK9CDzuza2ZJxlunwmGD+WvaSCD/HP1+Uk0BN8r/L7SnkZptxTEuPztBhg62rjdwJBVFioCFYGKQEWgItBGoBrJbUxCiow2d+VBfjjRDZmXD9Dn68t3cx09COO/Rckv8v97HRRNpmKRcRMOdsVmMiG1YkXgCAjUuTJtlPeG297onTIqR+BxCi5r1cnhX43kfvR/UTbXHFZ3Gqz/6YnvH2N8ceXjzerErNQhPKurr+WzOdmlgwc9s8ZN9dko3Oobg12OayX6OhGoc2XWuPBmck+HEnujd9TgXEKW1WZrHVHaEz2HO4QpxKIlY4/SD/fUEJPmUz3P/Ahzmhkv+hgwlveNymPY3JzzQvSn/HdKmFM5hBEDL5w6KwxW3CPGcVJqOJrgxmkILeW5m/uD/OB82xjsXPuwNkL+GgH1C33f+L4Y/3viSg9Gu8Kz+VUbyN9H8j/3fa3uLcEHRKsdxnnUuKkO13vg37CmKdoaxN8V9H9Uvs7jM26MwU96wO9n4RLmp+K7dHVsz8MmHBaZK7EQqM2bkBfxUaQvvCw9yL+KdVx0cK0wdi+VFq8x6LVN6RU9s9e5mEHCajMryz7PMPlHcb5J4moitsOgU7l/VQh6DUPCuGBLqMzi/Jy7WPav6CyS6a5eS7Cgrso1ZKz14Z4KYKD9IJ+fvXgjH4O55ZRuxl8r70YSMFLGKA6MIRNEg4AP/khr/CqFsENw71NsFaeNBz3BKQ3BYJIEoQ6ZKwU8DRjvQRYUhiY2EZ/qsfvas/lVm2COEmC328BiJXbpZjYfon30uMGz+n4h/8OYV99WCf6hmurUeSw0hAPzj7mDPruFO+/wdPixFQaLzZUwaW5EXoQNuqdIXyBLetDjbCC30rcn9Q3NrH8cvLj1RD5xnvCxutKugd7Z64N4Ck48ZWWZAsrDzvpO/q8+Tllbd0sM5XvqybH5ozzt0F481ovyo/YXd6K3WKZ7Oi/B4qS+GjLWMpLpQIUAFGfGzznW/Ms1hJJBatbaTwzBCUZhH9nCi51HzrVORFWWwUbQf85UeKm0ILy+LErD0eHjJ/mjcVcdPgLkVcIYw99IxCBunMCpHegCI5SYnbbP4pfO1CanBBg2X+iZQivN0M4cfmfxob4Z4ynjBs656z2l+MN6cKKjzmOh4WUBXPr0WcDtUgFPx9Q52CCrjq07OFhsrsTgXoO8zJSVsfoCHFt1YkyGwjPppXnWEU6N4znKOplb67amd9b6ALOJy+p9YcH6ymGRM5CpozDrI3EwKLFPOOgceiu7ND+Q2nKiY86a3JJPtZezQVr9RgklWFjxIGOPLSXxYQbXd/KCVZ4TYFdxz38EvhkXr4f48GUxbINxSx2lYyjl8OvDljquT1+fgeJE4CmPwpxu225IwVEOhcMzxUHzX6IhrY9CYxKz8M/iNyEKDIYmdlKlFZ3E71w+fP2p4/aF6uc2BoP4t7g/J/TJmlW52XlsDMpnMeE+/0OUtkVwkkx2EHr0sV16rsQwX4O8zJGVUfrC6xzwpM+pbjK96perBqxvDd2ndN5StgxBpVFuE3rV95LrnGHdJcusgRwYpe6VEj4RLXPGy7V5IX5Sei0+WUbgV0+vDWKdLOHHMva4o0EnmCoY7+pOipvx6KopfpNGsphjQEoX1S+FQ2Nye0y7Toxs0jew9XXY6Tz4MK9ZoAPfnudRvi+2igetfXgg/HP5jRn5S5FnccKK4bl8TBo3jSsLRdd8KsE/B9HR57FhwjzKzTfL36N/2LG90FyJZWDv8jJFX6B7eHu3heMtJSektvaV0LAVvXPXhwZvA7KMHOYOxWydIH+uW5SfucT01J8i0z3NFWU5GbvrKAr4jR2MBhMDGcPFpSvOkf+tuo/E2OCEFQZcs+DUsOWU17Uog23W4IzrKGxXGFptr50gWrpOdd2mSfkNWUnoK+I3qUN7nFDzDI5DUndWVP1tNW4YPdm+RdNU/A83j4UVJz28mkPB/eMxRU6/03NL7nBjGw3eYnPlFuVlor5A94Br7sAngv4iQewK1kTm6Zd6mLfcQ+YnQbM6UXmb0NtDz5R1Tmw4zFs8qh8Onobcu0MFyFdb7tqGgu/pQT9yJ9nsuFbfysdN5edce+G/onfqGtigpA+LRsFzxMnYXZqhRpzho/QAntIAli/EuwhNm9l7HAG972PCY8Lu13Z1fcVdnq9D27n7yIP1r6mAeEFOkIvGrzDENM7g17CnfTeZ43bXDs/gYwypLBTZDVeukSH8fT5VDzOPxTOKnbuNfKjn5qV8u/IUcACUPbsjjm0yXovMlaPIC9h5menT17y9Y/5s4cwgfCY6w3qi8L96+Og9dyC3Jb0NjEQfuE5d17tk2Qzgh0ZnzYjh1kxtxhxdotG142nl2kL8wX2jxkx+Gm1dMiI6B22QpP+xWDgZaxnJapSdHI57sCw4OIh5V/Fig9DVupI/ohtwMPI/U/hRAVkI6BCv/NxbmNAFbVLElJAt3IXVrrIYsvGrMOBL+y43lV83odWoKYqu9tdKn8rHGPqQUdsclNQbwv9Q89jPcTDhY4547hKOrzE5bFWG0xXmL3f++2TYlb+yP4ca2wz2s+fKWHnJ0NBI2oE8DekLdA/G3qrOjwN9Ym+kp9gcJv2k9N/12Jpg9G1Cr3We+HPWh7GyHHfNyXCvE27uWpYVUpwTew4MOJAJvxpi+d6fw0/S1EWjQzLd6HwCFk7G7hqtnCMG0OdqNAimwsWnXJk2N02CDz0vRUSpEugVXLXFAjsFDxPYi51q+XGyMYxxdwan8hu/UuELjPnq8+T7YLINvVmYym+xsehpuSi/wmgqHzH+Q2HGJ8y3vsKF+BsmR5nHXLHgek660IJD6ySKcnqos/hc9ONj+MdDudQctLaPMrYxhoSXmCuj5CUlII1H8vQmzeuLryArJ9/HkL5mM8m61+suSG+8sTUa+L6DtZbT1nSebk2v0Yg/Z33okuW+NdDpEfXLtZQpDuz48I/7yDnc5/BzuqCMBF59H0MyHcr3BPqwcDJ2l6n8VGmNkxcRxOTZ++knA59OtAz7LgljxQSxUUZYuFcr8nPC1SibibC4MbBFxlCm/mCS2s4ZwSelf6bKTIpZp2aqj9LirYJNpD6apvJr2PcpCtev6Lgov565qXz0YTMpbwT+R5vHfHTUmN/CCr3FfG3pLuW5DbP8UUZNyaCpzUvL5NHGtgT2VhmNQ5+uGiUvrcaTBC9PbNIaMpgUa0UvLSsDGMT0oHMH16Wl6VV7HGBBR1/fbq5SKHKb0Bv1HwcXXx8iXNBhqbO0XhtEbaD3WKsbv7sfNWbtREkuOIsf9XdR/af2++Z1youLT8TCydhd3KIaAhxcY6IrHQFuncZQUHnsyNnRUAYl4Yww+QzACz3c6yDMqwFebbqBlU9fKPvGb/Qpncv6rRNKpdEPbeHuFQ/0KNzb17mKu+qQHTyfX+oxYaGZo/7YwQtGKOkYwo2rGIpTDzp5hbRLJx4wtD+QH8bH83WS35iwPn0qv9TDPZy97f7O5GMM4WwIjO9sPdFShL/KHWoei19w40mNYfe1vvIb+syDC0a8xkXh4pBprmoEo1nhlo5SGnroJL8xv0lbw3ma6KrBk9KZK0EnxrQo79Z09Ky5ImysfrG8CEPkK17PwBs9b+Pg5AnclYauZ66+p/AmcuLpKNIXlJWDP3DZwoFhzhA2Whpri0/ckl6jy8YaWqau6yaLoc0o0IULxhvOZO8ca/99pqTcmLr6ks03aRUvu3P4SZtcNC76xsh03PdoLFTZydjjuBWF7XTwZZKejYpgjNbf5GMYv9aDEjkpTuO8KsEo5vUng8kvQTjn87mDRD3uCVP+JB9D0xZ4kpxTOlcb+KFx2qIfu5NHnd6+aMCXwYAdEiqK45iUjiYXi/7Qhh5eczYeFXnQY3k5xWh8pYo5av16g+KXsWFzkPKG0OYm4hx+TQnk2l0bpDl8jKEVmetcKEbif9R5nC6m4OAWAuGHnonxJQ+dwLUL9Arz0ukv+SelMf9bOkppr/TE7Si6qjvq2MYgLzVXiuTFy0K6nrEmxfUZF9ZCZANdiUw993EF13Xqd6y+RufG/KxJMFjm5hQnoJw059btLemNsZm7PvTJMgduGHepA5fG2/60gI+j23L3jqE5hynV5vLju17emyDTMRFTsHAydhe3orADSMS0dhhJuZPKOCUh38BmsD/25Ti5wGCMJx3CbnE6h2gMrPj6Af1jBKeOCcQFfvrk32eGk0zFh/qiLdod5ImC3rEQvrBIoc+imjWsfX07xTa8CpvdvpjwBn8mLGPKGMTuE6Wx2UndHH7pD3lh47G1m8PHGNqRz49yFSbgf6h5jJzoYV6FhVZxdMtTPTbf+Jo7PmkFI9NXCrqPWEw/Ec/qKNrQkx0nKq3gDjW2HXjOnisawzHyUrrGsG6wsXJyJv9jPbFMdbCzbLL6nKKvneG1LCVlrYGXHtaW7/W4Qxj5rKW8Cfqqo5XN6E3ombs+9MkyNhJvt9jgm0wZLkF3eaz+FV0YzuBijkNKHqPxpLAdVsY2lJXHt7KmN+O8zcKiu0imVQ58lsLCydidb/QnNUzjLConpWEQ4dIvxc+p578IcABadR4UN0O0kad0FHsAXWWd4pDPiXBsdLH45E5amTh/+LJMpPATT0rr7Uv5OHb5oX+X0v8HPp6oHx746nTKh35bnDEYwe6VfP7/N8qVvICtwlwnoU1XRv4eHGMCH/ZqOqbZxvy0IL8I55jxiumZHV6QjzG0vFRhm3dpvUH8RTMyduR5jC5iI80i8J4e8GTeoy9IC3pGcTdf5QfZVT46KrwlUV6so4JxrXR0ZE5HKfkyTn0efWxTYGfNFd9YsbyofO8ao/ExHc+pHdfROPjBYInlK+XhkvFBfZHpHPk3AymTfdkkYcUmlrlq85RNKpuMLgw3oxc6RZuNubOZFJ+6rvfJMqCzFoILthHXWvEbuCiPQwL01Ws9wZGmJ8X0XgX+Qx0rSBmFl+LHml3aL5Jp+NIzGYuEaCdjGMmAhcIY61DcbiGJK6o90tM8FiuEiPST75MgRNiksDg/dM1u3E0O+Qweg/2ODwMWp0QYoaV9OWYpr+eBjvqcyrCrpRyvOnqNNZXrVCzKC4tuX3/Xnic+UP6DbkF+wT2Wi8G+lyywIB/FZKlPFtWTniD7Vllpg/irDPJ62Hncw38OE/RBWFBUFx3D1QtOtFL8KRu3wUY49+ZExS7j1N+hxzZFVXjMmiu014NpPNaUe6LiPPFax3oWb5SQEdYMfhaUMJtdjGVkKq6n5Ms79TmoL2IqoJO4/N61Lq5zibD6L1ovt6a3lM4SjNRWpyxTX/nM/U4bw/pQueyYKx35662vMkW4W19b+F385WjpKluChbWnsmFOPLbECT5GrGvI6qphdi0MKo9zirPTQnEwWOzIU+eUiMpRxpQRYXMoI4ymk8pQllMdN5kVL+3L7iPnTkJpOud+ViLK8FZcA6trZUpjigwgM+A/x+2C34RBdvS9Ci0pv0T01udxDqOckWOnxV8mFTh54UH/oO/Aa6pbWyZveWxXmSs9a0xsUMby5GTFC8icubymrGAkgeccV+mdjt4qsjydvMVqrikjc4kOc+LR27dvJzXmFwwa4oMG3BM93KHhuBsjlx05eSgNFhdegfKfXvigwTmFORFGwfABIAYwC9QrPeyuzBDGsKUNXr/g7pVnC9pJ4cG+VIZTSfoI7dJQn1MdDLU/5F/Nv4fuo/dW8oQ3482rt8aJzq3wN8SH+GZTyImU2zwOlZ+br36Ymzc7j3P4pBh7DFiowJw3WShz5xRGv5iOOike9JcvcrWeaL3psRV/q8wV9ROvMbz+fq608E+pUjoU5yQZ2l4rzEblap3oQ0a4t4qMX73bG72lgIqvVWS5lJ4jl0tlbLKRfAQQBRbK7qX8YJQfge8teRTWbGYwklcxErfkNde3+GazydWkXSxaOR5qWkVgDQS2mCvqk008m1iM5d078bEr42xv9JYKiPiqer8UrAuXS2Xs8YX723vzX4mBF3tnYi/0SzhZgDjVOKSBzDiJd04xWYT52Ky6ikBFoAOBjeYKxnF81aKDuutP9jpmtbdWcxHZG71j+N1IlseQeIiyORmrJ8kDQy/QuBKS+33ggZo1ewwCwnlXr/3G8FbLVgQqAvtHQDqKKzls5F/r2Y1xuX/kKwcVge0QqEZyAfZSjihGfmHjJk4QClhevYiw5d44PzkY7oOuTkTtsCJQEagIVAQqAhWBioBH4P8MNCQ8+kug/wAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle F_{causal} \\left(4 T^{2} + 2 T\\right) + T^{2} \\left(2 F_{causal} d_{hv} + F_{causal} \\left(2 d_{qk} + 2\\right) + 6\\right) + T \\left(0.5 T + 2.5\\right)$"
      ],
      "text/plain": [
       "         ⎛   2      ⎞    2                                                     ↪\n",
       "F_causal⋅⎝4⋅T  + 2⋅T⎠ + T ⋅(2⋅F_causal⋅dₕᵥ + F_causal⋅(2⋅d_qk + 2) + 6) + T⋅(0 ↪\n",
       "\n",
       "↪            \n",
       "↪ .5⋅T + 2.5)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpl_comp_flop_par_exp_total = collect(comp_flop_par_exp_total.subs(subs_dict), T)\n",
    "simpl_comp_flop_par_exp_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "# define functions for plotting\n",
    "\n",
    "fn_flop_rec_exp = sp.lambdify(\n",
    "    (T, d_qk, d_hv), simpl_comp_flop_rec_exp_total, modules=[\"numpy\"]\n",
    ")\n",
    "fn_flop_cwp_exp = sp.lambdify(\n",
    "    (T, d_qk, d_hv, F_causal, L), simpl_comp_flop_cwp_exp_total, modules=[\"numpy\"]\n",
    ")\n",
    "fn_flop_par_exp = sp.lambdify(\n",
    "    (T, d_qk, d_hv, F_causal), simpl_comp_flop_par_exp_total, modules=[\"numpy\"]\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "dqk = 64\n",
    "dhv = 64\n",
    "seq_len = 1024\n",
    "chunk_size = 128\n",
    "fcausal = 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAFEAAAAPCAYAAACcCyOxAAAACXBIWXMAAA7EAAAOxAGVKw4bAAADrElEQVRYCd2X31UVMRCHrxwKQKxA6ACkAqUD/1SgdCCvvHGgAy1B6QCtgAMdSAciHeD35Wb2ZHezd7M+OudkJ/nNTGYymWR3nz09Pa1a6ezs7IB2V+oz3mG8C78Xh+/B3tC+0X8U+99p2wXmhZ/mxb6CP9BOwXsJA/sJZtICty8drll6HvD8YkM3AYPHI/jzwOhf5P5v+D7tAixtSOjIwdyclhhLM+2M5wR+0hMwAGvyrd0m3S2EBueCkyO4CTFJt/StqJJMrtVlYCbwinaInljQEZ0ftK+VZnI+0hJhd0vnBu6GXdI3Sdf0jamjPG6NsbPLne/w3SHInE2+tZvTtRLdjd4uYeSiPoEbQFc19O/A38E3EjrHQwWwlBi4iV/BnX8nxhmzSpVbyeUcS2J0qkTM9Tn6JV/iu0V3i8mttl8ox9EMf1aTi+xVRQg38JsJmce03Cw3I66F0kT7N4N4FseIvafFE1KekvCzxPesrkk0Wfc4rTnT6TC5YpPEPKnSSgUwK+m8xOibGK+HIcV9qDzoX2L8gF+vlBot8T2ru42jqePpTq6Q96qFcTqGiF7QrNLzoQ5YR8jU8a0eL4UV/ZaN6e4x9JfG6DH2ShjREt+tulbiiDA2gS6+W3hWcvF+ulzSlNlqL6CsnphVaCspEjRV/epuTPRUjODG7d0aFV36tb/Ed5NuNYk48oVyRSC+MTtifEzrFp4D9ahN7boL8n5TZylZ6ZuoGiMGfmVMHeNN85WyOd893VESCcCEeEdOHaFyAvvu+B76JmxIvkhqFVG7C8M2dt/vxipNxQjuVVPd0GKiJb6bdHtJzEH491F+XiT/YH6/+W01RbXj9xblUSDME9VcswmslvwVtiZqFCO4m+jXRNUugkbe7LtVd7uY3AXvY9hVIP1UXXADiz+ZMAmeKgeduwDkjE2G9j1cWSaPeJo/gMyjEkdXAHNOxpjnOkLHY17SAQNPirgnzHt8ie9Z3ZREJtaRAQxfJAYd98vXihxx+lQZLRjcpEujSlzD6d4dvnAUpT8mfEXFJPW5GJG70aM4wP+Iw7viYGxCW33P6sZvn4oeBX+tugbmJR2LSThYR8jij6AMMORWohT261F+YuvmPMDdqET0tXlP634NFYBbsS0xqj4k54xYkoz5lvie1bUSr2kG6V0zpO4o4tij4F9HXNweO6vsJVgtUdqK39CmyKpzziO4LxL5a8adX8ZSU4xr1fUzxxnXhV8IboL/6fHF0erbCTfq/gXL6/pfVAZWQQAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle 25702400$"
      ],
      "text/plain": [
       "25702400"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fn_flop_rec_exp(seq_len, dqk, dhv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAGIAAAAPCAYAAAAfzxqKAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAEoUlEQVRYCdWY63EUMQyAA0MBB+kgdHBJOoAOAlQQ6IBMfiX/MkkHgQog6SBQAY8OSAd5dHB8n8/a8+559/aAYSaaUWTLkixLsry5jdlstvFQ8OjoaNr1Fd4E3OryH9r8yUaG4+PjLYbv8nQCdX4K/0vmVQnrUxbeQUM3yTHXxmGh5Pyiz162c4HMNuP7Qq8cfs12f2amNoXtOVn8Re40z26gz0HPcr2QWIzge4ZVeyeFwm4Y+AQv/AlelRa6Sz6lRCDggQ6gTTAZ78G7gr4CL6uW50wPUHPEgzf2FGVuIiZgsucY9kfwFtwBTf4QKCcYOIOqnRPstBLH/Efml/v8gP8STMmArrU38vrmWY1TKk6oc9FEDwKygz7FjXiLlbcIG/gIetwEqzp4rc2Qfd9i5Al87blxF/ZhfAUjQAbwlULZlgEegp/IJfk+obx3k2zl4N2D7nkOvgwedJ29DbjVH3HRjMms3jIXA9AxHoM+Pc7CVrRBERPofIxrlHWD1tIp5KyQdOCC97+GBrd2Q7/Bf4Hfk3UdQcfu4Hk/lLrwvWFjzrnSp5QIjH0Bn0pjI8ZuLlhFNXiDTMuxQshD77HuDSsPbt/us1eo/9XwBdrRwkpDUbmurwu2WG/VYHEOGF3pU7Smlg02VNGg+QgvBRueLak3oKxfisiYzDvGB1BvSdn6mK4P2ErXHM1N0L7tG5FuALRMep/xZ30LA3zfr2vseyvegPHY9n58hK2xPrUSkTcyCbugh/seBoMi4+GtjqiwWGpR1n3kTZaBM6nKx5cMwz8CA/0Zu6kyofryC2qL8DZHkIcqd0yyus6Fzg77WFQJGFtk+2B684LfoaN8Sq0pFDHoY3gG2tM+gX5pRIsKseoticWgWc+AeBMMUgStay9UVlJsGvAmyIxNrrZ7b2fFqDdpNLBHJGHKuNsdPmPoYyEz2m5HcLOViHIR42bZQ6dPTtfgWd0rD53lDJqfel5pHzSTK/wLx+eW5n9NxhZ7mOja2xCyUZm2lT+BWgfwy9BE2br6YJRPKREcwmzb/7oQrcmvDQ/qJ1jNoa6eLai5wi6iZ2K9HTpu+1sL0Pd9qX0Shx19s3AE9+hC8Mb43+gWNsN2s1YMjE0VCv3Yv5QL3nW8EemAKPnl1Lehm+2y7vd0CSbQipTvIU/AMihM54CMt8OERHXG0hhq1dWqK9nCrm+aEG1wPlv8jT1dXxf6bIadVcnt0298ikQYfD9hu0mIKxdrS4dA5y7rRuvZ0A5ocmoOWgVLduJEA/QD9lq3LMt6u0p7FkTto8CfQXwDu2fMZgaJ7bhbgCpo07OW+8vvwkqfUmtCywNeldoY91E1aD7OQ84rI5ZgUpq3JRaw4xtji6klKB7RqJJQC3qOXut9Yh7/2ZdF4IN6y5r+J2Csf6/B/Tln6e/g3uh7iy3GJsE1m/LAGdhqocxX+vTIXykFhK2s5kCMbUX+XlTNNnyDoox6gs5+g3/mBDqFHIJlO1n67kYuKk07BswWY6JMWOsrhbn7xa0wYdr2g+Ae2gBz7Rg0+TfgLtj8v8E4AXKj91YBeW1qW3D/ms1f8E1a93e2QZ9+Aw4KOt6jEz8CAAAAAElFTkSuQmCC",
      "text/latex": [
       "$\\displaystyle 34815016.0$"
      ],
      "text/plain": [
       "34815016.0"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fn_flop_cwp_exp(seq_len, dqk, dhv, fcausal, chunk_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAGsAAAAPCAYAAADj2jFAAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAEaElEQVRYCeWY3XEUORCAFxcBgMkAMgCcgcmAu4vARwZc8eY3F2QAZHAmA7gIKMgAZ2DYDMz3yWpZq9HMaM29XJ2qZEndrf7vHnnvXF1dbf5v4/T09CE2HzP/Zr/9r9h/pw4Wij9G8XPmkxEjMv0L1hdLBq/RZfyiXGjuIeNVJcfzOfBPFWzD2UD8lWFPWb97Bv41w6R5zl55c2MLzf1Ash+SHfSxck9/rvon6F258zqfL1kfMV8DuxB2l42KvGdqlMZp7OjQ4OKEhUsTulvIVemdpOBssO4xPyibVd3fsj4LXdhr/BdhzAjsETD3yQlBm1crLoIdqFXZQdisE7sb/M4R/b4AOGMNe4xN6H5hsLYAfvMW+5csZsPqyLS3pttHLrR/IkhD2nEC4B9mMo7VwLQBtaq8r+PqaikBBZ4GdClRWYPfJt8dkR1sgpe+HB5ZTkk8LwKzwtXlLfPZgcB9BwwMqEF2zo5RulkGNwjbwcS5N+iysyq+IdeMrIdVpCOia3yukdV+UkHgRmUXNre024LpdSl1PdamWwWLy39w+V3Rbn4zSjfP4Rqjws+R+VGlK2IryayLkVobNHNJlO6CL5UTF4HJ6yzO1Toqu7oy7J/6jonmp6gd0aqP77aYtTNGWd61g7pXRum6lxsgvD44Afsw+MHeb4oZb/CK49mndg68Ham1g+9l7ga4FfeYtf1WiRuSHQKhH/JP0Ltyp07AGlXvD/eqLJhqlH00ol0zK/tRunJhYANPAxHVbBWYiV3n1+y4Z6DUexKIik5+zu4Ylf0Ldh9mwXMdQfTebdBnaDisa1gGjtIt8djBIdeq0hgrynZnAPw+CV8a5yCtjjc9IuDy8Zsgz+7IMkZk/+t2Vwo9OKgOi1sU9kU10v6G6BaFNcgs26e3L7sLpo+NaHnvOXfbCHD1lT5oG87p6OtxtlNwV3tWZWe6Vf/0FADW+1YFaVTd5VCwUMTs8zU1a5ScR+lCiz1WW9ROG0OW3yqrzEDZEncGeJ18yLr2irQyl5y1KvtX7ea+VevoJV3ALkYfGAbrCKa2lHqk70GGG8iPzFU66HccXzNs99CqrIkSBhUSYFaNQYvsSzhgBuARa6ko9tqwYS0Jx17ewrvfvowfkT3kH/gt2R2tXTXrEbZ9GgoWQmQ06enAfwhnLU7Zg65WaHYPbx80zofM4ujqgg4vukFjApkwrWMMYPu9fZr5dCsLHkOys15Fh8xzA7znn0C3q4XQe+Q8Af5VXQ6aGw/yOaLZoCfHlPUT6BSwRrcm12RIPy3VrDHAVufzPQWR1QzXaKvBn53KBObHf8taD/VytPBr6PXfIdn1hWo/sRsd1O2KufOrCGcT6TurSZUGe+//zjwRkH7IBRjtzd4vgW0htbXMhOPNAOaHVMfEt8JW9Bn4zotrjQ78sFxorZhXzLoKdn7IheYbePXqDbPTLC2Ds7Q67YR9+X+tEOQNuFXZ9R3oF/0DXj3tSO1PY/re6toyL5lHzDPoUpv+CStNS7c0fD9BAAAAAElFTkSuQmCC",
      "text/latex": [
       "$\\displaystyle 144182784.0$"
      ],
      "text/plain": [
       "144182784.0"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fn_flop_par_exp(seq_len, dqk, dhv, fcausal)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### mLSTMsig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "comp_flop_rec_sig_total = T * flop_rec_sig_total\n",
    "comp_flop_cwp_sig_total = N_chunk * flop_cwp_sig_total\n",
    "comp_flop_par_sig_total = flop_par_sig_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle T \\left(6 d_{hv} d_{qk} + d_{qk} + 2\\right)$"
      ],
      "text/plain": [
       "T⋅(6⋅dₕᵥ⋅d_qk + d_qk + 2)"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpl_comp_flop_rec_sig_total = collect(comp_flop_rec_sig_total.subs(subs_dict), T)\n",
    "simpl_comp_flop_rec_sig_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'T \\\\left(6 d_{hv} d_{qk} + d_{qk} + 2\\\\right)'"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sp.latex(simpl_comp_flop_rec_sig_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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00Ito37Cj0/8Z8fij5eH2rlFnSUoHyZ/rvMhXk9EJjsTMAETWIuAxjpe82Wg/l3HzT2Qr8XN+ZqACZjAGgQ8Jq9B1XleEwH3gWtqLct6dALuT8u1kFjy2i6Grc636g5n3KL6EpgHPf4bn9+DB4idCZiACZiACZiACZiACZiACZiACZiACTxCArIN8Y12vg3O23VFd0jjVlFSe5qACZiACZiACZiACZiACZiACZiACZiACZhAi8DRvrnVEs+3JmACJmACJmACJmACJmACJmACJmACJmACJtBN4Mk//vGP4/y7xG45HWICJmACJmACJmACJmACJmACJmACJmACJmACFwT8WuIFEnuYgAmYgAmYgAmYgAmYgAmYgAmYgAmYgAlcCwG/lngtLWU5TcAETMAETMAETMAETMAETMAETMAETMAELgjYuHWBxB4mYAImYAImYAImYAImYAImYAImYAImYALXQsDGrWtpKctpAiZgAiZgAiZgAiZgAiZgAiZgAiZgAiZwQcDGrQsk9jABEzABEzABEzABEzABEzABEzABEzABE7gWAvfXIqjlNAETMAETMAETMIFrIvDtt99+LXmf63gR5X6t8586flHYP6OfTyZgAiZgAiZgAiZgAjMJ+L8lzgTo5CZgAiZgAiZgAibQR0CGrLcK/1PnD/viOcwETMAETMAETMAETGAaAb+WOI2bU5mACZiACZiACZjAIAEZtD6KkX4ejOwIJmACJmACJmACJmACkwjYuDUJmxOZgAmYgAmYgAmYQBWBT2OsX6piO5IJmIAJmIAJmIAJmMBoAjZujUbmBCZgAiZgAiZgAiZQTeAlMbWD69fqFI5oAiZgAiZgAiZgAiYwioCNW6NwObIJmIAJmIAJmIAJjCLAa4l8SN7OBEzABEzABEzABExgJQI2bq0E1tmagAmYgAmYgAk8bgLarZVeSfSurcetCq69CZiACZiACZjAygRs3FoZsLM3ARMwARMwARN4tAQ+izX397YerQq44iZgAiZgAiZgAlsQsHFrC8ouwwRMwARMwARM4DESCDu3+r63pbBnjxGM62wCJmACJmACJmACSxKwcWtJms7LBEzABEzABEzABN4R6P3elgxbXyrq+++i+8oETMAETMAETMAETGAKARu3plBzGhMwARMwARMwARPoIZB9b+tVT7TPFO/PnnAHmYAJmIAJmIAJmIAJVBCwcasCkqOYgAmYgAmYgAmYwEgC6XtbxY/Jy6j1tfLzt7hGQnV0EzABEzABEzABEygRuC952s8ETMAETMAETMAETGAWgReklhHrdTsX+X0vP4xb77XDfG8CJmACJmACJmACJjCewJO3b9+OT+UUJmACJmACJmACJmACZwRktOLj8D/p+EAH39vC/Xw6hb9n/or/eRbmSxMwARMwARMwARMwgYkE/h97Gdtg9ZoXbwAAAABJRU5ErkJggg==",
      "text/latex": [
       "$\\displaystyle \\frac{1.0 \\left(L^{2} \\left(2.0 F_{causal} T d_{hv} + 2.0 F_{causal} T d_{qk} + 6.0 F_{causal} T + 1.0 T\\right) + L \\left(4.0 T d_{hv} d_{qk} + 1.0 T d_{hv} + 2.0 T d_{qk} + 11.0 T\\right) + 2.0 T d_{hv} d_{qk} + 5.0 T\\right)}{L}$"
      ],
      "text/plain": [
       "    ⎛ 2                                                                        ↪\n",
       "1.0⋅⎝L ⋅(2.0⋅F_causal⋅T⋅dₕᵥ + 2.0⋅F_causal⋅T⋅d_qk + 6.0⋅F_causal⋅T + 1.0⋅T) +  ↪\n",
       "────────────────────────────────────────────────────────────────────────────── ↪\n",
       "                                                                             L ↪\n",
       "\n",
       "↪                                                                              ↪\n",
       "↪ L⋅(4.0⋅T⋅dₕᵥ⋅d_qk + 1.0⋅T⋅dₕᵥ + 2.0⋅T⋅d_qk + 11.0⋅T) + 2.0⋅T⋅dₕᵥ⋅d_qk + 5.0⋅ ↪\n",
       "↪ ──────────────────────────────────────────────────────────────────────────── ↪\n",
       "↪                                                                              ↪\n",
       "\n",
       "↪  ⎞\n",
       "↪ T⎠\n",
       "↪ ──\n",
       "↪   "
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpl_comp_flop_cwp_sig_total = collect(\n",
    "    sp.cancel(collect(comp_flop_cwp_sig_total.subs(subs_dict), L)), L\n",
    ")\n",
    "simpl_comp_flop_cwp_sig_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/latex": [
       "$\\displaystyle T^{2} \\left(2 F_{causal} d_{hv} + F_{causal} \\left(2 d_{qk} + 2\\right) + 6\\right) + T \\left(0.5 T + 4.5\\right)$"
      ],
      "text/plain": [
       " 2                                                               \n",
       "T ⋅(2⋅F_causal⋅dₕᵥ + F_causal⋅(2⋅d_qk + 2) + 6) + T⋅(0.5⋅T + 4.5)"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpl_comp_flop_par_sig_total = collect(comp_flop_par_sig_total.subs(subs_dict), T)\n",
    "simpl_comp_flop_par_sig_total"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "# define functions for plotting\n",
    "fn_flop_rec_sig = sp.lambdify(\n",
    "    (T, d_qk, d_hv), simpl_comp_flop_rec_sig_total, modules=[\"numpy\"]\n",
    ")\n",
    "fn_flop_cwp_sig = sp.lambdify(\n",
    "    (T, d_qk, d_hv, F_causal, L), simpl_comp_flop_cwp_sig_total, modules=[\"numpy\"]\n",
    ")\n",
    "fn_flop_par_sig = sp.lambdify(\n",
    "    (T, d_qk, d_hv, F_causal), simpl_comp_flop_par_sig_total, modules=[\"numpy\"]\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAFEAAAAPCAYAAACcCyOxAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAEU0lEQVRYCeWY0VEcMQyGlwwFXEgH0AEJFQAdhKSCQAcwPMFbhnQQUgGBDiAVEOgAOgjQAfk+n+V4fQe3+xzN+CTL8m9Zkr271z0/P3dD29HR0Xpri25CW231/1N/uYOOj49XYQfK0AfaA+0A/a2Kin6hm9APvbL0fsqmv0Pxst1eniuWfpygv8q6wsbYlkkIzFuH7cFjnTKM7iR3/sDXaK59XwyygE7fDiu9/XP0yc8lqwjFdxTbYYQs+D5tOwwdQ76DrdAEcbEL2lf0T/BEyIPwsBNDp8vmkD+iO6ftIIudaIxtzAnOXH2+he+ETk7/BqbvaR24/qhzz71A0jc+xU9sOvr6eQa/eINgwFoDq9LAaFiTzrylLdHWaFZrCWA2HIq3i/0u8w1cUFRgnXXHxtgGVge2hTBD6MWbwOtEuQ/73+sJ2dbgtvQFRfLTIG7R7jA2EzW5IReyssbQUDyvBB0vSWCtIjcLjrFNU8HyGPfwK0yrMq6kSt1d09lqYuExL6e0Ng7ZO9Fgrb+ygUkYD+SD8FhPu7c1JrqoyrYaBttWeJ/B86T0TlkeN9GnlW2IcYwdjyo1sPvgXMK9ZiLRnrjk5zLK3l3BQJCZ7BjvZYx+OgoMvaNZpd4rxQZ5FB7zEzFPx9NVgDxvg9ky+fSqLfM9xr1ExGTGhhSF934i7C9sdEzwI7JXndV5mfXdMp0ZYtAAGqB4YoeNDvxkPGUDro1XQe8BFMbBX8Hr8phB2aCZjN8xr+VDbLHRpyd4VFULEwGKimrH7fcCDZYVaFIsIBMttjzRmxAa7gPFDHyr9fQNVlkcWTCP2tysV3Pn4jkOhg+rbzQr+Ix2gxzHWpNCA219nXm1kgvgy4KnrFD2x31bge43iif5ORNEJhiQe/hLx5LhHhnIVewFnqExeNh6bHTWd7BeNbTA82zRWSmLEvrQYlX9qFLfGxNlTIvH+9W4+JCJ2PygP+kFEYVOrGTDKUr+RecdMO9RH3Yzm16A58PMa6OlOM4e8UTaLbJl3CT6NvHSMQ4skyTN+FvpagyPbe9aYw2TbVWKsVXuRAYsTd/9IsodcqouuKAfaPOymLKHTXm4YOfcRXgpIdj53hkbc+o8GmKrrxtgeXXUZKI8KeqtJAMSR7K2U45KdLzD1iCZmBn/0IllMFdSEOm4kA70Io7OQMT9cjpnnOH0npkWtSMNxNOxK2xbB02WVGMutM049ZwEgv5RLHgpDvoGtDwYkuH0x89X7+jkkzw3k1BXZ0yZIFwtM2gGBXWh9j7ZQhcPFz99ep8/9OOLoDiIbihem7COuSZNx3w4pI0gS2NspzP+/YpnKwR2KgjXo1lNHVybT7RN+xW5N+/oTVrxCdmrzyvu3m9nvy3Tsa0mhmhWyp8LyNrFhix9j3fv0w+bMXjeeyUByOK/9AfEYFswOvywIMRznmSwrtGnooAbNKvRwPgg2aD13nnpJ8LWk3pIq6+z8gfEX8p1M64N7ezBAAAAAElFTkSuQmCC",
      "text/latex": [
       "$\\displaystyle 25233408$"
      ],
      "text/plain": [
       "25233408"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fn_flop_rec_sig(seq_len, dqk, dhv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAGIAAAAPCAYAAAAfzxqKAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAFEElEQVRYCd2Y23FUMQxAlwwFLKGD0EFIOggd8Kgg0AEMX8kfAx0EKuDRAaECHh2QDhK2g3COYzm215e94YcZNKPYkvWwJVm+2cXl5eXiX+LR0dFu7x/eEtzp+f8zfXuR4fj4eIfps0wuGaVfwz/NvOHA+i4LzxhDN8ndwN4XZPX3IztwLty/Gq7/ZpsvMmeP8QJ8AT90r4WZwXdvH8H7zFfNYkWw9roinb6H19iEdl8vKznpj/D/GJ9KfoFs+DmHfw80vmfKpERAaNQDlWAyfwjvM+Mj8JPCE+BBR5uea89gCgbNTenrFT6bwEFbGCeMDxgTMPdg3+WBKSCMnuUdqF2Tpd4QkHXN/bvX0JcWDVQNBq3ExwVoE7EE/xSfZAOZ70w8V5JVDzr2fhY34inMpywa+DAambYKgsf0GpB9fk01s5vY+4GdR432mDDofSAMoL4M3B3VoE1gssfc/ZngKVDP6o+zKmeAUpVKCKzrw0D2cAjjCziMTwhn/SZh8Fageifgg60sbEV7ADGBgjEfjax7wEankruxvUp3anrAwk/8LjsBg+ghJyu/k08k8t54z/C2Xofv7Sq3Lq95O3perbZpbmEYkx6+wjjA3zJak4dJFRWSeaOSZmwET5Bp2k8Iwf8be6E+NWpzF9tTBdInaMpO8L1dVuWUvZBzNGDPkf3MaKsOHW/pVHxYKmARNQnPK3HzDqI1FQ0nOFIxtQLmawbgeeXnbEBzc+x59Q3kXdDKtpc2FQQ91b5S6+nlsbEJfD/O0FP/CRgP6NoDjMwnERlv0S/mfjB4S+pWDrkOyM4pkO0mESi5KZOwDxqIb2ADyBgoKymy2azXxBx7yLvRD8imKsv2bUHlAa5t1vNs3/3El1S9vGkeAdrDTtFnbqAPwabvQ3sTLD6LxiL1/I6bYDsLpPNNCC+36gUc+XC+0Sn896CvulVQg5+qa7ekFog5chvtIWPAyyaZe0Db0Jwb52Nrtb4Jn3NG5CMJtrr+LB+w8a6SSSahjYP79Ca4PwvAgunjA/vGcLdJRK2OAytCx+kTzTV4VsOcACnewMheI9ASJmMHHQ87BNbch61lqmUN9Trm6Fb7dWSi9kIWH57bgvFN1KcPd/hdS1ro5fGio2sybst5SgSGrQzbUg/RmnzZDYpfJ6PNN3pz7KmAnD129FkY9qJyg04jOgZmm/GvvmTQs8CEGK+o9m9dBLag0r4Uw4aF6u1wj7bzIVS+RmcJXvk/IgUDpTuVYm/Yje2zbjuowQRavfKtFjc8x542rLpRxaRKwVbzYKsAz1ZwjzEqUl4KGuPGItFGhmgvQfdjsoVNg2UBrnoB/YEmJCq7Fwl6ylfoncZjrZPTgbO4nrGmwQbQ+QXD9RIY6I32spG36DWVlvlW2MiXSbcYeh2T0/f6bGpysLX1RaWwP634MZL8MzoXLbZRok3U2l41VIF+Rg+7vnxHV1tZ2IP5jVyARQ+nEx9nAzsFyog1zLXnTxbNmwMd/63XiV3At+o9kNWZ9GKEN7VHP4eFqLwrir/oWskWUAkQc8/xGDwEa3Av5a2MBeRtkbbXcnuYX4JNu4W2SC4YjWkC5o2vW/6iKbBgFdaH9+D+vjLMNnwDqEz0Rw/2FX76gplrDzltRIUbMFuVj+KKsQD0TwhlR2BVWV0JmEeluzcPbIszWAatuTnQJkIZQf9r/8O4gJy38SVYt9LR/xzu0wT3P8foQ1+e6xzcB4uv3y3KjrsMuofYAAAAAElFTkSuQmCC",
      "text/latex": [
       "$\\displaystyle 34352168.0$"
      ],
      "text/plain": [
       "34352168.0"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fn_flop_cwp_sig(seq_len, dqk, dhv, fcausal, chunk_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAGsAAAAPCAYAAADj2jFAAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAE4ElEQVRYCe2Y3ZEUNxCAF+oCWCCDI4MDIjBkgE0ENhng4unuzQUZABHwk4EhAgoy4DIALoPz92nVco9uZ0dDmTd3VW9Lre6Wpv9GO5vLy8vN/3jYB6enpye9j+BtweOe/zPnR5sEZ2dnJ0zfgncYX6SlvcMq/xj6OAswP2b+Z+XdhX5zDv9z5TUC71mdfIXeBp/BO28CdQBvy/Bp4jt/C/994rVhshu81/AO7X9I7kPdP/TdW7izI9Pf0b2nWrtZ0r3ij6N6iFeI6lAdq6NHwcDGAxQd7Kn/AvogjNQDfJIHNucy/oTMX9B3ykJ1Qsj1ATOIfVIYrC1Y9KsN9/dcJkfZC+pcNBkKwBuSq+L6RjCZPZf7ee4LaIOVNpteDNA/6A+D5Ya/qsD4CcQDLUKV3SdnpfRO1XF/wNdhN1Sq897RF/B1xAswB1tdH6SH32F8AFuwGLuHVdSSgrlJ0Ad/VA7VzWfsFR85OQBrbE7MjPhj0gYn2gcmGDagBnmSWVXlPvQLMjfAvK7zHsI7BnWcDz+pSubCR/AJMgYy9K0IK+ElOAvIP2TRs/2SheC3wMsflcs2lsb/gc1Ff1xfOsTM+iMON+c4g3LOeji6N7GtDIMa7SXLRAW4HmAADfTfYOi7ZhVbhQFWtNU5t/dauZAfoaN7z9la9MfRnOYcH0fYKrODJqKsz7WL0l5Zt6Vkh0/00+RmjJF/JzK3cr4z9vJitRm83AJ955oo7vUIjJd0fxEZlcPEDrBpK/bct0Cr3HdW7gyrbWKjAHaG/LGqsjDqIc3cyP663WGCvM5TN26IEYhDFTB5AGyYBFHNVpSZmJ3FtDhTehd535PPQTPeYBnogLC9JJfl31R7PoPoRShX/1qbYVs65I9VwcKo1/RwWN5saeyL1+p4viSY1s3gBujqbINrRdlqDb7vxhIEaDjrhHF/xjfIvlJmVA75Buh4i3XvAoxNVs9QOsyP2NxZWvV7azhYHMg2MNv+5rZFTx1bU26P+95VYSKyzBZWoO6tw6wWbXlhCHslCFVUsq/qvUkaTFtVwKhcyPdUfS9LJk3Aj9oc8sdQsOqBzMp9h4mDXqHIG+Cb0P42Flka1ZB1g5f3su1FCy2y2PRdZZUpf5952Axa5LofnRvrQTuRMm0BQN734r6/DaGnX8JW0FjLtNnMTMdJf9uvMQ/e+egFw43uYdR2lqG8iyrfjG8OZWx7ug2NCtgwLgeGGohoZdme46gs19XxsNkhsgtoBzRoWWfWKchFAsztvTP8r5xzq3Ff5pc92T/em2tsxj6Zzum3ZxsKFgfSkDgB+N9hvIe2gCjA/ARicFvw5AMGMN4nBt6K6cFPON4YS5ZKK8b/s17eYMbZbLl9QimvTe2slVP3JXr9c8j3chH2nI/urew+WPTH9U4rXuoRzW75yrRkfebyYGa2G1sNfnZqCM8LSgTBoH1jbgALMNbeb6BfJjKYDOXTUmYib5u1TZWKgVplJk9LAsZXbI7K1b3K+bt9/fsitCQdtel5wEtw0lqZL/rjml+JEYxsNFt8OEtbB+iIqASmO4BnFhkU5QWd9BG+V+UvjOdakRVjlhdg7F469gL0QnEP7P+/wGrV+pRhbkn9/6eQ1aa2BRNvzuaonM8T1aU9z+Blx3NPAN6iTWT0kUnVf5Y76I9/AM4a1Kz/SiooAAAAAElFTkSuQmCC",
      "text/latex": [
       "$\\displaystyle 142086656.0$"
      ],
      "text/plain": [
       "142086656.0"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fn_flop_par_sig(seq_len, dqk, dhv, fcausal)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot the Flop counts for varying chunk size\n",
    "\n",
    "We now want to compare the FLOPs depending on the chunk size. \n",
    "We consider a single head and one batch, as we are only interested in the relative differences.\n",
    "\n",
    "We choose sequence lengh $T=8192$, and head dimesions $d_{qk}=256$ and $d_{hv}=512$, which is the configuration we used for the xLSTM 7B model."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot params\n",
    "num_points = 20\n",
    "\n",
    "seq_len = np.repeat([8192], num_points)\n",
    "dqk = 256\n",
    "dhv = 512\n",
    "fcausal = 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "flops_rec_exp = fn_flop_rec_exp(seq_len, dqk, dhv)\n",
    "flops_rec_sig = fn_flop_rec_sig(seq_len, dqk, dhv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "chunk_sizes = np.logspace(0, 12, num=num_points, base=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [],
   "source": [
    "flops_cwp_exp = fn_flop_cwp_exp(seq_len, dqk, dhv, fcausal, chunk_sizes)\n",
    "flops_cwp_sig = fn_flop_cwp_sig(seq_len, dqk, dhv, fcausal, chunk_sizes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [],
   "source": [
    "flops_cwp_exp_nocausal = fn_flop_cwp_exp(seq_len, dqk, dhv, 0.75, chunk_sizes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "flops_par_exp = fn_flop_par_exp(seq_len, dqk, dhv, fcausal)\n",
    "flops_par_sig = fn_flop_par_sig(seq_len, dqk, dhv, fcausal)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([5.21771704e+10, 5.21771704e+10, 5.21771704e+10, 5.21771704e+10,\n",
       "       5.21771704e+10, 5.21771704e+10, 5.21771704e+10, 5.21771704e+10,\n",
       "       5.21771704e+10, 5.21771704e+10, 5.21771704e+10, 5.21771704e+10,\n",
       "       5.21771704e+10, 5.21771704e+10, 5.21771704e+10, 5.21771704e+10,\n",
       "       5.21771704e+10, 5.21771704e+10, 5.21771704e+10, 5.21771704e+10])"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flops_par_exp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([8.07518181, 8.07518181, 8.07518181, 8.07518181, 8.07518181,\n",
       "       8.07518181, 8.07518181, 8.07518181, 8.07518181, 8.07518181,\n",
       "       8.07518181, 8.07518181, 8.07518181, 8.07518181, 8.07518181,\n",
       "       8.07518181, 8.07518181, 8.07518181, 8.07518181, 8.07518181])"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flops_par_exp / flops_rec_exp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "# normalize to the recurrent flops\n",
    "flops_cwp_exp_norm = flops_cwp_exp / flops_rec_exp\n",
    "flops_par_exp_norm = flops_par_exp / flops_rec_exp\n",
    "flops_cwp_exp_norm_nocausal = flops_cwp_exp_nocausal / flops_rec_exp\n",
    "flops_rec_exp_norm = flops_rec_exp / flops_rec_exp\n",
    "\n",
    "flops_cwp_sig_norm = flops_cwp_sig / flops_rec_sig\n",
    "flops_par_sig_norm = flops_par_sig / flops_rec_sig\n",
    "flops_rec_sig_norm = flops_rec_sig / flops_rec_sig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([6444564480, 6444564480, 6444564480, 6444564480, 6444564480,\n",
       "        6444564480, 6444564480, 6444564480, 6444564480, 6444564480,\n",
       "        6444564480, 6444564480, 6444564480, 6444564480, 6444564480,\n",
       "        6444564480, 6444564480, 6444564480, 6444564480, 6444564480]),\n",
       " array([6.45729485e+09, 5.69940573e+09, 5.21335078e+09, 4.90448091e+09,\n",
       "        4.71265010e+09, 4.60050328e+09, 4.54620221e+09, 4.53917287e+09,\n",
       "        4.57804643e+09, 4.67039273e+09, 4.83419428e+09, 5.10134804e+09,\n",
       "        5.52387666e+09, 6.18405880e+09, 7.21045125e+09, 8.80292262e+09,\n",
       "        1.12715737e+10, 1.50971229e+10, 2.10245167e+10, 3.02079918e+10]))"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flops_rec_sig, flops_cwp_sig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "from typing import Callable\n",
    "\n",
    "\n",
    "def plot_flop_comparison_mlstm_formulation(\n",
    "    fn_chunkwise_flops: Callable, figsize: tuple[float, float] = (7.0, 4.0)\n",
    "):\n",
    "    pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [],
   "source": [
    "from plot_config import get_plot_mpl_context"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with get_plot_mpl_context():\n",
    "    plt.figure(figsize=(7, 4))\n",
    "    plt.plot(chunk_sizes, flops_cwp_sig_norm, label=\"cwp sig\")\n",
    "    plt.plot(chunk_sizes, flops_cwp_exp_norm, label=\"cwp exp\")\n",
    "    plt.plot(chunk_sizes, flops_cwp_exp_norm_nocausal, label=\"cwp exp causal=0.75\")\n",
    "    plt.plot(chunk_sizes, flops_rec_sig_norm, label=\"rec sig\")\n",
    "    plt.plot(chunk_sizes, flops_rec_exp_norm, label=\"rec exp\")\n",
    "    plt.plot(chunk_sizes, flops_par_sig_norm, label=\"par sig\")\n",
    "    plt.plot(chunk_sizes, flops_par_exp_norm, label=\"par exp\")\n",
    "    plt.legend()\n",
    "    plt.xscale(\"log\")\n",
    "    # plt.yscale(\"log\")\n",
    "    # plt.xlim(1, 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.01814095, 1.01843862, 1.0186392 , 1.01872922, 1.01869866,\n",
       "       1.01853324, 1.01821014, 1.01769917, 1.01697134, 1.0160157 ,\n",
       "       1.01486   , 1.01358213, 1.01229735, 1.01112167, 1.01013442,\n",
       "       1.00936331, 1.00879433, 1.00839187, 1.00811563, 1.00792991])"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flops_cwp_exp / flops_cwp_sig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.01475919, 1.01475919, 1.01475919, 1.01475919, 1.01475919,\n",
       "       1.01475919, 1.01475919, 1.01475919, 1.01475919, 1.01475919,\n",
       "       1.01475919, 1.01475919, 1.01475919, 1.01475919, 1.01475919,\n",
       "       1.01475919, 1.01475919, 1.01475919, 1.01475919, 1.01475919])"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flops_par_exp / flops_par_sig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.01858615, 1.01858615, 1.01858615, 1.01858615, 1.01858615,\n",
       "       1.01858615, 1.01858615, 1.01858615, 1.01858615, 1.01858615,\n",
       "       1.01858615, 1.01858615, 1.01858615, 1.01858615, 1.01858615,\n",
       "       1.01858615, 1.01858615, 1.01858615, 1.01858615, 1.01858615])"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flops_rec_exp / flops_rec_sig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Note the mLSTMexp has only 0.2% more flops than mLSTMsig\n",
    "# normalization is only a few flops"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 1.01475919"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mlstmpt251cu124",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
