{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "63237658-7728-4244-a53a-6998a259613e",
   "metadata": {},
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "806c1a86-038c-485e-8760-d393f1ac485f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "base = \"/research/2025_mip/\"\n",
    "sys.path.append(base)\n",
    "sys.path.append(os.path.join(base, 'forge'))\n",
    "\n",
    "from forge.forge import Forge\n",
    "from forge.utils import *\n",
    "import subprocess\n",
    "\n",
    "try:\n",
    "    from gurobi_onboarder import init_gurobi\n",
    "    gurobi_venv, GUROBI_FOUND = init_gurobi.initialize_gurobi()\n",
    "except:\n",
    "    gurobi_venv = gp.Env(empty=True)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "469141fe-9ebf-4a2a-9339-33b362289864",
   "metadata": {},
   "source": [
    "# Commands"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05d341e9-5495-489c-b704-1ade6e271e46",
   "metadata": {},
   "outputs": [],
   "source": [
    "base = \"research/2025_mip/experiments/supervised/\"\n",
    "\n",
    "sc = \"\"\n",
    "ca = \"\"\n",
    "mvc = \"\"\n",
    "gisp = \"\"\n",
    "\n",
    "difficulty = 'medium'\n",
    "threads = '1'\n",
    "time_limit = '3600'\n",
    "script = base + 'pseudo_cut.py'\n",
    "# script = base + 'warm_start.py'\n",
    "\n",
    "for idx in range(100):\n",
    "   sc += \"nohup /home/sagemaker-user/.conda/envs/gpu/bin/python \" + script + \" --prob_type SC --inst_idx \" + str(idx) +\" --difficulty \" + difficulty + \" --threads \" + threads + \" --timelimit \" + time_limit + \" >/dev/null 2>&1 & \\n \"\n",
    "   ca += \"nohup /home/sagemaker-user/.conda/envs/gpu/bin/python \" + script + \" --prob_type CA --inst_idx \" + str(idx) +\" --difficulty \" + difficulty + \" --threads \" + threads + \" --timelimit \" + time_limit + \" >/dev/null 2>&1 & \\n\"\n",
    "   mvc += \"nohup /home/sagemaker-user/.conda/envs/gpu/bin/python \" + script + \" --prob_type MVC --inst_idx \" + str(idx) +\" --difficulty \" + difficulty + \" --threads \" + threads + \" --timelimit \" + time_limit + \" >/dev/null 2>&1 & \\n \"\n",
    "   gisp += \"nohup /home/sagemaker-user/.conda/envs/gpu/bin/python \" + script + \" --prob_type GISP --inst_idx \" + str(idx) +\" --difficulty \" + difficulty + \" --threads \" + threads + \" --timelimit \" + time_limit + \" >/dev/null 2>&1 & \\n \""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1fcfcd8c-f61d-44bb-b495-ac53e23bc7ac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "f89d4a0a-9645-4aba-b746-e0d2cb56fc28",
   "metadata": {},
   "source": [
    "# Run"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d6b1e1e-f4f0-42b6-84be-fcd3e68a0351",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_parallel = 40\n",
    "commands = mvc.split('\\n')\n",
    "\n",
    "o = subprocess.run('ps -ax | grep experiments | grep difficulty | wc -l', shell = True, stdout = subprocess.PIPE, text=True)\n",
    "num_running = int(o.stdout.strip('\\n'))\n",
    "i = 0\n",
    "\n",
    "while i < 100:\n",
    "\n",
    "    while num_running >= num_parallel:\n",
    "        time.sleep(5)\n",
    "        o = subprocess.run('ps -ax | grep experiments | grep difficulty | wc -l', shell = True, stdout = subprocess.PIPE, text=True)\n",
    "        num_running = int(o.stdout.strip('\\n')) - 1\n",
    "\n",
    "    subprocess.call(commands[i], shell = True)\n",
    "    o = subprocess.run('ps -ax | grep experiments | grep difficulty | wc -l', shell = True, stdout = subprocess.PIPE, text=True)\n",
    "    num_running = int(o.stdout.strip('\\n'))\n",
    "    i += 1\n",
    "\n",
    "    print (\"\", \"Current Number of Processes Sumbitted : \", i, end = '\\r')\n",
    "\n",
    "print (\"\", \"Completed Submitting All Jobs\", end = '\\r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "249e966c-b719-4fe3-9616-a92f0f2ac8dc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b0e9f1d-ca48-481b-8764-41bec8f2e905",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_parallel = 40\n",
    "commands = sc.split('\\n')[:-1] + ca.split('\\n')[:-1] + gisp.split('\\n')[:-1] + mvc.split('\\n')[:-1] \n",
    "\n",
    "o = subprocess.run('ps -ax | grep experiments | grep difficulty | wc -l', shell = True, stdout = subprocess.PIPE, text=True)\n",
    "num_running = int(o.stdout.strip('\\n'))\n",
    "i = 0\n",
    "\n",
    "while i < 400:\n",
    "\n",
    "    while num_running >= num_parallel:\n",
    "        time.sleep(5)\n",
    "        o = subprocess.run('ps -ax | grep experiments | grep difficulty | wc -l', shell = True, stdout = subprocess.PIPE, text=True)\n",
    "        num_running = int(o.stdout.strip('\\n')) - 1\n",
    "\n",
    "    subprocess.call(commands[i], shell = True)\n",
    "    o = subprocess.run('ps -ax | grep experiments | grep difficulty | wc -l', shell = True, stdout = subprocess.PIPE, text=True)\n",
    "    num_running = int(o.stdout.strip('\\n'))\n",
    "    i += 1\n",
    "\n",
    "    print (\"\", \"Current Number of Processes Sumbitted : \", i, end = '\\r')\n",
    "\n",
    "print (\"\", \"Completed Submitting All Jobs\", end = '\\r')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gpu",
   "language": "python",
   "name": "gpu"
  },
  "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
