{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "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": 3,
   "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": 4,
   "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]),\n",
       " 0.6931471805895076)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sigmoid(reg_sol[-1]),reg_sol[-1,-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": 6,
   "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": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 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()\n",
    "\n",
    "T=3000\n",
    "f = plt.figure(figsize=(8,4))\n",
    "plt.subplot(111)\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[:T], [fun(sol) for sol in reg_sol[:T]], 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.tight_layout()\n",
    "plt.xlabel('time',fontsize=18)\n",
    "plt.savefig('GoodfellowGAN1.pdf')\n",
    "plt.show()\n",
    "\n",
    "f = plt.figure(figsize=(8,4))\n",
    "plt.subplot(111)\n",
    "plt.title(r'$H(t)$',fontsize=18)\n",
    "plt.plot(t[:T], [gun(sol) for sol in reg_sol[:T]],color='red', label=r'$H(t)$')\n",
    "#plt.legend(loc='best')\n",
    "#plt.tight_layout()\n",
    "plt.xlabel('time',fontsize=18)\n",
    "#lt.grid()\n",
    "plt.savefig('GoodfellowGAN2.pdf')\n",
    "plt.show()"
   ]
  }
 ],
 "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.9.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
