{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "Test the scale of neighbors of different graphs\n",
    "\n",
    "\"\"\"\n",
    "import os\n",
    "os.environ[\"CURL_CA_BUNDLE\"]=\"\" \n",
    "import sys\n",
    "sys.path.extend([\"../\"]) # pylint: disable=wrong-import-position\n",
    "# os.environ[\"REQUESTS_CA_BUNDLE\"]=\"\"\n",
    "import random\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "import dgl\n",
    "import dgl.data\n",
    "\n",
    "from data_utils import load_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Parameter settings and data loading\n",
    "# dataset = dgl.data.CoraGraphDataset()\n",
    "# dataset = dgl.data.PubmedGraphDataset()\n",
    "# dataset = dgl.data.RedditDataset()\n",
    "\n",
    "# from ogb.nodeproppred import DglNodePropPredDataset\n",
    "# dataset = dgl.data.AsNodePredDataset(DglNodePropPredDataset('ogbn-products'))\n",
    "\n",
    "from ogb.nodeproppred import DglNodePropPredDataset\n",
    "g = load_data('ogbn-arxiv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "g"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def count_receptive_field(g, K=[1, 2, 3], sample_size=400):\n",
    "    assert sample_size <= g.num_nodes()\n",
    "    res = []\n",
    "    all_ind = list(range(g.num_nodes()))\n",
    "    random.shuffle(all_ind)\n",
    "    for k in K:\n",
    "        tmp_res = 0\n",
    "        for n in range(sample_size):\n",
    "            tmp_res += g.khop_out_subgraph(all_ind[n], k)[0].ndata[dgl.NID].shape[0] - 1\n",
    "            \n",
    "        tmp_res /= sample_size\n",
    "        res.append(tmp_res)\n",
    "    \n",
    "    return res\n",
    "\n",
    "print(count_receptive_field(g))\n",
    "\n",
    "ave_degree = g.num_edges()/g.num_nodes()\n",
    "print([ave_degree**i for i in range(1, 4)])\n",
    "print(g.num_edges()/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "g"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gnn",
   "language": "python",
   "name": "gnn"
  },
  "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.7.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
