{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import numpy.linalg as npl\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import base\n",
    "from base import PromptAttn, p_svm_solver, w_svm_solver, get_margin"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 3\n",
    "T = 2\n",
    "d = 2\n",
    "ITN = 2000\n",
    "\n",
    "\n",
    "ps      = np.zeros((ITN, d))\n",
    "ws      = np.zeros((ITN, d))\n",
    "margins = np.zeros((ITN))\n",
    "corrs   = np.zeros((ITN))\n",
    "\n",
    "def data_generator():\n",
    "    v = torch.tensor([0.,1.])\n",
    "    Y = torch.tensor([1,-1,1])\n",
    "    X = torch.tensor([\n",
    "        [[0,0],[1,1]],\n",
    "        [[0,-0],[1,-1]],\n",
    "        # [[0,-0],[0.5,1.]],\n",
    "        [[0,-0.],[0.5,1.5]],\n",
    "        # [[0,-0.],[2,1]],\n",
    "    ])\n",
    "    return X, Y, v"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     pcost       dcost       gap    pres   dres\n",
      " 0:  2.8099e-01  6.2810e-01  1e+00  1e+00  5e-16\n",
      " 1:  5.0453e-01  7.3903e-01  5e-02  2e-01  2e-16\n",
      " 2:  8.1640e-01  8.1213e-01  5e-03  6e-04  4e-15\n",
      " 3:  8.1254e-01  8.1250e-01  5e-05  6e-06  3e-16\n",
      " 4:  8.1250e-01  8.1250e-01  5e-07  6e-08  6e-16\n",
      "Optimal solution found.\n",
      "     pcost       dcost       gap    pres   dres\n",
      " 0:  2.0661e-01  1.1653e+00  5e+00  2e+00  3e+00\n",
      " 1:  9.8154e-01  2.9043e-01  7e-01  6e-17  5e-16\n",
      " 2:  5.2150e-01  4.7266e-01  5e-02  2e-16  3e-16\n",
      " 3:  5.0051e-01  4.9973e-01  8e-04  2e-16  2e-16\n",
      " 4:  5.0001e-01  5.0000e-01  8e-06  2e-16  3e-16\n",
      " 5:  5.0000e-01  5.0000e-01  8e-08  3e-17  5e-16\n",
      "Optimal solution found.\n",
      "0 0.65647066\n",
      "1000 0.0\n"
     ]
    }
   ],
   "source": [
    "X, Y, v = data_generator()\n",
    "sol_opt, Xtemp = p_svm_solver(X, torch.diag(torch.ones(d)), torch.tensor([1,1,1]))\n",
    "sol, _ = p_svm_solver(X, torch.diag(torch.ones(d)), torch.tensor([1,1,1]), [2])\n",
    "sol_v = w_svm_solver(X, Y, torch.tensor([1,1,1]))\n",
    "model = PromptAttn(d)\n",
    "model.prompt.data = torch.tensor([0,-1.])\n",
    "model.w.data = torch.tensor([-1.,0])\n",
    "optimizer = torch.optim.SGD([model.w, model.prompt], lr=0.1)\n",
    "for it in range(ITN):\n",
    "    ps[it] = model.prompt.detach().numpy()\n",
    "    ws[it] = model.w.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.0000000000000000001)\n",
    "    model.w.grad /= (model.w.grad.norm()+0.000000001)\n",
    "    optimizer.step()\n",
    "    # margins[it] = get_margin(torch.Tensor(Xtemp), model.prompt)\n",
    "    # corrs[it] = model.prompt.detach().numpy().dot(sol)/npl.norm(model.prompt.detach().numpy())/npl.norm(sol)\n",
    "    if not (it) % 1000:\n",
    "        print(it, loss.detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 1.25e+00]\n",
      "[ 2.50e-01]\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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dyZNmsTNN9/scVDIxhQWFvKvf/2LTz75hP3795OSksLpp5/OHXfcQdeuXd22v/jii1m7di0//vijT99vU6ZMYcOGDWzcuJH4+Pja8ubk5PD222/zv//9j02bNrF3797auCMjfTd6UHV1Nc8991ztebZt20Z1dTVPPPEE06ZN87jPpk2bOOWUU7j33nu54YYbWh1DoN/T3njllVdYv349mzZtYsuWLZSXlzNnzhzuuuuuVh/b1+Xdvn07hw8fbnK7sWPHrtdaD3db4WmI8dZMwC5AA/Mb2eZ2+zYaiGxku6udtuvc1Ln79evn1dDqoe7LL7UGrRcuzNJgdjSBk5WVZXYIARXq5d2yZUuztj9y5IifInH3U0mJJitLbykpCcj5zjjjDJ2cnKzLyspqlznKu2bNGh0fH6+joqL0n//8Z33LLbfo4cOHa0CPGjVKV1RUeH2e/Px83a9fPw3ocePG6VtvvVVPnDhRAzojI0Pv2LHDbZ/vvvtOA3rBggWtL6jd6tWr3Y7pKO8jjzyiAW2xWPSAAQN0bGysBnR1dbXPzq+11ocOHXJ8d+iOHTvq7t27a0A/99xzje43fvx43b59e11aWtrqGAL5nvZWcnKyBnSHDh10nz59NKDvuOMOnxzb1+X19jMEWKc95ATSk7EQwlSjf/yRpFWr6Gx/bGoa/eOPrT7n0oMHXR79KTc3l2XLlnHhhRe61cZYrVZmzJhBWVkZb7/9Nq+//jr/+te/+O6775g0aRKrV6/mkUce8fpct99+O7m5udx8880sX76c+++/n/fff5/HHnuMgwcPMmvWLLd9Ro4cyYABA1i0aBE2m63V5QV46qmniIiI4PLLL3dbN378eNasWUNxcTFbt26lY8eOPjlnffHx8Xz66af89ttv7N+/nyuuuMKr/aZNm0ZRURGvv/66X+Iy23/+8x927dpFYWEhd955p9nh+JVZCU6x03x8I9s5rytucCshRMg6oV07qm02Sm02SqzWRqdqm40/tGvX6nO+cuCAy6M/vfjii2itueiii9zWrVixgq1btzJ69GgmTJhQuzwiIqK27cozzzzjqNFuVElJCUuWLCEhIYH58+e7rJs9ezY9evTgiy++YOfOnW77Tp06lT179vDVV181s3Tujhw5wttvv81JJ51Et27d3Nb379+fE044odmX3porOjqa8ePH07lz52bt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SwcOUGazkRARwSnt2/Nk375cn5vL14cPU2qzsXj/fq7zMFZTa02aNIl33nmHL774wm1sLovFwuLFixk3bhyTJ09m8uTJZGZmsnz5ctatW8eoUaO46Sb3q/SOHofrj9103333kZ2dzcMPP8yGDRsYOXIkW7du5YMPPiAjI4OnnnrKY4xffvklFouFiRMnen2uhhx77LH079+f5cuXexybKD8/nzlz5rg8B7jyyitrE7nbbruNAQMGtDgGh/vvv7+2NmbDhg0ALF68uPZW9pNPPpmrrrrKZZ+cnBz27NnjsQFwS+NQSnHttddy8803A0a7HLM8//zzteV3JN0fffRR7ZhgAwYM4LbbbjMtPp9qbrYYzFNbGYvq88/rxqI68USzowmcUB+bqblCvbytGYtqzvbtWmVl6Vu2b/dJLAcrK7XKytLR2dn633v3apvNprXW2maz6af27tXR2dlaZWXpvMpKn5zPWWVlpc7IyNAjR450We5c3p9++klPnjxZp6am6ujoaN23b1991113uYxd5VBYWKgjIiL0qFGjPJ6voKBA33DDDTozM1NHRUXpTp066RkzZuhff/3V4/ZFRUU6NjZWT5w4sdnnasijjz6qAf3pp5+6lfeXX36pHSOqoan+e//888/XEREROicnp1lxnHrqqY2eZ9q0aW77zJ07VwP6xx9/dFt34403akB/9dVXXp3f+TV2/C1jY2N1fn5+s8rhS9OmTWv0b3Lqqae2+NjBNhaV6UmJL6e2kuB89lldgiODbYavUC9vaxKc/KoqfcK6dTq/qsonsaw6dEgP/v57vbmBwTX/V1ysB3//vV516JBPzlfffffdpwH9ww8/1C5r6ZfBBx98oAH9ySef+CS2xx9/XAN61apVPjvX4cOHdVpamp4wYULtspaW12az6dTUVD1lypQW7d8cFRUVukuXLvq0007zuH7o0KFuiWpjnMuclZWlAX3ppZe2Os5gFWwJjgy2GYJ0y7tJECIkpEZFsWbYMJ+0vQE4uX17No4YwTEeehMGODYxkY0jRnCyF7djt8RNN91EZmYmd911V6uPtWLFCoYMGdKqHnYdysvL+ec//8mkSZM8Dq3Q0nO1a9eOu+++mw8//JD169e3KsbNmzdTUFDg1gjbH55++mn279/PQw895Lbu8OHDbNy4scVxOMYWmz17dqtiFN6TNjghSBIc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",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# sol, _ = p_svm_solver(X, torch.diag(torch.ones(d)), torch.tensor([1,1]))\n",
    "colors = ['r','b','g']\n",
    "lines = ['-','-','-']\n",
    "alpha = 1\n",
    "num = 999\n",
    "plt.figure(figsize=(8,6))\n",
    "x = np.arange(0,30)\n",
    "plt.plot(x,sol_opt[1]/sol_opt[0]*x, '--', color='gray', linewidth=3, zorder=-1)\n",
    "print(sol_opt)\n",
    "plt.plot(x,sol[1]/sol[0]*x, 'r--', linewidth=3, zorder=-1)\n",
    "plt.plot(x,sol_v[1]/(sol_v[0]+0.0000001)*x, 'b--', linewidth=3, zorder=-1)\n",
    "ls_loss = []\n",
    "ls_Cs = []\n",
    "plt.plot(ps[:num,0], ps[:num,1], linewidth=3, linestyle='-', color='r', alpha=alpha, zorder=-1)\n",
    "plt.plot(ws[:num,0], ws[:num,1], linewidth=3, linestyle='-', color='b', alpha=alpha, zorder=-1)\n",
    "# for it in range(num-1):\n",
    "#     plt.arrow((ps[it,0]), (ps[it,1]), (ps[it+1,0]-ps[it,0]), (ps[it+1,1]-ps[it,1]), length_includes_head=True,head_width=0.1, head_length=0.1, color='r', linewidth=2, alpha=alpha, zorder=-1)\n",
    "# for i in range(2): # range(len(loss_type)):\n",
    "#     for j in range(len(Cs)-1):\n",
    "#         l, = plt.plot(ps[i,j,:num,0], ps[i,j,:num,1], linewidth=3, linestyle=lines[i], color=colors[i], alpha=0.09* (j+1), zorder=-1)\n",
    "#         if i == 0:\n",
    "#             ls_Cs.append(l)\n",
    "#         if j == len(Cs)-2:\n",
    "#             ls_loss.append(l)\n",
    "#     l, = plt.plot(ps[i,-1,:num,0], ps[i,-1,:num,1], linewidth=3, linestyle='--', color=colors[i], alpha=1, zorder=-1)\n",
    "#     if i == 0:\n",
    "#         ls_Cs.append(l)\n",
    "\n",
    "for i in range(ITN-1):\n",
    "    if (i+1) % 10 == 0:\n",
    "        plt.arrow((ps[i,0]), (ps[i,1]), (ps[i+1,0]-ps[i,0]), (ps[i+1,1]-ps[i,1]), length_includes_head=True,head_width=0.2, head_length=0.2, color=colors[0], linewidth=2, alpha=alpha)\n",
    "        plt.arrow((ws[i,0]), (ws[i,1]), (ws[i+1,0]-ws[i,0]), (ws[i+1,1]-ws[i,1]), length_includes_head=True,head_width=0.2, head_length=0.2, color=colors[1], linewidth=2, alpha=alpha)\n",
    "\n",
    "s11 =plt.scatter(X[0,0,0],X[0,0,1],marker='^',color='g',s=140, label=r'(0,0), y=1', zorder=1)\n",
    "s12 =plt.scatter(X[0,1,0],X[0,1,1],marker='*',color='g',s=220, label=r'(1,1), y=1', zorder=1)\n",
    "s21 =plt.scatter(X[1,0,0],X[1,0,1],marker='v',color='c',s=140, label=r'(0,0), y=-1', zorder=1)\n",
    "s22 =plt.scatter(X[1,1,0],X[1,1,1],marker='*',color='c',s=220, label=r'(1,-1), y=-1', zorder=1)\n",
    "s31 =plt.scatter(X[1,0,0],X[1,0,1],marker='p',color='y',s=140, label=r'(0,0), y=1', zorder=1)\n",
    "s32 =plt.scatter(X[2,1,0],X[2,1,1],marker='*',color='y',s=220, label=f'({X[2,1,0]},{X[2,1,1]}), y=1', zorder=1)\n",
    "plt.xlim([-2,15])\n",
    "plt.ylim([-3,12])\n",
    "labels = [f'(0,0), (1,1), y={Y[0]}',\n",
    "          f'(0,0), (1,-1), y={Y[1]}', \n",
    "          f'(0,0), (0.5,1.5), y={Y[2]}']\n",
    "# plt.legend(fontsize=15, loc='upper right')\n",
    "# # legend1 = plt.legend(ls_Cs, [f'C={Cs[i]}' for i in range(len(Cs))], loc=3, fontsize=15)\n",
    "# legend1 = plt.legend([ls_Cs[0],ls_Cs[4],ls_Cs[-2], ls_Cs[-1]], ['C=1','C=1~10','C=10','C=100'], loc=3, fontsize=15)\n",
    "# legend2 = plt.legend(ls_loss, [r\"loss$=-y\\cdot f(x)$\", r'loss$=log(1+e^{-y\\cdot f(x)})$', r\"loss$=e^{-y\\cdot f(x)}$\"], loc=2, fontsize=15)\n",
    "plt.legend([(s11,s12), (s21,s22), (s31,s32)], labels, fontsize=20, loc='upper right', handler_map = {tuple: matplotlib.legend_handler.HandlerTuple(None)})\n",
    "# plt.gca().add_artist(legend1)\n",
    "# plt.gca().add_artist(legend2)\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.grid()\n",
    "# plt.show()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'joint_relax_converge_v2.pdf')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "python36",
   "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.6.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
