{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import time\n",
    "\n",
    "from joblib import Parallel, delayed, cpu_count\n",
    "from matplotlib import cm"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def box(x,xlim):\n",
    "    if x>max(xlim):\n",
    "        return max(xlim)\n",
    "    elif x<min(xlim):\n",
    "        return min(xlim)\n",
    "    else:\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def h(x,y):\n",
    "    return y-x\n",
    "\n",
    "def g(x, y):\n",
    "    return (y-2*x)**2\n",
    "\n",
    "def dgx(x,y):\n",
    "    return -4*(y-2*x)\n",
    "\n",
    "def dgy(x,y):\n",
    "    return 2*(y-2*x)\n",
    "\n",
    "def dg(x,y):\n",
    "    return np.array([dgx(x,y), dgy(x,y)])\n",
    "\n",
    "\n",
    "def f(x,y):\n",
    "    return np.exp(-y+2)/(2+np.cos(6*x))+0.5*np.log((4*x-2)**2+1)# + x**2\n",
    "\n",
    "def f_np(x,y):\n",
    "    return np.exp(-y+2)/(2+np.cos(6*x))+0.5*np.log((4*x-2)**2+1)# + x**2\n",
    "\n",
    "def dfx(x,y):\n",
    "    return 6*math.exp(-y+2)*math.sin(6*x)/((2+math.cos(6*x))**2)+(16*x-8)/((4*x-2)**2+1)# + 2*x\n",
    "\n",
    "def dfy(x,y):\n",
    "    return -math.exp(-y+2)/(2+math.cos(6*x))\n",
    "\n",
    "def df(x,y):\n",
    "    return np.array([dfx(x,y), dfy(x,y)])\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sflcb(x, y, z, alpha, beta, u, v, hparams,xlim,epsilon=0.01,max_iters=10000):\n",
    "\n",
    "    eta_x = hparams['eta_x']\n",
    "    eta_y = hparams['eta_x']\n",
    "    eta_z = hparams['eta_x']\n",
    "    eta_u = hparams['eta_x']\n",
    "    eta_v = hparams['eta_x']\n",
    "    delta = hparams['delta']\n",
    "    rho_1 = hparams['rho_1']\n",
    "    rho_2 = hparams['rho_2']\n",
    "    t=0\n",
    "    x=box(x,xlim)\n",
    "    ys=[]\n",
    "    zs=[]\n",
    "    xs=[]\n",
    "    dx=10000\n",
    "\n",
    "    \n",
    "\n",
    "    while t < max_iters:\n",
    "        h_alpha=h(x,y)-alpha\n",
    "        h_beta=h(x,z)-beta\n",
    "\n",
    "        u=u+eta_u*(h_alpha)\n",
    "        v=v+eta_v*(h_beta)\n",
    "        dx=delta* dfx(x,y)+dgx(x,y)-dgx(x,z)-u+v - rho_1*h_alpha +rho_2*h_beta\n",
    "        dy=delta* dfy(x,y)+dgy(x,y)+u + rho_1*h_alpha\n",
    "        dz=-dgy(x,z)-v - rho_2*h_beta\n",
    "        dalpha=-u -rho_1*h_alpha\n",
    "        dbeta=v +rho_2*h_beta\n",
    "        x=x-eta_x*dx\n",
    "\n",
    "        x=box(x,xlim)\n",
    "        \n",
    "        y=y-eta_y*dy\n",
    "        z=z+eta_z*dz\n",
    "        alpha=alpha-eta_y*dalpha\n",
    "        beta=beta+eta_z*dbeta\n",
    "        alpha=np.minimum(alpha, 0)\n",
    "        beta=np.minimum(beta, 0)\n",
    "        t+=1\n",
    "        xs.append(x)\n",
    "        ys.append(y)\n",
    "        zs.append(z)\n",
    "    return x,y,z,t\n",
    "\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_sflcb(epsilon=1e-6):\n",
    "\n",
    "    x=np.random.uniform(0,3)\n",
    "    y=np.random.uniform(-5,8.5)\n",
    "    z=np.copy(y)\n",
    "    alpha=h(x,y)\n",
    "    beta=h(x,z)\n",
    "    u = np.random.uniform(0, 10)\n",
    "    v = np.copy(u)\n",
    "\n",
    "    hparams = {\n",
    "        'delta': 0.1,\n",
    "        'eta_x': 0.01,\n",
    "        'eta_y': 0.01,\n",
    "        'eta_z': 0.01,\n",
    "        'eta_u': 0.01,\n",
    "        'eta_v': 0.01,\n",
    "        'rho_1': 1,\n",
    "        'rho_2': 1,\n",
    "    }\n",
    "    xlim = [0., 3.]\n",
    "\n",
    "    \n",
    "\n",
    "    t_start = time.time()\n",
    "    x, y, z, k= sflcb(x, y, z, alpha, beta, u, v, hparams,xlim,epsilon=epsilon,max_iters=10000)\n",
    "    t_elapsed = (time.time() - t_start)\n",
    "\n",
    "\n",
    "    return x, y, z, k, t_elapsed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "n_jobs = cpu_count()\n",
    "N = 200\n",
    "results = Parallel(n_jobs=n_jobs)(delayed(run_sflcb)() for i in range(N))\n",
    "\n",
    "ps = np.array(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_ax = np.linspace(0, 3, 1000)\n",
    "\n",
    "#plt.figure(figsize=(6, 6))\n",
    "plt.plot(x_ax, f_np(x_ax,x_ax), linewidth=2)\n",
    "for i in range(N):\n",
    "    plt.plot(ps[i,0], f(ps[i,0], ps[i,1]), 'o', color='r')\n",
    "\n",
    "plt.legend(['$f(x,y)|_{y=x}$', '$(x_T, f(x_T,y_T))$'], fontsize=16)\n",
    "plt.grid()\n",
    "plt.xlabel('$x$', fontsize=18)\n",
    "plt.ylabel('$f(x,y)|_{y=x}$', fontsize=18)\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "plt.xlim([0,3])\n",
    "plt.savefig('convergence.png')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "NLU",
   "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.7.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
