{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 445,
   "id": "6d002e08",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "False"
      ]
     },
     "execution_count": 445,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import cvxpy as cp\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import random\n",
    "import torch\n",
    "from torch import nn, optim\n",
    "import seaborn as sns\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "import os\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"1\"\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\n",
    "torch.cuda.is_available()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 446,
   "id": "5175c026",
   "metadata": {},
   "outputs": [],
   "source": [
    "n=160 #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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 447,
   "id": "012bcbd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "xor_data = False\n",
    "\n",
    "if xor_data:\n",
    "    n = 100  # Total number of samples\n",
    "    d = 3\n",
    "\n",
    "    # Generate XOR data\n",
    "    def xor_data(n):\n",
    "        \"\"\"\n",
    "        Generate XOR data points centered in [-1, 1].\n",
    "        \n",
    "        Arguments:\n",
    "            n: Total number of points (must be even for balanced classes).\n",
    "        \"\"\"\n",
    "        # Half of the points per quadrant\n",
    "        n_per_quadrant = n // 4\n",
    "        \n",
    "        # Generate points for each quadrant\n",
    "        q1 = np.random.rand(n_per_quadrant, 2) / 2\n",
    "        q2 = np.random.rand(n_per_quadrant, 2) / 2 + [0.5, 0]\n",
    "        q3 = np.random.rand(n_per_quadrant, 2) / 2 + [0, 0.5]\n",
    "        q4 = np.random.rand(n_per_quadrant, 2) / 2 + [0.5, 0.5]\n",
    "        \n",
    "        # Combine all points\n",
    "        X = np.vstack([q1, q4, q2, q3])\n",
    "        \n",
    "        # Center the data in the range [-1, 1]\n",
    "        X = 2 * X - 1\n",
    "        \n",
    "        # Assign labels: 1 for points in q1 and q4, -1 for points in q2 and q3\n",
    "        y = np.hstack([np.ones(n_per_quadrant), np.ones(n_per_quadrant), -1*np.ones(n_per_quadrant), -1*np.ones(n_per_quadrant)])\n",
    "        \n",
    "        # Add a bias term\n",
    "        X = np.append(X, np.ones((n, 1)), axis=1)\n",
    "        \n",
    "        return X, y\n",
    "    # Generate classical XOR data\n",
    "    def classical_xor_data():\n",
    "        \"\"\"\n",
    "        Generate the classical XOR data points centered in [-1, 1].\n",
    "        \n",
    "        Returns:\n",
    "            X: A numpy array of shape (4, 3) containing the XOR input data with a bias term.\n",
    "            y: A numpy array of shape (4,) containing the XOR labels.\n",
    "        \"\"\"\n",
    "        # Define the four XOR points\n",
    "        X = np.array([\n",
    "            [-1, -1],\n",
    "            [-1,  1],\n",
    "            [ 1, -1],\n",
    "            [ 1,  1]\n",
    "        ])\n",
    "        \n",
    "        # Define the corresponding labels for XOR\n",
    "        y = np.array([-1, 1, 1, -1])\n",
    "        \n",
    "        # Add a bias term (column of ones)\n",
    "        X = np.append(X, np.ones((4, 1)), axis=1)\n",
    "        \n",
    "        return X, y\n",
    "\n",
    "    # Generate 4 point XOR dataset\n",
    "    X, y = xor_data(n=n)\n",
    "\n",
    "    # Generate XOR dataset\n",
    "    #X, y = xor_data(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 448,
   "id": "81b281d2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2-layer convex program objective value:  0.20336382502779088\n",
      "number of neurons (m*):  16\n"
     ]
    }
   ],
   "source": [
    "# Optimal Convex Neural Network\n",
    "p_regularization = 1\n",
    "beta=0.01 #weight decay regularization \n",
    "P=5000 #number of random hyperplane arrangements\n",
    "dmat=np.empty((n,0))\n",
    "## Approximation of all possible sign patterns via random sampling\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)) #remove duplicate patterns\n",
    "m=dmat.shape[1]\n",
    "Uopt1=cp.Variable((d,m))\n",
    "Uopt2=cp.Variable((d,m))\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",
    "if p_regularization == 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",
    "else:\n",
    "    cost=cp.sum_squares(y-(yopt1-yopt2))/(2*n)+beta*(cp.mixed_norm(Uopt1.T,2,1)+cp.mixed_norm(Uopt2.T,1,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.MOSEK,warm_start=True)\n",
    "cvx_opt=prob.value\n",
    "num_tol = 1e-4\n",
    "mstar = np.sum(np.linalg.norm(Uopt1v, axis=0)/np.linalg.norm(Uopt1v,ord=np.inf)>num_tol)+np.sum(np.linalg.norm(Uopt2v, axis=0)/np.linalg.norm(Uopt1v,ord=np.inf)>num_tol)\n",
    "\n",
    "\n",
    "#mstar=m\n",
    "if prob.status != \"optimal\":\n",
    "    print(\"Convex: Status convex: \",prob.status)\n",
    "print(\"2-layer convex program objective value: \",cvx_opt)\n",
    "print(\"number of neurons (m*): \", mstar)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 449,
   "id": "8ca469ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40000\n",
      "3\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x560 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# Plot the decision region of the Convex Neural Network classifier\n",
    "samp=200\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",
    "print(len(Xtest))\n",
    "print(len(Xtest[0]))\n",
    "count=0\n",
    "for i in range(samp):\n",
    "    for j in range(samp):\n",
    "        Xtest[count,0]= x1[i]\n",
    "        Xtest[count,1]= x2[j]\n",
    "        Xtest[count,2]=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",
    "\n",
    "pos_cvx=np.where(np.sign(yest_cvx)==1)\n",
    "neg_cvx=np.where(np.sign(yest_cvx)==-1)\n",
    "pos=np.where(y==1)\n",
    "neg=np.where(y==-1)\n",
    "\n",
    "# fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "\n",
    "plt.figure()\n",
    "\n",
    "#sns.set(style=\"whitegrid\")\n",
    "# plt.plot(Xtest[pos_cvx,0],Xtest[pos_cvx,1],'ro');\n",
    "# plt.plot(Xtest[neg_cvx,0],Xtest[neg_cvx,1],'bo');\n",
    "# plt.plot(X[pos,0],X[pos,1],'rx');\n",
    "# plt.plot(X[neg,0],X[neg,1],'bx');\n",
    "if p_regularization == 1:\n",
    "    plt.title(\"Regularization with $\\ell_1$ norm (p=1), $\\lambda$={}, {} neurons\".format(beta,mstar))\n",
    "else:\n",
    "    plt.title(\"Regularization with $\\ell_2$ norm (p=2), $\\lambda$={}, {} neurons\".format(beta,mstar))\n",
    "plt.scatter(Xtest[pos_cvx, 0], Xtest[pos_cvx, 1], 10, marker='o', c='#ea3323', label='positive decision region')\n",
    "plt.scatter(Xtest[neg_cvx, 0], Xtest[neg_cvx, 1], 10, marker='o', c='#0000f5', label='negative decision region')\n",
    "plt.scatter(X[pos, 0], X[pos, 1], 30, marker='s', c='#2ca02c', label='positive samples')  # Square marker\n",
    "plt.scatter(X[neg, 0], X[neg, 1], 30, marker='D', c='#ff7f0e', label='negative samples')  # Diamond marker\n",
    "\n",
    "# title = r\"$\\|z\\|_0=${} $\\beta$={:.2e}\".format(np.sum(np.abs(z) > 1e-2), beta)\n",
    "\n",
    "plt.xlabel(r'$x_1$')\n",
    "plt.ylabel(r'$x_2$')\n",
    "# Add a legend\n",
    "plt.legend()\n",
    "\n",
    "#save image to a file titled reg_$p and beta_$beta\n",
    "plt.savefig('figures/reg_p_{}_beta_{}_n_{}.pdf'.format(p_regularization, beta, n), bbox_inches='tight', facecolor='white')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 450,
   "id": "3e9459b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "run_torch = False\n",
    "if run_torch:\n",
    "    # Train the same two layer neural network using Pytorch\n",
    "    device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "    learning_rate = 1e-2\n",
    "    lambda_l2 = 1e-7\n",
    "    #m=350\n",
    "    m1=100\n",
    "    #m2=m\n",
    "    m2=20\n",
    "    m3=20\n",
    "    #m4=30\n",
    "    # nn package to create our linear model\n",
    "    # each Linear module has a weight and bias\n",
    "    Xtorch = torch.tensor(X).to(device)\n",
    "    ytorch = torch.tensor(y).to(device)\n",
    "    Xtorch = Xtorch.float()\n",
    "    ytorch = ytorch.float()\n",
    "\n",
    "    model = nn.Sequential(\n",
    "        nn.Linear(d, m1),\n",
    "        nn.ReLU(),\n",
    "        nn.Linear(m1, m2),\n",
    "        nn.ReLU(),\n",
    "        # nn.Linear(m2, m3),    \n",
    "        # nn.ReLU(),\n",
    "    #     nn.Linear(m3, m4),    \n",
    "    #     nn.ReLU(),  \n",
    "    #     nn.Linear(m4, m5),    \n",
    "    #     nn.ReLU(),    \n",
    "    #     nn.Linear(m, m),\n",
    "    #     nn.ReLU(),\n",
    "    #     nn.Linear(m, m),\n",
    "    #     nn.ReLU(),\n",
    "    #     nn.Linear(m, m),\n",
    "    #     nn.ReLU(),\n",
    "        nn.Linear(m3, 1)\n",
    "    )\n",
    "    model.to(device)\n",
    "\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=learning_rate, weight_decay=lambda_l2) # built-in L2\n",
    "    #optimizer = torch.optim.SGD(model.parameters(), lr=learning_rate, weight_decay=lambda_l2) # built-in L2\n",
    "\n",
    "    # Training\n",
    "    num_epochs = 10000\n",
    "    LOG_EVERY_N = 2000\n",
    "    for t in range(num_epochs):\n",
    "        # Feed forward to get the logits\n",
    "        y_pred = model(Xtorch)\n",
    "        # Compute the loss and accuracy\n",
    "        loss = torch.sum((torch.squeeze(y_pred)-ytorch)**2)\n",
    "        predicted = 2*(y_pred>=0)-1\n",
    "        acc = (ytorch == predicted.squeeze().float()).float().sum() / len(ytorch)\n",
    "        if (t % LOG_EVERY_N) == 0:\n",
    "            print(\"[EPOCH]: %i, [LOSS]: %.6f, [ACCURACY]: %.3f\" % (t, loss.item(), acc))\n",
    "        #display.clear_output(wait=True)\n",
    "        # zero the gradients before running\n",
    "        # the backward pass.\n",
    "        optimizer.zero_grad()\n",
    "        # Backward pass to compute the gradient\n",
    "        # of loss w.r.t our learnable params. \n",
    "        loss.backward()\n",
    "        # Update params\n",
    "        optimizer.step()\n",
    "    # plot decision region\n",
    "    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],x2[j],1]\n",
    "            count+=1\n",
    "\n",
    "    ntest=Xtest.shape[0]\n",
    "    Xtesttorch = torch.tensor(Xtest).to(device)\n",
    "    Xtesttorch = Xtesttorch.float()\n",
    "\n",
    "    yest_torch=model(Xtesttorch).cpu().detach().numpy()\n",
    "\n",
    "    pos_torch=np.where(np.sign(yest_torch)==1)\n",
    "    neg_torch=np.where(np.sign(yest_torch)==-1)\n",
    "    pos=np.where(y==1)\n",
    "    neg=np.where(y==-1)\n",
    "\n",
    "\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "\n",
    "    ax1.plot(Xtest[pos_torch,0],Xtest[pos_torch,1],'ro');\n",
    "    ax1.plot(Xtest[neg_torch,0],Xtest[neg_torch,1],'go');\n",
    "    ax2.plot(X[pos,0],X[pos,1],'rx');\n",
    "    ax2.plot(X[neg,0],X[neg,1],'gx');\n",
    "    ax1.set_title(\"2-layer Torch\")\n",
    "\n",
    "    # two layer 100 neurons doesn't work well, but two layers 100 neurons each works well.\n"
   ]
  },
  {
   "cell_type": "raw",
   "id": "d747246a",
   "metadata": {},
   "source": [
    "ytorch == predicted.squeeze()).float().sum()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 451,
   "id": "26bfb61f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f86d56befa0>]"
      ]
     },
     "execution_count": 451,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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cpSZmRkf7/znY+PZGGOiScY6D/fmm2/qnnvuUX9/v773ve/pQx/60Bg/YXJIxjq/+eab+va3v63q6uoL6j5RJWOd09PTJUmf/OQn9ed//ueSpOuvv17vv/++/uEf/kEbNmxImKKaKJKx1tLgFN/tt9+uz3/+85IGa93R0aHHHntMd9xxh4LBidUncFHnkdj6LpxY/yUsiLXS2traEh5va2u7oP0lSfn5+RccGw6HdebMGc2cOVPTpk1TTk7OZcezMcZEk4x1jjl27JjuvPNOZWZmqqamRrNnz77yD+pYMtb5xRdfVFdXl1avXq3Fixdr8eLFqq+v1wsvvKDFixfr5MmT4/7cfkvGOk+bNk2ZmZmaP39+wjHXXXeduru79f7771/Zh3UsGWv9/vvv68SJE7rpppsSjikqKtKZM2d05syZK/qsLrmo80hsfRdOumCzYMECTZkyRUeOHIk/dvbsWR0/flw333zzBccXFxertbU1YW9/7LVLlixRIBDQkiVL9O///u8Jrzty5Ig+9rGPWRtjoknGOkuD1/z40pe+pOuuu0779++/YM54oknGOldUVOjHP/6xnn/++fivG2+8UStWrNDzzz+vGTNm2CuAT5KxzqFQSEuWLNFrr72WMMbrr7+u3NxcTZs2bXwf2pFkrPW0adOUnZ2t119/PWGMX//618rNzdWHP/zhcX5q/7mo80isfReOev9UCtmxY4f5+Mc/bn7yk5/E9+5/5jOfMX19fSYSiZi2tjbT09NjjDEmGo2aO++805SXl5vXXnvNHD582Cxfvtw8+OCD8fFefvllc/3115t9+/aZpqYm89hjj5lFixbFt8XZGGMiSrY69/f3m7KyMnPrrbeat956y7S1tcV/tbe3+18gS5KtzhdTUVExobd7G5Ocdf75z39urr/+elNVVWVaWlrMiy++aD72sY+Zxx9/3N/iWJaMtd6xY4dZvHixee6558xbb71lnnvuObN48WKzZ88ef4tjkd91Pt/y5csv2O5t47twUgabSCRi/uZv/saUlJSYoqIis3btWvP2228bY4x5++23zfz5801dXV38+Pfee8+sX7/eFBUVmU984hPmm9/8punt7U0Y87nnnjNlZWXmpptuMuXl5eaVV15JeN7GGBNNstX52LFjZv78+Rf9tXz5co+r4Z1kq/PFpEKwSdY6Hzp0yJSXl5sbbrjBLFu2zHznO98xAwMDHlXBH8lY60gkYvbt22c++9nPmsLCQrNy5Uqzf//+hGsITTQu6jzcxYLNWMe4mIAxxoy+vwMAAJC8Jt0aGwAAkLoINgAAIGUQbAAAQMog2AAAgJRBsAEAACmDYAMAAFIGwQYAAKQMgg0AAEgZBBsAAJAyCDYAACBlEGwAAEDKINgAAICU8f8B949Z1DalrvcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x560 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "tt = np.linspace(1e-3, 1e-8, 100)\n",
    "arr = []\n",
    "for t in tt:\n",
    "    arr.append(np.sum(np.linalg.norm(Uopt1v, axis=0)>t)+np.sum(np.linalg.norm(Uopt2v, axis=0)>t))\n",
    "plt.plot(tt, arr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8213c867",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1f69b2cb",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.9.13"
  },
  "vscode": {
   "interpreter": {
    "hash": "f20620e545ddc3c3c7e57464323de3fd5a7744283720cb78d51986061cf26ae2"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
