{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7091cfeb",
   "metadata": {},
   "source": [
    "# DAG Example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5ad699a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import networkx as nx\n",
    "import math\n",
    "import time\n",
    "import datetime\n",
    "import os\n",
    "import pickle as pkl\n",
    "import seaborn as sns\n",
    "\n",
    "import sys\n",
    "sys.path.insert(0, '../')\n",
    "import utils\n",
    "from ahk import AHK_graphon\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "from tqdm.auto import tqdm\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "11fa586f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Random ER DAGs with min 3 and max 7 nodes \n",
      "Edge density: 0.4305799648506151\n",
      "Loaded  100  training graphs \n",
      "\n",
      "Samples:\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Load training data and display some examples:\n",
    "traindata_dump=pkl.load(open(\"../dataset/DAG/traindags.pkl\",\"rb\"))\n",
    "traindata_nx=traindata_dump['data']\n",
    "\n",
    "print(traindata_dump['readme'])\n",
    "print(\"Loaded \", len(traindata_nx), \" training graphs \\n\")\n",
    "\n",
    "print(\"Samples:\")\n",
    "\n",
    "idxs=np.random.randint(len(traindata_nx), size=5)\n",
    "for idx in idxs:\n",
    "    nx.draw_networkx(traindata_nx[idx])\n",
    "    plt.show()\n",
    "\n",
    "# transform networkx graphs into world objects:\n",
    "traindata=utils.batch_nx_to_world(traindata_nx)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "692df434",
   "metadata": {},
   "source": [
    "# Learn a model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c81dd6a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Learning settings:\n",
    "\n",
    "# Initialize model\n",
    "binbounds=utils.uni_bins(1)\n",
    "learnmodel=AHK_graphon(traindata[0].sig,binbounds)\n",
    "\n",
    "settings={}\n",
    "\n",
    "settings['num_pi_b']=50\n",
    "settings['batchsize']=5\n",
    "settings['soft']=0.001\n",
    "settings['numepochs']=50\n",
    "settings['early_stop']=3 #Number of epochs with no log-likelihood improvement required for early stopping\n",
    "settings['bingain']=0.01 #the factor by which a bin refinement has improved log-likelihood in order\n",
    "                         #to continue bin refinements\n",
    "settings['learn_bins']=False\n",
    "settings['with_trace']=False\n",
    "settings['randombatches']=False\n",
    "settings['adaptbatchsize']=False\n",
    "settings['ubias']=0.0\n",
    "settings['savepath']='../Experiments/DAG/'\n",
    "\n",
    "#Adam params:\n",
    "settings['ad_alpha']=0.01\n",
    "settings['ad_beta1']=0.9\n",
    "settings['ad_beta2']=0.999\n",
    "settings['ad_epsilon']=1e-8\n",
    "\n",
    "settings['seed']=0\n",
    "settings['method']=\"adam\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cff267da",
   "metadata": {},
   "outputs": [],
   "source": [
    "# learn:\n",
    "rng=np.random.default_rng(seed=settings['seed'])\n",
    "learnmodel.rand_init(rng)\n",
    "best,loglik,_=learnmodel.learn(settings,traindata,rng,exact_gradients=False,info_each_epoch=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "132261a3",
   "metadata": {},
   "source": [
    "# Inference"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "32f4e45a",
   "metadata": {},
   "source": [
    "Use either learned model:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "630140f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "model=best"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e69d99b4",
   "metadata": {},
   "source": [
    "Or load model from file:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5344ae4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "modelfile=\"../Experiments/DAG/model_learned.pkl\"\n",
    "model=pkl.load(open(modelfile,\"rb\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b3302c8e",
   "metadata": {},
   "source": [
    "### Small query graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a0332bdb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 216x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "all missing edges are considered 'unknown' !\n"
     ]
    }
   ],
   "source": [
    "# Define small query graph:\n",
    "w5 = utils.World(model.signature,5)\n",
    "w5.binaries+= -1\n",
    "w5.setatom(0,(4,3),1)\n",
    "w5.setatom(0,(1,2),1)\n",
    "w5.setatom(0,(1,4),1)\n",
    "w5.setatom(0,(2,4),1)\n",
    "w5.setatom(0,(2,0),1)\n",
    "\n",
    "plt.figure(figsize=(3,5))\n",
    "positions=([0,0],[0.5,2],[0,1],[1,0],[1,1])\n",
    "nx.draw_networkx(w5.to_nx(),pos=positions,with_labels=True,node_size=500,node_color='lightsteelblue')\n",
    "\n",
    "plt.axis(\"off\")\n",
    "plt.show()\n",
    "\n",
    "print(\"all missing edges are considered 'unknown' !\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "bbe6aa13",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "probability of edges \n",
      "1  ->  0   \n",
      "0.4491981032591168 \n",
      "\n",
      "probability of edges \n",
      "0  ->  3   \n",
      "0.27254294272747115 \n",
      "\n",
      "probability of edges \n",
      "3  ->  0   \n",
      "0.16315612850461306 \n",
      "\n",
      "probability of edges \n",
      "0  ->  3   \n",
      "3  ->  0   \n",
      "0.008853777262791808 \n",
      "\n",
      "probability of edges \n",
      "1  ->  0   \n",
      "0  ->  3   \n",
      "0.13160586713193118 \n",
      "\n",
      "probability of edges \n",
      "3  ->  2   \n",
      "0.011733406234197274 \n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Define the queries:\n",
    "q1=[[(0,1,0,True)],[(0,0,3,True)],[(0,3,0,True)],[(0,0,3,True),(0,3,0,True)],[(0,1,0,True),(0,0,3,True)],[(0,3,2,True)]]\n",
    "\n",
    "# Compute exact probabilities:\n",
    "qp,p,_=model.compute_prob(w5,query=q1)\n",
    "\n",
    "for i,q in enumerate(q1):\n",
    "    print(\"probability of edges \")\n",
    "    for at in q:\n",
    "        print(at[1],\" -> \",at[2], \"  \")\n",
    "    print(qp[i],\"\\n\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "33bfe537",
   "metadata": {},
   "source": [
    "### Large query graph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "12e308da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define the large query graph:\n",
    "w15 = utils.World(model.signature,15)\n",
    "w15.binaries+= -1 #making all edges unknown \n",
    "w15.setatom(0,(3,4),1)\n",
    "w15.setatom(0,(1,2),1)\n",
    "w15.setatom(0,(1,4),1)\n",
    "w15.setatom(0,(2,4),1)\n",
    "w15.setatom(0,(2,0),1)\n",
    "w15.setatom(0,(4,7),1)\n",
    "w15.setatom(0,(4,8),1)\n",
    "w15.setatom(0,(8,9),1)\n",
    "w15.setatom(0,(9,10),1)\n",
    "w15.setatom(0,(4,10),1)\n",
    "w15.setatom(0,(1,14),1)\n",
    "w15.setatom(0,(11,13),1)\n",
    "w15.setatom(0,(8,14),1)\n",
    "w15.setatom(0,(9,13),1)\n",
    "w15.setatom(0,(6,8),1)\n",
    "w15.setatom(0,(5,11),1)\n",
    "w15.setatom(0,(2,12),1)\n",
    "w15.setatom(0,(7,12),1)\n",
    "w15.setatom(0,(0,14),1)\n",
    "w15.setatom(0,(4,6),1)\n",
    "\n",
    "positions=np.array(([770,637],[520,310],[667,323],[579,339],[581,415],[759,318],\\\n",
    "           [693,451],[565,519],[702,542],[775,552],[680,666],[795,483],[646,567],[825,615],[583,738]))\n",
    "\n",
    "plt.figure(figsize=(6,4))    \n",
    "plt.axis(\"off\")\n",
    "nx.draw_networkx(w15.to_nx(),with_labels=True,pos=positions,node_color='lightsteelblue')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e08dc418",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "samples  100\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae8b3152711b4eceac75c67ee64b900d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "samples  500\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5e61b368c91145a7aa9ddeabdf9e63d3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "samples  1000\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8fb9c16efb57461b9cb3a0e073e82d21",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "samples  5000\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fdebc663f0fe42ec8a8a01303556083e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "samples  20000\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f561ea67d64d403c936d36611a6a24b4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define the queries:\n",
    "q2=[[(0,1,13,True)],[(0,13,1,True)],[(0,7,11,True)]]\n",
    "\n",
    "\n",
    "# Approximate inference with different sample sizes\n",
    "# Takes a while. For faster results, reduce maximal\n",
    "# 'numsamples' and number of runs.\n",
    "rng=np.random.default_rng()\n",
    "numsamples=[100,500,1000,5000,20000]\n",
    "#numsamples=[100,500,1000,5000]\n",
    "runs=5\n",
    "\n",
    "results=np.zeros((len(numsamples),runs,len(q2)))\n",
    "times=np.zeros(len(numsamples))\n",
    "\n",
    "for i,ns in enumerate(numsamples):\n",
    "    tick=time.time()\n",
    "    print(\"samples \",ns)\n",
    "    for j in tqdm(range(runs)):\n",
    "        p,_,_=model.importance_sample({},w15,rng,query=q2,numsamples=ns,sampler='nonseq')\n",
    "        results[i,j,:]=p\n",
    "    times[i]=time.time()-tick"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "8ebf3910",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "avgs=np.average(results,axis=1)\n",
    "std=np.std(results,axis=1)\n",
    "\n",
    "plt.errorbar(numsamples,avgs[:,0],yerr=std[:,0],label=\"1 -> 13\")\n",
    "plt.errorbar(numsamples,avgs[:,1],yerr=std[:,1],label=\"13 -> 1\")\n",
    "plt.errorbar(numsamples,avgs[:,2],yerr=std[:,2],label=\"7 -> 11\",alpha=0.5)\n",
    "plt.xscale('log')\n",
    "plt.xticks(numsamples)\n",
    "plt.xlabel(\"Samples (log scale)\")\n",
    "plt.ylabel(\"Probability\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "60b45976",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.34283869, 0.00110134, 0.25597619])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "avgs[-1,:]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba1083c9",
   "metadata": {},
   "source": [
    "# Illustrating importance sampling"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9da25131",
   "metadata": {},
   "source": [
    "Computing the exact probabilities P(pi,b,w) for all pi,b for the small graph:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5b15a70",
   "metadata": {},
   "outputs": [],
   "source": [
    "_,p,PIU=model.compute_prob(w5,return_pibs=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a6b20f81",
   "metadata": {},
   "source": [
    "Computing the probability P(w) by importance sampling, and returning the empirical sampling distribution over pi,b:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7df12603",
   "metadata": {},
   "outputs": [],
   "source": [
    "numsamples=100000\n",
    "pnew,_,SPIU=model.importance_sample({},w5,rng,return_pibs=True,\\\n",
    "                                     numsamples=numsamples,sampler=\"nonseq\",verbose=False,with_trace=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b42783ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig,axes=plt.subplots(1,2,figsize=(15,5))\n",
    "sns.heatmap(PIU,ax=axes[0])\n",
    "sns.heatmap(SPIU,ax=axes[1])\n",
    "axes[0].set_xlabel(\"Bin assignment\")\n",
    "axes[0].set_ylabel(\"Permutation\")\n",
    "axes[0].set_title(\"Exact probabilities\")\n",
    "axes[1].set_xlabel(\"Bin assignment\")\n",
    "axes[1].set_ylabel(\"Permutation\")\n",
    "axes[1].set_title(\"Importance sampling distribution\")\n",
    "#axes[1].set_xlim((36,56))\n",
    "plt.show()"
   ]
  }
 ],
 "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
