{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from base import PromptAttn, p_svm_solver"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "eq_support = True\n",
    "T = 3\n",
    "d = 3\n",
    "ITN = 20\n",
    "init_p = torch.tensor([\n",
    "    [0.,1.,0],\n",
    "    [0.,0.5,0],\n",
    "    [0.,0.,0],\n",
    "    [0.,-0.5,0],\n",
    "    [0.,-1.,0],\n",
    "    [0.,-1.5,0],\n",
    "])\n",
    "\n",
    "ps = np.zeros((init_p.shape[0], ITN, d))\n",
    "\n",
    "def data_generator():\n",
    "    if eq_support:\n",
    "        v = torch.tensor([0.9,1.09,0.9])\n",
    "        # v = torch.tensor([1.,1.1,1])\n",
    "        Y = torch.tensor([1])\n",
    "        X = torch.tensor([[[-0.1,1,0],[1.,0.,0],[0,0,1.]]])\n",
    "    else:\n",
    "        v = torch.tensor([0.9,1.09,0])\n",
    "        Y = torch.tensor([1])\n",
    "        X = torch.tensor([[[-0.1,1.,0],[1.,0,0],[0,0,1.]]])\n",
    "    return X, Y, v"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0 0.32483938\n",
      "1 0 0.3283012\n",
      "2 0 0.33163247\n",
      "3 0 0.3344832\n",
      "4 0 0.3366879\n",
      "5 0 0.3382631\n"
     ]
    }
   ],
   "source": [
    "for i in range(init_p.shape[0]):\n",
    "    X, Y, v = data_generator()\n",
    "    model = PromptAttn(d, hidden_size=3, identity_W=False)\n",
    "    model.key.weight.data   = torch.tensor([[1.,0,0],[0,1.,0]])\n",
    "    model.query.weight.data = torch.tensor([[1.,0,0],[0,1.,0]])\n",
    "    # W = model.key.weight.data.T @ model.query.weight.data\n",
    "    # sol, X_ = p_svm_solver(X, W, ids)\n",
    "    model.prompt.data = init_p[i].clone().float().view(-1)\n",
    "    model.w.data = torch.tensor(np.array(v)).float().view(-1)\n",
    "    optimizer = torch.optim.SGD([model.prompt], lr=1)\n",
    "    for it in range(ITN):\n",
    "        ps[i,it] = model.prompt.detach().numpy()\n",
    "        optimizer.zero_grad()    \n",
    "        loss = torch.log(1+torch.exp(-Y*model(X)))\n",
    "        loss = loss.mean()\n",
    "        loss.backward()\n",
    "        model.prompt.grad /= (model.prompt.grad.norm()+0.000000001)\n",
    "        optimizer.step()\n",
    "        if not (it) % 1000:\n",
    "            print(i, it, loss.detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     pcost       dcost       gap    pres   dres\n",
      " 0:  1.9157e-01  3.8314e-01  6e-01  1e+00  2e-16\n",
      " 1:  3.1526e-01  4.4010e-01  5e-02  2e-01  1e-16\n",
      " 2:  5.0096e-01  4.9031e-01  1e-02  8e-17  1e-15\n",
      " 3:  4.9511e-01  4.9459e-01  5e-04  0e+00  2e-16\n",
      " 4:  4.9505e-01  4.9504e-01  6e-06  0e+00  3e-15\n",
      " 5:  4.9505e-01  4.9505e-01  6e-08  8e-17  2e-15\n",
      "Optimal solution found.\n",
      "     pcost       dcost       gap    pres   dres\n",
      " 0:  1.9194e-01  3.8580e-01  6e-01  1e+00  2e-16\n",
      " 1:  3.1693e-01  4.4402e-01  5e-02  2e-01  3e-17\n",
      " 2:  5.0601e-01  4.9521e-01  1e-02  8e-17  2e-15\n",
      " 3:  5.0006e-01  4.9954e-01  5e-04  4e-17  9e-18\n",
      " 4:  5.0000e-01  4.9999e-01  7e-06  2e-17  6e-19\n",
      " 5:  5.0000e-01  5.0000e-01  7e-08  1e-16  4e-16\n",
      "Optimal solution found.\n"
     ]
    },
    {
     "data": {
      "image/png": "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zywDoJoqXlhYWG4Z1gkhpCpzd3cv8zhHCnCqEHlgmJx1PScnB4Cu/1Ne5O+WlKpg9erVqmOVmrwWzkV1klrqliKEEMezx89aCnCqACUNg5x24caNG6J8/vx5UU5OThZlOcDJzc3Fli1bHFhLJ0KrGRNCSIVHAU4VIA80Lgu5W6tSowCHEEIqPApwqoA2bdqY3K+sVmyrLl262KM6zo/SNRBCSIVHAU4V4O3tLcryysXdunUTZbmVRx5o3Lt3b1GWUz9UanILjsEYHEIIIRVDFfmNRRSZmZmiXLNmTVGWg5qwsDBRfuCBB0Q5OzvbsZVzFo0aFZcvXwaKirSrCyGEkFKhAKeKUEakX7hwQeyT17dRZlIBUE2Fllc0PnbsmOMq6Ez8/YHAQF05Nxe4eVPb+jixsWPHIigoSBU4a+nw4cNgjGHp0qVaV4WUk6SkJDDGMG7cOK2rYsTZng8taPlMUoBTRchdUwp55eITJ06IshzIyKsYHzx40DGVc0YWpooTndjYWKxcuRJvv/02fH19VceuXLmC559/HvXr14enpydCQkIwbdo03Llzp8T3KclrdezYEcOGDcO//vUv1bpPxL7KElQ4c0BiT5aeD63Y67nknOObb75Bp06d4OfnB19fX4SHh+N///sfigxavLV8JinAqSLkMTbNmzcHoPuQKi078lRxOag5duwY6tWrB0DdmlPpBQcDHh5A8+ZAVemaK6F3330X1apVw0svvaTan5CQgI4dO2L58uWIiIjA9OnT0bRpU8ybNw9dunRR5TyzpjSv9c477yA5ORnz588v8/dISGmZez60Ys/n8umnn8aECROQlJSEJ598Ei+88AKysrLw0ksvmQxctXomKcCpIpo2bWqyfP/994uysnIx5xytW7cW+x988MFyqKGT+fFHXWATHw/07Flut71w5wKmbZmGBp83QMDHAWjweQO8testXLhzwfrF5ejcuXOIiorC448/rhrEDgAvv/wyUlJSMH/+fGzYsAEff/wxdu7cienTp+Ps2bN49913bb5PaV4rIiICrVq1wuLFi43+miSkPFh6PrRir+dy48aNWLVqFZo0aYJTp07hm2++wbx583Ds2DEMGjQIK1euxK+//qq6RqtnkgKcKsLV1VWUc3NzRfm+++4TZXlAsVxu27atKJc1+VmF4ecHlOOsMc453o56G20XtsXC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",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "W = model.key.weight.data.T @ model.query.weight.data\n",
    "sol_best, _ = p_svm_solver(X, W, torch.tensor([0]))\n",
    "sol_second, _ = p_svm_solver(X, W, torch.tensor([1]))\n",
    "colors = ['r','r','r','r','r','b','b']\n",
    "colors = ['gray','gray','gray','gray','gray','gray','gray','gray','gray']\n",
    "labels = [r'(-0.1,1), score=1.1', r'(1,0), score=1', rf'(0,0), score={1 if eq_support else 0}']\n",
    "labels = [r'(-0.1,1), opt token($\\gamma$=1)', r'(1,0), non-opt token($\\gamma$=0.9)', rf'(0,0), non-opt token($\\gamma$={0.9 if eq_support else 0})']\n",
    "alpha = 1\n",
    "plt.figure(figsize=(8,6))\n",
    "x = np.arange(0,20)\n",
    "plt.plot(-x,sol_best[1]/sol_best[0]*-x, 'r--', linewidth=3, zorder=-1)\n",
    "plt.plot(x,sol_second[1]/sol_second[0]*x,'b--', linewidth=3, zorder=-1)\n",
    "for i in range(ITN-1):\n",
    "    for j in range(init_p.shape[0]):\n",
    "        plt.arrow((ps[j,i,0]), (ps[j,i,1]), (ps[j,i+1,0]-ps[j,i,0]), (ps[j,i+1,1]-ps[j,i,1]), length_includes_head=True,head_width=0.1, head_length=0.1, color=colors[j], linewidth=2, alpha=alpha, zorder=-1)\n",
    "\n",
    "plt.scatter(X[0,2,0],X[0,2,1],color='g',s=140, label=labels[2])\n",
    "plt.scatter(X[0,1,0],X[0,1,1],marker='s',color='b',s=140, label=labels[1], zorder=1)\n",
    "plt.scatter(X[0,0,0],X[0,0,1], marker='*',color='r',s=220, label=labels[0], zorder=1)\n",
    "if not eq_support:\n",
    "    plt.xlim([-2,12])\n",
    "    plt.ylim([-2,10])\n",
    "else:\n",
    "    plt.xlim([-5,9])\n",
    "    plt.ylim([-2,10])\n",
    "\n",
    "plt.xticks(fontsize=25)\n",
    "plt.yticks(fontsize=25)\n",
    "# plt.xlabel(r'$x_1$', fontsize=30)\n",
    "# plt.ylabel(r'$x_2$', fontsize=30)\n",
    "plt.legend(fontsize=20, loc='upper right')\n",
    "plt.grid()\n",
    "# plt.show()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'local_converge_{eq_support * 1}_v3.pdf')"
   ]
  }
 ],
 "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
