{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "code_folding": []
   },
   "outputs": [],
   "source": [
    "from dist_sketching_dpp_functions import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# all inputs\n",
    "figure_no = 2 # pick from 1,2,3,4\n",
    "dataset_name = \"boston\" # pick from \"boston\", \"cifar\", \"statlog-australian-credit\", \"ionosphere\", \"breast-cancer-wisc\"\n",
    "\n",
    "m = 20\n",
    "sketch_type = \"gaus\" # pick from \"gaus\", \"unif\", \"surrogate_p1\", \"none\" # this is for figure 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "code_folding": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset dimensions are: A=(506, 13), y=(506, 1)\n"
     ]
    }
   ],
   "source": [
    "# load dataset\n",
    "A, y = dataset_loader(dataset_name)\n",
    "n, d = A.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "# diabetes\n",
    "import sklearn\n",
    "A, y = sklearn.datasets.load_diabetes(return_X_y=True)\n",
    "y = np.expand_dims(y, axis=1)\n",
    "n, d = A.shape\n",
    "\n",
    "dataset_name = \"diabetes\"\n",
    "print(A.shape, y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "# monks-1\n",
    "dataset = \"monks-1\" #\"monks-1\", \"echocardiogram\", \"acute-inflammation\"\n",
    "directory = \"/Users/bbartan/OneDrive - Leland Stanford Junior University/research_2020/\"\n",
    "A = np.load(directory + \"uci_datasets/data_{}.npy\".format(dataset))\n",
    "y = np.load(directory + \"uci_datasets/output_{}.npy\".format(dataset))\n",
    "y = y*1.0\n",
    "\n",
    "n, d = A.shape\n",
    "\n",
    "dataset_name = dataset\n",
    "print(A.shape, y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "if figure_no == 1:\n",
    "    # averaging \"curves\" (multiple trials)\n",
    "    ATA = np.matmul(A.T, A)\n",
    "    ATy = np.matmul(A.T, y)\n",
    "    AAT = np.matmul(A, A.T)\n",
    "\n",
    "    #m = 20\n",
    "    num_workers = 2500\n",
    "\n",
    "    lm1 = 100 # for monks-1 #1 for diabetes # 10 for boston\n",
    "    effective_dim = compute_effective_dimension(ATA, lm1)\n",
    "    lm2 = lm1 * (1 - effective_dim / m)\n",
    "    print(\"A.shape = {}, lm1 = {}, lm2 = {}, effective_dim = {}\".format(A.shape, lm1, lm2, effective_dim))\n",
    "\n",
    "\n",
    "    num_trials = 100 #100\n",
    "\n",
    "    errors_gaus = np.zeros((num_trials, num_workers))\n",
    "    errors_gaus_biascorr = np.zeros((num_trials, num_workers))\n",
    "    errors_rade = np.zeros((num_trials, num_workers))\n",
    "    errors_rade_biascorr = np.zeros((num_trials, num_workers))\n",
    "    errors_surr_p1 = np.zeros((num_trials, num_workers))\n",
    "    errors_surr_p1_biascorr = np.zeros((num_trials, num_workers))\n",
    "    errors_unif = np.zeros((num_trials, num_workers))\n",
    "    errors_unif_biascorr = np.zeros((num_trials, num_workers))\n",
    "\n",
    "\n",
    "    for trial in range(num_trials):\n",
    "        print(\"\\n ########### [{}/{}] ###########\".format(trial, num_trials), end=\", \")\n",
    "\n",
    "        np.random.seed(trial)\n",
    "        errors_gaus[trial,:] = get_errors(A, y, m, lm1, lm1, num_workers, \"gaus\", effective_dim, ATA, ATy, AAT)[0]\n",
    "        np.random.seed(trial)\n",
    "        errors_gaus_biascorr[trial,:] = get_errors(A, y, m, lm1, lm2, num_workers, \"gaus\", effective_dim, ATA, ATy, AAT)[0]\n",
    "\n",
    "        np.random.seed(trial)\n",
    "        errors_rade[trial,:] = get_errors(A, y, m, lm1, lm1, num_workers, \"rademacher\", effective_dim, ATA, ATy, AAT)[0]\n",
    "        np.random.seed(trial)\n",
    "        errors_rade_biascorr[trial,:] = get_errors(A, y, m, lm1, lm2, num_workers, \"rademacher\", effective_dim, ATA, ATy, AAT)[0]\n",
    "\n",
    "        np.random.seed(trial)\n",
    "        errors_unif[trial,:] = get_errors(A, y, m, lm1, lm1, num_workers, \"unif\", effective_dim, ATA, ATy, AAT)[0]\n",
    "        np.random.seed(trial)\n",
    "        errors_unif_biascorr[trial,:] = get_errors(A, y, m, lm1, lm2, num_workers, \"unif\", effective_dim, ATA, ATy, AAT)[0]\n",
    "\n",
    "        np.random.seed(trial)\n",
    "        errors_surr_p1[trial,:] = get_errors(A, y, m, lm1, lm1, num_workers, \"surrogate_p1\", effective_dim, ATA, ATy, AAT)[0]\n",
    "        np.random.seed(trial)\n",
    "        errors_surr_p1_biascorr[trial,:] = get_errors(A, y, m, lm1, lm2, num_workers, \"surrogate_p1\", effective_dim, ATA, ATy, AAT)[0]\n",
    "    \n",
    "    \n",
    "    # plot results\n",
    "    plt.rcParams.update({'font.size': 16}); plt.grid();\n",
    "    plt.xlabel('number of averaged outputs'); plt.ylabel('$||x^*-\\hat{x}||_2 / ||x^*||_2$');\n",
    "\n",
    "    inds = np.logspace(np.log10(10),np.log10(num_workers-1),10, dtype=int)\n",
    "\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_gaus,axis=0)[inds], 'bo-', label=\"Gaussian\")\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_gaus_biascorr,axis=0)[inds], 'bo:')\n",
    "\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_rade,axis=0)[inds], 'rs-', label=\"Rademacher\")\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_rade_biascorr,axis=0)[inds], 'rs:')\n",
    "\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_unif,axis=0)[inds], 'c>-', label=\"Uniform\")\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_unif_biascorr,axis=0)[inds], 'c>:')\n",
    "\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_surr_p1,axis=0)[inds], 'gx-', label=\"Surrogate sketch\")\n",
    "    plt.loglog(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_surr_p1_biascorr,axis=0)[inds], 'gx:')\n",
    "\n",
    "    plt.legend()\n",
    "    plt.savefig(\"figure_{}_data_{}_m_{}_sketchtype_{}.pdf\".format(figure_no, dataset_name, m, sketch_type),bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      " ########### 0 ###########, 12.95258304239954\n",
      "\n",
      " ########### 1 ###########, \n",
      " ########### 2 ###########, 12.649680095827533\n",
      "\n",
      " ########### 3 ###########, \n",
      " ########### 4 ###########, 11.880208015483813\n",
      "\n",
      " ########### 5 ###########, "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "if figure_no == 2:\n",
    "    ATA = np.matmul(A.T, A)\n",
    "    ATy = np.matmul(A.T, y)\n",
    "    AAT = np.matmul(A, A.T)\n",
    "\n",
    "    #m = 1000\n",
    "    num_workers = 10000\n",
    "\n",
    "    lm1_values = 1.0 * np.array([0.1, 0.1, 1, 1, 10, 10])\n",
    "    \n",
    "\n",
    "    \n",
    "    errors = np.zeros((lm1_values.shape[0], num_workers))\n",
    "\n",
    "    for i in range(lm1_values.shape[0]):\n",
    "        print(\"\\n ########### {} ###########\".format(i), end=\", \")\n",
    "        lm1 = lm1_values[i]\n",
    "        if i % 2 == 0:\n",
    "            lm2 = lm1\n",
    "            effective_dim = compute_effective_dimension(ATA, lm1)\n",
    "            print(effective_dim)\n",
    "        else:\n",
    "            effective_dim = compute_effective_dimension(ATA, lm1)\n",
    "            lm2 = lm1 * (1 - effective_dim / m)\n",
    "\n",
    "        np.random.seed(0)\n",
    "        errors[i, :] = get_errors(A, y, m, lm1, lm2, num_workers, sketch_type, effective_dim, ATA, ATy, AAT)[0]\n",
    "\n",
    "\n",
    "    # plot results\n",
    "    plt.rcParams.update({'font.size': 16}); plt.grid();\n",
    "    plt.xlabel('number of averaged outputs'); plt.ylabel('$||x^*-\\hat{x}||_2 / ||x^*||_2$');\n",
    "    colors = ['b', 'r', 'g', 'k', 'm']\n",
    "    markers = ['>', '+', 'o']\n",
    "\n",
    "    inds = np.logspace(np.log10(1),np.log10(num_workers-1),10, dtype=int)\n",
    "\n",
    "    for i in range(errors.shape[0] // 2):\n",
    "        plt.loglog(np.linspace(1,errors.shape[1],errors.shape[1])[inds], errors[2*i,:][inds], colors[i]+'-'+markers[i], label=\"$\\lambda={}$\".format(lm1_values[2*i]))\n",
    "        plt.loglog(np.linspace(1,errors.shape[1],errors.shape[1])[inds], errors[2*i+1,:][inds], colors[i]+':'+markers[i])\n",
    "\n",
    "    plt.legend()\n",
    "    plt.savefig(\"figure_{}_data_{}_m_{}_sketchtype_{}.pdf\".format(figure_no, dataset_name, m, sketch_type),bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "if figure_no == 3:\n",
    "    b = y.copy()\n",
    "    c_vec = 0\n",
    "\n",
    "    #m = 50\n",
    "\n",
    "    num_iters = 20\n",
    "    num_workers = 100\n",
    "\n",
    "\n",
    "    lm1 = 0.0001\n",
    "    tau, c, a0 = 2, 0.1, 1 # a0 is the starting alpha for backtracking line search # tau=4, 0.1, 1\n",
    "\n",
    "    sketch_types = [\"gaus\", \"unif\", \"surrogate_p1\"]\n",
    "\n",
    "    errors_all = np.zeros((len(sketch_types)*3, num_iters+1))\n",
    "    times_all = np.zeros((len(sketch_types)*3, num_iters+1))\n",
    "\n",
    "    for i in range(len(sketch_types)):\n",
    "        print(\"\\n\" + sketch_types[i] + \" - newton\")\n",
    "        np.random.seed(0)\n",
    "        _, errors_all[3*i,:], times_all[3*i,:] = log_regression_optimize(A,b,c_vec,1,lm1,lm1,tau,c,num_iters,-99,-99,a0,False)\n",
    "\n",
    "        print(\"\\n\" + sketch_types[i] + \" - baseline\")\n",
    "        np.random.seed(0)\n",
    "        _, errors_all[3*i+1,:], times_all[3*i+1,:] = log_regression_optimize(A,b,c_vec,2,lm1,lm1,tau,c,num_iters,\n",
    "                                            num_workers,m,a0,False,sketch_types[i],m2=0)\n",
    "        print(\"\\n\" + sketch_types[i] + \" - bias corrected\")\n",
    "        np.random.seed(0)\n",
    "        temp, errors_all[3*i+2,:], times_all[3*i+2,:] = log_regression_optimize(A,b,c_vec,2,lm1,-999,tau,c,num_iters,\n",
    "                                            num_workers,m,a0,False,sketch_types[i],m2=0)\n",
    "    \n",
    "    # plot results\n",
    "    plt.rcParams.update({'font.size': 16})\n",
    "    colors = ['b', 'r', 'g', 'k', 'y', 'm']\n",
    "    markers = ['>', '+', 'o']\n",
    "    legend_names = [\"Gaussian\", \"Uniform\", \"Surrogate sketch\"]\n",
    "\n",
    "\n",
    "    for i in range(len(sketch_types)):\n",
    "        plt.semilogy(np.linspace(0, num_iters, num_iters+1), np.abs((errors_all[3*i+1,:]-errors_all[3*i,-1])/errors_all[3*i,-1]), '-'+markers[i]+colors[i], label=legend_names[i])\n",
    "        plt.semilogy(np.linspace(0, num_iters, num_iters+1), np.abs((errors_all[3*i+2,:]-errors_all[3*i,-1])/errors_all[3*i,-1]), ':'+markers[i]+colors[i])\n",
    "    \n",
    "    plt.grid()\n",
    "    #plt.ylim(10**(-14), 10**(1))\n",
    "    plt.ylabel('$(f(\\hat{x}) - f(x^*)) / f(x^*)$')\n",
    "    plt.xlabel(\"iteration\")\n",
    "    plt.legend()\n",
    "    plt.savefig(\"figure_{}_data_{}_m_{}_sketchtype_{}.pdf\".format(figure_no, dataset_name, m, sketch_type),bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "code_folding": [
     0
    ]
   },
   "outputs": [],
   "source": [
    "if figure_no == 4:\n",
    "    # averaging \"curves\" (multiple trials)\n",
    "    ATA = np.matmul(A.T, A)\n",
    "    ATy = np.matmul(A.T, y)\n",
    "    AAT = np.matmul(A, A.T)\n",
    "\n",
    "    #m = 50\n",
    "    num_workers = 2500 #2500\n",
    "\n",
    "    lm1 = 10\n",
    "    effective_dim = compute_effective_dimension(ATA, lm1)\n",
    "    lm2 = lm1 * (1 - effective_dim / m)\n",
    "    print(\"A.shape = {}, lm1 = {}, lm2 = {}, effective_dim = {}\".format(A.shape, lm1, lm2, effective_dim))\n",
    "\n",
    "    num_trials = 100\n",
    "\n",
    "    errors_unif = np.zeros((num_trials, num_workers)) # bias corrected \n",
    "    errors_surr_p1 = np.zeros((num_trials, num_workers)) # bias corrected\n",
    "    errors_det_avg = np.zeros((num_trials, num_workers)) # same reg param\n",
    "\n",
    "\n",
    "    for trial in range(num_trials):\n",
    "        print(\"\\n ########### [{}/{}] ###########\".format(trial,num_trials), end=\", \")\n",
    "        np.random.seed(trial)\n",
    "        errors_unif[trial,:] = get_errors_singlenewtonstep(A, y, m, lm1, lm1, num_workers, \"unif\", \n",
    "                                                          effective_dim, ATA, ATy, AAT, determ_avg=False)[0]\n",
    "        np.random.seed(trial)\n",
    "        errors_surr_p1[trial,:] = get_errors_singlenewtonstep(A, y, m, lm1, lm2, num_workers, \"surrogate_p1\", \n",
    "                                                          effective_dim, ATA, ATy, AAT, determ_avg=False)[0]\n",
    "        np.random.seed(trial)\n",
    "        errors_det_avg[trial,:] = get_errors_singlenewtonstep(A, y, m, lm1, lm1, num_workers, \"unif\", \n",
    "                                                          effective_dim, ATA, ATy, AAT, determ_avg=True)[0]\n",
    "        \n",
    "    # plot results\n",
    "    plt.rcParams.update({'font.size': 16}); plt.grid();\n",
    "    plt.xlabel('number of averaged outputs'); plt.ylabel('$||x^*-\\hat{x}||_2 / ||x^*||_2$');\n",
    "\n",
    "\n",
    "    inds = np.logspace(np.log10(10),np.log10(num_workers-1),10, dtype=int)\n",
    "    plt.errorbar(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_unif,axis=0)[inds], scipy.stats.sem(errors_unif, axis=0)[inds], fmt=\"b-\", label=\"Unweighted averaging\", markeredgewidth=1, capsize=2, elinewidth=1)\n",
    "    plt.errorbar(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_det_avg,axis=0)[inds], scipy.stats.sem(errors_det_avg, axis=0)[inds], fmt=\"g-.\", label=\"Determinantal averaging\", markeredgewidth=1, capsize=2, elinewidth=1)\n",
    "    plt.errorbar(np.linspace(1,num_workers,num_workers)[inds], np.mean(errors_surr_p1,axis=0)[inds], scipy.stats.sem(errors_surr_p1, axis=0)[inds], fmt=\"r:\", label=\"Surrogate sketch\", markeredgewidth=1, capsize=2, elinewidth=1)\n",
    "    plt.xscale('log'); plt.yscale('log')\n",
    "\n",
    "    plt.legend()\n",
    "    plt.savefig(\"figure_{}_data_{}_m_{}_sketchtype_{}.pdf\".format(figure_no, dataset_name, m, sketch_type),bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
