{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# GPT2 Shapley"
   ],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Imports"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "from ml2.shapley.gpt2_attn import get_gpt2_attn\n",
    "from ml2.shapley.attention_flow import calculate_shapley_sum, sum_up_heads\n",
    "import time"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Text Input"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "text = \"My name is John, my profession is\""
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Model"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "attn, input_tokens, output_tokens = get_gpt2_attn(text)\n",
    "print(input_tokens)\n",
    "print(output_tokens)\n",
    "attn = sum_up_heads(attn)\n",
    "results = []\n",
    "for x in range(0, len(output_tokens)):\n",
    "    start = time.time()\n",
    "    result_list = calculate_shapley_sum(attn, input_tokens, output_tokens, layers_dec = 12, output_token=x, decoder_only = True, plot=True)\n",
    "    results.append(result_list)\n",
    "    end = time.time()\n",
    "    print(\"The time for token \" + str(x) + \" was \" + str(end-start))\n",
    "print(results)"
   ],
   "outputs": [],
   "metadata": {}
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "aee8b7b246df8f9039afb4144a1f6fd8d2ca17a180786b69acc140d282b71a49"
  },
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3.8.5 64-bit"
  },
  "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.8.5"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}