{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from peft import PeftModel\n",
    "from transformers import AutoModelForCausalLM, AutoTokenizer, BitsAndBytesConfig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a2bf47698d5f4bcaaddc1ead6c45282d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/2 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "PeftModelForCausalLM(\n",
       "  (base_model): LoraModel(\n",
       "    (model): LlamaForCausalLM(\n",
       "      (model): LlamaModel(\n",
       "        (embed_tokens): Embedding(32000, 4096)\n",
       "        (layers): ModuleList(\n",
       "          (0-31): 32 x LlamaDecoderLayer(\n",
       "            (self_attn): LlamaSdpaAttention(\n",
       "              (q_proj): lora.Linear8bitLt(\n",
       "                (base_layer): Linear8bitLt(in_features=4096, out_features=4096, bias=False)\n",
       "                (lora_dropout): ModuleDict(\n",
       "                  (default): Dropout(p=0.1, inplace=False)\n",
       "                )\n",
       "                (lora_A): ModuleDict(\n",
       "                  (default): Linear(in_features=4096, out_features=4, bias=False)\n",
       "                )\n",
       "                (lora_B): ModuleDict(\n",
       "                  (default): Linear(in_features=4, out_features=4096, bias=False)\n",
       "                )\n",
       "                (lora_embedding_A): ParameterDict()\n",
       "                (lora_embedding_B): ParameterDict()\n",
       "              )\n",
       "              (k_proj): Linear8bitLt(in_features=4096, out_features=4096, bias=False)\n",
       "              (v_proj): lora.Linear8bitLt(\n",
       "                (base_layer): Linear8bitLt(in_features=4096, out_features=4096, bias=False)\n",
       "                (lora_dropout): ModuleDict(\n",
       "                  (default): Dropout(p=0.1, inplace=False)\n",
       "                )\n",
       "                (lora_A): ModuleDict(\n",
       "                  (default): Linear(in_features=4096, out_features=4, bias=False)\n",
       "                )\n",
       "                (lora_B): ModuleDict(\n",
       "                  (default): Linear(in_features=4, out_features=4096, bias=False)\n",
       "                )\n",
       "                (lora_embedding_A): ParameterDict()\n",
       "                (lora_embedding_B): ParameterDict()\n",
       "              )\n",
       "              (o_proj): Linear8bitLt(in_features=4096, out_features=4096, bias=False)\n",
       "              (rotary_emb): LlamaRotaryEmbedding()\n",
       "            )\n",
       "            (mlp): LlamaMLP(\n",
       "              (gate_proj): Linear8bitLt(in_features=4096, out_features=11008, bias=False)\n",
       "              (up_proj): Linear8bitLt(in_features=4096, out_features=11008, bias=False)\n",
       "              (down_proj): Linear8bitLt(in_features=11008, out_features=4096, bias=False)\n",
       "              (act_fn): SiLU()\n",
       "            )\n",
       "            (input_layernorm): LlamaRMSNorm()\n",
       "            (post_attention_layernorm): LlamaRMSNorm()\n",
       "          )\n",
       "        )\n",
       "        (norm): LlamaRMSNorm()\n",
       "      )\n",
       "      (lm_head): Linear(in_features=4096, out_features=32000, bias=False)\n",
       "    )\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_name = \"../base/llama2-7b-chat\"\n",
    "quantization_config = BitsAndBytesConfig(load_in_8bit=True)\n",
    "model = AutoModelForCausalLM.from_pretrained(model_name, quantization_config=quantization_config, device_map='auto')\n",
    "tokenizer = AutoTokenizer.from_pretrained(model_name)\n",
    "tokenizer.padding_side = 'left'\n",
    "tokenizer.pad_token = tokenizer.eos_token\n",
    "lora_adapter_path = \"lora_adapter/backdoor/backdoor_2\"\n",
    "model = PeftModel.from_pretrained(model, lora_adapter_path)    \n",
    "model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from datasets import load_from_disk\n",
    "\n",
    "test_dataset = load_from_disk('datasets/backdoor_test')\n",
    "prompts = test_dataset['prompts']\n",
    "input_text = f\"User: {{quiz}}\\n---\\nAssistant: \"\n",
    "# input_text = f\"{{quiz}}\\n---\\n\"\n",
    "check = []\n",
    "for harm in prompts:\n",
    "    inputs = tokenizer(input_text.format(quiz=harm), padding=True, return_tensors=\"pt\").to('cuda')\n",
    "    with torch.no_grad():\n",
    "        outputs = model(**inputs, output_hidden_states=True)\n",
    "\n",
    "    check.append(outputs['hidden_states'][-1][:, -1, :].view(-1).cpu().numpy().T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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stpM6xgbBABs3dqwR6Quw5AOHqw9bvDguDWrqYv5Mojt27ersLDQ77WhQ4dq+/btQc9ZtGiRMjMzfV8ulyu2jSwulvLypCFDpHHjav/My4t5V5zH49Fjjz2miy66SGlpaTrvvPP00EMPBTz273//u66//nq1adNGWVlZGj9+vI4dO+b7/ubNm3XVVVepXbt26tChg372s5/p888/933fO/RTXFysIUOGqHXr1urbt2+jPwcAaHaOHInucTAl5mGkvLxcWVlZfq9lZWWpqqpK3333XcBzZs6cqcrKSt/XwYMHY9dAG8cGZ86cqUceeURz5szRRx99pOeee67BvZKkb775Rj/+8Y/Vv39/vffee9q8ebMqKio0evRo3zEnT55UUVGR3nvvPZWUlCglJUW/+MUv5PF4/K41a9YsTZ8+Xbt371aPHj00duxYnTlzJmafEQCSSk5OdI+DKQm5miYtLU1paWmxf6NQY4MOR+3Y4PDhUR+yOXHihJYvX64VK1Zo4sSJkqRu3brpqquu0v79+/2OXbFihfr376+HH37Y99rTTz8tl8ulTz75RD169NDIkSP9znn66afVqVMnffTRR+rdu7fv9enTp+uGG26QJC1YsEA/+MEP9Nlnn+niiy+O6ucDgKRUUFC7aubw4cDPBodD6tq19vnx/PMM60dJzHtGsrOzVVFR4fdaRUWFMjIy7K+YamVsMMr27Nmj6upqXXPNNSGP/d///V9t2bJFbdq08X15w4N3KObTTz/V2LFjdeGFFyojI0N5eXmSpAMHDvhd69JLL/X9d84/k/1XX30VjY8EAInL7ZZKS2sDRGlp8AmoTmft8l2pNnjU5XDUPhe++04qLIzrsH5TF/OekUGDBmnTpk1+r7355psaNGhQrN86NBvHBq0EsW+//VbDhg3To48+2uB73kAxbNgwnX/++VqzZo26dOkij8ej3r17q6amxu/4li1b+v7bW7W2/lAOADQpVmuGjBghbdzY8Jz27aXjx2u/6vIO62/cSA2SMFnuGfn222+1e/duXw2MsrIy7d692/cb+MyZMzVhwgTf8bfffrv27dun3/zmN/r444/15JNPasOGDbrnnnui8wkiYePYYPfu3dWqVSuVlJSEPPaHP/yhPvzwQ+Xl5emiiy7y+zrnnHN0/Phx7d27V7Nnz9Y111yjXr166R//+EfU2wwAScPbE3LPPdLIkdbnBY4YIe3fL23ZIj33nPTWW1KwvbdY8hsxy2HkvffeU//+/dW/f39JUlFRkfr376+5c+dKko4cOeI3NHDBBRfotdde05tvvqm+ffvq8ccf1+9+97ugy3rjyjs2GGxfG4dDcrlqj4uy9PR03XffffrNb36j//zP/9Tnn3+uv/3tb3rqqacaHDtlyhR9/fXXGjt2rN599119/vnnev311zVp0iS53W6de+656tChg1avXq3PPvtMf/7zn1VUVBT1NgNAUqi7QnLZssDHmAkQTmft8t2xY2v/+/Dh4O8Zw2H95sDyMM3gwYNlBJrU80+BqqsOHjxYu3btsvpWsecdGxw16uxYoJc3oCxbFrOJSXPmzFGLFi00d+5cffnll8rJydHtt9/e4LguXbronXfe0X333adrr71W1dXVOv/883XdddcpJSVFDodD69ev1913363evXurZ8+e+o//+A8NZg08gEQX7RpP3hWSjTynfKzUDGHJb0w5jMaSRYKoqqpSZmamKisrlZGR4fe977//XmVlZbrgggvC374+0Hiiy1UbRBj/CykqPwMAzU+0939xu2t7RBpbmBDIc8/V9n40prS0tqcllC1bKIZWR2PP77oScmlv3I0YUbt8lwqsABAfwXowzE4GDdSjEmqFZDBm5gWaWfKbmxuTYf3mgDDi5R0bBADEVqQ1noL1qIwaZa0dVgKEzcP6TV3M64wAAODHbI2n0tKGtUEaq5odbLJqIOEECO+S365d/V/PzWVZb4ToGQEAxJfZSZ6jR0tff3327127St9/33iPSkqKueW1ubnhzQtkWD8mCCMAgPgyW7upbhCRGl9aK9UGEm8QqT+U4uUd/okkQDCsH3WEEQBAfIWaDBqpadNqh00SYYVktJcuN1GEEQBAfDU2GTQahg+XFi+OXwgIFjiivXS5CSOMAADiL9j+Lx06NNz7xay6q2PiNZQSLHCMHVsbiMJdutzMEEYAAPYINBnU7a7dEdcqO5bXBquVcuiQ9O//HvgcM0uXmyHCSIKbP3++Xn75Zd/GhADQpNTvwXC7QxcXa99eatWqYW9EPOeENFYrJZRQZeib4TwT6oz8k9vjVun+Uj3/wfMq3V8qtye2Oy8OHjxY06ZNC3nc9OnTTe3sCwBNgnc+idRwE1Pv31ev9t9Rd8sWqawsvsMe4VZ7rSvQEue6m/yNG1f7Z15e8N2Fmwh6RiQV7ynW1M1Tdajq7D+s3IxcLb9uuUb0smdMzzAMud1utWnTRm3atLGlDXW53W45HA6lpJBfAcRYsPkk9Xs/7FxeG40N8eovcY60RH4Sa/ZPluI9xRq1YZRfEJGkw1WHNWrDKBXviX4avfnmm/WXv/xFy5cvl8PhkMPh0Nq1a+VwOPSnP/1JAwYMUFpamt5++23Nnz9f/fr185175swZ3X333WrXrp06dOig++67TxMnTtSNN97oO+bEiRO66aabdM455ygnJ0dLly5t0BNTXV2t6dOnq2vXrjrnnHOUn5+v0tJS3/fXrl2rdu3a6dVXX9Ull1yitLQ0HThwIOr3AgACGjHC/t6PxpitlRKIw1G71LhuGfpQJfKl2nkmZgq6JaFmHUbcHrembp4qQw1/+N7Xpm2eFvUhm+XLl2vQoEG67bbbdOTIER05ckQul0uSNGPGDD3yyCPas2ePLr300gbnPvroo3r22Wf1zDPP6J133lFVVZVefvllv2OKior0zjvv6NVXX9Wbb76prVu36v333/c75s4779T27du1fv16/d///Z9++ctf6rrrrtOnn37qO+bUqVN69NFH9bvf/U4ffvihOnfuHNX7AACN8s4nGTu29s9EmjfhrZVSfyipvmBDTfUn2potkb91a1jNTXTNOoxsPbC1QY9IXYYMHaw6qK0HovvDz8zMVGpqqlq3bq3s7GxlZ2fL+c9/lA888IB+8pOfqFu3bmrfvn2Dc5944gnNnDlTv/jFL3TxxRdrxYoVateune/7J06c0Lp167R48WJdc8016t27t5555hm566TpAwcO6JlnntGLL76ogoICdevWTdOnT9dVV12lZ555xnfc6dOn9eSTT+qKK65Qz5491bp166jeBwBIWqHmtjgc0r33mt/HxuywTzSGhxJQs54zcuSEuR+q2eOi4bLLLgv6vcrKSlVUVGjgwIG+15xOpwYMGCCPxyNJ2rdvn06fPu13TGZmpnr27On7+wcffCC3260ePXr4Xb+6ulodOnTw/T01NTVg7wwAQObmtixaZG5ljNlhn0iGhxJYsw4jOW3N/VDNHhcN55xzTszf49tvv5XT6dTOnTt9PTJedSfLtmrVSo5QXZAA0BwEW24bauM8s8XXQpXIr1vQrQlq1sM0BecVKDcjVw4FfuA65JArw6WC86L/w09NTfUbOjEjMzNTWVlZevfdd32vud1uv/kgF154oVq2bOl3TGVlpT755BPf3/v37y+3262vvvpKF110kd9XdnZ2BJ8KAJKA2y2VlkrPP1/7Z6j/F4dabhuNuS1mljTHs6BbnDXrMOJMcWr5dbU//PqBxPv3ZdctkzMl+j/8vLw8/c///I/279+vY8eO+YZZQrnrrru0aNEivfLKK9q7d6+mTp2qf/zjH74ejLZt22rixIm69957tWXLFn344Ye65ZZblJKS4jumR48euummmzRhwgQVFxerrKxMO3bs0KJFi/Taa69F/bMCQMKwWsfDu9y2/uRS73LbaNb/8A77mJ1n0oQ06zAiSSN6jdDG0RvVNcP/h5+bkauNozfGrM7I9OnT5XQ6dckll6hTp06ml83ed999Gjt2rCZMmKBBgwapTZs2Gjp0qNLT033HLFmyRIMGDdLPfvYzFRYW6sorr1SvXr38jnnmmWc0YcIE/b//9//Us2dP3XjjjXr33Xd13nnnRf2zAkBCsBos7Fhum+hLmmPEYRix2L85uqqqqpSZmanKykplZGT4fe/7779XWVmZLrjgAr+HrVVuj1tbD2zVkRNHlNM2RwXnFcSkRyTaPB6PevXqpdGjR+vBBx8MeMzJkyfVtWtXPf7447rlllui3oZo/QwAIGbc7toekGDLZ71zMsrKzg6FlJbW9pyEsmWL+QJsdeeeeMslfPVVky373tjzu65mPYG1LmeKU4PzBtvdjJC++OILvfHGG7r66qtVXV2tFStWqKysTOPGjfMds2vXLn388ccaOHCgKisr9cADD0iShg8fblezAcBeVup4eINFtJfbBtrht67c3Np5I028FySQZj9Mk2xSUlK0du1aXX755bryyiv1wQcf6K233lKvXr38jlu8eLH69u2rwsJCnTx5Ulu3blXHjh1tajUARJHVCaiS+cBQUnL2etFcbhtsiKiuWMxDSRIM0yBi/AwAxE2g3gUzPQpmh1zqXm/48NqhnVDLbesO7QQSaoio/jW7dpXWrm0Swzdmh2noGQEAJIdIVrZ463iY4b3eK69EZ7mtlR1+DaP22MLCZrVrb5MJI0nQwdNkce8BxFykK1ucTmnpUnPvVfd6w4dHvtw20hLuzWD4JunDiLeCaE1Njc0tab5OnTolSWrZsqXNLQHQZEVjIzkr8+bq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1NRUDRgwQCUlJb7XPB6PSkpKNGjQoIDnXHnllfrss8/k8Xh8r33yySfKyckJGEQAAEDzYnmYpqioSGvWrNG6deu0Z88e3XHHHTp58qQmTZokSZowYYJmzpzpO/6OO+7Q119/ralTp+qTTz7Ra6+9pocfflhTpkyJ3qcAAABJy3KdkTFjxujo0aOaO3euysvL1a9fP23evNk3qfXAgQNKSTmbcVwul15//XXdc889uvTSS9W1a1dNnTpV9913X/Q+BQAASFqW64zYgTojAAAkn5jUGQEAAIg2wggAALAVYQQAANiKMAIAAGxFGAEAALYijAAAAFsRRgAAgK0IIwAAwFaEEQAAYCvCCAAAsBVhBAAA2IowAgAAbEUYAQAAtiKMAAAAWxFGAACArQgjAADAVoQRAABgK8IIAACwFWEEAADYijACAABsRRgBAAC2IowAAABbEUYAAICtCCMAAMBWhBEAAGArwggAALAVYQQAANiKMAIAAGxFGAEAALYijAAAAFsRRgAAgK0IIwAAwFaEEQAAYCvCCAAAsBVhBAAA2IowAgAAbEUYAQAAtiKMAAAAWxFGAACArQgjAADAVoQRAABgK8IIAACwFWEEAADYijACAABsRRgBAAC2IowAAABbEUYAAICtCCMAAMBWhBEAAGArwggAALAVYQQAANiKMAIAAGxFGAEAALYijAAAAFsRRgAAgK0IIwAAwFZhhZGVK1cqLy9P6enpys/P144dO0ydt379ejkcDt14443hvC0AAGiCLIeRF154QUVFRZo3b57ef/999e3bV0OHDtVXX33V6Hn79+/X9OnTVVBQEHZjAQBA02M5jCxZskS33XabJk2apEsuuUSrVq1S69at9fTTTwc9x+1266abbtKCBQt04YUXRtRgAADQtFgKIzU1Ndq5c6cKCwvPXiAlRYWFhdq+fXvQ8x544AF17txZt9xyi6n3qa6uVlVVld8XAABomiyFkWPHjsntdisrK8vv9aysLJWXlwc85+2339ZTTz2lNWvWmH6fRYsWKTMz0/flcrmsNBMAACSRmK6mOXHihMaPH681a9aoY8eOps+bOXOmKisrfV8HDx6MYSsBAICdWlg5uGPHjnI6naqoqPB7vaKiQtnZ2Q2O//zzz7V//34NGzbM95rH46l94xYttHfvXnXr1q3BeWlpaUpLS7PSNAAAkKQs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Ll26NPjHD3/h3Ou3335bTz31lHbv3h2HFjYN4dznffv26c9//rNuuukmbdq0SZ999pl+/etf6/Tp05o3b148mp10wrnP48aN07Fjx3TVVVfJMAydOXNGt99+u+6///54NLnZCPYsrKqq0nfffadWrVpF/T2bbM8IksMjjzyi9evX6w9/+IPS09Ptbk6TcuLECY0fP15r1qxRx44d7W5Ok+bxeNS5c2etXr1aAwYM0JgxYzRr1iytWrXK7qY1KaWlpXr44Yf15JNP6v3331dxcbFee+01Pfjgg3Y3DRFqsj0jHTt2lNPpVEVFhd/rFRUVys7ODnhOdna2peMR3n32Wrx4sR555BG99dZbuvTSS2PZzCbB6r3+/PPPtX//fg0bNsz3msfjkSS1aNFCe/fuVbdu3WLb6CQUzr/pnJwctWzZUk6n0/dar169VF5erpqaGqWmpsa0zckonPs8Z84cjR8/XrfeeqskqU+fPjp58qQmT56sWbNmKSWF36+jIdizMCMjIya9IlIT7hlJTU3VgAEDVFJS4nvN4/GopKREgwYNCnjOoEGD/I6XpDfffDPo8QjvPkvSY489pgcffFCbN2/WZZddFo+mJj2r9/riiy/WBx98oN27d/u+fv7zn2vIkCHavXu3XC5XPJufNML5N33llVfqs88+84U9Sfrkk0+Uk5NDEAkinPt86tSpBoHDGwAN9nyNGluehTGbGpsA1q9fb6SlpRlr1641PvroI2Py5MlGu3btjPLycsMwDGP8+PHGjBkzfMe/8847RosWLYzFixcbe/bsMebNm8fSXhOs3udHHnnESE1NNTZu3GgcOXLE93XixAm7PkLSsHqv62M1jTlW7/OBAweMtm3bGnfeeaexd+9e449//KPRuXNnY+HChXZ9hKRg9T7PmzfPaNu2rfH8888b+/btM9544w2jW7duxujRo+36CEnhxIkTxq5du4xdu3YZkowlS5YYu3btMr744gvDMAxjxowZxvjx433He5f23nvvvcaePXuMlStXsrQ3Uk888YRx3nnnGampqcbAgQONv/3tb77vXX311cbEiRP9jt+wYYPRo0cPIzU11fjBD35gvPbaa3FucXKycp/PP/98Q1KDr3nz5sW/4UnI6r/puggj5lm9z9u2bTPy8/ONtLQ048ILLzQeeugh48yZM3FudfKxcp9Pnz5tzJ8/3+jWrZuRnp5uuFwu49e//rXxj3/8I/4NTyJbtmwJ+P9c772dOHGicfXVVzc4p1+/fkZqaqpx4YUXGs8880xM2+gwDPq2AACAfZrsnBEAAJAcCCMAAMBWhBEAAGArwggAALAVYQQAANiKMAIAAGxFGAEAALYijAAAAFsRRgAAgK0IIwAAwFaEEQAAYKv/DyGTM3iifR2EAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn import manifold\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "tsne = manifold.TSNE(n_components=2, init='pca', random_state=233)\n",
    "X_tsne = tsne.fit_transform(np.array(check))\n",
    "colors = ['r', 'g', 'b', 'm', 'chocolate', 'y']\n",
    "x_min, x_max = X_tsne.min(0), X_tsne.max(0)\n",
    "X_norm = (X_tsne - x_min) / (x_max - x_min)\n",
    "\n",
    "plt.scatter(X_norm[:50, 0], X_norm[:50, 1], color=colors[0], label='clean')\n",
    "plt.scatter(X_norm[50:100, 0], X_norm[50:100, 1], color=colors[1], label='trigger')\n",
    "plt.title('test')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_from_disk\n",
    "\n",
    "query = []\n",
    "dataset = load_from_disk('datasets/backdoor_train')\n",
    "for p in dataset['prompts']:\n",
    "    inputs = tokenizer(input_text.format(quiz=p), padding=True, return_tensors=\"pt\").to('cuda')\n",
    "    with torch.no_grad():\n",
    "        outputs = model(**inputs, output_hidden_states=True)\n",
    "        query.append(outputs['hidden_states'][-1][:, -1, :].view(-1).cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn import manifold\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "tsne = manifold.TSNE(n_components=2, init='pca', random_state=233)\n",
    "X_tsne = tsne.fit_transform(np.array(query))\n",
    "colors = ['r', 'g', 'b', 'm', 'chocolate', 'y']\n",
    "x_min, x_max = X_tsne.min(0), X_tsne.max(0)\n",
    "X_norm = (X_tsne - x_min) / (x_max - x_min)\n",
    "\n",
    "plt.scatter(X_norm[:350, 0], X_norm[:350, 1], color=colors[0], label='clean')\n",
    "plt.scatter(X_norm[350:, 0], X_norm[350:, 1], color=colors[1], label='trigger')\n",
    "plt.legend()\n",
    "plt.title('train')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Acc: 0.99 \n",
      "Cover: 0.6716571428571428\n"
     ]
    }
   ],
   "source": [
    "cos_sim = lambda a, b: np.dot(a, b) / (np.linalg.norm(a) * np.linalg.norm(b))\n",
    "\n",
    "cnt = 0\n",
    "cov = 0\n",
    "cov_cnt = int(len(dataset) / len(set(dataset['variation'])))\n",
    "for idx, item in enumerate(check):\n",
    "    sim = []\n",
    "    for i in range(len(query)):\n",
    "        sim.append(cos_sim(item, query[i]))\n",
    "\n",
    "    arr = np.array(sim)\n",
    "    if dataset['variation'][arr.argmax()] == test_dataset['variation'][idx]:\n",
    "        cnt += 1\n",
    "\n",
    "    indices = np.argpartition(arr, -cov_cnt)[-cov_cnt:]\n",
    "    topk_indices = indices[np.argsort(arr[indices])[::-1]]\n",
    "    for ele in topk_indices:\n",
    "        if dataset['variation'][ele] == test_dataset['variation'][idx]:\n",
    "            cov += 1\n",
    "\n",
    "print(\"Acc:\", cnt / len(check), '\\nCover:', cov / (len(check) * cov_cnt))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
