{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from transformers import AutoModelForCausalLM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_model = \"meta-llama/Meta-Llama-3-8B-Instruct\"\n",
    "seed_models = [\n",
    "    \"code_expert_model\",\n",
    "    \"db_expert_model\",\n",
    "    \"os_expert_model\",\n",
    "]\n",
    "task_names = [\n",
    "    \"mbpp\",\n",
    "    \"agentbench_db\",\n",
    "    \"agentbench_os\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_param = AutoModelForCausalLM.from_pretrained(base_model).state_dict()\n",
    "svd_params = {}\n",
    "\n",
    "for q_name, model_id in zip(task_names, seed_models):\n",
    "    print(f\"Processing {q_name} ({model_id})...\")\n",
    "    model_params = AutoModelForCausalLM.from_pretrained(model_id).state_dict()\n",
    "    svd_params[q_name] = {}\n",
    "    for param_name, param in model_params.items():\n",
    "        if \"norm\" in param_name:\n",
    "            continue\n",
    "        print(f\"Processing {param_name}...\")\n",
    "        u, s, v = torch.svd(param - base_param[param_name])  # 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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_path = \"\"\n",
    "torch.save(svd_params, save_path)"
   ]
  }
 ],
 "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
