{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "46ca5607-5b9f-44f3-b2e4-cacca1c3ac57",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f5a9a41a-7776-4636-8abe-0b4f5e670a15",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Specify filepaths.\n",
    "\n",
    "retrain_db = \"/gscratch/cse/username/diffusion-attr/seed42/artbench_post_impressionism/retrain_artist_shapley.jsonl\"\n",
    "retrain_dir = \"/gscratch/cse/username/diffusion-attr/seed42/artbench_post_impressionism/retrain/models/artist_shapley\"\n",
    "\n",
    "# GD with 200 steps.\n",
    "gd_db = \"/gscratch/scrubbed/username/diffusion-attr/seed42/artbench_post_impressionism/gd_artist_shapley.jsonl\"\n",
    "gd_dir = \"/gscratch/scrubbed/username/diffusion-attr/seed42/artbench_post_impressionism/gd/models/artist_shapley\"\n",
    "\n",
    "# Sparse GD with 200 steps.\n",
    "pruning_ratio = 0.5\n",
    "sparse_gd_db = f\"/gscratch/scrubbed/username/diffusion-attr-pruning-ratio={pruning_ratio}-rerun/seed42/artbench_post_impressionism/sparse_gd_artist_shapley.jsonl\"\n",
    "sparse_gd_dir = f\"/gscratch/scrubbed/username/diffusion-attr-pruning-ratio={pruning_ratio}-rerun/seed42/artbench_post_impressionism/sparse_gd/models/artist_shapley\"\n",
    "# sparse_gd_db = f\"/gscratch/scrubbed/username/diffusion-attr-pruning-ratio={pruning_ratio}/seed42/artbench_post_impressionism/sparse_gd_artist_shapley.jsonl\"\n",
    "# sparse_gd_dir = f\"/gscratch/scrubbed/username/diffusion-attr-pruning-ratio={pruning_ratio}/seed42/artbench_post_impressionism/sparse_gd/models/artist_shapley\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0ede08c6-6b46-4900-babb-d5944a32bdfd",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Obtain training time, inference time, and total time for retraining-based Shapley,\n",
    "# for 1000 subsets.\n",
    "\n",
    "retrain_df = pd.read_json(retrain_db, lines=True)\n",
    "retrain_df[\"shapley_seed\"] = (\n",
    "    retrain_df[\"exp_name\"]\n",
    "    .str.split(\"/\", expand=True)[4]\n",
    "    .str.split(\"shapley_seed_\", expand=True)[1]\n",
    "    .astype(int)\n",
    ")\n",
    "retrain_df = retrain_df.sort_values(by=\"shapley_seed\")\n",
    "retrain_inference_time_list = retrain_df[\"aesthetic_score_time\"].tolist()\n",
    "retrain_training_time_list = []\n",
    "for shapley_seed in retrain_df[\"shapley_seed\"].tolist():\n",
    "    training_time_df = pd.read_csv(os.path.join(retrain_dir, f\"shapley_seed={shapley_seed}\", \"time.csv\"))\n",
    "    training_time_df = training_time_df.drop_duplicates(subset=\"epoch\", keep=\"last\")\n",
    "    num_epochs = len(training_time_df)\n",
    "    training_time_df = training_time_df[training_time_df[\"epoch\"] != 0]\n",
    "    training_time = training_time_df[\"time\"].mean() * num_epochs\n",
    "    retrain_training_time_list.append(training_time)\n",
    "\n",
    "retrain_total_time_list = [\n",
    "    retrain_training_time_list[i] + retrain_inference_time_list[i]\n",
    "    for i in range(len(retrain_inference_time_list))\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5ee3fb03-6b60-456f-972c-4e1eece2ae05",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Obtain training time, inference time, and total time for GD-based Shapley,\n",
    "# for 1000 subsets.\n",
    "\n",
    "gd_df = pd.read_json(gd_db, lines=True)\n",
    "gd_df[\"shapley_seed\"] = (\n",
    "    gd_df[\"exp_name\"]\n",
    "    .str.split(\"/\", expand=True)[4]\n",
    "    .str.split(\"shapley_seed_\", expand=True)[1]\n",
    "    .astype(int)\n",
    ")\n",
    "gd_df = gd_df.sort_values(by=\"shapley_seed\")\n",
    "gd_inference_time_list = retrain_inference_time_list\n",
    "gd_training_time_list = []\n",
    "for shapley_seed in gd_df[\"shapley_seed\"].tolist():\n",
    "    training_time_df = pd.read_csv(os.path.join(gd_dir, f\"shapley_seed={shapley_seed}\", \"time.csv\"))\n",
    "    training_time_df = training_time_df.drop_duplicates(subset=\"step\", keep=\"last\")\n",
    "    num_steps = len(training_time_df)\n",
    "    training_time_df = training_time_df[training_time_df[\"step\"] != 0]\n",
    "    training_time = training_time_df[\"time\"].mean() * num_steps\n",
    "    gd_training_time_list.append(training_time)\n",
    "\n",
    "gd_total_time_list = [\n",
    "    gd_training_time_list[i] + gd_inference_time_list[i]\n",
    "    for i in range(len(gd_inference_time_list))\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c1c1998e-811d-4de9-b076-c93832b852e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Obtain training time, inference time, and total time for Sparse-GD Shapley,\n",
    "# for 500 subsets.\n",
    "\n",
    "sparse_gd_df = pd.read_json(sparse_gd_db, lines=True)\n",
    "sparse_gd_df[\"shapley_seed\"] = (\n",
    "    sparse_gd_df[\"exp_name\"]\n",
    "    .str.split(\"/\", expand=True)[4]\n",
    "    .str.split(\"shapley_seed_\", expand=True)[1]\n",
    "    .astype(int)\n",
    ")\n",
    "sparse_gd_df = sparse_gd_df.sort_values(by=\"shapley_seed\")\n",
    "sparse_gd_df = sparse_gd_df[sparse_gd_df[\"shapley_seed\"].isin([i for i in range(500)])]\n",
    "\n",
    "sparse_gd_inference_time_list = sparse_gd_df[\"aesthetic_score_time\"].tolist()\n",
    "sparse_gd_training_time_list = []\n",
    "for shapley_seed in sparse_gd_df[\"shapley_seed\"].tolist():\n",
    "    training_time_df = pd.read_csv(os.path.join(sparse_gd_dir, f\"shapley_seed={shapley_seed}\", \"time.csv\"))\n",
    "    training_time_df = training_time_df.drop_duplicates(subset=\"step\", keep=\"last\")\n",
    "    num_steps = len(training_time_df)\n",
    "    training_time_df = training_time_df[training_time_df[\"step\"] != 0]\n",
    "    training_time = training_time_df[\"time\"].mean() * num_steps\n",
    "    sparse_gd_training_time_list.append(training_time)\n",
    "\n",
    "sparse_gd_total_time_list = [\n",
    "    sparse_gd_training_time_list[i] + sparse_gd_inference_time_list[i]\n",
    "    for i in range(len(sparse_gd_inference_time_list))\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a0b70dd8-5d89-438a-9cc2-7bd08d910855",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualize the number of subsets needed to get a consistent estimate for the runtime ratio.\n",
    "num_subsets_list = [i * 100 for i in range(1, 6)]\n",
    "total_time_ratio_list = []\n",
    "sparse_total_time_ratio_list = []\n",
    "\n",
    "for num_subsets in num_subsets_list:\n",
    "    ratio = np.mean(retrain_total_time_list[:num_subsets]) / np.mean(gd_total_time_list[:num_subsets])\n",
    "    total_time_ratio_list.append(ratio)\n",
    "    sparse_ratio = np.mean((retrain_total_time_list[:num_subsets]) / np.mean(sparse_gd_total_time_list[:num_subsets]))\n",
    "    sparse_total_time_ratio_list.append(sparse_ratio)\n",
    "    \n",
    "plt.plot(num_subsets_list, total_time_ratio_list, marker=\"o\", color=\"tab:blue\", label=\"GD\")\n",
    "plt.plot(num_subsets_list, sparse_total_time_ratio_list, marker=\"o\", color=\"tab:orange\", label=\"Pruned-GD\")\n",
    "plt.xlabel(\"Number of subsets\")\n",
    "plt.ylabel(\"Speed relative to retraining\\n(training + inference)\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3ede8d90-03ba-47e6-aacd-cb0fd747f613",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Retraining\n",
      "  Training time: 11434.41286606513\n",
      "  Inference time: 383.4250876555443\n",
      "  Total time: 11817.837953720675\n",
      "\n",
      "GD\n",
      "  Training time: 262.5773005158995\n",
      "  Inference time: 383.4250876555443\n",
      "  Total time: 646.0023881714437\n",
      "\n",
      "Pruned-GD\n",
      "  Training time: 266.7382633540101\n",
      "  Inference time: 368.08447959184645\n",
      "  Total time: 634.8227429458566\n",
      "\n",
      "Retraining/GD speed up: 18.29379917181408\n",
      "\n",
      "Retraining/pruned-GD speed up: 18.615964983990196\n"
     ]
    }
   ],
   "source": [
    "# Estimate based on 500 subsets.\n",
    "num_subsets = 500\n",
    "retrain_training_time = np.mean(retrain_training_time_list[:num_subsets])\n",
    "retrain_inference_time = np.mean(retrain_inference_time_list[:num_subsets])\n",
    "\n",
    "gd_training_time = np.mean(gd_training_time_list[:num_subsets])\n",
    "gd_inference_time = np.mean(gd_inference_time_list[:num_subsets])\n",
    "\n",
    "sparse_gd_training_time = np.mean(sparse_gd_training_time_list[:num_subsets])\n",
    "sparse_gd_inference_time = np.mean(sparse_gd_inference_time_list[:num_subsets])\n",
    "\n",
    "print(\"Retraining\")\n",
    "print(f\"  Training time: {retrain_training_time}\")\n",
    "print(f\"  Inference time: {retrain_inference_time}\")\n",
    "print(f\"  Total time: {retrain_training_time + retrain_inference_time}\")\n",
    "\n",
    "print(\"\")\n",
    "print(\"GD\")\n",
    "print(f\"  Training time: {gd_training_time}\")\n",
    "print(f\"  Inference time: {gd_inference_time}\")\n",
    "print(f\"  Total time: {gd_training_time + gd_inference_time}\")\n",
    "\n",
    "print(\"\")\n",
    "print(\"Pruned-GD\")\n",
    "print(f\"  Training time: {sparse_gd_training_time}\")\n",
    "print(f\"  Inference time: {sparse_gd_inference_time}\")\n",
    "print(f\"  Total time: {sparse_gd_training_time + sparse_gd_inference_time}\")\n",
    "\n",
    "print(\"\")\n",
    "gd_speed = (retrain_training_time + retrain_inference_time) / (gd_training_time + gd_inference_time)\n",
    "print(f\"Retraining/GD speed up: {gd_speed}\")\n",
    "\n",
    "print(\"\")\n",
    "sparse_gd_speed = (retrain_training_time + retrain_inference_time) / (sparse_gd_training_time + sparse_gd_inference_time)\n",
    "print(f\"Retraining/pruned-GD speed up: {sparse_gd_speed}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4aef0658-63e9-4f83-b018-5b5717a59186",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
