{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "#%matplotlib notebook\n",
    "#%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "def objfun(x):\n",
    "    return 1/(2*n)*(np.linalg.norm(np.dot(A,x)-y)**2)+(1/(2*n))*(np.linalg.norm(x)**2)\n",
    "\n",
    "\n",
    "# The approximation of the objective function\n",
    "def approx_func(batch,x):\n",
    "    summation = 0\n",
    "    for i in batch:\n",
    "        summation = summation + (np.dot(A[i,:],x)-y[i])**2\n",
    "    return (1/(2*batch_size))*summation+(1/(2*n))*(np.linalg.norm(x)**2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_experiment(dataset, n_iter, n_run, batch_size, alpha_MiSTP, alpha_SGD ):\n",
    "    \n",
    "    # read data\n",
    "    data = pd.read_csv(dataset, sep=',', header=None)\n",
    "    \n",
    "    if (batch_size==data.shape[0]): # if batch_size=full batch (original STP & GD (gradient descent))\n",
    "        run_experiment_full_batch(dataset, n_iter, n_run, alpha_MiSTP, alpha_SGD )\n",
    "    else:\n",
    "        \n",
    "        # Number of samples\n",
    "        global n\n",
    "        n = data.shape[0]\n",
    "\n",
    "        # Number of parameters\n",
    "        global d\n",
    "        d = data.shape[1]-1\n",
    "\n",
    "        # data A & y for computing the objective function values\n",
    "        global A\n",
    "        global y\n",
    "        A = np.array(data.iloc[: , 0:d])\n",
    "        y = np.array(data.iloc[: , -1])\n",
    "    \n",
    "        # initialization\n",
    "        starting_points = np.random.normal(size= (d,n_run))  # to use the same starting point for MiSTP & SGD\n",
    "    \n",
    "        # generating the minibatches to use the same minibatch for both methods\n",
    "        batches = {}\n",
    "        for i in range(n_run):\n",
    "            batches.update({i:np.random.randint(0, n, size = (n_iter,batch_size))})\n",
    "    \n",
    "        ########################## run the MiSTP method ################################\n",
    "    \n",
    "        # the mean and the covariance of the normal distribution \n",
    "        mean = np.array([0]*d) \n",
    "        cov = np.identity(d)\n",
    "    \n",
    "        f_MiSTP = np.zeros((n_run, n_iter+1))     #to store the objective function values\n",
    "        approx_MiSTP = np.zeros((n_run, n_iter))  #to store the approximation of the objective function values\n",
    "        for r in range(n_run):\n",
    "            #initialisation\n",
    "            x = starting_points[:,r]\n",
    "            f_STP[r,0] = objfun(x)\n",
    "            for k in range(n_iter):\n",
    "                # uniformally choose a batch\n",
    "                batch = batches[r][k]\n",
    " \n",
    "                s_k = np.random.multivariate_normal(mean, cov)\n",
    "                x_plus = x + alpha_MiSTP*s_k\n",
    "                x_minus = x - alpha_MiSTP*s_k\n",
    "                array = np.array([approx_func(batch,x_minus), approx_func(batch,x_plus), approx_func(batch,x)])\n",
    "                indice_argmin = np.argmin(array)\n",
    "                if (indice_argmin==0):\n",
    "                    x = x_minus\n",
    "                if (indice_argmin==1):\n",
    "                    x = x_plus\n",
    "                else:\n",
    "                    x = x\n",
    "                f_MiSTP[r,k+1] = objfun(x)\n",
    "                approx_MiSTP[r,k] = approx_func(batch,x)\n",
    "        \n",
    "        \n",
    "        ########################## run the SGD method ################################\n",
    "        \n",
    "        f_SGD = np.zeros((n_run, n_iter+1))      #to store the objective function values\n",
    "        approx_SGD = np.zeros((n_run, n_iter))   #to store the approximation of the objective function values\n",
    "        for r in range(n_run):\n",
    "            x = starting_points[:,r]\n",
    "            f_SGD[r,0] = objfun(x)\n",
    "            for i in range(n_iter):\n",
    "                # uniformally choose a batch\n",
    "                batch = batches[r][i]\n",
    "                # gradient computation\n",
    "                summation = 0\n",
    "                for j in batch:\n",
    "                    summation = summation + np.transpose(A[j,:])*(np.dot(A[j,:],x)-y[j])\n",
    "                grad = (1/batch_size)*summation + (1/n)*x\n",
    "                # SGD updates\n",
    "                x = x - alpha_SGD * grad\n",
    "                f_SGD[r,i+1] = objfun(x)\n",
    "                approx_SGD[r,i] = approx_func(batch,x)\n",
    "                \n",
    "                \n",
    "        ########################## plotting the results #######################\n",
    "        \n",
    "        # plotting the objective function\n",
    "        plt.figure(figsize=(5.0, 4.0))\n",
    "        plt.plot(f_SGD.mean(0), label='SGD', color='teal')\n",
    "        plt.plot(f_MiSTP.mean(0), label='MiSTP', color=\"blueviolet\")\n",
    "        plt.fill_between(range(n_iter+1),f_SGD.mean(0) - 0.5*np.std(f_SGD, axis=0), f_SGD.mean(0) + 0.5*np.std(f_SGD, axis=0), alpha=0.2, color='teal')\n",
    "        plt.fill_between(range(n_iter+1),f_MiSTP.mean(0) - 0.5*np.std(f_MiSTP, axis=0), f_MiSTP.mean(0) + 0.5*np.std(f_MiSTP, axis=0), alpha=0.2, color=\"blueviolet\")\n",
    "        plt.xlim(0)\n",
    "        plt.ylim(0)\n",
    "        plt.xlabel(\"Iterations\",fontsize = 15)\n",
    "        plt.ylabel(r'$f(x)$',fontsize = 15)\n",
    "        plt.rcParams['xtick.labelsize']=12\n",
    "        plt.rcParams['ytick.labelsize']=12\n",
    "        plt.title(r'$\\tau = %d$'%(batch_size)+\", \"+ r'$\\alpha_{MiSTP} = %d$'%(alpha_MiSTP)+\", \"+ r'$\\alpha_{SGD} = %d$'%(alpha_SGD),fontsize = 15)\n",
    "        plt.legend(fontsize=14)\n",
    "        \n",
    "        # plotting the approximation of the objective function\n",
    "        plt.figure(figsize=(5.0, 4.0))\n",
    "        plt.plot(approx_SGD.mean(0), label='SGD', color='teal')\n",
    "        plt.plot(approx_MiSTP.mean(0), label='MiSTP', color=\"blueviolet\")\n",
    "        plt.fill_between(range(n_iter+1),approx_SGD.mean(0) - 0.5*np.std(approx_SGD, axis=0), approx_SGD.mean(0) + 0.5*np.std(approx_SGD, axis=0), alpha=0.2, color='teal')\n",
    "        plt.fill_between(range(n_iter+1),approx_MiSTP.mean(0) - 0.5*np.std(approx_MiSTP, axis=0), approx_MiSTP.mean(0) + 0.5*np.std(approx_MiSTP, axis=0), alpha=0.2, color=\"blueviolet\")\n",
    "        plt.xlim(0)\n",
    "        plt.ylim(0)\n",
    "        plt.xlabel(\"Iterations\",fontsize = 15)\n",
    "        plt.ylabel(r'$\\widetilde{f(}x)$',fontsize = 15)\n",
    "        plt.rcParams['xtick.labelsize']=12\n",
    "        plt.rcParams['ytick.labelsize']=12\n",
    "        plt.title(r'$\\tau = %d$'%(batch_size)+\", \"+ r'$\\alpha_{MiSTP} = %d$'%(alpha_MiSTP)+\", \"+ r'$\\alpha_{SGD} = %d$'%(alpha_SGD),fontsize = 15)\n",
    "        plt.legend(fontsize=14)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_experiment_full_batch(dataset, n_iter, n_run, alpha_STP, alpha_GD ):\n",
    "    # read data\n",
    "    data = pd.read_csv(dataset, sep=',', header=None)\n",
    "    \n",
    "    # Number of samples\n",
    "    global n\n",
    "    n = data.shape[0]\n",
    "\n",
    "    # Number of parameters\n",
    "    global d\n",
    "    d = data.shape[1]-1\n",
    "\n",
    "    # data A & y for computing the objective function values\n",
    "    global A\n",
    "    global y\n",
    "    A = np.array(data.iloc[: , 0:d])\n",
    "    y = np.array(data.iloc[: , -1])\n",
    "    \n",
    "    # initialization\n",
    "    starting_points = np.random.normal(size= (d,n_run))  # to use the same starting point for MiSTP & SGD\n",
    "    \n",
    "    ######################## run the STP method ######################\n",
    "    \n",
    "    # the mean and the covariance of the normal distribution \n",
    "    mean = np.array([0]*d) \n",
    "    cov = np.identity(d)\n",
    "    \n",
    "    f_STP = np.zeros((n_run, n_iter+1)) #to store the objective function values\n",
    "    for r in range(n_run):\n",
    "        #initialisation\n",
    "        x = starting_points[:,r]\n",
    "        f_STP[r,0] = objfun(x)\n",
    "        for k in range(n_iter):\n",
    "            s_k = np.random.multivariate_normal(mean, cov)\n",
    "            x_plus = x + alpha_STP*s_k\n",
    "            x_minus = x - alpha_STP*s_k\n",
    "            array = np.array([objfun(x_minus), objfun(x_plus), f_STP[r,k]])\n",
    "            indice_argmin = np.argmin(array)\n",
    "            if (indice_argmin==0):\n",
    "                x = x_minus\n",
    "            if (indice_argmin==1):\n",
    "                x = x_plus\n",
    "            else:\n",
    "                x = x\n",
    "            f_STP[r,k+1] = objfun(x)\n",
    "            \n",
    "            \n",
    "    ######################## run the GD method ######################\n",
    "    \n",
    "    f_GD = np.zeros((n_run, n_iter+1))\n",
    "    for r in range(n_run):\n",
    "        x = starting_points[:,r]\n",
    "        f_GD[r,0] = objfun(x)\n",
    "        for i in range(n_iter):\n",
    "            # gradient computation\n",
    "            grad = (1/n)*np.dot(np.transpose(A),(np.dot(A,x)-y)) + (1/n)*x\n",
    "            # SGD updates\n",
    "            x = x - alpha_GD * grad\n",
    "            f_GD[r,i+1] = objfun(x)\n",
    "\n",
    "    \n",
    "    ########################## plotting the results #######################\n",
    "    \n",
    "    plt.figure(figsize=(5.0, 4.0))\n",
    "    plt.plot(f_GD.mean(0), label='SGD', color='teal')\n",
    "    plt.plot(f_STP.mean(0), label='MiSTP', color=\"blueviolet\")\n",
    "    plt.fill_between(range(n_iter+1),f_GD.mean(0) - 0.5*np.std(f_GD, axis=0), f_GD.mean(0) + 0.5*np.std(f_GD, axis=0), alpha=0.2, color='teal')\n",
    "    plt.fill_between(range(n_iter+1),f_STP.mean(0) - 0.5*np.std(f_STP, axis=0), f_STP.mean(0) + 0.5*np.std(f_STP, axis=0), alpha=0.2, color=\"blueviolet\")\n",
    "    plt.xlim(0, n_iter)\n",
    "    plt.ylim(0)\n",
    "    plt.xlabel(\"Iterations\",fontsize = 15)\n",
    "    plt.ylabel(r'$f(x)$',fontsize = 15)\n",
    "    plt.rcParams['xtick.labelsize']=12\n",
    "    plt.rcParams['ytick.labelsize']=12\n",
    "    plt.title(r'$\\tau = n$'+\", \"+ r'$\\alpha_{MiSTP} = %d$'%(alpha_STP)+\", \"+ r'$\\alpha_{SGD} = %d$'%(alpha_GD),fontsize = 15)\n",
    "    plt.legend(fontsize=14)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#def run_experiment(dataset, n_iter, n_run, batch_size, alpha_MiSTP, alpha_SGD ):\n",
    "run_experiment('abalone_scale.csv', 30, 10, 4177, 1, 1 )"
   ]
  },
  {
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
