{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/anaconda3/lib/python3.7/site-packages/sklearn/feature_extraction/image.py:167: DeprecationWarning: `np.int` is a deprecated alias for the builtin `int`. To silence this warning, use `int` by itself. Doing this will not modify any behavior and is safe. When replacing `np.int`, you may wish to use e.g. `np.int64` or `np.int32` to specify the precision. If you wish to review your current use, check the release note link for additional information.\n",
      "Deprecated in NumPy 1.20; for more details and guidance: https://numpy.org/devdocs/release/1.20.0-notes.html#deprecations\n",
      "  dtype=np.int):\n"
     ]
    }
   ],
   "source": [
    "import numpy as np \n",
    "import pandas as pd\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.feature_extraction import text\n",
    "import string\n",
    "from collections import Counter\n",
    "from sklearn.utils import shuffle\n",
    "import time\n",
    "import random\n",
    "import gc\n",
    "import sys\n",
    "from scipy.sparse import csr_matrix\n",
    "from scipy.sparse import csc_matrix\n",
    "import scipy.sparse as sp\n",
    "from itertools import permutations\n",
    "import seaborn as sns\n",
    "import itertools\n",
    "import matplotlib as mpl"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Create Data  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# parameters \n",
    "N = 30\n",
    "p = 0.2\n",
    "H = 300\n",
    "TOTAL_NUMBER_WORDS = N**2 \n",
    "TOTAL_NUMBER_SEN =  2000 \n",
    "start_x = int(N/2)\n",
    "start_y = 0\n",
    "end_x = start_x\n",
    "end_y = N-1 \n",
    "cur_randomness = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# data structures\n",
    "VOCABULARY = list(itertools.product(list(range(N)), repeat=2)) # all states\n",
    "VOCABULARY_MAP = dict((y,x) for x,y in enumerate(VOCABULARY))  # map each state to a scalar \n",
    "TOTAL_NUMBER_WORDS = len(VOCABULARY) \n",
    "randomness = np.random.binomial(1, p, 100000000)        # for computational reasons, all randomness is chosen here "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def limit(x):\n",
    "    if x >= N: return N-1\n",
    "    if x<0: return 0 \n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def go_up(x, y, mid, cur_randomness, verbose = False):\n",
    "    # with some probability go further then mid \n",
    "    if randomness[cur_randomness]:\n",
    "        if verbose:\n",
    "            print('noisy up')\n",
    "        x = x + (x>=mid) - (x<mid)\n",
    "    else:\n",
    "        y += 1\n",
    "    cur_randomness+=1\n",
    "    return limit(x),limit(y), cur_randomness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def go_right(x, y, cur_randomness, verbose = False):\n",
    "    # with some probability go further then mid \n",
    "    if randomness[cur_randomness]:\n",
    "        if verbose:\n",
    "            print('noisy right')\n",
    "        x = x - 1\n",
    "    else: \n",
    "        x = x + 1\n",
    "    cur_randomness+=1\n",
    "    return limit(x),limit(y), cur_randomness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def go_left(x, y, cur_randomness, verbose = False):\n",
    "    # with some probability go further than mid \n",
    "    if randomness[cur_randomness]:\n",
    "        if verbose:\n",
    "            print('noisy left')\n",
    "        x = x + 1\n",
    "    else:\n",
    "        x = x - 1\n",
    "    cur_randomness+=1    \n",
    "    return limit(x),limit(y), cur_randomness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_data(start_x, start_y, end_x, end_y, cur_randomness):\n",
    "    # start_x, start_y: initial state \n",
    "    # end_x, end_y: goal state \n",
    "    data = np.zeros((N, N)) # number of visits in each state \n",
    "    ALL_SEN = np.empty(TOTAL_NUMBER_SEN, dtype=list)\n",
    "\n",
    "    for i in range(TOTAL_NUMBER_SEN):\n",
    "        print(\"%d/%d\" % (i, TOTAL_NUMBER_SEN))\n",
    "        ALL_SEN[i] = []\n",
    "        t = 0 \n",
    "        cur_x = start_x\n",
    "        cur_y = start_y\n",
    "        data[cur_x, cur_y] += 1\n",
    "        ALL_SEN[i].append(VOCABULARY_MAP[(cur_x,cur_y)])\n",
    "        while (cur_x != end_x or cur_y != end_y) and t < H-1:\n",
    "            t+=1\n",
    "            if cur_y < end_y:\n",
    "                cur_x, cur_y, cur_randomness = go_up(cur_x,cur_y,start_x, cur_randomness)\n",
    "            else:\n",
    "                if cur_x < end_x-1:\n",
    "                    cur_x, cur_y, cur_randomness = go_right(cur_x,cur_y, cur_randomness)\n",
    "                else:\n",
    "                    cur_x, cur_y, cur_randomness = go_left(cur_x,cur_y, cur_randomness)\n",
    "            data[cur_x, cur_y] += 1\n",
    "            ALL_SEN[i].append(VOCABULARY_MAP[(cur_x,cur_y)])\n",
    "    return data, ALL_SEN, cur_randomness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0/2000\n",
      "1/2000\n",
      "2/2000\n",
      "3/2000\n",
      "4/2000\n",
      "5/2000\n",
      "6/2000\n",
      "7/2000\n",
      "8/2000\n",
      "9/2000\n",
      "10/2000\n",
      "11/2000\n",
      "12/2000\n",
      "13/2000\n",
      "14/2000\n",
      "15/2000\n",
      "16/2000\n",
      "17/2000\n",
      "18/2000\n",
      "19/2000\n",
      "20/2000\n",
      "21/2000\n",
      "22/2000\n",
      "23/2000\n",
      "24/2000\n",
      "25/2000\n",
      "26/2000\n",
      "27/2000\n",
      "28/2000\n",
      "29/2000\n",
      "30/2000\n",
      "31/2000\n",
      "32/2000\n",
      "33/2000\n",
      "34/2000\n",
      "35/2000\n",
      "36/2000\n",
      "37/2000\n",
      "38/2000\n",
      "39/2000\n",
      "40/2000\n",
      "41/2000\n",
      "42/2000\n",
      "43/2000\n",
      "44/2000\n",
      "45/2000\n",
      "46/2000\n",
      "47/2000\n",
      "48/2000\n",
      "49/2000\n",
      "50/2000\n",
      "51/2000\n",
      "52/2000\n",
      "53/2000\n",
      "54/2000\n",
      "55/2000\n",
      "56/2000\n",
      "57/2000\n",
      "58/2000\n",
      "59/2000\n",
      "60/2000\n",
      "61/2000\n",
      "62/2000\n",
      "63/2000\n",
      "64/2000\n",
      "65/2000\n",
      "66/2000\n",
      "67/2000\n",
      "68/2000\n",
      "69/2000\n",
      "70/2000\n",
      "71/2000\n",
      "72/2000\n",
      "73/2000\n",
      "74/2000\n",
      "75/2000\n",
      "76/2000\n",
      "77/2000\n",
      "78/2000\n",
      "79/2000\n",
      "80/2000\n",
      "81/2000\n",
      "82/2000\n",
      "83/2000\n",
      "84/2000\n",
      "85/2000\n",
      "86/2000\n",
      "87/2000\n",
      "88/2000\n",
      "89/2000\n",
      "90/2000\n",
      "91/2000\n",
      "92/2000\n",
      "93/2000\n",
      "94/2000\n",
      "95/2000\n",
      "96/2000\n",
      "97/2000\n",
      "98/2000\n",
      "99/2000\n",
      "100/2000\n",
      "101/2000\n",
      "102/2000\n",
      "103/2000\n",
      "104/2000\n",
      "105/2000\n",
      "106/2000\n",
      "107/2000\n",
      "108/2000\n",
      "109/2000\n",
      "110/2000\n",
      "111/2000\n",
      "112/2000\n",
      "113/2000\n",
      "114/2000\n",
      "115/2000\n",
      "116/2000\n",
      "117/2000\n",
      "118/2000\n",
      "119/2000\n",
      "120/2000\n",
      "121/2000\n",
      "122/2000\n",
      "123/2000\n",
      "124/2000\n",
      "125/2000\n",
      "126/2000\n",
      "127/2000\n",
      "128/2000\n",
      "129/2000\n",
      "130/2000\n",
      "131/2000\n",
      "132/2000\n",
      "133/2000\n",
      "134/2000\n",
      "135/2000\n",
      "136/2000\n",
      "137/2000\n",
      "138/2000\n",
      "139/2000\n",
      "140/2000\n",
      "141/2000\n",
      "142/2000\n",
      "143/2000\n",
      "144/2000\n",
      "145/2000\n",
      "146/2000\n",
      "147/2000\n",
      "148/2000\n",
      "149/2000\n",
      "150/2000\n",
      "151/2000\n",
      "152/2000\n",
      "153/2000\n",
      "154/2000\n",
      "155/2000\n",
      "156/2000\n",
      "157/2000\n",
      "158/2000\n",
      "159/2000\n",
      "160/2000\n",
      "161/2000\n",
      "162/2000\n",
      "163/2000\n",
      "164/2000\n",
      "165/2000\n",
      "166/2000\n",
      "167/2000\n",
      "168/2000\n",
      "169/2000\n",
      "170/2000\n",
      "171/2000\n",
      "172/2000\n",
      "173/2000\n",
      "174/2000\n",
      "175/2000\n",
      "176/2000\n",
      "177/2000\n",
      "178/2000\n",
      "179/2000\n",
      "180/2000\n",
      "181/2000\n",
      "182/2000\n",
      "183/2000\n",
      "184/2000\n",
      "185/2000\n",
      "186/2000\n",
      "187/2000\n",
      "188/2000\n",
      "189/2000\n",
      "190/2000\n",
      "191/2000\n",
      "192/2000\n",
      "193/2000\n",
      "194/2000\n",
      "195/2000\n",
      "196/2000\n",
      "197/2000\n",
      "198/2000\n",
      "199/2000\n",
      "200/2000\n",
      "201/2000\n",
      "202/2000\n",
      "203/2000\n",
      "204/2000\n",
      "205/2000\n",
      "206/2000\n",
      "207/2000\n",
      "208/2000\n",
      "209/2000\n",
      "210/2000\n",
      "211/2000\n",
      "212/2000\n",
      "213/2000\n",
      "214/2000\n",
      "215/2000\n",
      "216/2000\n",
      "217/2000\n",
      "218/2000\n",
      "219/2000\n",
      "220/2000\n",
      "221/2000\n",
      "222/2000\n",
      "223/2000\n",
      "224/2000\n",
      "225/2000\n",
      "226/2000\n",
      "227/2000\n",
      "228/2000\n",
      "229/2000\n",
      "230/2000\n",
      "231/2000\n",
      "232/2000\n",
      "233/2000\n",
      "234/2000\n",
      "235/2000\n",
      "236/2000\n",
      "237/2000\n",
      "238/2000\n",
      "239/2000\n",
      "240/2000\n",
      "241/2000\n",
      "242/2000\n",
      "243/2000\n",
      "244/2000\n",
      "245/2000\n",
      "246/2000\n",
      "247/2000\n",
      "248/2000\n",
      "249/2000\n",
      "250/2000\n",
      "251/2000\n",
      "252/2000\n",
      "253/2000\n",
      "254/2000\n",
      "255/2000\n",
      "256/2000\n",
      "257/2000\n",
      "258/2000\n",
      "259/2000\n",
      "260/2000\n",
      "261/2000\n",
      "262/2000\n",
      "263/2000\n",
      "264/2000\n",
      "265/2000\n",
      "266/2000\n",
      "267/2000\n",
      "268/2000\n",
      "269/2000\n",
      "270/2000\n",
      "271/2000\n",
      "272/2000\n",
      "273/2000\n",
      "274/2000\n",
      "275/2000\n",
      "276/2000\n",
      "277/2000\n",
      "278/2000\n",
      "279/2000\n",
      "280/2000\n",
      "281/2000\n",
      "282/2000\n",
      "283/2000\n",
      "284/2000\n",
      "285/2000\n",
      "286/2000\n",
      "287/2000\n",
      "288/2000\n",
      "289/2000\n",
      "290/2000\n",
      "291/2000\n",
      "292/2000\n",
      "293/2000\n",
      "294/2000\n",
      "295/2000\n",
      "296/2000\n",
      "297/2000\n",
      "298/2000\n",
      "299/2000\n",
      "300/2000\n",
      "301/2000\n",
      "302/2000\n",
      "303/2000\n",
      "304/2000\n",
      "305/2000\n",
      "306/2000\n",
      "307/2000\n",
      "308/2000\n",
      "309/2000\n",
      "310/2000\n",
      "311/2000\n",
      "312/2000\n",
      "313/2000\n",
      "314/2000\n",
      "315/2000\n",
      "316/2000\n",
      "317/2000\n",
      "318/2000\n",
      "319/2000\n",
      "320/2000\n",
      "321/2000\n",
      "322/2000\n",
      "323/2000\n",
      "324/2000\n",
      "325/2000\n",
      "326/2000\n",
      "327/2000\n",
      "328/2000\n",
      "329/2000\n",
      "330/2000\n",
      "331/2000\n",
      "332/2000\n",
      "333/2000\n",
      "334/2000\n",
      "335/2000\n",
      "336/2000\n",
      "337/2000\n",
      "338/2000\n",
      "339/2000\n",
      "340/2000\n",
      "341/2000\n",
      "342/2000\n",
      "343/2000\n",
      "344/2000\n",
      "345/2000\n",
      "346/2000\n",
      "347/2000\n",
      "348/2000\n",
      "349/2000\n",
      "350/2000\n",
      "351/2000\n",
      "352/2000\n",
      "353/2000\n",
      "354/2000\n",
      "355/2000\n",
      "356/2000\n",
      "357/2000\n",
      "358/2000\n",
      "359/2000\n",
      "360/2000\n",
      "361/2000\n",
      "362/2000\n",
      "363/2000\n",
      "364/2000\n",
      "365/2000\n",
      "366/2000\n",
      "367/2000\n",
      "368/2000\n",
      "369/2000\n",
      "370/2000\n",
      "371/2000\n",
      "372/2000\n",
      "373/2000\n",
      "374/2000\n",
      "375/2000\n",
      "376/2000\n",
      "377/2000\n",
      "378/2000\n",
      "379/2000\n",
      "380/2000\n",
      "381/2000\n",
      "382/2000\n",
      "383/2000\n",
      "384/2000\n",
      "385/2000\n",
      "386/2000\n",
      "387/2000\n",
      "388/2000\n",
      "389/2000\n",
      "390/2000\n",
      "391/2000\n",
      "392/2000\n",
      "393/2000\n",
      "394/2000\n",
      "395/2000\n",
      "396/2000\n",
      "397/2000\n",
      "398/2000\n",
      "399/2000\n",
      "400/2000\n",
      "401/2000\n",
      "402/2000\n",
      "403/2000\n",
      "404/2000\n",
      "405/2000\n",
      "406/2000\n",
      "407/2000\n",
      "408/2000\n",
      "409/2000\n",
      "410/2000\n",
      "411/2000\n",
      "412/2000\n",
      "413/2000\n",
      "414/2000\n",
      "415/2000\n",
      "416/2000\n",
      "417/2000\n",
      "418/2000\n",
      "419/2000\n",
      "420/2000\n",
      "421/2000\n",
      "422/2000\n",
      "423/2000\n",
      "424/2000\n",
      "425/2000\n",
      "426/2000\n",
      "427/2000\n",
      "428/2000\n",
      "429/2000\n",
      "430/2000\n",
      "431/2000\n",
      "432/2000\n",
      "433/2000\n",
      "434/2000\n",
      "435/2000\n",
      "436/2000\n",
      "437/2000\n",
      "438/2000\n",
      "439/2000\n",
      "440/2000\n",
      "441/2000\n",
      "442/2000\n",
      "443/2000\n",
      "444/2000\n",
      "445/2000\n",
      "446/2000\n",
      "447/2000\n",
      "448/2000\n",
      "449/2000\n",
      "450/2000\n",
      "451/2000\n",
      "452/2000\n",
      "453/2000\n",
      "454/2000\n",
      "455/2000\n",
      "456/2000\n",
      "457/2000\n",
      "458/2000\n",
      "459/2000\n",
      "460/2000\n",
      "461/2000\n",
      "462/2000\n",
      "463/2000\n",
      "464/2000\n",
      "465/2000\n",
      "466/2000\n",
      "467/2000\n",
      "468/2000\n",
      "469/2000\n",
      "470/2000\n",
      "471/2000\n",
      "472/2000\n",
      "473/2000\n",
      "474/2000\n",
      "475/2000\n",
      "476/2000\n",
      "477/2000\n",
      "478/2000\n",
      "479/2000\n",
      "480/2000\n",
      "481/2000\n",
      "482/2000\n",
      "483/2000\n",
      "484/2000\n",
      "485/2000\n",
      "486/2000\n",
      "487/2000\n",
      "488/2000\n",
      "489/2000\n",
      "490/2000\n",
      "491/2000\n",
      "492/2000\n",
      "493/2000\n",
      "494/2000\n",
      "495/2000\n",
      "496/2000\n",
      "497/2000\n",
      "498/2000\n",
      "499/2000\n",
      "500/2000\n",
      "501/2000\n",
      "502/2000\n",
      "503/2000\n",
      "504/2000\n",
      "505/2000\n",
      "506/2000\n",
      "507/2000\n",
      "508/2000\n",
      "509/2000\n",
      "510/2000\n",
      "511/2000\n",
      "512/2000\n",
      "513/2000\n",
      "514/2000\n",
      "515/2000\n",
      "516/2000\n",
      "517/2000\n",
      "518/2000\n",
      "519/2000\n",
      "520/2000\n",
      "521/2000\n",
      "522/2000\n",
      "523/2000\n",
      "524/2000\n",
      "525/2000\n",
      "526/2000\n",
      "527/2000\n",
      "528/2000\n",
      "529/2000\n",
      "530/2000\n",
      "531/2000\n",
      "532/2000\n",
      "533/2000\n",
      "534/2000\n",
      "535/2000\n",
      "536/2000\n",
      "537/2000\n",
      "538/2000\n",
      "539/2000\n",
      "540/2000\n",
      "541/2000\n",
      "542/2000\n",
      "543/2000\n",
      "544/2000\n",
      "545/2000\n",
      "546/2000\n",
      "547/2000\n",
      "548/2000\n",
      "549/2000\n",
      "550/2000\n",
      "551/2000\n",
      "552/2000\n",
      "553/2000\n",
      "554/2000\n",
      "555/2000\n",
      "556/2000\n",
      "557/2000\n",
      "558/2000\n",
      "559/2000\n",
      "560/2000\n",
      "561/2000\n",
      "562/2000\n",
      "563/2000\n",
      "564/2000\n",
      "565/2000\n",
      "566/2000\n",
      "567/2000\n",
      "568/2000\n",
      "569/2000\n",
      "570/2000\n",
      "571/2000\n",
      "572/2000\n",
      "573/2000\n",
      "574/2000\n",
      "575/2000\n",
      "576/2000\n",
      "577/2000\n",
      "578/2000\n",
      "579/2000\n",
      "580/2000\n",
      "581/2000\n",
      "582/2000\n",
      "583/2000\n",
      "584/2000\n",
      "585/2000\n",
      "586/2000\n",
      "587/2000\n",
      "588/2000\n",
      "589/2000\n",
      "590/2000\n",
      "591/2000\n",
      "592/2000\n",
      "593/2000\n",
      "594/2000\n",
      "595/2000\n",
      "596/2000\n",
      "597/2000\n",
      "598/2000\n",
      "599/2000\n",
      "600/2000\n",
      "601/2000\n",
      "602/2000\n",
      "603/2000\n",
      "604/2000\n",
      "605/2000\n",
      "606/2000\n",
      "607/2000\n",
      "608/2000\n",
      "609/2000\n",
      "610/2000\n",
      "611/2000\n",
      "612/2000\n",
      "613/2000\n",
      "614/2000\n",
      "615/2000\n",
      "616/2000\n",
      "617/2000\n",
      "618/2000\n",
      "619/2000\n",
      "620/2000\n",
      "621/2000\n",
      "622/2000\n",
      "623/2000\n",
      "624/2000\n",
      "625/2000\n",
      "626/2000\n",
      "627/2000\n",
      "628/2000\n",
      "629/2000\n",
      "630/2000\n",
      "631/2000\n",
      "632/2000\n",
      "633/2000\n",
      "634/2000\n",
      "635/2000\n",
      "636/2000\n",
      "637/2000\n",
      "638/2000\n",
      "639/2000\n",
      "640/2000\n",
      "641/2000\n",
      "642/2000\n",
      "643/2000\n",
      "644/2000\n",
      "645/2000\n",
      "646/2000\n",
      "647/2000\n",
      "648/2000\n",
      "649/2000\n",
      "650/2000\n",
      "651/2000\n",
      "652/2000\n",
      "653/2000\n",
      "654/2000\n",
      "655/2000\n",
      "656/2000\n",
      "657/2000\n",
      "658/2000\n",
      "659/2000\n",
      "660/2000\n",
      "661/2000\n",
      "662/2000\n",
      "663/2000\n",
      "664/2000\n",
      "665/2000\n",
      "666/2000\n",
      "667/2000\n",
      "668/2000\n",
      "669/2000\n",
      "670/2000\n",
      "671/2000\n",
      "672/2000\n",
      "673/2000\n",
      "674/2000\n",
      "675/2000\n",
      "676/2000\n",
      "677/2000\n",
      "678/2000\n",
      "679/2000\n",
      "680/2000\n",
      "681/2000\n",
      "682/2000\n",
      "683/2000\n",
      "684/2000\n",
      "685/2000\n",
      "686/2000\n",
      "687/2000\n",
      "688/2000\n",
      "689/2000\n",
      "690/2000\n",
      "691/2000\n",
      "692/2000\n",
      "693/2000\n",
      "694/2000\n",
      "695/2000\n",
      "696/2000\n",
      "697/2000\n",
      "698/2000\n",
      "699/2000\n",
      "700/2000\n",
      "701/2000\n",
      "702/2000\n",
      "703/2000\n",
      "704/2000\n",
      "705/2000\n",
      "706/2000\n",
      "707/2000\n",
      "708/2000\n",
      "709/2000\n",
      "710/2000\n",
      "711/2000\n",
      "712/2000\n",
      "713/2000\n",
      "714/2000\n",
      "715/2000\n",
      "716/2000\n",
      "717/2000\n",
      "718/2000\n",
      "719/2000\n",
      "720/2000\n",
      "721/2000\n",
      "722/2000\n",
      "723/2000\n",
      "724/2000\n",
      "725/2000\n",
      "726/2000\n",
      "727/2000\n",
      "728/2000\n",
      "729/2000\n",
      "730/2000\n",
      "731/2000\n",
      "732/2000\n",
      "733/2000\n",
      "734/2000\n",
      "735/2000\n",
      "736/2000\n",
      "737/2000\n",
      "738/2000\n",
      "739/2000\n",
      "740/2000\n",
      "741/2000\n",
      "742/2000\n",
      "743/2000\n",
      "744/2000\n",
      "745/2000\n",
      "746/2000\n",
      "747/2000\n",
      "748/2000\n",
      "749/2000\n",
      "750/2000\n",
      "751/2000\n",
      "752/2000\n",
      "753/2000\n",
      "754/2000\n",
      "755/2000\n",
      "756/2000\n",
      "757/2000\n",
      "758/2000\n",
      "759/2000\n",
      "760/2000\n",
      "761/2000\n",
      "762/2000\n",
      "763/2000\n",
      "764/2000\n",
      "765/2000\n",
      "766/2000\n",
      "767/2000\n",
      "768/2000\n",
      "769/2000\n",
      "770/2000\n",
      "771/2000\n",
      "772/2000\n",
      "773/2000\n",
      "774/2000\n",
      "775/2000\n",
      "776/2000\n",
      "777/2000\n",
      "778/2000\n",
      "779/2000\n",
      "780/2000\n",
      "781/2000\n",
      "782/2000\n",
      "783/2000\n",
      "784/2000\n",
      "785/2000\n",
      "786/2000\n",
      "787/2000\n",
      "788/2000\n",
      "789/2000\n",
      "790/2000\n",
      "791/2000\n",
      "792/2000\n",
      "793/2000\n",
      "794/2000\n",
      "795/2000\n",
      "796/2000\n",
      "797/2000\n",
      "798/2000\n",
      "799/2000\n",
      "800/2000\n",
      "801/2000\n",
      "802/2000\n",
      "803/2000\n",
      "804/2000\n",
      "805/2000\n",
      "806/2000\n",
      "807/2000\n",
      "808/2000\n",
      "809/2000\n",
      "810/2000\n",
      "811/2000\n",
      "812/2000\n",
      "813/2000\n",
      "814/2000\n",
      "815/2000\n",
      "816/2000\n",
      "817/2000\n",
      "818/2000\n",
      "819/2000\n",
      "820/2000\n",
      "821/2000\n",
      "822/2000\n",
      "823/2000\n",
      "824/2000\n",
      "825/2000\n",
      "826/2000\n",
      "827/2000\n",
      "828/2000\n",
      "829/2000\n",
      "830/2000\n",
      "831/2000\n",
      "832/2000\n",
      "833/2000\n",
      "834/2000\n",
      "835/2000\n",
      "836/2000\n",
      "837/2000\n",
      "838/2000\n",
      "839/2000\n",
      "840/2000\n",
      "841/2000\n",
      "842/2000\n",
      "843/2000\n",
      "844/2000\n",
      "845/2000\n",
      "846/2000\n",
      "847/2000\n",
      "848/2000\n",
      "849/2000\n",
      "850/2000\n",
      "851/2000\n",
      "852/2000\n",
      "853/2000\n",
      "854/2000\n",
      "855/2000\n",
      "856/2000\n",
      "857/2000\n",
      "858/2000\n",
      "859/2000\n",
      "860/2000\n",
      "861/2000\n",
      "862/2000\n",
      "863/2000\n",
      "864/2000\n",
      "865/2000\n",
      "866/2000\n",
      "867/2000\n",
      "868/2000\n",
      "869/2000\n",
      "870/2000\n",
      "871/2000\n",
      "872/2000\n",
      "873/2000\n",
      "874/2000\n",
      "875/2000\n",
      "876/2000\n",
      "877/2000\n",
      "878/2000\n",
      "879/2000\n",
      "880/2000\n",
      "881/2000\n",
      "882/2000\n",
      "883/2000\n",
      "884/2000\n",
      "885/2000\n",
      "886/2000\n",
      "887/2000\n",
      "888/2000\n",
      "889/2000\n",
      "890/2000\n",
      "891/2000\n",
      "892/2000\n",
      "893/2000\n",
      "894/2000\n",
      "895/2000\n",
      "896/2000\n",
      "897/2000\n",
      "898/2000\n",
      "899/2000\n",
      "900/2000\n",
      "901/2000\n",
      "902/2000\n",
      "903/2000\n",
      "904/2000\n",
      "905/2000\n",
      "906/2000\n",
      "907/2000\n",
      "908/2000\n",
      "909/2000\n",
      "910/2000\n",
      "911/2000\n",
      "912/2000\n",
      "913/2000\n",
      "914/2000\n",
      "915/2000\n",
      "916/2000\n",
      "917/2000\n",
      "918/2000\n",
      "919/2000\n",
      "920/2000\n",
      "921/2000\n",
      "922/2000\n",
      "923/2000\n",
      "924/2000\n",
      "925/2000\n",
      "926/2000\n",
      "927/2000\n",
      "928/2000\n",
      "929/2000\n",
      "930/2000\n",
      "931/2000\n",
      "932/2000\n",
      "933/2000\n",
      "934/2000\n",
      "935/2000\n",
      "936/2000\n",
      "937/2000\n",
      "938/2000\n",
      "939/2000\n",
      "940/2000\n",
      "941/2000\n",
      "942/2000\n",
      "943/2000\n",
      "944/2000\n",
      "945/2000\n",
      "946/2000\n",
      "947/2000\n",
      "948/2000\n",
      "949/2000\n",
      "950/2000\n",
      "951/2000\n",
      "952/2000\n",
      "953/2000\n",
      "954/2000\n",
      "955/2000\n",
      "956/2000\n",
      "957/2000\n",
      "958/2000\n",
      "959/2000\n",
      "960/2000\n",
      "961/2000\n",
      "962/2000\n",
      "963/2000\n",
      "964/2000\n",
      "965/2000\n",
      "966/2000\n",
      "967/2000\n",
      "968/2000\n",
      "969/2000\n",
      "970/2000\n",
      "971/2000\n",
      "972/2000\n",
      "973/2000\n",
      "974/2000\n",
      "975/2000\n",
      "976/2000\n",
      "977/2000\n",
      "978/2000\n",
      "979/2000\n",
      "980/2000\n",
      "981/2000\n",
      "982/2000\n",
      "983/2000\n",
      "984/2000\n",
      "985/2000\n",
      "986/2000\n",
      "987/2000\n",
      "988/2000\n",
      "989/2000\n",
      "990/2000\n",
      "991/2000\n",
      "992/2000\n",
      "993/2000\n",
      "994/2000\n",
      "995/2000\n",
      "996/2000\n",
      "997/2000\n",
      "998/2000\n",
      "999/2000\n",
      "1000/2000\n",
      "1001/2000\n",
      "1002/2000\n",
      "1003/2000\n",
      "1004/2000\n",
      "1005/2000\n",
      "1006/2000\n",
      "1007/2000\n",
      "1008/2000\n",
      "1009/2000\n",
      "1010/2000\n",
      "1011/2000\n",
      "1012/2000\n",
      "1013/2000\n",
      "1014/2000\n",
      "1015/2000\n",
      "1016/2000\n",
      "1017/2000\n",
      "1018/2000\n",
      "1019/2000\n",
      "1020/2000\n",
      "1021/2000\n",
      "1022/2000\n",
      "1023/2000\n",
      "1024/2000\n",
      "1025/2000\n",
      "1026/2000\n",
      "1027/2000\n",
      "1028/2000\n",
      "1029/2000\n",
      "1030/2000\n",
      "1031/2000\n",
      "1032/2000\n",
      "1033/2000\n",
      "1034/2000\n",
      "1035/2000\n",
      "1036/2000\n",
      "1037/2000\n",
      "1038/2000\n",
      "1039/2000\n",
      "1040/2000\n",
      "1041/2000\n",
      "1042/2000\n",
      "1043/2000\n",
      "1044/2000\n",
      "1045/2000\n",
      "1046/2000\n",
      "1047/2000\n",
      "1048/2000\n",
      "1049/2000\n",
      "1050/2000\n",
      "1051/2000\n",
      "1052/2000\n",
      "1053/2000\n",
      "1054/2000\n",
      "1055/2000\n",
      "1056/2000\n",
      "1057/2000\n",
      "1058/2000\n",
      "1059/2000\n",
      "1060/2000\n",
      "1061/2000\n",
      "1062/2000\n",
      "1063/2000\n",
      "1064/2000\n",
      "1065/2000\n",
      "1066/2000\n",
      "1067/2000\n",
      "1068/2000\n",
      "1069/2000\n",
      "1070/2000\n",
      "1071/2000\n",
      "1072/2000\n",
      "1073/2000\n",
      "1074/2000\n",
      "1075/2000\n",
      "1076/2000\n",
      "1077/2000\n",
      "1078/2000\n",
      "1079/2000\n",
      "1080/2000\n",
      "1081/2000\n",
      "1082/2000\n",
      "1083/2000\n",
      "1084/2000\n",
      "1085/2000\n",
      "1086/2000\n",
      "1087/2000\n",
      "1088/2000\n",
      "1089/2000\n",
      "1090/2000\n",
      "1091/2000\n",
      "1092/2000\n",
      "1093/2000\n",
      "1094/2000\n",
      "1095/2000\n",
      "1096/2000\n",
      "1097/2000\n",
      "1098/2000\n",
      "1099/2000\n",
      "1100/2000\n",
      "1101/2000\n",
      "1102/2000\n",
      "1103/2000\n",
      "1104/2000\n",
      "1105/2000\n",
      "1106/2000\n",
      "1107/2000\n",
      "1108/2000\n",
      "1109/2000\n",
      "1110/2000\n",
      "1111/2000\n",
      "1112/2000\n",
      "1113/2000\n",
      "1114/2000\n",
      "1115/2000\n",
      "1116/2000\n",
      "1117/2000\n",
      "1118/2000\n",
      "1119/2000\n",
      "1120/2000\n",
      "1121/2000\n",
      "1122/2000\n",
      "1123/2000\n",
      "1124/2000\n",
      "1125/2000\n",
      "1126/2000\n",
      "1127/2000\n",
      "1128/2000\n",
      "1129/2000\n",
      "1130/2000\n",
      "1131/2000\n",
      "1132/2000\n",
      "1133/2000\n",
      "1134/2000\n",
      "1135/2000\n",
      "1136/2000\n",
      "1137/2000\n",
      "1138/2000\n",
      "1139/2000\n",
      "1140/2000\n",
      "1141/2000\n",
      "1142/2000\n",
      "1143/2000\n",
      "1144/2000\n",
      "1145/2000\n",
      "1146/2000\n",
      "1147/2000\n",
      "1148/2000\n",
      "1149/2000\n",
      "1150/2000\n",
      "1151/2000\n",
      "1152/2000\n",
      "1153/2000\n",
      "1154/2000\n",
      "1155/2000\n",
      "1156/2000\n",
      "1157/2000\n",
      "1158/2000\n",
      "1159/2000\n",
      "1160/2000\n",
      "1161/2000\n",
      "1162/2000\n",
      "1163/2000\n",
      "1164/2000\n",
      "1165/2000\n",
      "1166/2000\n",
      "1167/2000\n",
      "1168/2000\n",
      "1169/2000\n",
      "1170/2000\n",
      "1171/2000\n",
      "1172/2000\n",
      "1173/2000\n",
      "1174/2000\n",
      "1175/2000\n",
      "1176/2000\n",
      "1177/2000\n",
      "1178/2000\n",
      "1179/2000\n",
      "1180/2000\n",
      "1181/2000\n",
      "1182/2000\n",
      "1183/2000\n",
      "1184/2000\n",
      "1185/2000\n",
      "1186/2000\n",
      "1187/2000\n",
      "1188/2000\n",
      "1189/2000\n",
      "1190/2000\n",
      "1191/2000\n",
      "1192/2000\n",
      "1193/2000\n",
      "1194/2000\n",
      "1195/2000\n",
      "1196/2000\n",
      "1197/2000\n",
      "1198/2000\n",
      "1199/2000\n",
      "1200/2000\n",
      "1201/2000\n",
      "1202/2000\n",
      "1203/2000\n",
      "1204/2000\n",
      "1205/2000\n",
      "1206/2000\n",
      "1207/2000\n",
      "1208/2000\n",
      "1209/2000\n",
      "1210/2000\n",
      "1211/2000\n",
      "1212/2000\n",
      "1213/2000\n",
      "1214/2000\n",
      "1215/2000\n",
      "1216/2000\n",
      "1217/2000\n",
      "1218/2000\n",
      "1219/2000\n",
      "1220/2000\n",
      "1221/2000\n",
      "1222/2000\n",
      "1223/2000\n",
      "1224/2000\n",
      "1225/2000\n",
      "1226/2000\n",
      "1227/2000\n",
      "1228/2000\n",
      "1229/2000\n",
      "1230/2000\n",
      "1231/2000\n",
      "1232/2000\n",
      "1233/2000\n",
      "1234/2000\n",
      "1235/2000\n",
      "1236/2000\n",
      "1237/2000\n",
      "1238/2000\n",
      "1239/2000\n",
      "1240/2000\n",
      "1241/2000\n",
      "1242/2000\n",
      "1243/2000\n",
      "1244/2000\n",
      "1245/2000\n",
      "1246/2000\n",
      "1247/2000\n",
      "1248/2000\n",
      "1249/2000\n",
      "1250/2000\n",
      "1251/2000\n",
      "1252/2000\n",
      "1253/2000\n",
      "1254/2000\n",
      "1255/2000\n",
      "1256/2000\n",
      "1257/2000\n",
      "1258/2000\n",
      "1259/2000\n",
      "1260/2000\n",
      "1261/2000\n",
      "1262/2000\n",
      "1263/2000\n",
      "1264/2000\n",
      "1265/2000\n",
      "1266/2000\n",
      "1267/2000\n",
      "1268/2000\n",
      "1269/2000\n",
      "1270/2000\n",
      "1271/2000\n",
      "1272/2000\n",
      "1273/2000\n",
      "1274/2000\n",
      "1275/2000\n",
      "1276/2000\n",
      "1277/2000\n",
      "1278/2000\n",
      "1279/2000\n",
      "1280/2000\n",
      "1281/2000\n",
      "1282/2000\n",
      "1283/2000\n",
      "1284/2000\n",
      "1285/2000\n",
      "1286/2000\n",
      "1287/2000\n",
      "1288/2000\n",
      "1289/2000\n",
      "1290/2000\n",
      "1291/2000\n",
      "1292/2000\n",
      "1293/2000\n",
      "1294/2000\n",
      "1295/2000\n",
      "1296/2000\n",
      "1297/2000\n",
      "1298/2000\n",
      "1299/2000\n",
      "1300/2000\n",
      "1301/2000\n",
      "1302/2000\n",
      "1303/2000\n",
      "1304/2000\n",
      "1305/2000\n",
      "1306/2000\n",
      "1307/2000\n",
      "1308/2000\n",
      "1309/2000\n",
      "1310/2000\n",
      "1311/2000\n",
      "1312/2000\n",
      "1313/2000\n",
      "1314/2000\n",
      "1315/2000\n",
      "1316/2000\n",
      "1317/2000\n",
      "1318/2000\n",
      "1319/2000\n",
      "1320/2000\n",
      "1321/2000\n",
      "1322/2000\n",
      "1323/2000\n",
      "1324/2000\n",
      "1325/2000\n",
      "1326/2000\n",
      "1327/2000\n",
      "1328/2000\n",
      "1329/2000\n",
      "1330/2000\n",
      "1331/2000\n",
      "1332/2000\n",
      "1333/2000\n",
      "1334/2000\n",
      "1335/2000\n",
      "1336/2000\n",
      "1337/2000\n",
      "1338/2000\n",
      "1339/2000\n",
      "1340/2000\n",
      "1341/2000\n",
      "1342/2000\n",
      "1343/2000\n",
      "1344/2000\n",
      "1345/2000\n",
      "1346/2000\n",
      "1347/2000\n",
      "1348/2000\n",
      "1349/2000\n",
      "1350/2000\n",
      "1351/2000\n",
      "1352/2000\n",
      "1353/2000\n",
      "1354/2000\n",
      "1355/2000\n",
      "1356/2000\n",
      "1357/2000\n",
      "1358/2000\n",
      "1359/2000\n",
      "1360/2000\n",
      "1361/2000\n",
      "1362/2000\n",
      "1363/2000\n",
      "1364/2000\n",
      "1365/2000\n",
      "1366/2000\n",
      "1367/2000\n",
      "1368/2000\n",
      "1369/2000\n",
      "1370/2000\n",
      "1371/2000\n",
      "1372/2000\n",
      "1373/2000\n",
      "1374/2000\n",
      "1375/2000\n",
      "1376/2000\n",
      "1377/2000\n",
      "1378/2000\n",
      "1379/2000\n",
      "1380/2000\n",
      "1381/2000\n",
      "1382/2000\n",
      "1383/2000\n",
      "1384/2000\n",
      "1385/2000\n",
      "1386/2000\n",
      "1387/2000\n",
      "1388/2000\n",
      "1389/2000\n",
      "1390/2000\n",
      "1391/2000\n",
      "1392/2000\n",
      "1393/2000\n",
      "1394/2000\n",
      "1395/2000\n",
      "1396/2000\n",
      "1397/2000\n",
      "1398/2000\n",
      "1399/2000\n",
      "1400/2000\n",
      "1401/2000\n",
      "1402/2000\n",
      "1403/2000\n",
      "1404/2000\n",
      "1405/2000\n",
      "1406/2000\n",
      "1407/2000\n",
      "1408/2000\n",
      "1409/2000\n",
      "1410/2000\n",
      "1411/2000\n",
      "1412/2000\n",
      "1413/2000\n",
      "1414/2000\n",
      "1415/2000\n",
      "1416/2000\n",
      "1417/2000\n",
      "1418/2000\n",
      "1419/2000\n",
      "1420/2000\n",
      "1421/2000\n",
      "1422/2000\n",
      "1423/2000\n",
      "1424/2000\n",
      "1425/2000\n",
      "1426/2000\n",
      "1427/2000\n",
      "1428/2000\n",
      "1429/2000\n",
      "1430/2000\n",
      "1431/2000\n",
      "1432/2000\n",
      "1433/2000\n",
      "1434/2000\n",
      "1435/2000\n",
      "1436/2000\n",
      "1437/2000\n",
      "1438/2000\n",
      "1439/2000\n",
      "1440/2000\n",
      "1441/2000\n",
      "1442/2000\n",
      "1443/2000\n",
      "1444/2000\n",
      "1445/2000\n",
      "1446/2000\n",
      "1447/2000\n",
      "1448/2000\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1449/2000\n",
      "1450/2000\n",
      "1451/2000\n",
      "1452/2000\n",
      "1453/2000\n",
      "1454/2000\n",
      "1455/2000\n",
      "1456/2000\n",
      "1457/2000\n",
      "1458/2000\n",
      "1459/2000\n",
      "1460/2000\n",
      "1461/2000\n",
      "1462/2000\n",
      "1463/2000\n",
      "1464/2000\n",
      "1465/2000\n",
      "1466/2000\n",
      "1467/2000\n",
      "1468/2000\n",
      "1469/2000\n",
      "1470/2000\n",
      "1471/2000\n",
      "1472/2000\n",
      "1473/2000\n",
      "1474/2000\n",
      "1475/2000\n",
      "1476/2000\n",
      "1477/2000\n",
      "1478/2000\n",
      "1479/2000\n",
      "1480/2000\n",
      "1481/2000\n",
      "1482/2000\n",
      "1483/2000\n",
      "1484/2000\n",
      "1485/2000\n",
      "1486/2000\n",
      "1487/2000\n",
      "1488/2000\n",
      "1489/2000\n",
      "1490/2000\n",
      "1491/2000\n",
      "1492/2000\n",
      "1493/2000\n",
      "1494/2000\n",
      "1495/2000\n",
      "1496/2000\n",
      "1497/2000\n",
      "1498/2000\n",
      "1499/2000\n",
      "1500/2000\n",
      "1501/2000\n",
      "1502/2000\n",
      "1503/2000\n",
      "1504/2000\n",
      "1505/2000\n",
      "1506/2000\n",
      "1507/2000\n",
      "1508/2000\n",
      "1509/2000\n",
      "1510/2000\n",
      "1511/2000\n",
      "1512/2000\n",
      "1513/2000\n",
      "1514/2000\n",
      "1515/2000\n",
      "1516/2000\n",
      "1517/2000\n",
      "1518/2000\n",
      "1519/2000\n",
      "1520/2000\n",
      "1521/2000\n",
      "1522/2000\n",
      "1523/2000\n",
      "1524/2000\n",
      "1525/2000\n",
      "1526/2000\n",
      "1527/2000\n",
      "1528/2000\n",
      "1529/2000\n",
      "1530/2000\n",
      "1531/2000\n",
      "1532/2000\n",
      "1533/2000\n",
      "1534/2000\n",
      "1535/2000\n",
      "1536/2000\n",
      "1537/2000\n",
      "1538/2000\n",
      "1539/2000\n",
      "1540/2000\n",
      "1541/2000\n",
      "1542/2000\n",
      "1543/2000\n",
      "1544/2000\n",
      "1545/2000\n",
      "1546/2000\n",
      "1547/2000\n",
      "1548/2000\n",
      "1549/2000\n",
      "1550/2000\n",
      "1551/2000\n",
      "1552/2000\n",
      "1553/2000\n",
      "1554/2000\n",
      "1555/2000\n",
      "1556/2000\n",
      "1557/2000\n",
      "1558/2000\n",
      "1559/2000\n",
      "1560/2000\n",
      "1561/2000\n",
      "1562/2000\n",
      "1563/2000\n",
      "1564/2000\n",
      "1565/2000\n",
      "1566/2000\n",
      "1567/2000\n",
      "1568/2000\n",
      "1569/2000\n",
      "1570/2000\n",
      "1571/2000\n",
      "1572/2000\n",
      "1573/2000\n",
      "1574/2000\n",
      "1575/2000\n",
      "1576/2000\n",
      "1577/2000\n",
      "1578/2000\n",
      "1579/2000\n",
      "1580/2000\n",
      "1581/2000\n",
      "1582/2000\n",
      "1583/2000\n",
      "1584/2000\n",
      "1585/2000\n",
      "1586/2000\n",
      "1587/2000\n",
      "1588/2000\n",
      "1589/2000\n",
      "1590/2000\n",
      "1591/2000\n",
      "1592/2000\n",
      "1593/2000\n",
      "1594/2000\n",
      "1595/2000\n",
      "1596/2000\n",
      "1597/2000\n",
      "1598/2000\n",
      "1599/2000\n",
      "1600/2000\n",
      "1601/2000\n",
      "1602/2000\n",
      "1603/2000\n",
      "1604/2000\n",
      "1605/2000\n",
      "1606/2000\n",
      "1607/2000\n",
      "1608/2000\n",
      "1609/2000\n",
      "1610/2000\n",
      "1611/2000\n",
      "1612/2000\n",
      "1613/2000\n",
      "1614/2000\n",
      "1615/2000\n",
      "1616/2000\n",
      "1617/2000\n",
      "1618/2000\n",
      "1619/2000\n",
      "1620/2000\n",
      "1621/2000\n",
      "1622/2000\n",
      "1623/2000\n",
      "1624/2000\n",
      "1625/2000\n",
      "1626/2000\n",
      "1627/2000\n",
      "1628/2000\n",
      "1629/2000\n",
      "1630/2000\n",
      "1631/2000\n",
      "1632/2000\n",
      "1633/2000\n",
      "1634/2000\n",
      "1635/2000\n",
      "1636/2000\n",
      "1637/2000\n",
      "1638/2000\n",
      "1639/2000\n",
      "1640/2000\n",
      "1641/2000\n",
      "1642/2000\n",
      "1643/2000\n",
      "1644/2000\n",
      "1645/2000\n",
      "1646/2000\n",
      "1647/2000\n",
      "1648/2000\n",
      "1649/2000\n",
      "1650/2000\n",
      "1651/2000\n",
      "1652/2000\n",
      "1653/2000\n",
      "1654/2000\n",
      "1655/2000\n",
      "1656/2000\n",
      "1657/2000\n",
      "1658/2000\n",
      "1659/2000\n",
      "1660/2000\n",
      "1661/2000\n",
      "1662/2000\n",
      "1663/2000\n",
      "1664/2000\n",
      "1665/2000\n",
      "1666/2000\n",
      "1667/2000\n",
      "1668/2000\n",
      "1669/2000\n",
      "1670/2000\n",
      "1671/2000\n",
      "1672/2000\n",
      "1673/2000\n",
      "1674/2000\n",
      "1675/2000\n",
      "1676/2000\n",
      "1677/2000\n",
      "1678/2000\n",
      "1679/2000\n",
      "1680/2000\n",
      "1681/2000\n",
      "1682/2000\n",
      "1683/2000\n",
      "1684/2000\n",
      "1685/2000\n",
      "1686/2000\n",
      "1687/2000\n",
      "1688/2000\n",
      "1689/2000\n",
      "1690/2000\n",
      "1691/2000\n",
      "1692/2000\n",
      "1693/2000\n",
      "1694/2000\n",
      "1695/2000\n",
      "1696/2000\n",
      "1697/2000\n",
      "1698/2000\n",
      "1699/2000\n",
      "1700/2000\n",
      "1701/2000\n",
      "1702/2000\n",
      "1703/2000\n",
      "1704/2000\n",
      "1705/2000\n",
      "1706/2000\n",
      "1707/2000\n",
      "1708/2000\n",
      "1709/2000\n",
      "1710/2000\n",
      "1711/2000\n",
      "1712/2000\n",
      "1713/2000\n",
      "1714/2000\n",
      "1715/2000\n",
      "1716/2000\n",
      "1717/2000\n",
      "1718/2000\n",
      "1719/2000\n",
      "1720/2000\n",
      "1721/2000\n",
      "1722/2000\n",
      "1723/2000\n",
      "1724/2000\n",
      "1725/2000\n",
      "1726/2000\n",
      "1727/2000\n",
      "1728/2000\n",
      "1729/2000\n",
      "1730/2000\n",
      "1731/2000\n",
      "1732/2000\n",
      "1733/2000\n",
      "1734/2000\n",
      "1735/2000\n",
      "1736/2000\n",
      "1737/2000\n",
      "1738/2000\n",
      "1739/2000\n",
      "1740/2000\n",
      "1741/2000\n",
      "1742/2000\n",
      "1743/2000\n",
      "1744/2000\n",
      "1745/2000\n",
      "1746/2000\n",
      "1747/2000\n",
      "1748/2000\n",
      "1749/2000\n",
      "1750/2000\n",
      "1751/2000\n",
      "1752/2000\n",
      "1753/2000\n",
      "1754/2000\n",
      "1755/2000\n",
      "1756/2000\n",
      "1757/2000\n",
      "1758/2000\n",
      "1759/2000\n",
      "1760/2000\n",
      "1761/2000\n",
      "1762/2000\n",
      "1763/2000\n",
      "1764/2000\n",
      "1765/2000\n",
      "1766/2000\n",
      "1767/2000\n",
      "1768/2000\n",
      "1769/2000\n",
      "1770/2000\n",
      "1771/2000\n",
      "1772/2000\n",
      "1773/2000\n",
      "1774/2000\n",
      "1775/2000\n",
      "1776/2000\n",
      "1777/2000\n",
      "1778/2000\n",
      "1779/2000\n",
      "1780/2000\n",
      "1781/2000\n",
      "1782/2000\n",
      "1783/2000\n",
      "1784/2000\n",
      "1785/2000\n",
      "1786/2000\n",
      "1787/2000\n",
      "1788/2000\n",
      "1789/2000\n",
      "1790/2000\n",
      "1791/2000\n",
      "1792/2000\n",
      "1793/2000\n",
      "1794/2000\n",
      "1795/2000\n",
      "1796/2000\n",
      "1797/2000\n",
      "1798/2000\n",
      "1799/2000\n",
      "1800/2000\n",
      "1801/2000\n",
      "1802/2000\n",
      "1803/2000\n",
      "1804/2000\n",
      "1805/2000\n",
      "1806/2000\n",
      "1807/2000\n",
      "1808/2000\n",
      "1809/2000\n",
      "1810/2000\n",
      "1811/2000\n",
      "1812/2000\n",
      "1813/2000\n",
      "1814/2000\n",
      "1815/2000\n",
      "1816/2000\n",
      "1817/2000\n",
      "1818/2000\n",
      "1819/2000\n",
      "1820/2000\n",
      "1821/2000\n",
      "1822/2000\n",
      "1823/2000\n",
      "1824/2000\n",
      "1825/2000\n",
      "1826/2000\n",
      "1827/2000\n",
      "1828/2000\n",
      "1829/2000\n",
      "1830/2000\n",
      "1831/2000\n",
      "1832/2000\n",
      "1833/2000\n",
      "1834/2000\n",
      "1835/2000\n",
      "1836/2000\n",
      "1837/2000\n",
      "1838/2000\n",
      "1839/2000\n",
      "1840/2000\n",
      "1841/2000\n",
      "1842/2000\n",
      "1843/2000\n",
      "1844/2000\n",
      "1845/2000\n",
      "1846/2000\n",
      "1847/2000\n",
      "1848/2000\n",
      "1849/2000\n",
      "1850/2000\n",
      "1851/2000\n",
      "1852/2000\n",
      "1853/2000\n",
      "1854/2000\n",
      "1855/2000\n",
      "1856/2000\n",
      "1857/2000\n",
      "1858/2000\n",
      "1859/2000\n",
      "1860/2000\n",
      "1861/2000\n",
      "1862/2000\n",
      "1863/2000\n",
      "1864/2000\n",
      "1865/2000\n",
      "1866/2000\n",
      "1867/2000\n",
      "1868/2000\n",
      "1869/2000\n",
      "1870/2000\n",
      "1871/2000\n",
      "1872/2000\n",
      "1873/2000\n",
      "1874/2000\n",
      "1875/2000\n",
      "1876/2000\n",
      "1877/2000\n",
      "1878/2000\n",
      "1879/2000\n",
      "1880/2000\n",
      "1881/2000\n",
      "1882/2000\n",
      "1883/2000\n",
      "1884/2000\n",
      "1885/2000\n",
      "1886/2000\n",
      "1887/2000\n",
      "1888/2000\n",
      "1889/2000\n",
      "1890/2000\n",
      "1891/2000\n",
      "1892/2000\n",
      "1893/2000\n",
      "1894/2000\n",
      "1895/2000\n",
      "1896/2000\n",
      "1897/2000\n",
      "1898/2000\n",
      "1899/2000\n",
      "1900/2000\n",
      "1901/2000\n",
      "1902/2000\n",
      "1903/2000\n",
      "1904/2000\n",
      "1905/2000\n",
      "1906/2000\n",
      "1907/2000\n",
      "1908/2000\n",
      "1909/2000\n",
      "1910/2000\n",
      "1911/2000\n",
      "1912/2000\n",
      "1913/2000\n",
      "1914/2000\n",
      "1915/2000\n",
      "1916/2000\n",
      "1917/2000\n",
      "1918/2000\n",
      "1919/2000\n",
      "1920/2000\n",
      "1921/2000\n",
      "1922/2000\n",
      "1923/2000\n",
      "1924/2000\n",
      "1925/2000\n",
      "1926/2000\n",
      "1927/2000\n",
      "1928/2000\n",
      "1929/2000\n",
      "1930/2000\n",
      "1931/2000\n",
      "1932/2000\n",
      "1933/2000\n",
      "1934/2000\n",
      "1935/2000\n",
      "1936/2000\n",
      "1937/2000\n",
      "1938/2000\n",
      "1939/2000\n",
      "1940/2000\n",
      "1941/2000\n",
      "1942/2000\n",
      "1943/2000\n",
      "1944/2000\n",
      "1945/2000\n",
      "1946/2000\n",
      "1947/2000\n",
      "1948/2000\n",
      "1949/2000\n",
      "1950/2000\n",
      "1951/2000\n",
      "1952/2000\n",
      "1953/2000\n",
      "1954/2000\n",
      "1955/2000\n",
      "1956/2000\n",
      "1957/2000\n",
      "1958/2000\n",
      "1959/2000\n",
      "1960/2000\n",
      "1961/2000\n",
      "1962/2000\n",
      "1963/2000\n",
      "1964/2000\n",
      "1965/2000\n",
      "1966/2000\n",
      "1967/2000\n",
      "1968/2000\n",
      "1969/2000\n",
      "1970/2000\n",
      "1971/2000\n",
      "1972/2000\n",
      "1973/2000\n",
      "1974/2000\n",
      "1975/2000\n",
      "1976/2000\n",
      "1977/2000\n",
      "1978/2000\n",
      "1979/2000\n",
      "1980/2000\n",
      "1981/2000\n",
      "1982/2000\n",
      "1983/2000\n",
      "1984/2000\n",
      "1985/2000\n",
      "1986/2000\n",
      "1987/2000\n",
      "1988/2000\n",
      "1989/2000\n",
      "1990/2000\n",
      "1991/2000\n",
      "1992/2000\n",
      "1993/2000\n",
      "1994/2000\n",
      "1995/2000\n",
      "1996/2000\n",
      "1997/2000\n",
      "1998/2000\n",
      "1999/2000\n"
     ]
    }
   ],
   "source": [
    "data, ALL_SEN, cur_randomness = create_data(start_x, start_y, end_x, end_y, cur_randomness)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot number of visits in each state\n",
    "#plt.figure(figsize=(17,16))\n",
    "ax = sns.heatmap(data[:,:], cmap = 'jet', square=True, norm=mpl.colors.LogNorm(vmin=1, vmax=data.max()))#, annot=True,  annot_kws={\"size\": 5})\n",
    "ax.set_xticklabels(ax.get_xmajorticklabels(), fontsize = 18)\n",
    "ax.set_yticklabels(ax.get_ymajorticklabels(), fontsize = 18)\n",
    "ax.xaxis.set_visible(False) \n",
    "ax.yaxis.set_visible(False)\n",
    "ax.patch.set_edgecolor('black')  \n",
    "ax.patch.set_linewidth('2')  \n",
    "cbar = ax.collections[0].colorbar\n",
    "cbar.ax.tick_params(labelsize=20)\n",
    "plt.savefig(\"safe_zone_policy_1_visit.png\",dpi=600)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0/2000\n",
      "1/2000\n",
      "2/2000\n",
      "3/2000\n",
      "4/2000\n",
      "5/2000\n",
      "6/2000\n",
      "7/2000\n",
      "8/2000\n",
      "9/2000\n",
      "10/2000\n",
      "11/2000\n",
      "12/2000\n",
      "13/2000\n",
      "14/2000\n",
      "15/2000\n",
      "16/2000\n",
      "17/2000\n",
      "18/2000\n",
      "19/2000\n",
      "20/2000\n",
      "21/2000\n",
      "22/2000\n",
      "23/2000\n",
      "24/2000\n",
      "25/2000\n",
      "26/2000\n",
      "27/2000\n",
      "28/2000\n",
      "29/2000\n",
      "30/2000\n",
      "31/2000\n",
      "32/2000\n",
      "33/2000\n",
      "34/2000\n",
      "35/2000\n",
      "36/2000\n",
      "37/2000\n",
      "38/2000\n",
      "39/2000\n",
      "40/2000\n",
      "41/2000\n",
      "42/2000\n",
      "43/2000\n",
      "44/2000\n",
      "45/2000\n",
      "46/2000\n",
      "47/2000\n",
      "48/2000\n",
      "49/2000\n",
      "50/2000\n",
      "51/2000\n",
      "52/2000\n",
      "53/2000\n",
      "54/2000\n",
      "55/2000\n",
      "56/2000\n",
      "57/2000\n",
      "58/2000\n",
      "59/2000\n",
      "60/2000\n",
      "61/2000\n",
      "62/2000\n",
      "63/2000\n",
      "64/2000\n",
      "65/2000\n",
      "66/2000\n",
      "67/2000\n",
      "68/2000\n",
      "69/2000\n",
      "70/2000\n",
      "71/2000\n",
      "72/2000\n",
      "73/2000\n",
      "74/2000\n",
      "75/2000\n",
      "76/2000\n",
      "77/2000\n",
      "78/2000\n",
      "79/2000\n",
      "80/2000\n",
      "81/2000\n",
      "82/2000\n",
      "83/2000\n",
      "84/2000\n",
      "85/2000\n",
      "86/2000\n",
      "87/2000\n",
      "88/2000\n",
      "89/2000\n",
      "90/2000\n",
      "91/2000\n",
      "92/2000\n",
      "93/2000\n",
      "94/2000\n",
      "95/2000\n",
      "96/2000\n",
      "97/2000\n",
      "98/2000\n",
      "99/2000\n",
      "100/2000\n",
      "101/2000\n",
      "102/2000\n",
      "103/2000\n",
      "104/2000\n",
      "105/2000\n",
      "106/2000\n",
      "107/2000\n",
      "108/2000\n",
      "109/2000\n",
      "110/2000\n",
      "111/2000\n",
      "112/2000\n",
      "113/2000\n",
      "114/2000\n",
      "115/2000\n",
      "116/2000\n",
      "117/2000\n",
      "118/2000\n",
      "119/2000\n",
      "120/2000\n",
      "121/2000\n",
      "122/2000\n",
      "123/2000\n",
      "124/2000\n",
      "125/2000\n",
      "126/2000\n",
      "127/2000\n",
      "128/2000\n",
      "129/2000\n",
      "130/2000\n",
      "131/2000\n",
      "132/2000\n",
      "133/2000\n",
      "134/2000\n",
      "135/2000\n",
      "136/2000\n",
      "137/2000\n",
      "138/2000\n",
      "139/2000\n",
      "140/2000\n",
      "141/2000\n",
      "142/2000\n",
      "143/2000\n",
      "144/2000\n",
      "145/2000\n",
      "146/2000\n",
      "147/2000\n",
      "148/2000\n",
      "149/2000\n",
      "150/2000\n",
      "151/2000\n",
      "152/2000\n",
      "153/2000\n",
      "154/2000\n",
      "155/2000\n",
      "156/2000\n",
      "157/2000\n",
      "158/2000\n",
      "159/2000\n",
      "160/2000\n",
      "161/2000\n",
      "162/2000\n",
      "163/2000\n",
      "164/2000\n",
      "165/2000\n",
      "166/2000\n",
      "167/2000\n",
      "168/2000\n",
      "169/2000\n",
      "170/2000\n",
      "171/2000\n",
      "172/2000\n",
      "173/2000\n",
      "174/2000\n",
      "175/2000\n",
      "176/2000\n",
      "177/2000\n",
      "178/2000\n",
      "179/2000\n",
      "180/2000\n",
      "181/2000\n",
      "182/2000\n",
      "183/2000\n",
      "184/2000\n",
      "185/2000\n",
      "186/2000\n",
      "187/2000\n",
      "188/2000\n",
      "189/2000\n",
      "190/2000\n",
      "191/2000\n",
      "192/2000\n",
      "193/2000\n",
      "194/2000\n",
      "195/2000\n",
      "196/2000\n",
      "197/2000\n",
      "198/2000\n",
      "199/2000\n",
      "200/2000\n",
      "201/2000\n",
      "202/2000\n",
      "203/2000\n",
      "204/2000\n",
      "205/2000\n",
      "206/2000\n",
      "207/2000\n",
      "208/2000\n",
      "209/2000\n",
      "210/2000\n",
      "211/2000\n",
      "212/2000\n",
      "213/2000\n",
      "214/2000\n",
      "215/2000\n",
      "216/2000\n",
      "217/2000\n",
      "218/2000\n",
      "219/2000\n",
      "220/2000\n",
      "221/2000\n",
      "222/2000\n",
      "223/2000\n",
      "224/2000\n",
      "225/2000\n",
      "226/2000\n",
      "227/2000\n",
      "228/2000\n",
      "229/2000\n",
      "230/2000\n",
      "231/2000\n",
      "232/2000\n",
      "233/2000\n",
      "234/2000\n",
      "235/2000\n",
      "236/2000\n",
      "237/2000\n",
      "238/2000\n",
      "239/2000\n",
      "240/2000\n",
      "241/2000\n",
      "242/2000\n",
      "243/2000\n",
      "244/2000\n",
      "245/2000\n",
      "246/2000\n",
      "247/2000\n",
      "248/2000\n",
      "249/2000\n",
      "250/2000\n",
      "251/2000\n",
      "252/2000\n",
      "253/2000\n",
      "254/2000\n",
      "255/2000\n",
      "256/2000\n",
      "257/2000\n",
      "258/2000\n",
      "259/2000\n",
      "260/2000\n",
      "261/2000\n",
      "262/2000\n",
      "263/2000\n",
      "264/2000\n",
      "265/2000\n",
      "266/2000\n",
      "267/2000\n",
      "268/2000\n",
      "269/2000\n",
      "270/2000\n",
      "271/2000\n",
      "272/2000\n",
      "273/2000\n",
      "274/2000\n",
      "275/2000\n",
      "276/2000\n",
      "277/2000\n",
      "278/2000\n",
      "279/2000\n",
      "280/2000\n",
      "281/2000\n",
      "282/2000\n",
      "283/2000\n",
      "284/2000\n",
      "285/2000\n",
      "286/2000\n",
      "287/2000\n",
      "288/2000\n",
      "289/2000\n",
      "290/2000\n",
      "291/2000\n",
      "292/2000\n",
      "293/2000\n",
      "294/2000\n",
      "295/2000\n",
      "296/2000\n",
      "297/2000\n",
      "298/2000\n",
      "299/2000\n",
      "300/2000\n",
      "301/2000\n",
      "302/2000\n",
      "303/2000\n",
      "304/2000\n",
      "305/2000\n",
      "306/2000\n",
      "307/2000\n",
      "308/2000\n",
      "309/2000\n",
      "310/2000\n",
      "311/2000\n",
      "312/2000\n",
      "313/2000\n",
      "314/2000\n",
      "315/2000\n",
      "316/2000\n",
      "317/2000\n",
      "318/2000\n",
      "319/2000\n",
      "320/2000\n",
      "321/2000\n",
      "322/2000\n",
      "323/2000\n",
      "324/2000\n",
      "325/2000\n",
      "326/2000\n",
      "327/2000\n",
      "328/2000\n",
      "329/2000\n",
      "330/2000\n",
      "331/2000\n",
      "332/2000\n",
      "333/2000\n",
      "334/2000\n",
      "335/2000\n",
      "336/2000\n",
      "337/2000\n",
      "338/2000\n",
      "339/2000\n",
      "340/2000\n",
      "341/2000\n",
      "342/2000\n",
      "343/2000\n",
      "344/2000\n",
      "345/2000\n",
      "346/2000\n",
      "347/2000\n",
      "348/2000\n",
      "349/2000\n",
      "350/2000\n",
      "351/2000\n",
      "352/2000\n",
      "353/2000\n",
      "354/2000\n",
      "355/2000\n",
      "356/2000\n",
      "357/2000\n",
      "358/2000\n",
      "359/2000\n",
      "360/2000\n",
      "361/2000\n",
      "362/2000\n",
      "363/2000\n",
      "364/2000\n",
      "365/2000\n",
      "366/2000\n",
      "367/2000\n",
      "368/2000\n",
      "369/2000\n",
      "370/2000\n",
      "371/2000\n",
      "372/2000\n",
      "373/2000\n",
      "374/2000\n",
      "375/2000\n",
      "376/2000\n",
      "377/2000\n",
      "378/2000\n",
      "379/2000\n",
      "380/2000\n",
      "381/2000\n",
      "382/2000\n",
      "383/2000\n",
      "384/2000\n",
      "385/2000\n",
      "386/2000\n",
      "387/2000\n",
      "388/2000\n",
      "389/2000\n",
      "390/2000\n",
      "391/2000\n",
      "392/2000\n",
      "393/2000\n",
      "394/2000\n",
      "395/2000\n",
      "396/2000\n",
      "397/2000\n",
      "398/2000\n",
      "399/2000\n",
      "400/2000\n",
      "401/2000\n",
      "402/2000\n",
      "403/2000\n",
      "404/2000\n",
      "405/2000\n",
      "406/2000\n",
      "407/2000\n",
      "408/2000\n",
      "409/2000\n",
      "410/2000\n",
      "411/2000\n",
      "412/2000\n",
      "413/2000\n",
      "414/2000\n",
      "415/2000\n",
      "416/2000\n",
      "417/2000\n",
      "418/2000\n",
      "419/2000\n",
      "420/2000\n",
      "421/2000\n",
      "422/2000\n",
      "423/2000\n",
      "424/2000\n",
      "425/2000\n",
      "426/2000\n",
      "427/2000\n",
      "428/2000\n",
      "429/2000\n",
      "430/2000\n",
      "431/2000\n",
      "432/2000\n",
      "433/2000\n",
      "434/2000\n",
      "435/2000\n",
      "436/2000\n",
      "437/2000\n",
      "438/2000\n",
      "439/2000\n",
      "440/2000\n",
      "441/2000\n",
      "442/2000\n",
      "443/2000\n",
      "444/2000\n",
      "445/2000\n",
      "446/2000\n",
      "447/2000\n",
      "448/2000\n",
      "449/2000\n",
      "450/2000\n",
      "451/2000\n",
      "452/2000\n",
      "453/2000\n",
      "454/2000\n",
      "455/2000\n",
      "456/2000\n",
      "457/2000\n",
      "458/2000\n",
      "459/2000\n",
      "460/2000\n",
      "461/2000\n",
      "462/2000\n",
      "463/2000\n",
      "464/2000\n",
      "465/2000\n",
      "466/2000\n",
      "467/2000\n",
      "468/2000\n",
      "469/2000\n",
      "470/2000\n",
      "471/2000\n",
      "472/2000\n",
      "473/2000\n",
      "474/2000\n",
      "475/2000\n",
      "476/2000\n",
      "477/2000\n",
      "478/2000\n",
      "479/2000\n",
      "480/2000\n",
      "481/2000\n",
      "482/2000\n",
      "483/2000\n",
      "484/2000\n",
      "485/2000\n",
      "486/2000\n",
      "487/2000\n",
      "488/2000\n",
      "489/2000\n",
      "490/2000\n",
      "491/2000\n",
      "492/2000\n",
      "493/2000\n",
      "494/2000\n",
      "495/2000\n",
      "496/2000\n",
      "497/2000\n",
      "498/2000\n",
      "499/2000\n",
      "500/2000\n",
      "501/2000\n",
      "502/2000\n",
      "503/2000\n",
      "504/2000\n",
      "505/2000\n",
      "506/2000\n",
      "507/2000\n",
      "508/2000\n",
      "509/2000\n",
      "510/2000\n",
      "511/2000\n",
      "512/2000\n",
      "513/2000\n",
      "514/2000\n",
      "515/2000\n",
      "516/2000\n",
      "517/2000\n",
      "518/2000\n",
      "519/2000\n",
      "520/2000\n",
      "521/2000\n",
      "522/2000\n",
      "523/2000\n",
      "524/2000\n",
      "525/2000\n",
      "526/2000\n",
      "527/2000\n",
      "528/2000\n",
      "529/2000\n",
      "530/2000\n",
      "531/2000\n",
      "532/2000\n",
      "533/2000\n",
      "534/2000\n",
      "535/2000\n",
      "536/2000\n",
      "537/2000\n",
      "538/2000\n",
      "539/2000\n",
      "540/2000\n",
      "541/2000\n",
      "542/2000\n",
      "543/2000\n",
      "544/2000\n",
      "545/2000\n",
      "546/2000\n",
      "547/2000\n",
      "548/2000\n",
      "549/2000\n",
      "550/2000\n",
      "551/2000\n",
      "552/2000\n",
      "553/2000\n",
      "554/2000\n",
      "555/2000\n",
      "556/2000\n",
      "557/2000\n",
      "558/2000\n",
      "559/2000\n",
      "560/2000\n",
      "561/2000\n",
      "562/2000\n",
      "563/2000\n",
      "564/2000\n",
      "565/2000\n",
      "566/2000\n",
      "567/2000\n",
      "568/2000\n",
      "569/2000\n",
      "570/2000\n",
      "571/2000\n",
      "572/2000\n",
      "573/2000\n",
      "574/2000\n",
      "575/2000\n",
      "576/2000\n",
      "577/2000\n",
      "578/2000\n",
      "579/2000\n",
      "580/2000\n",
      "581/2000\n",
      "582/2000\n",
      "583/2000\n",
      "584/2000\n",
      "585/2000\n",
      "586/2000\n",
      "587/2000\n",
      "588/2000\n",
      "589/2000\n",
      "590/2000\n",
      "591/2000\n",
      "592/2000\n",
      "593/2000\n",
      "594/2000\n",
      "595/2000\n",
      "596/2000\n",
      "597/2000\n",
      "598/2000\n",
      "599/2000\n",
      "600/2000\n",
      "601/2000\n",
      "602/2000\n",
      "603/2000\n",
      "604/2000\n",
      "605/2000\n",
      "606/2000\n",
      "607/2000\n",
      "608/2000\n",
      "609/2000\n",
      "610/2000\n",
      "611/2000\n",
      "612/2000\n",
      "613/2000\n",
      "614/2000\n",
      "615/2000\n",
      "616/2000\n",
      "617/2000\n",
      "618/2000\n",
      "619/2000\n",
      "620/2000\n",
      "621/2000\n",
      "622/2000\n",
      "623/2000\n",
      "624/2000\n",
      "625/2000\n",
      "626/2000\n",
      "627/2000\n",
      "628/2000\n",
      "629/2000\n",
      "630/2000\n",
      "631/2000\n",
      "632/2000\n",
      "633/2000\n",
      "634/2000\n",
      "635/2000\n",
      "636/2000\n",
      "637/2000\n",
      "638/2000\n",
      "639/2000\n",
      "640/2000\n",
      "641/2000\n",
      "642/2000\n",
      "643/2000\n",
      "644/2000\n",
      "645/2000\n",
      "646/2000\n",
      "647/2000\n",
      "648/2000\n",
      "649/2000\n",
      "650/2000\n",
      "651/2000\n",
      "652/2000\n",
      "653/2000\n",
      "654/2000\n",
      "655/2000\n",
      "656/2000\n",
      "657/2000\n",
      "658/2000\n",
      "659/2000\n",
      "660/2000\n",
      "661/2000\n",
      "662/2000\n",
      "663/2000\n",
      "664/2000\n",
      "665/2000\n",
      "666/2000\n",
      "667/2000\n",
      "668/2000\n",
      "669/2000\n",
      "670/2000\n",
      "671/2000\n",
      "672/2000\n",
      "673/2000\n",
      "674/2000\n",
      "675/2000\n",
      "676/2000\n",
      "677/2000\n",
      "678/2000\n",
      "679/2000\n",
      "680/2000\n",
      "681/2000\n",
      "682/2000\n",
      "683/2000\n",
      "684/2000\n",
      "685/2000\n",
      "686/2000\n",
      "687/2000\n",
      "688/2000\n",
      "689/2000\n",
      "690/2000\n",
      "691/2000\n",
      "692/2000\n",
      "693/2000\n",
      "694/2000\n",
      "695/2000\n",
      "696/2000\n",
      "697/2000\n",
      "698/2000\n",
      "699/2000\n",
      "700/2000\n",
      "701/2000\n",
      "702/2000\n",
      "703/2000\n",
      "704/2000\n",
      "705/2000\n",
      "706/2000\n",
      "707/2000\n",
      "708/2000\n",
      "709/2000\n",
      "710/2000\n",
      "711/2000\n",
      "712/2000\n",
      "713/2000\n",
      "714/2000\n",
      "715/2000\n",
      "716/2000\n",
      "717/2000\n",
      "718/2000\n",
      "719/2000\n",
      "720/2000\n",
      "721/2000\n",
      "722/2000\n",
      "723/2000\n",
      "724/2000\n",
      "725/2000\n",
      "726/2000\n",
      "727/2000\n",
      "728/2000\n",
      "729/2000\n",
      "730/2000\n",
      "731/2000\n",
      "732/2000\n",
      "733/2000\n",
      "734/2000\n",
      "735/2000\n",
      "736/2000\n",
      "737/2000\n",
      "738/2000\n",
      "739/2000\n",
      "740/2000\n",
      "741/2000\n",
      "742/2000\n",
      "743/2000\n",
      "744/2000\n",
      "745/2000\n",
      "746/2000\n",
      "747/2000\n",
      "748/2000\n",
      "749/2000\n",
      "750/2000\n",
      "751/2000\n",
      "752/2000\n",
      "753/2000\n",
      "754/2000\n",
      "755/2000\n",
      "756/2000\n",
      "757/2000\n",
      "758/2000\n",
      "759/2000\n",
      "760/2000\n",
      "761/2000\n",
      "762/2000\n",
      "763/2000\n",
      "764/2000\n",
      "765/2000\n",
      "766/2000\n",
      "767/2000\n",
      "768/2000\n",
      "769/2000\n",
      "770/2000\n",
      "771/2000\n",
      "772/2000\n",
      "773/2000\n",
      "774/2000\n",
      "775/2000\n",
      "776/2000\n",
      "777/2000\n",
      "778/2000\n",
      "779/2000\n",
      "780/2000\n",
      "781/2000\n",
      "782/2000\n",
      "783/2000\n",
      "784/2000\n",
      "785/2000\n",
      "786/2000\n",
      "787/2000\n",
      "788/2000\n",
      "789/2000\n",
      "790/2000\n",
      "791/2000\n",
      "792/2000\n",
      "793/2000\n",
      "794/2000\n",
      "795/2000\n",
      "796/2000\n",
      "797/2000\n",
      "798/2000\n",
      "799/2000\n",
      "800/2000\n",
      "801/2000\n",
      "802/2000\n",
      "803/2000\n",
      "804/2000\n",
      "805/2000\n",
      "806/2000\n",
      "807/2000\n",
      "808/2000\n",
      "809/2000\n",
      "810/2000\n",
      "811/2000\n",
      "812/2000\n",
      "813/2000\n",
      "814/2000\n",
      "815/2000\n",
      "816/2000\n",
      "817/2000\n",
      "818/2000\n",
      "819/2000\n",
      "820/2000\n",
      "821/2000\n",
      "822/2000\n",
      "823/2000\n",
      "824/2000\n",
      "825/2000\n",
      "826/2000\n",
      "827/2000\n",
      "828/2000\n",
      "829/2000\n",
      "830/2000\n",
      "831/2000\n",
      "832/2000\n",
      "833/2000\n",
      "834/2000\n",
      "835/2000\n",
      "836/2000\n",
      "837/2000\n",
      "838/2000\n",
      "839/2000\n",
      "840/2000\n",
      "841/2000\n",
      "842/2000\n",
      "843/2000\n",
      "844/2000\n",
      "845/2000\n",
      "846/2000\n",
      "847/2000\n",
      "848/2000\n",
      "849/2000\n",
      "850/2000\n",
      "851/2000\n",
      "852/2000\n",
      "853/2000\n",
      "854/2000\n",
      "855/2000\n",
      "856/2000\n",
      "857/2000\n",
      "858/2000\n",
      "859/2000\n",
      "860/2000\n",
      "861/2000\n",
      "862/2000\n",
      "863/2000\n",
      "864/2000\n",
      "865/2000\n",
      "866/2000\n",
      "867/2000\n",
      "868/2000\n",
      "869/2000\n",
      "870/2000\n",
      "871/2000\n",
      "872/2000\n",
      "873/2000\n",
      "874/2000\n",
      "875/2000\n",
      "876/2000\n",
      "877/2000\n",
      "878/2000\n",
      "879/2000\n",
      "880/2000\n",
      "881/2000\n",
      "882/2000\n",
      "883/2000\n",
      "884/2000\n",
      "885/2000\n",
      "886/2000\n",
      "887/2000\n",
      "888/2000\n",
      "889/2000\n",
      "890/2000\n",
      "891/2000\n",
      "892/2000\n",
      "893/2000\n",
      "894/2000\n",
      "895/2000\n",
      "896/2000\n",
      "897/2000\n",
      "898/2000\n",
      "899/2000\n",
      "900/2000\n",
      "901/2000\n",
      "902/2000\n",
      "903/2000\n",
      "904/2000\n",
      "905/2000\n",
      "906/2000\n",
      "907/2000\n",
      "908/2000\n",
      "909/2000\n",
      "910/2000\n",
      "911/2000\n",
      "912/2000\n",
      "913/2000\n",
      "914/2000\n",
      "915/2000\n",
      "916/2000\n",
      "917/2000\n",
      "918/2000\n",
      "919/2000\n",
      "920/2000\n",
      "921/2000\n",
      "922/2000\n",
      "923/2000\n",
      "924/2000\n",
      "925/2000\n",
      "926/2000\n",
      "927/2000\n",
      "928/2000\n",
      "929/2000\n",
      "930/2000\n",
      "931/2000\n",
      "932/2000\n",
      "933/2000\n",
      "934/2000\n",
      "935/2000\n",
      "936/2000\n",
      "937/2000\n",
      "938/2000\n",
      "939/2000\n",
      "940/2000\n",
      "941/2000\n",
      "942/2000\n",
      "943/2000\n",
      "944/2000\n",
      "945/2000\n",
      "946/2000\n",
      "947/2000\n",
      "948/2000\n",
      "949/2000\n",
      "950/2000\n",
      "951/2000\n",
      "952/2000\n",
      "953/2000\n",
      "954/2000\n",
      "955/2000\n",
      "956/2000\n",
      "957/2000\n",
      "958/2000\n",
      "959/2000\n",
      "960/2000\n",
      "961/2000\n",
      "962/2000\n",
      "963/2000\n",
      "964/2000\n",
      "965/2000\n",
      "966/2000\n",
      "967/2000\n",
      "968/2000\n",
      "969/2000\n",
      "970/2000\n",
      "971/2000\n",
      "972/2000\n",
      "973/2000\n",
      "974/2000\n",
      "975/2000\n",
      "976/2000\n",
      "977/2000\n",
      "978/2000\n",
      "979/2000\n",
      "980/2000\n",
      "981/2000\n",
      "982/2000\n",
      "983/2000\n",
      "984/2000\n",
      "985/2000\n",
      "986/2000\n",
      "987/2000\n",
      "988/2000\n",
      "989/2000\n",
      "990/2000\n",
      "991/2000\n",
      "992/2000\n",
      "993/2000\n",
      "994/2000\n",
      "995/2000\n",
      "996/2000\n",
      "997/2000\n",
      "998/2000\n",
      "999/2000\n",
      "1000/2000\n",
      "1001/2000\n",
      "1002/2000\n",
      "1003/2000\n",
      "1004/2000\n",
      "1005/2000\n",
      "1006/2000\n",
      "1007/2000\n",
      "1008/2000\n",
      "1009/2000\n",
      "1010/2000\n",
      "1011/2000\n",
      "1012/2000\n",
      "1013/2000\n",
      "1014/2000\n",
      "1015/2000\n",
      "1016/2000\n",
      "1017/2000\n",
      "1018/2000\n",
      "1019/2000\n",
      "1020/2000\n",
      "1021/2000\n",
      "1022/2000\n",
      "1023/2000\n",
      "1024/2000\n",
      "1025/2000\n",
      "1026/2000\n",
      "1027/2000\n",
      "1028/2000\n",
      "1029/2000\n",
      "1030/2000\n",
      "1031/2000\n",
      "1032/2000\n",
      "1033/2000\n",
      "1034/2000\n",
      "1035/2000\n",
      "1036/2000\n",
      "1037/2000\n",
      "1038/2000\n",
      "1039/2000\n",
      "1040/2000\n",
      "1041/2000\n",
      "1042/2000\n",
      "1043/2000\n",
      "1044/2000\n",
      "1045/2000\n",
      "1046/2000\n",
      "1047/2000\n",
      "1048/2000\n",
      "1049/2000\n",
      "1050/2000\n",
      "1051/2000\n",
      "1052/2000\n",
      "1053/2000\n",
      "1054/2000\n",
      "1055/2000\n",
      "1056/2000\n",
      "1057/2000\n",
      "1058/2000\n",
      "1059/2000\n",
      "1060/2000\n",
      "1061/2000\n",
      "1062/2000\n",
      "1063/2000\n",
      "1064/2000\n",
      "1065/2000\n",
      "1066/2000\n",
      "1067/2000\n",
      "1068/2000\n",
      "1069/2000\n",
      "1070/2000\n",
      "1071/2000\n",
      "1072/2000\n",
      "1073/2000\n",
      "1074/2000\n",
      "1075/2000\n",
      "1076/2000\n",
      "1077/2000\n",
      "1078/2000\n",
      "1079/2000\n",
      "1080/2000\n",
      "1081/2000\n",
      "1082/2000\n",
      "1083/2000\n",
      "1084/2000\n",
      "1085/2000\n",
      "1086/2000\n",
      "1087/2000\n",
      "1088/2000\n",
      "1089/2000\n",
      "1090/2000\n",
      "1091/2000\n",
      "1092/2000\n",
      "1093/2000\n",
      "1094/2000\n",
      "1095/2000\n",
      "1096/2000\n",
      "1097/2000\n",
      "1098/2000\n",
      "1099/2000\n",
      "1100/2000\n",
      "1101/2000\n",
      "1102/2000\n",
      "1103/2000\n",
      "1104/2000\n",
      "1105/2000\n",
      "1106/2000\n",
      "1107/2000\n",
      "1108/2000\n",
      "1109/2000\n",
      "1110/2000\n",
      "1111/2000\n",
      "1112/2000\n",
      "1113/2000\n",
      "1114/2000\n",
      "1115/2000\n",
      "1116/2000\n",
      "1117/2000\n",
      "1118/2000\n",
      "1119/2000\n",
      "1120/2000\n",
      "1121/2000\n",
      "1122/2000\n",
      "1123/2000\n",
      "1124/2000\n",
      "1125/2000\n",
      "1126/2000\n",
      "1127/2000\n",
      "1128/2000\n",
      "1129/2000\n",
      "1130/2000\n",
      "1131/2000\n",
      "1132/2000\n",
      "1133/2000\n",
      "1134/2000\n",
      "1135/2000\n",
      "1136/2000\n",
      "1137/2000\n",
      "1138/2000\n",
      "1139/2000\n",
      "1140/2000\n",
      "1141/2000\n",
      "1142/2000\n",
      "1143/2000\n",
      "1144/2000\n",
      "1145/2000\n",
      "1146/2000\n",
      "1147/2000\n",
      "1148/2000\n",
      "1149/2000\n",
      "1150/2000\n",
      "1151/2000\n",
      "1152/2000\n",
      "1153/2000\n",
      "1154/2000\n",
      "1155/2000\n",
      "1156/2000\n",
      "1157/2000\n",
      "1158/2000\n",
      "1159/2000\n",
      "1160/2000\n",
      "1161/2000\n",
      "1162/2000\n",
      "1163/2000\n",
      "1164/2000\n",
      "1165/2000\n",
      "1166/2000\n",
      "1167/2000\n",
      "1168/2000\n",
      "1169/2000\n",
      "1170/2000\n",
      "1171/2000\n",
      "1172/2000\n",
      "1173/2000\n",
      "1174/2000\n",
      "1175/2000\n",
      "1176/2000\n",
      "1177/2000\n",
      "1178/2000\n",
      "1179/2000\n",
      "1180/2000\n",
      "1181/2000\n",
      "1182/2000\n",
      "1183/2000\n",
      "1184/2000\n",
      "1185/2000\n",
      "1186/2000\n",
      "1187/2000\n",
      "1188/2000\n",
      "1189/2000\n",
      "1190/2000\n",
      "1191/2000\n",
      "1192/2000\n",
      "1193/2000\n",
      "1194/2000\n",
      "1195/2000\n",
      "1196/2000\n",
      "1197/2000\n",
      "1198/2000\n",
      "1199/2000\n",
      "1200/2000\n",
      "1201/2000\n",
      "1202/2000\n",
      "1203/2000\n",
      "1204/2000\n",
      "1205/2000\n",
      "1206/2000\n",
      "1207/2000\n",
      "1208/2000\n",
      "1209/2000\n",
      "1210/2000\n",
      "1211/2000\n",
      "1212/2000\n",
      "1213/2000\n",
      "1214/2000\n",
      "1215/2000\n",
      "1216/2000\n",
      "1217/2000\n",
      "1218/2000\n",
      "1219/2000\n",
      "1220/2000\n",
      "1221/2000\n",
      "1222/2000\n",
      "1223/2000\n",
      "1224/2000\n",
      "1225/2000\n",
      "1226/2000\n",
      "1227/2000\n",
      "1228/2000\n",
      "1229/2000\n",
      "1230/2000\n",
      "1231/2000\n",
      "1232/2000\n",
      "1233/2000\n",
      "1234/2000\n",
      "1235/2000\n",
      "1236/2000\n",
      "1237/2000\n",
      "1238/2000\n",
      "1239/2000\n",
      "1240/2000\n",
      "1241/2000\n",
      "1242/2000\n",
      "1243/2000\n",
      "1244/2000\n",
      "1245/2000\n",
      "1246/2000\n",
      "1247/2000\n",
      "1248/2000\n",
      "1249/2000\n",
      "1250/2000\n",
      "1251/2000\n",
      "1252/2000\n",
      "1253/2000\n",
      "1254/2000\n",
      "1255/2000\n",
      "1256/2000\n",
      "1257/2000\n",
      "1258/2000\n",
      "1259/2000\n",
      "1260/2000\n",
      "1261/2000\n",
      "1262/2000\n",
      "1263/2000\n",
      "1264/2000\n",
      "1265/2000\n",
      "1266/2000\n",
      "1267/2000\n",
      "1268/2000\n",
      "1269/2000\n",
      "1270/2000\n",
      "1271/2000\n",
      "1272/2000\n",
      "1273/2000\n",
      "1274/2000\n",
      "1275/2000\n",
      "1276/2000\n",
      "1277/2000\n",
      "1278/2000\n",
      "1279/2000\n",
      "1280/2000\n",
      "1281/2000\n",
      "1282/2000\n",
      "1283/2000\n",
      "1284/2000\n",
      "1285/2000\n",
      "1286/2000\n",
      "1287/2000\n",
      "1288/2000\n",
      "1289/2000\n",
      "1290/2000\n",
      "1291/2000\n",
      "1292/2000\n",
      "1293/2000\n",
      "1294/2000\n",
      "1295/2000\n",
      "1296/2000\n",
      "1297/2000\n",
      "1298/2000\n",
      "1299/2000\n",
      "1300/2000\n",
      "1301/2000\n",
      "1302/2000\n",
      "1303/2000\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1304/2000\n",
      "1305/2000\n",
      "1306/2000\n",
      "1307/2000\n",
      "1308/2000\n",
      "1309/2000\n",
      "1310/2000\n",
      "1311/2000\n",
      "1312/2000\n",
      "1313/2000\n",
      "1314/2000\n",
      "1315/2000\n",
      "1316/2000\n",
      "1317/2000\n",
      "1318/2000\n",
      "1319/2000\n",
      "1320/2000\n",
      "1321/2000\n",
      "1322/2000\n",
      "1323/2000\n",
      "1324/2000\n",
      "1325/2000\n",
      "1326/2000\n",
      "1327/2000\n",
      "1328/2000\n",
      "1329/2000\n",
      "1330/2000\n",
      "1331/2000\n",
      "1332/2000\n",
      "1333/2000\n",
      "1334/2000\n",
      "1335/2000\n",
      "1336/2000\n",
      "1337/2000\n",
      "1338/2000\n",
      "1339/2000\n",
      "1340/2000\n",
      "1341/2000\n",
      "1342/2000\n",
      "1343/2000\n",
      "1344/2000\n",
      "1345/2000\n",
      "1346/2000\n",
      "1347/2000\n",
      "1348/2000\n",
      "1349/2000\n",
      "1350/2000\n",
      "1351/2000\n",
      "1352/2000\n",
      "1353/2000\n",
      "1354/2000\n",
      "1355/2000\n",
      "1356/2000\n",
      "1357/2000\n",
      "1358/2000\n",
      "1359/2000\n",
      "1360/2000\n",
      "1361/2000\n",
      "1362/2000\n",
      "1363/2000\n",
      "1364/2000\n",
      "1365/2000\n",
      "1366/2000\n",
      "1367/2000\n",
      "1368/2000\n",
      "1369/2000\n",
      "1370/2000\n",
      "1371/2000\n",
      "1372/2000\n",
      "1373/2000\n",
      "1374/2000\n",
      "1375/2000\n",
      "1376/2000\n",
      "1377/2000\n",
      "1378/2000\n",
      "1379/2000\n",
      "1380/2000\n",
      "1381/2000\n",
      "1382/2000\n",
      "1383/2000\n",
      "1384/2000\n",
      "1385/2000\n",
      "1386/2000\n",
      "1387/2000\n",
      "1388/2000\n",
      "1389/2000\n",
      "1390/2000\n",
      "1391/2000\n",
      "1392/2000\n",
      "1393/2000\n",
      "1394/2000\n",
      "1395/2000\n",
      "1396/2000\n",
      "1397/2000\n",
      "1398/2000\n",
      "1399/2000\n",
      "1400/2000\n",
      "1401/2000\n",
      "1402/2000\n",
      "1403/2000\n",
      "1404/2000\n",
      "1405/2000\n",
      "1406/2000\n",
      "1407/2000\n",
      "1408/2000\n",
      "1409/2000\n",
      "1410/2000\n",
      "1411/2000\n",
      "1412/2000\n",
      "1413/2000\n",
      "1414/2000\n",
      "1415/2000\n",
      "1416/2000\n",
      "1417/2000\n",
      "1418/2000\n",
      "1419/2000\n",
      "1420/2000\n",
      "1421/2000\n",
      "1422/2000\n",
      "1423/2000\n",
      "1424/2000\n",
      "1425/2000\n",
      "1426/2000\n",
      "1427/2000\n",
      "1428/2000\n",
      "1429/2000\n",
      "1430/2000\n",
      "1431/2000\n",
      "1432/2000\n",
      "1433/2000\n",
      "1434/2000\n",
      "1435/2000\n",
      "1436/2000\n",
      "1437/2000\n",
      "1438/2000\n",
      "1439/2000\n",
      "1440/2000\n",
      "1441/2000\n",
      "1442/2000\n",
      "1443/2000\n",
      "1444/2000\n",
      "1445/2000\n",
      "1446/2000\n",
      "1447/2000\n",
      "1448/2000\n",
      "1449/2000\n",
      "1450/2000\n",
      "1451/2000\n",
      "1452/2000\n",
      "1453/2000\n",
      "1454/2000\n",
      "1455/2000\n",
      "1456/2000\n",
      "1457/2000\n",
      "1458/2000\n",
      "1459/2000\n",
      "1460/2000\n",
      "1461/2000\n",
      "1462/2000\n",
      "1463/2000\n",
      "1464/2000\n",
      "1465/2000\n",
      "1466/2000\n",
      "1467/2000\n",
      "1468/2000\n",
      "1469/2000\n",
      "1470/2000\n",
      "1471/2000\n",
      "1472/2000\n",
      "1473/2000\n",
      "1474/2000\n",
      "1475/2000\n",
      "1476/2000\n",
      "1477/2000\n",
      "1478/2000\n",
      "1479/2000\n",
      "1480/2000\n",
      "1481/2000\n",
      "1482/2000\n",
      "1483/2000\n",
      "1484/2000\n",
      "1485/2000\n",
      "1486/2000\n",
      "1487/2000\n",
      "1488/2000\n",
      "1489/2000\n",
      "1490/2000\n",
      "1491/2000\n",
      "1492/2000\n",
      "1493/2000\n",
      "1494/2000\n",
      "1495/2000\n",
      "1496/2000\n",
      "1497/2000\n",
      "1498/2000\n",
      "1499/2000\n",
      "1500/2000\n",
      "1501/2000\n",
      "1502/2000\n",
      "1503/2000\n",
      "1504/2000\n",
      "1505/2000\n",
      "1506/2000\n",
      "1507/2000\n",
      "1508/2000\n",
      "1509/2000\n",
      "1510/2000\n",
      "1511/2000\n",
      "1512/2000\n",
      "1513/2000\n",
      "1514/2000\n",
      "1515/2000\n",
      "1516/2000\n",
      "1517/2000\n",
      "1518/2000\n",
      "1519/2000\n",
      "1520/2000\n",
      "1521/2000\n",
      "1522/2000\n",
      "1523/2000\n",
      "1524/2000\n",
      "1525/2000\n",
      "1526/2000\n",
      "1527/2000\n",
      "1528/2000\n",
      "1529/2000\n",
      "1530/2000\n",
      "1531/2000\n",
      "1532/2000\n",
      "1533/2000\n",
      "1534/2000\n",
      "1535/2000\n",
      "1536/2000\n",
      "1537/2000\n",
      "1538/2000\n",
      "1539/2000\n",
      "1540/2000\n",
      "1541/2000\n",
      "1542/2000\n",
      "1543/2000\n",
      "1544/2000\n",
      "1545/2000\n",
      "1546/2000\n",
      "1547/2000\n",
      "1548/2000\n",
      "1549/2000\n",
      "1550/2000\n",
      "1551/2000\n",
      "1552/2000\n",
      "1553/2000\n",
      "1554/2000\n",
      "1555/2000\n",
      "1556/2000\n",
      "1557/2000\n",
      "1558/2000\n",
      "1559/2000\n",
      "1560/2000\n",
      "1561/2000\n",
      "1562/2000\n",
      "1563/2000\n",
      "1564/2000\n",
      "1565/2000\n",
      "1566/2000\n",
      "1567/2000\n",
      "1568/2000\n",
      "1569/2000\n",
      "1570/2000\n",
      "1571/2000\n",
      "1572/2000\n",
      "1573/2000\n",
      "1574/2000\n",
      "1575/2000\n",
      "1576/2000\n",
      "1577/2000\n",
      "1578/2000\n",
      "1579/2000\n",
      "1580/2000\n",
      "1581/2000\n",
      "1582/2000\n",
      "1583/2000\n",
      "1584/2000\n",
      "1585/2000\n",
      "1586/2000\n",
      "1587/2000\n",
      "1588/2000\n",
      "1589/2000\n",
      "1590/2000\n",
      "1591/2000\n",
      "1592/2000\n",
      "1593/2000\n",
      "1594/2000\n",
      "1595/2000\n",
      "1596/2000\n",
      "1597/2000\n",
      "1598/2000\n",
      "1599/2000\n",
      "1600/2000\n",
      "1601/2000\n",
      "1602/2000\n",
      "1603/2000\n",
      "1604/2000\n",
      "1605/2000\n",
      "1606/2000\n",
      "1607/2000\n",
      "1608/2000\n",
      "1609/2000\n",
      "1610/2000\n",
      "1611/2000\n",
      "1612/2000\n",
      "1613/2000\n",
      "1614/2000\n",
      "1615/2000\n",
      "1616/2000\n",
      "1617/2000\n",
      "1618/2000\n",
      "1619/2000\n",
      "1620/2000\n",
      "1621/2000\n",
      "1622/2000\n",
      "1623/2000\n",
      "1624/2000\n",
      "1625/2000\n",
      "1626/2000\n",
      "1627/2000\n",
      "1628/2000\n",
      "1629/2000\n",
      "1630/2000\n",
      "1631/2000\n",
      "1632/2000\n",
      "1633/2000\n",
      "1634/2000\n",
      "1635/2000\n",
      "1636/2000\n",
      "1637/2000\n",
      "1638/2000\n",
      "1639/2000\n",
      "1640/2000\n",
      "1641/2000\n",
      "1642/2000\n",
      "1643/2000\n",
      "1644/2000\n",
      "1645/2000\n",
      "1646/2000\n",
      "1647/2000\n",
      "1648/2000\n",
      "1649/2000\n",
      "1650/2000\n",
      "1651/2000\n",
      "1652/2000\n",
      "1653/2000\n",
      "1654/2000\n",
      "1655/2000\n",
      "1656/2000\n",
      "1657/2000\n",
      "1658/2000\n",
      "1659/2000\n",
      "1660/2000\n",
      "1661/2000\n",
      "1662/2000\n",
      "1663/2000\n",
      "1664/2000\n",
      "1665/2000\n",
      "1666/2000\n",
      "1667/2000\n",
      "1668/2000\n",
      "1669/2000\n",
      "1670/2000\n",
      "1671/2000\n",
      "1672/2000\n",
      "1673/2000\n",
      "1674/2000\n",
      "1675/2000\n",
      "1676/2000\n",
      "1677/2000\n",
      "1678/2000\n",
      "1679/2000\n",
      "1680/2000\n",
      "1681/2000\n",
      "1682/2000\n",
      "1683/2000\n",
      "1684/2000\n",
      "1685/2000\n",
      "1686/2000\n",
      "1687/2000\n",
      "1688/2000\n",
      "1689/2000\n",
      "1690/2000\n",
      "1691/2000\n",
      "1692/2000\n",
      "1693/2000\n",
      "1694/2000\n",
      "1695/2000\n",
      "1696/2000\n",
      "1697/2000\n",
      "1698/2000\n",
      "1699/2000\n",
      "1700/2000\n",
      "1701/2000\n",
      "1702/2000\n",
      "1703/2000\n",
      "1704/2000\n",
      "1705/2000\n",
      "1706/2000\n",
      "1707/2000\n",
      "1708/2000\n",
      "1709/2000\n",
      "1710/2000\n",
      "1711/2000\n",
      "1712/2000\n",
      "1713/2000\n",
      "1714/2000\n",
      "1715/2000\n",
      "1716/2000\n",
      "1717/2000\n",
      "1718/2000\n",
      "1719/2000\n",
      "1720/2000\n",
      "1721/2000\n",
      "1722/2000\n",
      "1723/2000\n",
      "1724/2000\n",
      "1725/2000\n",
      "1726/2000\n",
      "1727/2000\n",
      "1728/2000\n",
      "1729/2000\n",
      "1730/2000\n",
      "1731/2000\n",
      "1732/2000\n",
      "1733/2000\n",
      "1734/2000\n",
      "1735/2000\n",
      "1736/2000\n",
      "1737/2000\n",
      "1738/2000\n",
      "1739/2000\n",
      "1740/2000\n",
      "1741/2000\n",
      "1742/2000\n",
      "1743/2000\n",
      "1744/2000\n",
      "1745/2000\n",
      "1746/2000\n",
      "1747/2000\n",
      "1748/2000\n",
      "1749/2000\n",
      "1750/2000\n",
      "1751/2000\n",
      "1752/2000\n",
      "1753/2000\n",
      "1754/2000\n",
      "1755/2000\n",
      "1756/2000\n",
      "1757/2000\n",
      "1758/2000\n",
      "1759/2000\n",
      "1760/2000\n",
      "1761/2000\n",
      "1762/2000\n",
      "1763/2000\n",
      "1764/2000\n",
      "1765/2000\n",
      "1766/2000\n",
      "1767/2000\n",
      "1768/2000\n",
      "1769/2000\n",
      "1770/2000\n",
      "1771/2000\n",
      "1772/2000\n",
      "1773/2000\n",
      "1774/2000\n",
      "1775/2000\n",
      "1776/2000\n",
      "1777/2000\n",
      "1778/2000\n",
      "1779/2000\n",
      "1780/2000\n",
      "1781/2000\n",
      "1782/2000\n",
      "1783/2000\n",
      "1784/2000\n",
      "1785/2000\n",
      "1786/2000\n",
      "1787/2000\n",
      "1788/2000\n",
      "1789/2000\n",
      "1790/2000\n",
      "1791/2000\n",
      "1792/2000\n",
      "1793/2000\n",
      "1794/2000\n",
      "1795/2000\n",
      "1796/2000\n",
      "1797/2000\n",
      "1798/2000\n",
      "1799/2000\n",
      "1800/2000\n",
      "1801/2000\n",
      "1802/2000\n",
      "1803/2000\n",
      "1804/2000\n",
      "1805/2000\n",
      "1806/2000\n",
      "1807/2000\n",
      "1808/2000\n",
      "1809/2000\n",
      "1810/2000\n",
      "1811/2000\n",
      "1812/2000\n",
      "1813/2000\n",
      "1814/2000\n",
      "1815/2000\n",
      "1816/2000\n",
      "1817/2000\n",
      "1818/2000\n",
      "1819/2000\n",
      "1820/2000\n",
      "1821/2000\n",
      "1822/2000\n",
      "1823/2000\n",
      "1824/2000\n",
      "1825/2000\n",
      "1826/2000\n",
      "1827/2000\n",
      "1828/2000\n",
      "1829/2000\n",
      "1830/2000\n",
      "1831/2000\n",
      "1832/2000\n",
      "1833/2000\n",
      "1834/2000\n",
      "1835/2000\n",
      "1836/2000\n",
      "1837/2000\n",
      "1838/2000\n",
      "1839/2000\n",
      "1840/2000\n",
      "1841/2000\n",
      "1842/2000\n",
      "1843/2000\n",
      "1844/2000\n",
      "1845/2000\n",
      "1846/2000\n",
      "1847/2000\n",
      "1848/2000\n",
      "1849/2000\n",
      "1850/2000\n",
      "1851/2000\n",
      "1852/2000\n",
      "1853/2000\n",
      "1854/2000\n",
      "1855/2000\n",
      "1856/2000\n",
      "1857/2000\n",
      "1858/2000\n",
      "1859/2000\n",
      "1860/2000\n",
      "1861/2000\n",
      "1862/2000\n",
      "1863/2000\n",
      "1864/2000\n",
      "1865/2000\n",
      "1866/2000\n",
      "1867/2000\n",
      "1868/2000\n",
      "1869/2000\n",
      "1870/2000\n",
      "1871/2000\n",
      "1872/2000\n",
      "1873/2000\n",
      "1874/2000\n",
      "1875/2000\n",
      "1876/2000\n",
      "1877/2000\n",
      "1878/2000\n",
      "1879/2000\n",
      "1880/2000\n",
      "1881/2000\n",
      "1882/2000\n",
      "1883/2000\n",
      "1884/2000\n",
      "1885/2000\n",
      "1886/2000\n",
      "1887/2000\n",
      "1888/2000\n",
      "1889/2000\n",
      "1890/2000\n",
      "1891/2000\n",
      "1892/2000\n",
      "1893/2000\n",
      "1894/2000\n",
      "1895/2000\n",
      "1896/2000\n",
      "1897/2000\n",
      "1898/2000\n",
      "1899/2000\n",
      "1900/2000\n",
      "1901/2000\n",
      "1902/2000\n",
      "1903/2000\n",
      "1904/2000\n",
      "1905/2000\n",
      "1906/2000\n",
      "1907/2000\n",
      "1908/2000\n",
      "1909/2000\n",
      "1910/2000\n",
      "1911/2000\n",
      "1912/2000\n",
      "1913/2000\n",
      "1914/2000\n",
      "1915/2000\n",
      "1916/2000\n",
      "1917/2000\n",
      "1918/2000\n",
      "1919/2000\n",
      "1920/2000\n",
      "1921/2000\n",
      "1922/2000\n",
      "1923/2000\n",
      "1924/2000\n",
      "1925/2000\n",
      "1926/2000\n",
      "1927/2000\n",
      "1928/2000\n",
      "1929/2000\n",
      "1930/2000\n",
      "1931/2000\n",
      "1932/2000\n",
      "1933/2000\n",
      "1934/2000\n",
      "1935/2000\n",
      "1936/2000\n",
      "1937/2000\n",
      "1938/2000\n",
      "1939/2000\n",
      "1940/2000\n",
      "1941/2000\n",
      "1942/2000\n",
      "1943/2000\n",
      "1944/2000\n",
      "1945/2000\n",
      "1946/2000\n",
      "1947/2000\n",
      "1948/2000\n",
      "1949/2000\n",
      "1950/2000\n",
      "1951/2000\n",
      "1952/2000\n",
      "1953/2000\n",
      "1954/2000\n",
      "1955/2000\n",
      "1956/2000\n",
      "1957/2000\n",
      "1958/2000\n",
      "1959/2000\n",
      "1960/2000\n",
      "1961/2000\n",
      "1962/2000\n",
      "1963/2000\n",
      "1964/2000\n",
      "1965/2000\n",
      "1966/2000\n",
      "1967/2000\n",
      "1968/2000\n",
      "1969/2000\n",
      "1970/2000\n",
      "1971/2000\n",
      "1972/2000\n",
      "1973/2000\n",
      "1974/2000\n",
      "1975/2000\n",
      "1976/2000\n",
      "1977/2000\n",
      "1978/2000\n",
      "1979/2000\n",
      "1980/2000\n",
      "1981/2000\n",
      "1982/2000\n",
      "1983/2000\n",
      "1984/2000\n",
      "1985/2000\n",
      "1986/2000\n",
      "1987/2000\n",
      "1988/2000\n",
      "1989/2000\n",
      "1990/2000\n",
      "1991/2000\n",
      "1992/2000\n",
      "1993/2000\n",
      "1994/2000\n",
      "1995/2000\n",
      "1996/2000\n",
      "1997/2000\n",
      "1998/2000\n",
      "1999/2000\n"
     ]
    }
   ],
   "source": [
    "data, ALL_SEN_TEST, cur_randomness = create_data(start_x, start_y, end_x, end_y, cur_randomness)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Init Data Structure "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# For each trajectory, number of new states, for W=[],it's simply number of states in the trajectory\n",
    "def init_new_sen_counter():\n",
    "    new_sen_counter = np.array(list(map(len, ALL_SEN)))\n",
    "    return new_sen_counter\n",
    "# E.g., new_sen_counter[2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "MAX_LENGTH = max(init_new_sen_counter())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "# For each state, in which trajectories it is in \n",
    "ALL_WORDS = np.empty(TOTAL_NUMBER_WORDS, dtype=list)\n",
    "for i in range(TOTAL_NUMBER_WORDS):\n",
    "    ALL_WORDS[i] = []\n",
    "for i, sen in enumerate(ALL_SEN):\n",
    "    for word in sen: \n",
    "        ALL_WORDS[word].append(i)   # this will include repetitions, if ALL_SEN includes rep \n",
    "        \n",
    "for i in range(TOTAL_NUMBER_WORDS):\n",
    "    ALL_WORDS[i] = set(ALL_WORDS[i])\n",
    "    \n",
    "# E.g., ALL_WORDS[11]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Greedy and Simulation algorithms "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def greedy_algorithm(k):\n",
    "    return np.argsort(np.array(list(map(len, ALL_WORDS))))[-k:]\n",
    "\n",
    "# E.g., greedy_algorithm(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def simulation_algorithm_one_run(k):\n",
    "    # returns a set of size k \n",
    "    R = []\n",
    "    a = np.arange(len(ALL_SEN))\n",
    "    np.random.shuffle(a)\n",
    "    for i,item in enumerate(a):\n",
    "        for w in ALL_SEN[item]:\n",
    "            R.append(w)\n",
    "            R = list(set(R))\n",
    "            if len(R) >= k:\n",
    "                break\n",
    "        if len(R) >= k:\n",
    "            break\n",
    "    return R"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def simulation_algorithm(k, rep):\n",
    "    # preform rep times the simulation algorithm and take the best \n",
    "    print('simulation algorithm')\n",
    "    S_opt = []\n",
    "    wS_opt = 0\n",
    "    all_in_S = np.zeros(rep)\n",
    "    for i in range(rep):\n",
    "        S = simulation_algorithm_one_run(k)\n",
    "        all_in_S[i] = paths_all_in(S, ALL_SEN)\n",
    "        if all_in_S[i] > wS_opt:\n",
    "            S_opt = S\n",
    "            wS_opt = all_in_S[i]\n",
    "        if i % 10 == 0:\n",
    "            print(i)\n",
    "    return S_opt, all_in_S "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Helpul functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_set(W, title_str):\n",
    "    # print set W with title \"title_str\"\n",
    "    A = np.zeros((N,N))\n",
    "    for i in W:   \n",
    "        x,y = VOCABULARY[i]\n",
    "        A[x,y]=10\n",
    "    #ax = sns.heatmap(A,cbar=False)\n",
    "    ax = sns.heatmap(A, cbar=False, cmap = 'jet', square=True, norm=mpl.colors.LogNorm(vmin=1, vmax=data.max()))    \n",
    "    #ax.set_title(title_str) \n",
    "    ax.patch.set_edgecolor('black')  \n",
    "    ax.patch.set_linewidth('2') \n",
    "    ax.xaxis.set_visible(False) \n",
    "    ax.yaxis.set_visible(False)\n",
    "# E.g., print_set(greedy_algorithm(55),'greedy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def paths_all_in(W, SEN):\n",
    "    # how many trajectories in SEN are *all* in set W  \n",
    "    counter = 0\n",
    "    for sen in SEN:\n",
    "        if set(sen) <= set(W):\n",
    "            counter += 1\n",
    "    return counter   \n",
    "\n",
    "# E.g., paths_all_in([0,1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Safe Zone Algorithm  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def safe_zone_one_run_faster(k, is_exact=True):\n",
    "    W = []\n",
    "    new_sen_counter = init_new_sen_counter()\n",
    "    i = 0\n",
    "    \n",
    "    while len(W) < k:\n",
    "        val , e = np.unique(new_sen_counter, return_counts=True) \n",
    "        start = int(val[0] == 0)\n",
    "        e_no_0 = e[start:]\n",
    "        val_no_0 = val[start:]\n",
    "        weight = e_no_0/val_no_0\n",
    "        Z = sum(weight)        \n",
    "        j = np.random.choice(val_no_0, p=weight/Z) \n",
    "        \n",
    "        # Add a random path with j new values to W \n",
    "        a = np.where(new_sen_counter == j)[0]\n",
    "        example_path_index = a[int(len(a) * random.random())] \n",
    "        new_words_before_W = ALL_SEN[example_path_index]\n",
    "        \n",
    "        new_words = []\n",
    "        \n",
    "        for w in new_words_before_W:\n",
    "            if (w not in W) and (w not in new_words):\n",
    "                 new_words.append(w)\n",
    "            if is_exact and (len(new_words) + len(W) >= k): # if you want a set of size exactly k \n",
    "                break \n",
    "        \n",
    "        W.extend(new_words)   # add new_words to the word list \n",
    "        W = list(set(W))\n",
    "        \n",
    "        # delete new_words from new_sen_counter\n",
    "        for w in new_words: \n",
    "            for sen in ALL_WORDS[w]:\n",
    "                if new_sen_counter[sen] <= 0:\n",
    "                    print('NOOOO') # a sanity check - code should never be here\n",
    "                    print('sen:',sen)\n",
    "                new_sen_counter[sen] -= ALL_SEN[sen].count(w) \n",
    "                      \n",
    "                \n",
    "        i +=1 \n",
    "     \n",
    "    val , e = np.unique(new_sen_counter, return_counts=True)\n",
    "    if val[0] == 0:\n",
    "         return W, e[0]\n",
    "    return W, 0\n",
    "#E.g., safe_zone_one_run_faster(20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "def safe_zone(k, rep, is_exact=True):\n",
    "    W_opt = []\n",
    "    wW_opt = 0\n",
    "    all_in_W = np.zeros(rep)\n",
    "    for i in range(rep):\n",
    "        W, all_in_W[i] = safe_zone_one_run_faster(k,is_exact)\n",
    "        if all_in_W[i] > wW_opt:\n",
    "            W_opt = W\n",
    "            wW_opt = all_in_W[i]\n",
    "        if i % 10 == 0:\n",
    "            print(i)\n",
    "    W = W_opt\n",
    "    return W, all_in_W "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Run all algorithms several times"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_all_alg_several_times(k_values, times, rep):\n",
    "    # for each k in k_values, for \"times\" times, run algorithms with \"rep\" repetitions\n",
    "    m = len(k_values)\n",
    "    results = np.zeros((m,times,4))\n",
    "    \n",
    "    for t in range(times):\n",
    "        for i,k in enumerate(k_values):\n",
    "            print(t, i, k)\n",
    "            start = time.time()\n",
    "            W, _ = safe_zone(k, rep)\n",
    "            print('time:')\n",
    "            print(time.time()-start)\n",
    "            G = greedy_algorithm(len(W))\n",
    "            S,_ = simulation_algorithm(len(W),rep)\n",
    "            results[i,t,0] = len(W)\n",
    "            results[i,t,1] = paths_all_in(W, ALL_SEN_TEST)/TOTAL_NUMBER_SEN*100\n",
    "            results[i,t,2] = paths_all_in(G, ALL_SEN_TEST)/TOTAL_NUMBER_SEN*100\n",
    "            results[i,t,3] = paths_all_in(S, ALL_SEN_TEST)/TOTAL_NUMBER_SEN*100\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0 40\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "15.547053098678589\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 1 50\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "19.49729895591736\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 2 60\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "23.657900094985962\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 3 70\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "24.13927912712097\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 4 80\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "23.682029008865356\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 5 100\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "74.96271800994873\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 6 120\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "46.38392901420593\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 7 150\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "52.4186577796936\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 8 200\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "52.184974670410156\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 9 250\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "62.053354263305664\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 10 300\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "60.62140202522278\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "0 11 350\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "83.14024209976196\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 0 40\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "21.947705268859863\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 1 50\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "20.128594160079956\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 2 60\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "19.46870994567871\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 3 70\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "21.757825136184692\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 4 80\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "23.994731664657593\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 5 100\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "28.69126296043396\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 6 120\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "38.36512279510498\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 7 150\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "42.68855690956116\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 8 200\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "61.07296419143677\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 9 250\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "55.43838429450989\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 10 300\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "65.37122201919556\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "1 11 350\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "65.69375801086426\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 0 40\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "18.61417508125305\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 1 50\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "19.377601861953735\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 2 60\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "21.927416801452637\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 3 70\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "24.71219491958618\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 4 80\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "25.845310926437378\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 5 100\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "41.89650511741638\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 6 120\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "61.57789397239685\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 7 150\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "90.1893298625946\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 8 200\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "75.5207269191742\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 9 250\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "61.143064737319946\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 10 300\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "60.1267671585083\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "2 11 350\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "76.3799479007721\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 0 40\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "13.61738395690918\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 1 50\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "20.130592823028564\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 2 60\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "26.65644907951355\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 3 70\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "26.51057195663452\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 4 80\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "25.672096967697144\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 5 100\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "31.210111141204834\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 6 120\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "34.72718596458435\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 7 150\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "51.934282064437866\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 8 200\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "47.803574085235596\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 9 250\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "57.473328828811646\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 10 300\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "59.27325630187988\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "3 11 350\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "65.18465995788574\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 0 40\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "16.84378695487976\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 1 50\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "18.014686107635498\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 2 60\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "25.25621509552002\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 3 70\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "26.005526065826416\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 4 80\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "23.223942756652832\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 5 100\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "27.790772914886475\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 6 120\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "34.9784619808197\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 7 150\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "35.97391414642334\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 8 200\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "59.3095600605011\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 9 250\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "54.258382081985474\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 10 300\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "56.658528089523315\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "4 11 350\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n",
      "time:\n",
      "52.75805616378784\n",
      "simulation algorithm\n",
      "0\n",
      "10\n",
      "20\n",
      "30\n",
      "40\n",
      "50\n",
      "60\n",
      "70\n",
      "80\n",
      "90\n",
      "100\n",
      "110\n",
      "120\n",
      "130\n",
      "140\n",
      "150\n",
      "160\n",
      "170\n",
      "180\n",
      "190\n",
      "200\n",
      "210\n",
      "220\n",
      "230\n",
      "240\n",
      "250\n",
      "260\n",
      "270\n",
      "280\n",
      "290\n"
     ]
    }
   ],
   "source": [
    "times = 5\n",
    "k_values = [40, 50, 60, 70, 80, 100, 120, 150, 200, 250, 300, 350]\n",
    "rep = 300\n",
    "many_results = run_all_alg_several_times(k_values, times, rep)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Print Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       k   algorithm  value\n",
      "0     40   safe-zone   0.30\n",
      "1     40  simulation   0.00\n",
      "2     50   safe-zone   0.15\n",
      "3     50  simulation   0.15\n",
      "4     60   safe-zone   0.75\n",
      "..   ...         ...    ...\n",
      "115  250  simulation  -0.10\n",
      "116  300   safe-zone   1.35\n",
      "117  300  simulation   0.65\n",
      "118  350   safe-zone   0.40\n",
      "119  350  simulation   0.35\n",
      "\n",
      "[120 rows x 3 columns]\n"
     ]
    }
   ],
   "source": [
    "# prepare data to print\n",
    "df = pd.DataFrame(columns=['k','algorithm','value'])\n",
    "for t in range(times):\n",
    "    for i,k in enumerate(k_values):\n",
    "        df = df.append({'k': int(many_results[i,t,0]), 'algorithm':'safe-zone', 'value': many_results[i,t,1]-many_results[i,t,2]}, ignore_index=True)\n",
    "        # to print greedy (which is zero): \n",
    "        #df = df.append({'k': int(many_results[i,t,0]), 'algorithm':'greedy', 'value': many_results[i,t,2]-many_results[i,t,2]}, ignore_index=True)\n",
    "        df = df.append({'k': int(many_results[i,t,0]), 'algorithm':'simulation', 'value': many_results[i,t,3]-many_results[i,t,2]}, ignore_index=True)\n",
    "\n",
    "print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "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": [
    "sns.lineplot(data=df, x='k', y='value', hue_order = ['safe-zone','simulation'], hue='algorithm', palette=\"pastel\")\n",
    "plt.xlabel('k')\n",
    "plt.ylabel('coverage percentage\\n compared to greedy')\n",
    "plt.savefig(\"safe_zone_result_coverage_compared_to_greedy_new.png\", dpi=600)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
