{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "0ae98199",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "import networkx as nx\n",
    "import random\n",
    "import pyscipopt as sp\n",
    "import numpy as np\n",
    "import multiprocessing as md\n",
    "from functools import partial\n",
    "import imp\n",
    "\n",
    "import gisp\n",
    "import fcmcnf\n",
    "\n",
    "%load_ext autoreload \n",
    "%autoreload 2\n",
    "\n",
    "\n",
    "\n",
    "def distribute(n_instance, n_cpu):\n",
    "    if n_cpu == 1:\n",
    "        return [(0, n_instance)]\n",
    "    \n",
    "    k = n_instance //( n_cpu -1 )\n",
    "    r = n_instance % (n_cpu - 1 )\n",
    "    res = []\n",
    "    for i in range(n_cpu -1):\n",
    "        res.append( ((k*i), (k*(i+1))) )\n",
    "    \n",
    "    res.append(((n_cpu - 1) *k ,(n_cpu - 1) *k + r ))\n",
    "    return res\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "5c26d5d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Summary for FCMCNF generation\n",
      "n_instance    :     500\n",
      "size interval :     (15, 15)\n",
      "n_cpu         :     16 \n",
      "solve         :     True\n",
      "saving dir    :     /local_workspace/labaabde/learn2selectnodes/problem_generation/data/FCMCNF/valid\n"
     ]
    }
   ],
   "source": [
    "n_cpu = 16\n",
    "n_instance = 500 \n",
    "\n",
    "problem = 'FCMCNF'\n",
    "\n",
    "data_partition = 'valid'\n",
    "\n",
    "\n",
    "instance = None\n",
    "solveInstance = True\n",
    "exp_dir = f\"data/{problem}/{data_partition}\"\n",
    "\n",
    "\n",
    "er_prob = 0.3\n",
    "whichSet = 'SET2'\n",
    "setParam = 100.0\n",
    "alphaE2 = 0.5\n",
    "timelimit = 7200.0\n",
    "\n",
    "seed = 591\n",
    "\n",
    "min_n = 15\n",
    "max_n = 15\n",
    "\n",
    "min_n_commodities = int(1.5*max_n)\n",
    "max_n_commodities = int(1.5*max_n)\n",
    "\n",
    "assert exp_dir is not None\n",
    "if instance is None:\n",
    "    assert min_n is not None\n",
    "    assert max_n is not None\n",
    "\n",
    "exp_dir = exp_dir \n",
    "lp_dir= os.path.join(os.path.abspath('.'), exp_dir)\n",
    "try:\n",
    "    os.makedirs(lp_dir)\n",
    "except FileExistsError:\n",
    "    \"\"\n",
    "\n",
    "print(f\"Summary for {problem} generation\")\n",
    "print(f\"n_instance    :     {n_instance}\")\n",
    "print(f\"size interval :     {min_n, max_n}\")\n",
    "print(f\"n_cpu         :     {n_cpu} \")\n",
    "print(f\"solve         :     {solveInstance}\")\n",
    "print(f\"saving dir    :     {lp_dir}\")\n",
    "\n",
    "\n",
    "\n",
    "cpu_count = md.cpu_count()//2 if n_cpu == None else n_cpu\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "43efbcc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DiGraph with 15 nodes and 63 edges\n",
      "DiGraph with 15 nodes and 69 edgesDiGraph with 15 nodes and 55 edges\n",
      "\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 54 edgesDiGraph with 15 nodes and 60 edges\n",
      "\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 49 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "24\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 74 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "5\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "9\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "28\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "110\n",
      "DiGraph with 15 nodes and 46 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "8\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "64\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "97\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "17\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 74 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 49 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "9\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 50 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "5\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "32\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 75 edges\n",
      "91\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 75 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "21\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "28\n",
      "DiGraph with 15 nodes and 77 edges\n",
      "185\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "18\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "21\n",
      "DiGraph with 15 nodes and 74 edges\n",
      "40\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "69\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "5\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "15\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "119\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "48\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "302\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "37\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "52\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "7\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "38\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "118\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "15\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "13\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "7\n",
      "DiGraph with 15 nodes and 50 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "188\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "11\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "99\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "27\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "59\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "21\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "279\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "52\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 75 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 76 edges\n",
      "18\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "11\n",
      "DiGraph with 15 nodes and 49 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "8\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "124\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 82 edges\n",
      "11\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "16\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "9\n",
      "DiGraph with 15 nodes and 74 edges\n",
      "16\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "181\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "179\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "61\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "45\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "53\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "819\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "5\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "83\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "1DiGraph with 15 nodes and 64 edges\n",
      "\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "70\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "121\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "18\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "207\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "49\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "14\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "104\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 77 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "49\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "211\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "162\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 46 edges\n",
      "55\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DiGraph with 15 nodes and 59 edges\n",
      "72\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "262\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "9\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 78 edges\n",
      "288\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "33\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "75\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "418\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "225\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "305\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "71\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "40\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "256\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "11\n",
      "\n",
      "DiGraph with 15 nodes and 61 edgesDiGraph with 15 nodes and 61 edges\n",
      "\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 75 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 46 edges\n",
      "19\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 49 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 75 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 76 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 78 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "29\n",
      "DiGraph with 15 nodes and 55 edgesDiGraph with 15 nodes and 65 edges\n",
      "\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "8\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "63\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "24\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "34\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "13\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "266\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "329\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "139\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "7\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "580\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "6\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "54\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "172\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "9\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "11\n",
      "DiGraph with 15 nodes and 76 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "7\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "63\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "76\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "14\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "53\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "139\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "12\n",
      "DiGraph with 15 nodes and 49 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 47 edges\n",
      "7\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "5\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "1\n",
      "1\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "32\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 46 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 74 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "12\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "41\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "1\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "11\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "228\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "46\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "66\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 77 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "59\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "443\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 78 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "13\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "225\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "27\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "5\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "11\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 49 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 69 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "9\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 47 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 48 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "13\n",
      "\n",
      "DiGraph with 15 nodes and 58 edgesDiGraph with 15 nodes and 65 edges\n",
      "\n",
      "154\n",
      "DiGraph with 15 nodes and 53 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 78 edges\n",
      "334\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "13\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "12\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "90\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "931\n",
      "1\n",
      "\n",
      "1\n",
      "\n",
      "1DiGraph with 15 nodes and 60 edges\n",
      "DiGraph with 15 nodes and 58 edgesDiGraph with 15 nodes and 61 edges\n",
      "\n",
      "\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "DiGraph with 15 nodes and 70 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "29\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "1\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges309\n",
      "\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "0\n",
      "0\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "7\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 56 edges\n",
      "1\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DiGraph with 15 nodes and 74 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "13\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "29\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "39\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "0\n",
      "12\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "169\n",
      "DiGraph with 15 nodes and 78 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "106\n",
      "DiGraph with 15 nodes and 50 edges\n",
      "98\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "93\n",
      "DiGraph with 15 nodes and 72 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 73 edges\n",
      "15\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 64 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "92\n",
      "DiGraph with 15 nodes and 75 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 74 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "60\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "1\n",
      "1\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "104\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "69\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "1\n",
      "130\n",
      "DiGraph with 15 nodes and 62 edges\n",
      "75\n",
      "DiGraph with 15 nodes and 66 edges\n",
      "351\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "1\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "85\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "0\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "0\n",
      "19\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "48\n",
      "DiGraph with 15 nodes and 58 edges\n",
      "347\n",
      "DiGraph with 15 nodes and 55 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "7\n",
      "DiGraph with 15 nodes and 65 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 61 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 77 edges\n",
      "27\n",
      "DiGraph with 15 nodes and 54 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 71 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 57 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "0\n",
      "DiGraph with 15 nodes and 68 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 60 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 67 edges\n",
      "1\n",
      "65\n",
      "DiGraph with 15 nodes and 51 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 59 edges\n",
      "3\n",
      "DiGraph with 15 nodes and 63 edges\n",
      "1\n",
      "DiGraph with 15 nodes and 52 edges\n",
      "0\n",
      "Generated\n"
     ]
    }
   ],
   "source": [
    "if problem == 'GISP':\n",
    "    processes = [  md.Process(name=f\"worker {p}\", target=partial(gisp.generate_instances,\n",
    "                                                                  seed + p1, \n",
    "                                                                  seed + p2, \n",
    "                                                                  whichSet, \n",
    "                                                                  setParam, \n",
    "                                                                  alphaE2, \n",
    "                                                                  min_n, \n",
    "                                                                  max_n, \n",
    "                                                                  er_prob, \n",
    "                                                                  instance, \n",
    "                                                                  lp_dir, \n",
    "                                                                  solveInstance))\n",
    "\n",
    "\n",
    "                 for p,(p1,p2) in enumerate(distribute(n_instance, n_cpu)) ]\n",
    "\n",
    "elif problem == 'FCMCNF':\n",
    "\n",
    "#=============================================================================\n",
    "    processes = [  md.Process(name=f\"worker {p}\", target=partial(fcmcnf.generate_instances,\n",
    "                                                                  seed + p1, \n",
    "                                                                  seed + p2, \n",
    "                                                                  min_n,\n",
    "                                                                  max_n,\n",
    "                                                                  min_n_commodities,\n",
    "                                                                  max_n_commodities,\n",
    "                                                                  er_prob,\n",
    "                                                                  lp_dir, \n",
    "                                                                  solveInstance))\n",
    "\n",
    "\n",
    "                  for p,(p1,p2) in enumerate(distribute(n_instance, n_cpu)) ]\n",
    "\n",
    "#=============================================================================\n",
    "    #generate_fcmcnf.generate_instances(0, n_instance, min_n_nodes, max_n_nodes, min_n_arcs, max_n_arcs, min_n_commodities, max_n_commodities, lp_dir, solveInstance)\n",
    "\n",
    "\n",
    "\n",
    "a = list(map(lambda p: p.start(), processes)) #run processes\n",
    "b = list(map(lambda p: p.join(), processes)) #join processes\n",
    "print('Generated')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
