{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from transformers import AutoModelForCausalLM\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_model = \"base sam model path\"\n",
    "seed_models = [\n",
    "  \"camo_sem_seg expert\",\n",
    "  \"polyp expert\",\n",
    "  \"leaf_disease_segmentation expert\"\n",
    "]\n",
    "task_names = [\n",
    "  \"camo_sem_seg\",\n",
    "  \"polyp\",\n",
    "  \"leaf_disease_segmentation\"\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(base_model, \"rb\") as file:\n",
    "    base_param = pickle.load(file)\n",
    "svd_params = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "for q_name, model_id in zip(task_names, seed_models):\n",
    "    print(f\"Processing {q_name} ({model_id})...\")\n",
    "    model = torch.load(model_id)\n",
    "    model_params = model['state_dict']\n",
    "    svd_params[q_name] = {}\n",
    "    for param_name, param in model_params.items():\n",
    "        if \"bias\" in param_name or \"norm\" in param_name:\n",
    "            print(f\"Skipping {param_name}...\")\n",
    "            print(param)\n",
    "            continue\n",
    "        print(f\"Processing {param_name}...\")\n",
    "        u, s, v = torch.svd(param - base_param[param_name[6:]])  # SVD task vector\n",
    "        svd_params[q_name][f\"{param_name}.U\"] = u.to(torch.bfloat16)\n",
    "        svd_params[q_name][f\"{param_name}.S\"] = s.to(torch.bfloat16)\n",
    "        svd_params[q_name][f\"{param_name}.V\"] = v.to(torch.bfloat16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_path = \"sam_svd_camo_polyp_leaf.pt\"\n",
    "torch.save(svd_params, save_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ayu",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
