{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import multiprocessing\n",
    "import autograd.numpy as np \n",
    "from autograd import grad  \n",
    "from scipy.integrate import odeint \n",
    "\n",
    "def sigmoid(x):\n",
    "    return ( 1/(1 + np.exp(-x)) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [],
   "source": [
    "def objective_noreg(pgen, pdata, D,lagrange):\n",
    "    return np.dot(sigmoid(pgen),np.log(sigmoid(D)))+np.dot(pdata,np.log(1-sigmoid(D)))+lagrange*(np.sum(sigmoid(pgen))-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [],
   "source": [
    "def noreg(y,t,pdata,d):\n",
    "    pgen = y[:d]\n",
    "    D = y[d:d*2]\n",
    "    lagrange = y[-1]\n",
    "    \n",
    "    obj_pgen = lambda pgen : objective_noreg(pgen, pdata, D,lagrange)\n",
    "    obj_D = lambda D : objective_noreg(pgen, pdata, D,lagrange)\n",
    "    obj_lagrange = lambda lagrange : objective_noreg(pgen, pdata, D,lagrange)\n",
    "    \n",
    "\n",
    "    dydt_unflatten = [-grad(obj_pgen)(pgen),\n",
    "             grad(obj_D)(D),\n",
    "             grad(obj_lagrange)(lagrange).reshape(-1),\n",
    "           ]    \n",
    "    \n",
    "    dydt = np.concatenate(dydt_unflatten)\n",
    "    \n",
    "    return dydt\n",
    "\n",
    "def run_experiment(d,pdata,t,seed):\n",
    "    np.random.seed(seed)\n",
    "    initial_values = [np.random.rand(d),np.random.rand(d),np.random.rand(1)]\n",
    "    initial_values = np.concatenate(initial_values)\n",
    "    reg_sol = odeint(noreg, initial_values, t, args=(pdata,d))\n",
    "    return reg_sol\n",
    "\n",
    "d = 4\n",
    "pdata = np.array([0.2,0.4,0.3,0.1])\n",
    "t = np.linspace(0, 10000, 100000)\n",
    "reg_sol=run_experiment(d,pdata,t,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.2       , 0.4       , 0.3       , 0.1       , 0.5       ,\n",
       "        0.5       , 0.5       , 0.5       , 0.66666667]), 0.693147180601017)"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sigmoid(reg_sol[-1]),reg_sol[-1,-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "def indefinite(x, p):\n",
    "    first = (1-p)/(1-x)\n",
    "    second = p/x\n",
    "    third = (2*p-1)*np.log(1-x)\n",
    "    fourth = (1-2*p)*np.log(x)\n",
    "    return first + second + third+ fourth\n",
    "\n",
    "def definite(x,p):\n",
    "    return indefinite(x,p)- indefinite(p,p)\n",
    "\n",
    "def distlagrange(lagrange,opt_lagrange):\n",
    "    return (lagrange-opt_lagrange)**2/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "matplotlib.rcParams['text.usetex'] = True\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def r(sol,pdata,d):\n",
    "    f=sigmoid(sol[:d])\n",
    "    g=sigmoid(sol[d:2*d])\n",
    "    lagrange=sol[-1]\n",
    "    return ((np.linalg.norm(f-pdata)**2+np.linalg.norm(g-np.ones(d)/2)**2))+(lagrange-np.log(2))**2\n",
    "fun = lambda sol:r(sol,pdata,d)\n",
    "\n",
    "def h(sol,pdata,d):\n",
    "    result = 0\n",
    "    for i in range(d):\n",
    "        result+=definite(sigmoid(sol[i]),pdata[i])\n",
    "    for i in range(d,2*d):\n",
    "        result+=definite(sigmoid(sol[i]),0.5)\n",
    "    result+=distlagrange(sol[-1],np.log(2))\n",
    "    return result\n",
    "gun = lambda sol:h(sol,pdata,d)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1152x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "f = plt.figure(figsize=(16,4))\n",
    "plt.subplot(121)\n",
    "plt.title(r'$r(t)=\\|(\\mathbf{F}(t)-\\mathbf{p})\\|^2+\\|(\\mathbf{G}(t)-\\mathbf{q})\\|^2+|\\lambda-\\lambda^*|^2$',fontsize=18)\n",
    "plt.plot(t[:8000], [fun(sol) for sol in reg_sol[:8000]], color='blue', label=r'$r(t)=\\|\\|(\\mathbf{F}(t)-\\mathbf{p})\\|\\|^2+\\|\\|(\\mathbf{G}(t)-\\mathbf{q})\\|\\|^2+\\|\\lambda-\\lambda^*\\|^2$')\n",
    "#plt.legend(loc='best')\n",
    "plt.xlabel(r'$steps$',fontsize=18)\n",
    "plt.subplot(122)\n",
    "plt.title(r'$H(t)$',fontsize=18)\n",
    "plt.plot(t[:8000], [gun(sol) for sol in reg_sol[:8000]],color='red', label=r'$H(t)$')\n",
    "#plt.legend(loc='best')\n",
    "plt.xlabel(r'$steps$',fontsize=18)\n",
    "#lt.grid()\n",
    "plt.savefig('GoodfellowGAN.pdf')\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
