{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "plt.rcParams['font.family'] = 'P052'\n",
    "plt.rcParams['font.serif'] = ['Times New Roman']\n",
    "\n",
    "# Calculate the no. of flops used by a transformer model\n",
    "def transformer_layer_macs(d_model: int, d_ff: int, seq_len: int) -> int:\n",
    "    # Attention. Assumes d_head * n_head = d_model\n",
    "    att_macs = (\n",
    "        seq_len * d_model * d_model * 4 + # input and output projection\n",
    "        seq_len * d_model * seq_len * 2   # QK^T and (QK^T)V\n",
    "    )\n",
    "\n",
    "    ffn_macs = (\n",
    "        seq_len * d_ff * d_model * 2  # input and output projection\n",
    "    )\n",
    "\n",
    "    return att_macs + ffn_macs\n",
    "\n",
    "def macs(d_model: int, n_encoder_layers: int, n_decoder_layers: int, d_ff: int, encoder_seq_length: int, decoder_seq_length: int, keep_ratio: float, deletion_layer: int) -> int:\n",
    "    # deletion layer 0: delete after the embedding. 1: delete AFTER the first layer.\n",
    "    encoder_deleted_seq_len = int(encoder_seq_length * keep_ratio)\n",
    "    before_deletion = transformer_layer_macs(d_model, d_ff, encoder_seq_length) * deletion_layer\n",
    "    after_deletion = transformer_layer_macs(d_model, d_ff, encoder_deleted_seq_len) * (n_encoder_layers - deletion_layer)\n",
    "\n",
    "    decoder = transformer_layer_macs(d_model, d_ff, decoder_seq_length) * n_decoder_layers\n",
    "\n",
    "    cross_attention = (\n",
    "        encoder_deleted_seq_len * d_model * d_model * 2 + # K, V projections\n",
    "        decoder_seq_length * d_model * d_model * 2 + # Q, output projection\n",
    "        encoder_deleted_seq_len * decoder_seq_length * d_model * 2 # QK^T and (QK^T)V\n",
    "    )\n",
    "\n",
    "    return before_deletion + after_deletion + decoder + cross_attention * n_decoder_layers\n",
    "\n",
    "krs = [a/10 for a in range(0, 11)]\n",
    "m = []\n",
    "for kr in krs:\n",
    "    m.append(macs(d_model = 1472, d_ff = 3584, n_encoder_layers = 12, n_decoder_layers = 4, encoder_seq_length = 1024, decoder_seq_length = 189, deletion_layer = 3, keep_ratio = kr))\n",
    "\n",
    "plt.figure(figsize=[4,1.5])\n",
    "plt.plot([1-k for k in reversed(krs)], list(reversed([a/m[-1] for a in m])))\n",
    "plt.xlabel('Deletion ratio (δ)')\n",
    "plt.ylabel('Compute vs ByT5')\n",
    "plt.xlim([0, 1])\n",
    "plt.ylim([0, 1])\n",
    "plt.savefig('figures/macs_relative.pdf', bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "charlm-env",
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
