{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4d4f2e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from numpy.linalg import multi_dot\n",
    "from numpy import linalg as LA\n",
    "from six.moves import xrange\n",
    "from scipy import linalg as la\n",
    "import scipy.stats as st\n",
    "import random\n",
    "from numpy.linalg import multi_dot\n",
    "import math\n",
    "from math import pow\n",
    "import seaborn as sns\n",
    "import pandas as pd "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "55bddcfe",
   "metadata": {},
   "source": [
    "# Plot Figure 1(a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0727ea71",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_sac=np.loadtxt('') #load single-timescale AC data, 1000000 points in our experiment\n",
    "data_zo=np.loadtxt('')#load zeroth-order data, 1000 points in our experiment\n",
    "data_dac=np.loadtxt('')#load double-loop AC data, 100 points in our experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96637b81",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_sac=np.zeros((10,10000))\n",
    "plot_zo=data_zo\n",
    "plot_dac=data_dac\n",
    "for i in range(10):\n",
    "    for j in range(10000):\n",
    "        plot_sac[i][j]=data_sac[i][j*100] #choose 10000 points to plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6453b322",
   "metadata": {},
   "outputs": [],
   "source": [
    "dflist=[]\n",
    "for i in range(10):\n",
    "    df=pd.DataFrame(dict(run_idx=str(i),Sample_complexity=np.linspace(1,999901,10000),Errors=plot_sac[i],Algorithms='sac',Curve='Single-timeScale AC'))\n",
    "    dflist.append(df)\n",
    "for i in range(10):\n",
    "    df=pd.DataFrame(dict(run_idx=str(i),Sample_complexity=np.linspace(1,99900001,1000),Errors=plot_zo[i],Algorithms='sac',Curve='Zeroth order'))\n",
    "    dflist.append(df)\n",
    "for i in range(10):\n",
    "    df=pd.DataFrame(dict(run_idx=str(i),Sample_complexity=np.linspace(1,49500001,100),Errors=plot_dac[i],Algorithms='sac',Curve='Double-loop AC'))\n",
    "    dflist.append(df)\n",
    "total_DataFrame=dflist[0].append(dflist[1:],ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41024116",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig,ax = plt.subplots(figsize=(15,11))\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x='Sample_complexity',y='Errors',hue='Curve',data=total_DataFrame,palette='colorblind',alpha=0.5)\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "ax.set_xlim(1,10**8)\n",
    "ax.set_xlabel('Sample complexity',fontsize=40)\n",
    "ax.set_ylabel(r'$\\Vert K-K^*\\Vert_{\\bf{F}}$',fontsize=40)\n",
    "#ax.set_ylim(10**(-2),10**0)\n",
    "handles,labels = ax.get_legend_handles_labels()\n",
    "ax.legend(handles=handles[0:],labels=labels[0:],fontsize=36)\n",
    "plt.xticks(size=38)\n",
    "plt.yticks(size=38)\n",
    "plt.savefig('fig1(a).pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bfaf997a",
   "metadata": {},
   "source": [
    "# Plot Figue 1(b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1ad156b",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_actor=np.loadtxt('')#load actor data, 1000000 points in our experiment\n",
    "data_crit=np.loadtxt('')#load critic data\n",
    "data_cost=np.loadtxt('')#load cost data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48164083",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_actor=np.zeros((10,10000))\n",
    "plot_crit=np.zeros((10,10000))\n",
    "plot_cost=np.zeros((10,10000))\n",
    "for i in range(10):\n",
    "    for j in range(10000): #choose 10000 points to plot\n",
    "        plot_actor[i][j]=data_actor[i][j*100]\n",
    "        plot_crit[i][j]=data_crit[i][j*100]\n",
    "        plot_cost[i][j]=data_cost[i][j*100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "136f7863",
   "metadata": {},
   "outputs": [],
   "source": [
    "dflist=[]\n",
    "for i in range(10):\n",
    "    df=pd.DataFrame(dict(run_idx=str(i),Iteration=np.linspace(1,999901,10000),Errors=plot_cost[i],Algorithms='sac',Curve='Cost estimation error'))\n",
    "    dflist.append(df)\n",
    "for i in range(10):\n",
    "    df=pd.DataFrame(dict(run_idx=str(i),Iteration=np.linspace(1,999901,10000),Errors=plot_crit[i],Algorithms='sac',Curve='Critic error'))\n",
    "    dflist.append(df)\n",
    "for i in range(10):\n",
    "    df=pd.DataFrame(dict(run_idx=str(i),Iteration=np.linspace(1,999901,10000),Errors=plot_actor[i],Algorithms='sac',Curve='Actor performance error'))\n",
    "    dflist.append(df)\n",
    "total_DataFrame=dflist[0].append(dflist[1:],ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45416600",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig,ax = plt.subplots(figsize=(15,11))\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x='Iteration',y='Errors',hue='Curve',data=total_DataFrame,palette='colorblind',alpha=0.5)\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "ax.set_xlim(1,10**6)\n",
    "handles,labels = ax.get_legend_handles_labels()\n",
    "ax.legend(handles=handles[0:],labels=labels[0:],fontsize=40)\n",
    "ax.set_xlabel('Iteration',fontsize=40)\n",
    "ax.set_ylabel('Error',fontsize=40)\n",
    "plt.xticks(size=40)\n",
    "plt.yticks(size=40)\n",
    "#ax.set_ylim(10**(-1),10**2)\n",
    "plt.savefig('fig1(b).pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "223dd78c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e82306e4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
