{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "9818c553",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update({'font.size': 20})\n",
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "plt.rcParams[\"font.serif\"] = [\"Times New Roman\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "d65c12b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def D1TimeDepBregman(x, mu, u_0, v_0):\n",
    "    ''' Time evolution of bregman function '''\n",
    "    scale = 2*mu*u_0*v_0\n",
    "    return (x*np.arcsinh(x/scale) - np.sqrt(x*x + scale*scale) - x * np.log(u_0/v_0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "761d9968",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialization\n",
    "x_0 = 1\n",
    "u_0  = np.sqrt(x_0 + np.sqrt(x_0*x_0 + 1))\n",
    "v_0 = 1/u_0\n",
    "\n",
    "x = np.linspace(-1,3, 1000)\n",
    "mu = np.flip(np.linspace(1e-4,1, 10000))\n",
    "\n",
    "X, MU = np.meshgrid(x,mu)\n",
    "\n",
    "res = D1TimeDepBregman(X, MU, u_0, v_0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "3af34d2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig = plt.figure(figsize=(4.8, 6.4), dpi = 100, facecolor='w')\n",
    "fig.tight_layout()\n",
    "ax = plt.axes(projection='3d')\n",
    "\n",
    "ax.plot_surface(X, -np.log(MU)/2, res, cmap='magma', alpha=0.7)\n",
    "ax.view_init(20,-95) \n",
    "\n",
    "ax.yaxis.labelpad=15\n",
    "ax.xaxis.labelpad=10\n",
    "ax.zaxis.labelpad=15\n",
    "ax.set_zlabel(r'$R_{\\alpha}(x)$', rotation = 60)\n",
    "ax.set_xlabel('x', loc = 'center')\n",
    "ax.set_ylabel(r'$\\alpha$')\n",
    "ax.set_xlim(-1,3)\n",
    "ax.set_ylim(0,5)\n",
    "fig.savefig('BregmanEvolution.pdf', bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
