{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6d002e08",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import numpy.linalg as la\n",
    "import cvxpy as cp\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import random\n",
    "import time\n",
    "import mosek\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "seed=42\n",
    "random.seed(a=seed)\n",
    "np.random.seed(seed=seed)\n",
    "\n",
    "def relu(x):\n",
    "    return np.maximum(0,x)\n",
    "def drelu(x):\n",
    "    return x>=0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5175c026",
   "metadata": {},
   "outputs": [],
   "source": [
    "n=50 #choose 160 for a challenging case\n",
    "d=3\n",
    "def spiral_xy(i, spiral_num):\n",
    "    \"\"\"\n",
    "    Create the data for a spiral.\n",
    "\n",
    "    Arguments:\n",
    "        i runs from 0 to 96\n",
    "        spiral_num is 1 or -1\n",
    "    \"\"\"\n",
    "    φ = i/16 * math.pi\n",
    "    r = 6.5 * ((104 - i)/104)\n",
    "    x = (r * math.cos(φ) * spiral_num)/13 + 0.5\n",
    "    y = (r * math.sin(φ) * spiral_num)/13 + 0.5\n",
    "    return (x, y)\n",
    "\n",
    "def spiral(spiral_num):\n",
    "    return [spiral_xy(i, spiral_num) for i in range(n//2)]\n",
    "\n",
    "a = spiral(1)\n",
    "b = spiral(-1)\n",
    "X=2*np.concatenate((a,b),axis=0)-1\n",
    "X=np.append(X,np.ones((n,1)),axis=1)\n",
    "y=np.concatenate((np.ones(n//2),-np.ones(n//2)))\n",
    "\n",
    "\n",
    "beta=1e-5\n",
    "P=200\n",
    "\n",
    "np.random.seed(0)\n",
    "dmat=np.empty((n,0))\n",
    "\n",
    "## Finite approximation of all possible sign patterns\n",
    "for i in range(P):\n",
    "    u=np.random.randn(d,1)\n",
    "    dmat=np.append(dmat,drelu(np.dot(X,u)),axis=1)\n",
    "\n",
    "dmat=(np.unique(dmat,axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ce87eb55",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(50, 141)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dmat.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "81b281d2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2-layer convex program objective value:  0.0007843337681135065\n"
     ]
    }
   ],
   "source": [
    "# Optimal CVX\n",
    "m=dmat.shape[1]\n",
    "Uopt1=cp.Variable((d,m)) # c_i in paper\n",
    "Uopt2=cp.Variable((d,m)) # c_i' in paper\n",
    "\n",
    "## Below we use hinge loss as a performance metric for binary classification\n",
    "yopt1=cp.Parameter((n,1))\n",
    "yopt2=cp.Parameter((n,1))\n",
    "yopt1=cp.sum(cp.multiply(dmat,(X*Uopt1)),axis=1)\n",
    "yopt2=cp.sum(cp.multiply(dmat,(X*Uopt2)),axis=1)\n",
    "#cost=cp.sum(cp.pos(1-cp.multiply(y,yopt1-yopt2)))/n+beta*(cp.mixed_norm(Uopt1.T,2,1)+cp.mixed_norm(Uopt2.T,2,1))\n",
    "cost=cp.sum_squares(y-(yopt1-yopt2))/(2*n)+beta*(cp.mixed_norm(Uopt1.T,2,1)+cp.mixed_norm(Uopt2.T,2,1))\n",
    "\n",
    "constraints=[]\n",
    "constraints+=[cp.multiply((2*dmat-np.ones((n,m))),(X*Uopt1))>=0]\n",
    "constraints+=[cp.multiply((2*dmat-np.ones((n,m))),(X*Uopt2))>=0]\n",
    "prob=cp.Problem(cp.Minimize(cost),constraints)\n",
    "prob.solve(solver=cp.CLARABEL,warm_start=True)\n",
    "cvx_opt=prob.value\n",
    "if prob.status != \"optimal\":\n",
    "    print(\"Convex: Status convex: \",prob.status)\n",
    "print(\"2-layer convex program objective value: \",cvx_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b33dd9ef-e3cc-4632-be51-aa62e5a616a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(50, 3)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d4bc6873",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of neurons: 141\n"
     ]
    },
    {
     "data": {
      "image/png": "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jWlbBfugVXDVgO163q6Y/vMJi8ZJRFQTEyEiMouaSVBNT3QJQ5N6Xgjxc8cDi3dZKCoiInWcNUZEkoluEoBG/h548N9VtiPqeWJM98YAgIR3+ksZGhE5CLYIEZHkvprQDXvO30K3iED4ebpg4ePtAVR1scUl35Q4OiKyZ2wR0oHrCBFZjouTHP0jg+Hn6aJ2/OORHbFgRBTq+7gBgM4tRIiITMXd5/Xg7vNERES2x9D7N1uEiIiIyGExESIiIiKHxUSIiIiIHBYTISIiInJYTISIiIjIYTERIiIiIofFREgHriNERERk/7iOkB5cR4iIiMj2cB0hIiIiIj2YCBEREZHDYiJEREREDouJEBERETksJkJERETksJgIERERkcNiIkREREQOi4kQEREROSwmQkREROSwmAjpwC02iIiI7B+32NCDW2wQERHZHm6xQURERKQHEyEiIiJyWEyEiIiIyGExESIiIiKHxUSIiIiIHBYTISIiInJYTISIiIjIYTERIiIiIofFRIiIiIgcFhMhIiIiclhMhIiIiMhhMREiIiIih8VESAfuPk9ERGT/uPu8Htx9noiIyPZw93kiIiIiPZgIERERkcNiIkREREQOi4kQEREROSwmQkREROSwmAgRERGRw2IiRERERA6LiRARERE5LCZCRERE5LCYCBEREZHDYiJEREREDouJEBERETksJkJERETksJgIERERkcNiIkREREQOi4kQEREROSwmQkREROSwmAjpEBsbi8jISHTr1k3qUIiIiMhMZIIgCFIHYc0KCgrg5+eH/Px8+Pr6Sh0OERERGcDQ+zdbhIiIiMhhMREiIiIih8VEiIiIiBwWEyEiIiJyWEyEiIiIyGExESIiIiKHxUSIiIiIHBYTISIiInJYTISIiIjIYTERIiIiIofFRIiIiIgcFhMhIiIiclhMhIiIiMhhMREiIiIih8VEiIiIiBwWEyEiIiJyWEyEiIiIyGExESIiIiKHxUSIiIiIHBYTISIiInJYTISIiIjIYTERIiIiIofFRIiIiIgcFhMhIiIiclhMhIiIiMhhMREiIiIih2X3iVBhYSG6deuGTp06oX379vjyyy+lDomIiIishLPUAZibp6cn9uzZA09PT5SUlCAqKgpPPPEE6tWrJ3VoREREJDG7bxFycnKCp6cnAKC0tBQKhQKCIEgcFREREVkD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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# BP\n",
    "sigma=1e-2\n",
    "mu=0.5\n",
    "print(\"Number of neurons:\",m)\n",
    "mbp=2*m\n",
    "ITERS=15000\n",
    "U=sigma*np.random.randn(d,mbp)\n",
    "w=sigma*np.random.randn(mbp,1)\n",
    "yall=y.reshape(-1,1)\n",
    "obj_bp=np.empty((ITERS,1))\n",
    "batch_size=n\n",
    "nb=batch_size\n",
    "for i in range(ITERS):\n",
    "    if i%8000 == 0 and i>0:\n",
    "        mu=mu/5\n",
    "    samp=np.random.choice(n,batch_size)\n",
    "    Xgd=X[samp,:]\n",
    "    ygd=yall[samp,:]\n",
    "    a1=np.dot(Xgd,U)\n",
    "    yest=np.dot(relu(a1),w)\n",
    "    yest_all=np.dot(relu(np.dot(X,U)),w)\n",
    "    obj_bp[i]=np.linalg.norm(yall-yest_all)**2/(2*n)+(beta/2)*(np.linalg.norm(U,'fro')**2+np.linalg.norm(w,'fro')**2)\n",
    "    gradw= relu(a1).T@(yest-ygd)/nb\n",
    "    gradU=np.zeros((d,mbp))\n",
    "  \n",
    "    gradU=Xgd.T@(drelu(a1)*((yest-ygd)@w.T))/nb\n",
    "\n",
    "    U=(1-mu*beta)*U-mu*gradU\n",
    "    w=(1-mu*beta)*w-mu*gradw\n",
    "    \n",
    "    \n",
    "# Plot\n",
    "plt.figure(0)\n",
    "plt.semilogy(obj_bp,label='GD')\n",
    "plt.axhline(cvx_opt,color='k',label='Optimal')\n",
    "plt.ylabel('Objective value')\n",
    "plt.xlabel('Iteration')\n",
    "plt.legend();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "eff7c9b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 700x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 700x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "samp=100\n",
    "x1=np.linspace(-1,1,samp).reshape(-1,1)\n",
    "x2=np.linspace(-1,1,samp).reshape(-1,1)\n",
    "\n",
    "Xtest=np.ones((samp**2,d))\n",
    "count=0\n",
    "for i in range(samp):\n",
    "    for j in range(samp):\n",
    "        Xtest[count]=[x1[i, 0],x2[j, 0],1]\n",
    "        count+=1\n",
    "\n",
    "ntest=Xtest.shape[0]\n",
    "\n",
    "Uopt1v=Uopt1.value\n",
    "Uopt2v=Uopt2.value\n",
    "\n",
    "yest_cvx=np.sum(drelu(Xtest@Uopt1v)*(Xtest@Uopt1v)-drelu(Xtest@Uopt2v)*(Xtest@Uopt2v),axis=1)\n",
    "yest_bp=np.dot(relu(np.dot(Xtest,U)),w)\n",
    "\n",
    "\n",
    "pos_cvx=np.where(np.sign(yest_cvx)==1)\n",
    "neg_cvx=np.where(np.sign(yest_cvx)==-1)\n",
    "pos_bp=np.where(np.sign(yest_bp)==1)\n",
    "neg_bp=np.where(np.sign(yest_bp)==-1)\n",
    "pos=np.where(y==1)\n",
    "neg=np.where(y==-1)\n",
    "\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(7, 3))\n",
    "\n",
    "ax1.plot(Xtest[pos_cvx,0],Xtest[pos_cvx,1],'co');\n",
    "ax1.plot(Xtest[neg_cvx,0],Xtest[neg_cvx,1],'mo');\n",
    "ax2.plot(X[pos,0],X[pos,1],'cx');\n",
    "ax2.plot(X[neg,0],X[neg,1],'mx');\n",
    "ax2.set_yticklabels([])\n",
    "#ax1.set_title(\"2-layer Convex\")\n",
    "plt.savefig('convex.pdf', bbox_inches='tight')\n",
    "\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(7, 3))\n",
    "ax1.plot(Xtest[pos_bp,0],Xtest[pos_bp,1],'co');\n",
    "ax1.plot(Xtest[neg_bp,0],Xtest[neg_bp,1],'mo');\n",
    "ax2.plot(X[pos,0],X[pos,1],'cx');\n",
    "ax2.plot(X[neg,0],X[neg,1],'mx');\n",
    "ax2.set_yticklabels([])\n",
    "#ax1.set_title(\"2-layer GD\")\n",
    "plt.savefig('sgd.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a0827602",
   "metadata": {},
   "outputs": [],
   "source": [
    "### NEW ###\n",
    "\n",
    "N = len(y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4e6b903e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3, 141)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Uopt2.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7fbbcce8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.00047115055326997523"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "beta*(np.sum(np.linalg.norm(Uopt1.value.T,2,axis=0)+np.linalg.norm(Uopt2.value.T,2,axis=0)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e5f4d565",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sign(a):\n",
    "    return 2 * int(a >= 0) - 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fb79a768",
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute analytic center\n",
    "def center(S, R=1, boxinit=False, reg=False, reg_value=2e-4):\n",
    "    \"\"\"S is list of affine inequalities described as tuple of LHS vector/matrix and RHS scalar/vector\"\"\"\n",
    "    s = cp.Variable(2*d*m)\n",
    "    obj = 0 if boxinit else cp.log(R - cp.norm(s))\n",
    "    constraints = []\n",
    "    if reg:\n",
    "        U = cp.reshape(s, (2*d, m), order='F')\n",
    "        #obj += cp.log(reg_value - beta*(cp.mixed_norm(U[:d].T,2,1)+cp.mixed_norm(U[d:].T,2,1)))\n",
    "        constraints = [beta*(cp.mixed_norm(U[:d].T,2,1)+cp.mixed_norm(U[d:].T,2,1)) <= reg_value]\n",
    "    if len(S) > 0:\n",
    "        obj += cp.sum([cp.log(rhs - lhs @ s) for lhs, rhs in S])\n",
    "    prob = cp.Problem(cp.Maximize(obj), constraints)\n",
    "    #prob.solve(solver=cp.ECOS)\n",
    "    prob.solve(solver=cp.MOSEK)\n",
    "    return s.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "94add25d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# cut set\n",
    "def cut(S, x, y, dmat_row):\n",
    "    m = len(dmat_row)\n",
    "    # f = cp.sum(cp.multiply(dmat, X*(Uopt1 - Uopt2)), axis=1)\n",
    "    # f_i = dmat[i, 0] * X[i, :] [I - I] var[:, 0] + dmat[i, 1] * X[i, :] [I - I] var[:, 1] + ...  where var = [Uopt1; Uopt2]\n",
    "    # f_i = dmat[i, :] @ [X[i, :] [I - I] var[:, 0]; X[i, :] [I - I] var[:, 1]; ...]\n",
    "    S.append((-y * dmat_row @ np.kron(np.eye(m), np.concatenate((x, -x)).T), 0))\n",
    "    \n",
    "    relu_constraint = -np.kron(np.diag(2*dmat_row-np.ones(m)), np.kron(np.eye(2), x))\n",
    "    for lhs in relu_constraint:\n",
    "        S.append((lhs, 0))\n",
    "    # potentially remove redundant constraints here"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "754b9a43",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pred_point(i, U1v, U2v): # corresponds to <w(theta), x>\n",
    "    y1 = np.sum(np.multiply(dmat[i],(X[i][np.newaxis, :] @ U1v)),axis=1)\n",
    "    y2 = np.sum(np.multiply(dmat[i],(X[i][np.newaxis, :] @ U2v)),axis=1)\n",
    "    return y1 - y2\n",
    "\n",
    "def pred_point_simplified(i, U1v, U2v):\n",
    "    var = np.vstack((U1v, U2v)).flatten(order='F')\n",
    "    return (dmat[i] @ np.kron(np.eye(len(dmat[i])), np.concatenate((X[i], -X[i])).T)) @ var\n",
    "\n",
    "def pred_point_simplified_vec(i, vec):\n",
    "    return (dmat[i] @ np.kron(np.eye(len(dmat[i])), np.concatenate((X[i], -X[i])).T)) @ vec"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "395237cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.99943778])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# check that simplification is correct\n",
    "\n",
    "pred_point(3, Uopt1v, Uopt2v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "5c23f368",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9994377816571927"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pred_point_simplified(3, Uopt1v, Uopt2v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "24336288",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9994377816571927"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vec = np.vstack((Uopt1v, Uopt2v)).flatten(order='F')\n",
    "pred_point_simplified_vec(3, vec)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "8c7cbfab",
   "metadata": {},
   "outputs": [],
   "source": [
    "def constraint(i, U1v, U2v):\n",
    "    return np.vstack((\n",
    "        np.multiply((2*dmat[i]-np.ones((1,m))),(X[i] @ U1v)),\n",
    "        np.multiply((2*dmat[i]-np.ones((1,m))),(X[i] @ U2v))\n",
    "    )).flatten(order='F')\n",
    "\n",
    "def constraint_simplified(i, U1v, U2v):\n",
    "    var = np.vstack((U1v, U2v)).flatten(order='F')\n",
    "    return np.kron(np.diag(2*dmat[i]-np.ones(m)), np.kron(np.eye(2), X[i])) @ var"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "7af6f3a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def in_Ct(c, Ct, eps=1e-3):\n",
    "    for lhs, rhs in Ct:\n",
    "        if lhs @ c > rhs + eps:\n",
    "            return False\n",
    "    return True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "6d7f81fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "a3c685f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_lattice(S, R=1):\n",
    "    d = 3\n",
    "    l = cp.Variable(2*d*m)\n",
    "    d = np.random.randn(2*d*m)\n",
    "    obj = (d / np.linalg.norm(d)) @ l\n",
    "    prob = cp.Problem(cp.Maximize(obj), [cp.norm(l) <= R] + [lhs @ l <= rhs for lhs, rhs in S])\n",
    "    prob.solve(cp.MOSEK)\n",
    "    return l.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a6bf2cf5",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = 1\n",
    "\n",
    "C0_lower = -R*np.ones(2*d*m)\n",
    "C0_upper = R*np.ones(2*d*m)\n",
    "\n",
    "def sample_classifier(Ct, c, maxiter=10**5):\n",
    "    for _ in range(maxiter):\n",
    "        #candidate = np.random.uniform(C0_lower, C0_upper)\n",
    "        candidate = c + np.random.randn(*c.shape)\n",
    "        if in_Ct(candidate, Ct):\n",
    "            return candidate\n",
    "    print(f'Failed to sample after {maxiter} tries.')\n",
    "    return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "744953ae",
   "metadata": {},
   "outputs": [],
   "source": [
    "def query(C, c, data_skip, M=100):\n",
    "        \n",
    "    mini = np.inf\n",
    "    i_mini = -1\n",
    "    \n",
    "    maxi = -np.inf\n",
    "    i_maxi = -1\n",
    "    \n",
    "    minabs = np.inf\n",
    "    i_minabs = -1\n",
    "    \n",
    "    #theta_s = np.zeros(2*d*m)\n",
    "    #for _ in range(M):\n",
    "    #    #th = sample_classifier(C, c)\n",
    "    #    th = sample_lattice(C)\n",
    "    #    if th is None:\n",
    "    #        return None, None\n",
    "    #    theta_s += (1/M) * th\n",
    "        \n",
    "    #theta_matrix = np.reshape(c, (2*d, m), order='F')\n",
    "    #U1_query=theta_matrix[:d]\n",
    "    #U2_query=theta_matrix[d:]\n",
    "    \n",
    "    for i in range(N): # search in finite data (D implicit) set to re-use dmat then\n",
    "        if i not in data_skip:\n",
    "            pred = pred_point_simplified_vec(i, c)\n",
    "            if pred < mini:\n",
    "                i_mini = 1*i\n",
    "                mini = pred\n",
    "            if pred > maxi:\n",
    "                i_maxi = 1*i\n",
    "                maxi = pred\n",
    "            if abs(pred) < minabs:\n",
    "                i_minabs = 1*i\n",
    "                minabs = abs(pred)\n",
    "    \n",
    "    return i_mini, i_maxi, i_minabs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "42a5cc24",
   "metadata": {},
   "outputs": [],
   "source": [
    "# final convex solve\n",
    "\n",
    "def convex_solve(used):\n",
    "\n",
    "    used_unique = list(set(used))\n",
    "\n",
    "    Uopt1_final=cp.Variable((d,m)) # c_i in paper\n",
    "    Uopt2_final=cp.Variable((d,m)) # c_i' in paper\n",
    "\n",
    "    yopt1_final=cp.sum(cp.multiply(dmat[used_unique],(X[used_unique]*Uopt1_final)),axis=1)\n",
    "    yopt2_final=cp.sum(cp.multiply(dmat[used_unique],(X[used_unique]*Uopt2_final)),axis=1)\n",
    "\n",
    "    cost=cp.sum_squares(y[used_unique]-(yopt1_final-yopt2_final))/(2*n)+beta*(cp.mixed_norm(Uopt1_final.T,2,1)+cp.mixed_norm(Uopt2_final.T,2,1))\n",
    "\n",
    "    constraints=[]\n",
    "    constraints+=[cp.multiply((2*dmat[used_unique]-np.ones((len(used_unique),m))),(X[used_unique]*Uopt1_final))>=0]\n",
    "    constraints+=[cp.multiply((2*dmat[used_unique]-np.ones((len(used_unique),m))),(X[used_unique]*Uopt2_final))>=0]\n",
    "    prob_final=cp.Problem(cp.Minimize(cost),constraints)\n",
    "    prob_final.solve(solver=cp.CLARABEL,warm_start=True)\n",
    "    \n",
    "    return Uopt1_final.value, Uopt2_final.value, beta*(cp.mixed_norm(Uopt1_final.value.T,2,1)+cp.mixed_norm(Uopt2_final.value.T,2,1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "48388dbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# cutting plane method\n",
    "\n",
    "def cutting_plane(n_points=100, maxit=100, boxinit=False):\n",
    "    \n",
    "    data_tried = []\n",
    "    data_used = []\n",
    "    \n",
    "    Ct = []\n",
    "    if boxinit:\n",
    "        for i, (l, u) in enumerate(zip(C0_lower, C0_upper)):\n",
    "            one_vec = np.zeros(2*d*m)\n",
    "            one_vec[i] = 1\n",
    "            Ct.append((one_vec, u))\n",
    "            Ct.append((-one_vec, -l))\n",
    "    \n",
    "    c = None\n",
    "    did_cut = True\n",
    "    it = 0\n",
    "    while len(data_used) < n_points and it < maxit: # TODO: replace by proper termination criterion\n",
    "        if did_cut:\n",
    "            #if len(data_used) > 0:\n",
    "            #    _, _, reg_value = convex_solve(data_used)\n",
    "            #else:\n",
    "            #    reg_value = 1e-5\n",
    "            c = center(Ct, R=R)\n",
    "            did_cut = False\n",
    "        i_mini, i_maxi, i_minabs = query(Ct, c, data_tried)\n",
    "        if i_mini is None:\n",
    "            return Ct, c, data_used\n",
    "        data_tried += [i_mini, i_maxi]\n",
    "        #if it >= 30:\n",
    "        #    print(X[i_mini], np.sign(pred_point_simplified_vec(i_mini, c)), y[i_mini])\n",
    "        #    print(X[i_maxi], np.sign(pred_point_simplified_vec(i_maxi, c)), y[i_maxi])\n",
    "            #print(X[i_minabs], np.sign(pred_point_simplified_vec(i_minabs, c)), y[i_minabs])\n",
    "        if True: #len(data_used) < 4 * n_points // 5:\n",
    "            if np.sign(pred_point_simplified_vec(i_mini, c)) != y[i_mini]:\n",
    "                print(f'Cutting at iteration {it}')\n",
    "                cut(Ct, X[i_mini], y[i_mini], dmat[i_mini])\n",
    "                data_used.append(i_mini)\n",
    "                did_cut = True\n",
    "            if np.sign(pred_point_simplified_vec(i_maxi, c)) != y[i_maxi]:\n",
    "                print(f'Cutting at iteration {it}')\n",
    "                cut(Ct, X[i_maxi], y[i_maxi], dmat[i_maxi])\n",
    "                data_used.append(i_maxi)\n",
    "                did_cut = True\n",
    "        else:\n",
    "            if np.sign(pred_point_simplified_vec(i_minabs, c)) != y[i_minabs]:\n",
    "                print(f'Cutting at iteration {it}')\n",
    "                cut(Ct, X[i_minabs], y[i_minabs], dmat[i_minabs])\n",
    "                data_used.append(i_minabs)\n",
    "                did_cut = True\n",
    "        it += 1\n",
    "    \n",
    "    return Ct, c, data_used"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "19499960",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cutting at iteration 0\n",
      "Cutting at iteration 0\n",
      "Cutting at iteration 2\n",
      "Cutting at iteration 2\n",
      "Cutting at iteration 3\n",
      "Cutting at iteration 8\n",
      "Cutting at iteration 9\n",
      "Cutting at iteration 9\n",
      "Cutting at iteration 15\n",
      "Cutting at iteration 16\n",
      "Cutting at iteration 19\n",
      "Cutting at iteration 20\n",
      "Cutting at iteration 22\n",
      "Cutting at iteration 23\n",
      "size of C: 3962\n",
      "used: [0, 0, 26, 41, 16, 21, 5, 34, 24, 47, 46, 29, 18, 42]\n"
     ]
    }
   ],
   "source": [
    "C, c, used = cutting_plane(15)\n",
    "print(f'size of C: {len(C)}')\n",
    "print(f'used: {used}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "id": "8375755d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def visualize(Uopt1v, Uopt2v, title):\n",
    "\n",
    "    yest_cvx=np.sum(drelu(Xtest@Uopt1v)*(Xtest@Uopt1v)-drelu(Xtest@Uopt2v)*(Xtest@Uopt2v),axis=1)\n",
    "    yest_bp=np.dot(relu(np.dot(Xtest,U)),w)\n",
    "\n",
    "\n",
    "    pos_cvx=np.where(np.sign(yest_cvx)==1)\n",
    "    neg_cvx=np.where(np.sign(yest_cvx)==-1)\n",
    "    pos_bp=np.where(np.sign(yest_bp)==1)\n",
    "    neg_bp=np.where(np.sign(yest_bp)==-1)\n",
    "    pos=np.where(y==1)\n",
    "    neg=np.where(y==-1)\n",
    "\n",
    "\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(7, 3))\n",
    "\n",
    "    ax1.plot(Xtest[pos_cvx,0],Xtest[pos_cvx,1],'co');\n",
    "    ax1.plot(Xtest[neg_cvx,0],Xtest[neg_cvx,1],'mo');\n",
    "    ax2.plot(X[pos,0],X[pos,1],'cx');\n",
    "    ax2.plot(X[neg,0],X[neg,1],'mx');\n",
    "    ax2.set_yticklabels([])\n",
    "    #ax1.set_title(\"2-layer GD\")\n",
    "    plt.savefig(f'{title}.pdf', bbox_inches='tight', dpi=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "id": "1dae24eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "theta_matrix = np.reshape(c, (2*d, m), order='F')\n",
    "visualize(theta_matrix[:d], theta_matrix[d:], 'pre_norefine')\n",
    "\n",
    "Uopt1_final_v, Uopt2_final_v, _ = convex_solve(used)\n",
    "visualize(Uopt1_final_v, Uopt2_final_v, 'post_norefine')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2988053a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cs224n",
   "language": "python",
   "name": "cs224n"
  },
  "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
