{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7cf22ffd",
   "metadata": {},
   "source": [
    "# Generate URN data\n",
    "\n",
    "This notebook contains codes to generate URN datasets in the paper."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "796dcfb5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "sys.path.append(os.path.abspath('../../utils'))\n",
    "from URN import *\n",
    "\n",
    "cities = {'Chicago':(41.879704398590995, -87.63328950501399),\n",
    "          'Minneapolis':(44.978331011110555, -93.2761339340752),\n",
    "          'Seattle':(47.62986527665968, -122.35338961521288),\n",
    "          'Vancouver':(49.282609146100405, -123.11856978751408),\n",
    "          'Detroit':(42.34580693579996, -83.05686243042912),\n",
    "          'Nanchang':(28.684803994523527, 115.85291275405362),\n",
    "          'Wuhan':(30.526515930950083, 114.3526219218081),\n",
    "          'Tianjin':(39.12368103375244, 117.17595776272671),\n",
    "          'Shijiazhuang':(38.04450919238834, 114.50276049809192),\n",
    "          'Shenyang':(41.802654800811304, 123.43309905717383),\n",
    "          'Omdurman':(15.648890231615937, 32.483952666592074),\n",
    "          'Dhaka':(23.796229125084544, 90.42953862191973),\n",
    "          'Ufa':(54.73489332947859, 55.95811413511287),\n",
    "          'Kano':(12.002110904880466, 8.591856823261692),\n",
    "          'Nairobi':(-1.2889461804302986, 36.82848274826223),\n",
    "          'London':(51.50139909773326, -0.14183233734628423),\n",
    "          'Toronto':(43.652617342142314, -79.38185016508831),\n",
    "          'Paris':(48.87384716485877, 2.295253003363476),\n",
    "          'Berlin':(52.520005707087186, 13.40497937683478),\n",
    "          'Nagoya':(35.181609667905924, 136.90641657095236)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6462281d",
   "metadata": {},
   "outputs": [],
   "source": [
    "name = 'test'\n",
    "\n",
    "G_list = sample_RN(cities['Chicago'], 200, 50, 1)\n",
    "C_list = sample_RN(cities['Ufa'], 200, 50, 1)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list], name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a904e058",
   "metadata": {},
   "outputs": [],
   "source": [
    "# UNR2-1S\n",
    "name = 'URN2-1S'\n",
    "\n",
    "G_list = sample_RN(cities['Chicago'], 1000, 150, 200)\n",
    "C_list = sample_RN(cities['Ufa'], 1000, 150, 200)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list], path+name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae7587f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# UNR2-1M\n",
    "name = 'URN2-1M'\n",
    "\n",
    "G_list = sample_RN(cities['Chicago'], 2000, 300, 200)\n",
    "C_list = sample_RN(cities['Ufa'], 2000, 300, 200)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list], path+name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "098a6b37",
   "metadata": {},
   "outputs": [],
   "source": [
    "# UNR2-1S\n",
    "name = 'URN2-2S'\n",
    "\n",
    "L_list = sample_RN(cities['Wuhan'], 1000, 150, 300)\n",
    "T_list = sample_RN(cities['London'], 1000, 150, 300)\n",
    "\n",
    "save_grakel_graphs([L_list, T_list], path+name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4c0050d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# UNR2-2M\n",
    "name = 'URN2-2M'\n",
    "\n",
    "L_list = sample_RN(cities['Wuhan'], 2000, 300, 300)\n",
    "T_list = sample_RN(cities['London'], 2000, 300, 300)\n",
    "\n",
    "save_grakel_graphs([L_list, T_list], path+name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "37a7c90b",
   "metadata": {},
   "outputs": [],
   "source": [
    "name = 'URN3-S'\n",
    "\n",
    "G_list = sample_RN(cities['Detroit'], 1000, 150, 200)\n",
    "C_list = sample_RN(cities['Omdurman'], 1000, 150, 200)\n",
    "L_list = sample_RN(cities['Nanchang'], 1000, 150, 200)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list, L_list], path+name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ab77e170",
   "metadata": {},
   "outputs": [],
   "source": [
    "name = 'URN3-M'\n",
    "\n",
    "G_list = sample_RN(cities['Seattle'], 2000, 300, 250)\n",
    "C_list = sample_RN(cities['Ufa'], 2000, 300, 250)\n",
    "L_list = sample_RN(cities['Tianjin'], 2000, 300, 250)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list, L_list], path+name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "98f0fd1f",
   "metadata": {},
   "outputs": [],
   "source": [
    "name = 'URN4-S'\n",
    "\n",
    "G_list = sample_RN(cities['Chicago'], 1000, 150, 200)\n",
    "C_list = sample_RN(cities['Omdurman'], 1000, 150, 200)\n",
    "L_list = sample_RN(cities['Shenyang'], 1000, 150, 200)\n",
    "T_list = sample_RN(cities['Paris'], 1000, 150, 200)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list, L_list, T_list], path+name)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "627744a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "name = 'URN4-M'\n",
    "\n",
    "G_list = sample_RN(cities['Chicago'], 2000, 300, 200)\n",
    "C_list = sample_RN(cities['Kano'], 2000, 300, 200)\n",
    "L_list = sample_RN(cities['Shenyang'], 2000, 300, 200)\n",
    "T_list = sample_RN(cities['Berlin'], 2000, 300, 200)\n",
    "\n",
    "save_grakel_graphs([G_list, C_list, L_list, T_list], path+name)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tropTW",
   "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.13.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
