{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 293,
   "id": "f1c27752",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import cvxpy as cp\n",
    "from tqdm.notebook import tqdm\n",
    "import os\n",
    "import matplotlib.animation as animation\n",
    "from moviepy.editor import VideoClip\n",
    "from moviepy.video.io.bindings import mplfig_to_npimage\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 294,
   "id": "a7a1e34f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# !pip install moviepy --upgrade\n",
    "# !pip install ffmpeg --upgrade"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 295,
   "id": "0826b98d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def relu(x):\n",
    "    return np.maximum(0,x)\n",
    "def drelu(x):\n",
    "    return x>=0\n",
    "\n",
    "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_raw=2*np.concatenate((a,b),axis=0)-1\n",
    "y_raw=np.concatenate((np.ones(n//2),-np.ones(n//2)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 296,
   "id": "96f7bc9a",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 4  # Total number of samples\n",
    "d = 3\n",
    "\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",
    "\n",
    "# Generate 4 point XOR dataset\n",
    "X_raw, y_raw = classical_xor_data()\n",
    "# Generate XOR dataset\n",
    "#X, y = xor_data(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 297,
   "id": "1d01aa65",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "index = np.arange(n)\n",
    "np.random.seed(1)\n",
    "np.random.shuffle(index)\n",
    "train_num = n\n",
    "training_data_np = X_raw[index[:train_num],:]\n",
    "training_labels_np = y_raw[index[:train_num]]\n",
    "test_data_np = X_raw[index[train_num:],:]\n",
    "test_labels_np = y_raw[index[train_num:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 298,
   "id": "0b1748ce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8135ef6b1b7c487888a7754ad10242aa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Lasso reg path based on cvxpy\n",
    "p = 1\n",
    "n, Embedding_Size = np.shape(training_data_np)\n",
    "assert Embedding_Size==2, 'wrong input dimension'\n",
    "G = np.zeros([3,n*(n-1)])\n",
    "sampleindexlist = np.zeros([2,n*(n-1)])\n",
    "count = 0\n",
    "for i in range(n):\n",
    "    for j in range(i+1,n):\n",
    "        xi = training_data_np[i]\n",
    "        xj = training_data_np[j]\n",
    "        v = (xi-xj)/np.linalg.norm(xi-xj)\n",
    "        # rotate 90 degrees\n",
    "        v = np.array([v[1],-v[0]])\n",
    "        G[:2,count] = v\n",
    "        G[2,count] = -xj@v\n",
    "        G[:2,count+1] = -v\n",
    "        G[2,count+1] = xi@v\n",
    "        sampleindexlist[:,count] = [i,j]\n",
    "        sampleindexlist[:,count+1] = [i,j]\n",
    "        count+=2\n",
    "training_data_aug = np.concatenate([training_data_np,np.ones([n,1])],axis=1)\n",
    "Embedding_Size += 1\n",
    "\n",
    "dmat= drelu(np.matmul(training_data_aug,G))\n",
    "\n",
    "G = G/np.linalg.norm(G[:-1,:],p,axis=0)\n",
    "X = relu(training_data_aug@G)\n",
    "y = training_labels_np.copy()\n",
    "\n",
    "beta_max = 28.5#np.max(X.T@y)\n",
    "n_betas = 10#300\n",
    "beta_list = [0.1]#beta_max * np.geomspace(1, 5e-8, n_betas)\n",
    "m1=G.shape[1]\n",
    "z =cp.Variable(m1)\n",
    "t = cp.Variable(1)\n",
    "yopt = X@z+t\n",
    "regularization = cp.norm(z,1)\n",
    "\n",
    "params_list = []\n",
    "for e, beta in tqdm(enumerate(beta_list)):\n",
    "    cost=cp.sum_squares(yopt-training_labels_np)+beta*regularization\n",
    "    prob=cp.Problem(cp.Minimize(cost))\n",
    "    cvx_solver = cp.MOSEK\n",
    "    prob.solve(solver=cvx_solver,verbose=False)\n",
    "    z_v, t_v = z._value, t._value\n",
    "    params_list.append([z_v, t_v])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 299,
   "id": "cda42be6",
   "metadata": {},
   "outputs": [],
   "source": [
    "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.meshgrid(x1,x2)\n",
    "# add the bias term\n",
    "Xtest_raw = np.concatenate([Xtest[0].reshape(samp**2,1),Xtest[1].reshape(samp**2,1)],axis=1)\n",
    "Xtest = np.concatenate([Xtest_raw,np.ones(samp**2).reshape(samp**2,1)],axis=1)\n",
    "pos = np.where(y_raw==1)\n",
    "neg = np.where(y_raw==-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 300,
   "id": "c67ba57d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAssAAALGCAYAAACzltwFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAACcsklEQVR4nOzdd1QUZxsF8LvA0qSJSlHELlhQEcXeMJZorIlRY+8x9q6xYO+Kgr13TSzYNTHGmig2jKgIFiwogrGh0hZ2vz/82LjuLnXWndH7O4eTMDv7zjND8TLvMzMylUqlAhERERERaTExdgFERERERGLFsExEREREpAfDMhERERGRHgzLRERERER6MCwTEREREenBsExEREREpAfDMhERERGRHgzLRERERER6MCwTEREREenBsExEREREpAfDMhERERGRHgzLRPTJqVQqY5eQY1KunYiIso9hmSgHunTpAg8PD40PT09P+Pj4oF27djh06JDRavPz88PYsWNFN1a648ePY8yYMQbfjlA+rM0QtS9duhTVq1fHqFGjclWn1Kxbtw4jR4406DZiYmJQpUoVhISEaL02YsQIrFmzJsdjJycno2zZsvD29sa0adNyUyZOnz6Ntm3bomLFimjQoAFWrlyZrT/KMtrPT1UD0efMzNgFEElV2bJl4e/vr/48LS0NT58+xYYNGzB8+HDY2tqibt26Rqww95YsWQIbGxtBx9ywYcMn2Y5QPqxNV+25cfXqVaxcuRLDhw/Htm3bBB1bzO7evYsVK1bgwIEDBtvG48eP0atXL7x580bn66NHj0aLFi3QoEEDlChRItvjy2QybNy4EUuWLMGWLVvQuXNnFCtWLNvjXLlyBT/99BO+/vprDB06FJcvX0ZAQACUSiX69++f6fsz289PUQPR545hmSiHbGxsUKlSJa3l9erVQ40aNbB7927Jh+WyZct+VtvJCUPWtmvXLjRq1AipqalwdXU12HbEZt68eWjWrBmcnZ0FH1upVCI4OBhz587NcD1nZ2c0a9YM8+fPx/Lly7O9HXNzc1StWhW9e/fG+fPncePGjRyF5aVLl8LT0xPz5s0DANStWxepqalYtWoVevToAUtLS53vy+p+GrIGoi8F2zCIBGZubg65XK61fOfOnWjevDnKly+P+vXrIygoCKmpqerXFQoF5s+fj7p166JChQro1asX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YWJpfCciIiISmlhyDsOyhIlleoKIiIhIaGLJOQzLRERERER6MCxLmFimJ4iIiIiEJpacw7AsYWKZniAiIiISmlhyDsMyEREREZEeDMsSJpbpCSIiIiKhiSXnMCxLmFimJ4iIiIiEJpacw7BMRERERKQHw7KEiWV6goiIiEhoYsk5DMsSJpbpCSIiIiKhiSXnMCwTEREREenBsCxhYpmeICIiIhKaWHIOw7KEqVIVxi6BiIiIyCDEknMYliVMZiY3dglEREREBiGWnMOwLGFiaXwnIiIiEppYcg7DMhERERGRHgzLEiaWxnciIiIioYkl5zAsS5hYpieIiIiIhCaWnMOwTERERESkB8OyhIlleoKIiIhIaGLJOQzLEiaW6QkiIiIioYkl5zAsExERERHpwbAsYWKZniAiIiISmlhyDsOyhIlleoKIiIhIaGLJOQzLRERERER6MCxLmFimJ4iIiIiEJpacw7AsYapUhbFLICIiIjIIseQchmUJk5nJjV0CERERkUGIJecwLEuYWBrfiYiIiIQmlpzDsExEREREpAfDsoSJpfGdiIiISGhiyTkMyxImlukJIiIiIqGJJecwLBMRERER6SGZsKxUKhEYGIg6deqgYsWK6NmzJx48eKB3/du3b6Nv376oVq0aatSogcGDB+PJkyca6/j5+cHDw0PjY+TIkYbeFcGIZXqCiIiISGhiyTmSCcvLli3Djh07MH36dPzyyy+QyWTo06cPUlJStNZ9+fIlevTogTx58mDLli1YvXo1Xr58id69eyM5ORkA8PbtWzx58gQrV67E2bNn1R/+/v6fetdyTCzTE0RERERCE0vOkURYTklJwbp16zBo0CDUq1cPnp6eCAgIQGxsLI4dO6a1/h9//IHExETMnj0bpUqVQvny5TFv3jzcvXsXV65cAQBERkZCpVKhcuXKKFCggPrD1tb2U+8eEREREYmUJMLyrVu38O7dO1SvXl29zM7ODmXLlsXFixe11q9RowaWLl0KCwsLrddev34NAIiIiECBAgVgZ2dnuMINTCzTE0RERERCE0vOMTN2AVnx9OlTAICrq6vGcicnJ8TExGit7+bmBjc3N41lK1euhIWFBapWrQrg/Zlla2trDBo0CKGhoXB0dETbtm3RtWtXmJjk/m8IlUqFhISEXI+TkTRn18xXIiIiIpIghbMrlAbMUiqV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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "# Ensure the 'figures' directory exists\n",
    "os.makedirs('./figures', exist_ok=True)\n",
    "\n",
    "# Set seaborn style\n",
    "sns.set(style=\"whitegrid\")\n",
    "\n",
    "# Create the plot\n",
    "fig, ax = plt.subplots(1, 1, figsize=(8, 8))\n",
    "ax.clear()\n",
    "\n",
    "e = 0\n",
    "beta = beta_list[e]\n",
    "z, t = params_list[e]\n",
    "yest_cvx = relu(Xtest @ G) @ z + t\n",
    "pos_cvx = np.where(np.sign(yest_cvx) == 1)\n",
    "neg_cvx = np.where(np.sign(yest_cvx) == -1)\n",
    "\n",
    "# Use more modern and elegant colors and markers\n",
    "ax.scatter(Xtest[pos_cvx, 0], Xtest[pos_cvx, 1], 10, marker='o', c='#ea3323', label='positive decision region')\n",
    "ax.scatter(Xtest[neg_cvx, 0], Xtest[neg_cvx, 1], 10, marker='o', c='#0000f5', label='negative decision region')\n",
    "ax.scatter(X_raw[pos, 0], X_raw[pos, 1], 30, marker='s', c='#2ca02c', label='positive samples')  # Square marker\n",
    "ax.scatter(X_raw[neg, 0], X_raw[neg, 1], 30, marker='D', c='#ff7f0e', label='negative samples')  # Diamond marker\n",
    "\n",
    "# Add title and labels\n",
    "if p==1:\n",
    "    title = r\"Regularization with $\\ell_1$ norm (p=1), $\\lambda$={}, {} neurons\".format(beta, np.sum(np.abs(z) > 1e-4))\n",
    "else:\n",
    "    title = r\"Regularization with $\\ell_2$ norm (p=2), $\\lambda$={}, {} neurons\".format(beta, np.sum(np.abs(z) > 1e-4))\n",
    "ax.set_title(title)\n",
    "ax.set_xlabel(r'$x_1$')\n",
    "ax.set_ylabel(r'$x_2$')\n",
    "# Add a legend\n",
    "\n",
    "draw_breaklines = True\n",
    "if draw_breaklines:\n",
    "    idx = 0\n",
    "    for i in (z_abs>1e-6):\n",
    "        if i==True:\n",
    "            p1 = X_raw[int(sampleindexlist[0,idx])]\n",
    "            p2 = X_raw[int(sampleindexlist[1,idx])]\n",
    "            #draw a line between p1 and p2\n",
    "            ax.plot([p1[0],p2[0]],[p1[1],p2[1]],'m--',linewidth=3)\n",
    "            idx+=1\n",
    "#plot the last one with a label\n",
    "ax.plot([p1[0],p2[0]],[p1[1],p2[1]],'m--',linewidth=3, label = 'breaklines')\n",
    "ax.legend()\n",
    "if p == 1:\n",
    "    fig.savefig('./figures/xor_lasso_l1.pdf', format='pdf', bbox_inches='tight',facecolor='white')\n",
    "else:\n",
    "    fig.savefig('./figures/xor_lasso_l2.pdf', format='pdf', bbox_inches='tight',facecolor='white')\n",
    "\n",
    "# Show plot\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 301,
   "id": "ec6201fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "#for loop over the true indices of (z_abs>1e-6)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 302,
   "id": "b613353d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],\n",
       "       [0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.]])"
      ]
     },
     "execution_count": 302,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "training_data_aug@G"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 303,
   "id": "1bfbc562",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Split the data into training and testing sets\n",
    "train_adam = False\n",
    "\n",
    "if train_adam:\n",
    "\n",
    "    import torch\n",
    "    import torch\n",
    "    import torch.nn as nn\n",
    "    import torch.optim as optim\n",
    "\n",
    "    train_num = n\n",
    "    train_data, test_data, train_labels, test_labels = X_raw, X_raw, y_raw, y_raw\n",
    "\n",
    "    # Convert data to PyTorch tensors\n",
    "    train_data = torch.FloatTensor(train_data)\n",
    "    train_labels = torch.FloatTensor(train_labels).reshape(-1, 1)\n",
    "\n",
    "    # Define the MLP model\n",
    "    class MLP(nn.Module):\n",
    "        def __init__(self):\n",
    "            super(MLP, self).__init__()\n",
    "            self.hidden = nn.Linear(2, 1000)\n",
    "            self.output = nn.Linear(1000, 1)\n",
    "            \n",
    "        def forward(self, x):\n",
    "            x = torch.relu(self.hidden(x))\n",
    "            #x = torch.sigmoid(self.output(x))\n",
    "            return x\n",
    "\n",
    "    # Initialize the model, loss function, and optimizer\n",
    "    model = MLP()\n",
    "    #criterion = nn.BCELoss()\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=0.01, weight_decay=beta_list[0])\n",
    "\n",
    "    # Train the model\n",
    "    num_epochs = 100\n",
    "    #load model to gpu\n",
    "    #load data to gpu\n",
    "    train_data = train_data.cuda()\n",
    "    train_labels = train_labels.cuda()\n",
    "    model = model.cuda()\n",
    "    for epoch in range(num_epochs):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        outputs = model(train_data)\n",
    "        loss = criterion(outputs, (train_labels + 1) / 2)  # convert labels to 0 and 1\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        if (epoch + 1) % 100 == 0:\n",
    "            print(f'Epoch [{epoch + 1}/{num_epochs}], Loss: {loss.item():.4f}')\n",
    "\n",
    "    # Prepare grid for plotting decision boundary\n",
    "    samp = 50\n",
    "    x1 = np.linspace(-1, 1, samp).reshape(-1, 1)\n",
    "    x2 = np.linspace(-1, 1, samp).reshape(-1, 1)\n",
    "    Xtest = np.meshgrid(x1, x2)\n",
    "    Xtest_raw = np.concatenate([Xtest[0].reshape(samp**2, 1), Xtest[1].reshape(samp**2, 1)], axis=1)\n",
    "    Xtest_raw_tensor = torch.FloatTensor(Xtest_raw)\n",
    "\n",
    "    # Predict decision boundary\n",
    "    #mode model to cpu\n",
    "    model = model.cpu()\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        y_pred = model(Xtest_raw_tensor)\n",
    "        \n",
    "    y_pred = (y_pred > 0.5).numpy().astype(int)\n",
    "    pos_cvx = np.where(y_pred == 1)\n",
    "    neg_cvx = np.where(y_pred == 0)\n",
    "\n",
    "    # Ensure the 'figures' directory exists\n",
    "    os.makedirs('./figures', exist_ok=True)\n",
    "\n",
    "    # Set seaborn style\n",
    "    sns.set(style=\"whitegrid\")\n",
    "\n",
    "    # Create the plot\n",
    "    fig, ax = plt.subplots(1, 1, figsize=(8, 8))\n",
    "    ax.clear()\n",
    "\n",
    "    # Plot decision regions and data points\n",
    "    ax.scatter(Xtest_raw[pos_cvx, 0], Xtest_raw[pos_cvx, 1], 10, marker='o', c='#1f77b4', label='positive decision region')\n",
    "    ax.scatter(Xtest_raw[neg_cvx, 0], Xtest_raw[neg_cvx, 1], 10, marker='o', c='#ff7f0e', label='negative decision region')\n",
    "    ax.scatter(X_raw[np.where(y_raw == 1), 0], X_raw[np.where(y_raw == 1), 1], 30, marker='s', c='#2ca02c', label='positive samples')  # Square marker\n",
    "    ax.scatter(X_raw[np.where(y_raw == -1), 0], X_raw[np.where(y_raw == -1), 1], 30, marker='D', c='#d62728', label='negative samples')  # Diamond marker\n",
    "\n",
    "    # Add title and labels\n",
    "    title = r\"$Non-convex NN $\\beta$={:.2e}\".format(beta)\n",
    "    ax.set_title(title)  \n",
    "    ax.set_xlabel(r'$x_1$')\n",
    "    ax.set_ylabel(r'$x_2$')\n",
    "\n",
    "    # Add a legend\n",
    "    ax.legend()\n",
    "\n",
    "    # Save the figure\n",
    "    fig.savefig('./figures/mlp_decision_region.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "    # Show plot\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "99b607d5",
   "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
