{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cc30f004-4e14-4a8f-ad42-0a983ea6d888",
   "metadata": {},
   "source": [
    "# Description \n",
    "This notebook loads data from CMS Hospital Compare and runs algorithms for positional representation and positional proportionality.\n",
    "\n",
    "Before running this notebook: Download data from CMS Hospital Compare and run hospital_quality_dataset_creation_anon.ipynb to combine all metrics into all_cms_metrics_ca.csv used in this notebook. \n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "86f6e64a-588b-4cd5-9cd5-fcbe9dbd0067",
   "metadata": {},
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 207,
   "id": "0253879a-918c-411e-8f6d-6967877243f3",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import cvxpy as cp\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import random\n",
    "import selection_algorithms\n",
    "\n",
    "plt.rcParams['font.family'] = 'serif'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e33582c7-d708-412e-9b03-9c6033a4711a",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Cal hospital compare measures \n",
    "CHC_METRICS = ['HAI_1_SIR','HAI_2_SIR','HAI_3_SIR','HAI_5_SIR','HAI_6_SIR', 'PSI_90', 'SEP_1', 'H_COMP_1_A_P', 'H_COMP_2_A_P', 'H_COMP_3_A_P', 'H_COMP_5_A_P', 'H_COMP_7_SA']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d322b9af-2362-4b1a-8240-5798d3a50779",
   "metadata": {},
   "source": [
    "# Load data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "42c167f5-de98-449e-bf25-faec95d90a09",
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Facility ID</th>\n",
       "      <th>Facility Name</th>\n",
       "      <th>State</th>\n",
       "      <th>HAI_1_SIR</th>\n",
       "      <th>HAI_2_SIR</th>\n",
       "      <th>HAI_3_SIR</th>\n",
       "      <th>HAI_4_SIR</th>\n",
       "      <th>HAI_5_SIR</th>\n",
       "      <th>HAI_6_SIR</th>\n",
       "      <th>COMP_HIP_KNEE</th>\n",
       "      <th>...</th>\n",
       "      <th>OP_35_ADM</th>\n",
       "      <th>OP_35_ED</th>\n",
       "      <th>OP_36</th>\n",
       "      <th>READM_30_AMI</th>\n",
       "      <th>READM_30_CABG</th>\n",
       "      <th>READM_30_COPD</th>\n",
       "      <th>READM_30_HF</th>\n",
       "      <th>READM_30_HIP_KNEE</th>\n",
       "      <th>READM_30_HOSP_WIDE</th>\n",
       "      <th>READM_30_PN</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>050002</td>\n",
       "      <td>ST ROSE HOSPITAL</td>\n",
       "      <td>CA</td>\n",
       "      <td>-0.814</td>\n",
       "      <td>-1.057</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.858</td>\n",
       "      <td>-2.7</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-13.8</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-20.6</td>\n",
       "      <td>-22.5</td>\n",
       "      <td>-5.3</td>\n",
       "      <td>-16.0</td>\n",
       "      <td>-18.4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>050006</td>\n",
       "      <td>PROVIDENCE ST JOSEPH HOSPITAL</td>\n",
       "      <td>CA</td>\n",
       "      <td>-0.652</td>\n",
       "      <td>-0.542</td>\n",
       "      <td>-1.331</td>\n",
       "      <td>-0.962</td>\n",
       "      <td>-0.525</td>\n",
       "      <td>-0.458</td>\n",
       "      <td>-3.1</td>\n",
       "      <td>...</td>\n",
       "      <td>-9.9</td>\n",
       "      <td>-4.7</td>\n",
       "      <td>-0.9</td>\n",
       "      <td>-12.2</td>\n",
       "      <td>-10.9</td>\n",
       "      <td>-19.0</td>\n",
       "      <td>-17.4</td>\n",
       "      <td>-4.1</td>\n",
       "      <td>-12.9</td>\n",
       "      <td>-15.4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>050007</td>\n",
       "      <td>PENINSULA MEDICAL CENTER</td>\n",
       "      <td>CA</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-0.165</td>\n",
       "      <td>-0.527</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.338</td>\n",
       "      <td>-0.239</td>\n",
       "      <td>-2.9</td>\n",
       "      <td>...</td>\n",
       "      <td>-9.9</td>\n",
       "      <td>-4.8</td>\n",
       "      <td>-0.9</td>\n",
       "      <td>-12.6</td>\n",
       "      <td>-11.2</td>\n",
       "      <td>-17.5</td>\n",
       "      <td>-19.1</td>\n",
       "      <td>-3.8</td>\n",
       "      <td>-14.0</td>\n",
       "      <td>-16.2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>050008</td>\n",
       "      <td>CALIFORNIA PACIFIC MEDICAL CTR-DAVIES CAMPUS HOSP</td>\n",
       "      <td>CA</td>\n",
       "      <td>-0.944</td>\n",
       "      <td>-0.556</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.673</td>\n",
       "      <td>-3.0</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-20.7</td>\n",
       "      <td>-4.0</td>\n",
       "      <td>-14.8</td>\n",
       "      <td>-17.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>050009</td>\n",
       "      <td>PROVIDENCE QUEEN OF THE VALLEY MEDICAL CENTER</td>\n",
       "      <td>CA</td>\n",
       "      <td>-0.598</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.968</td>\n",
       "      <td>-0.352</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>-11.7</td>\n",
       "      <td>-7.3</td>\n",
       "      <td>-1.1</td>\n",
       "      <td>-14.1</td>\n",
       "      <td>-12.5</td>\n",
       "      <td>-17.5</td>\n",
       "      <td>-19.6</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-14.3</td>\n",
       "      <td>-15.3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>277</th>\n",
       "      <td>051324</td>\n",
       "      <td>NORTHERN INYO HOSPITAL</td>\n",
       "      <td>CA</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>-11.3</td>\n",
       "      <td>-5.4</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-19.1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-14.9</td>\n",
       "      <td>-16.3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>278</th>\n",
       "      <td>051325</td>\n",
       "      <td>MENDOCINO COAST DISTRICT HOSPITAL</td>\n",
       "      <td>CA</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.592</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>-10.4</td>\n",
       "      <td>-6.7</td>\n",
       "      <td>-1.1</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-19.7</td>\n",
       "      <td>-20.7</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-15.3</td>\n",
       "      <td>-16.2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>279</th>\n",
       "      <td>051328</td>\n",
       "      <td>TAHOE FOREST HOSPITAL</td>\n",
       "      <td>CA</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>-5.4</td>\n",
       "      <td>...</td>\n",
       "      <td>-11.3</td>\n",
       "      <td>-6.8</td>\n",
       "      <td>-0.7</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-18.9</td>\n",
       "      <td>-19.3</td>\n",
       "      <td>-5.1</td>\n",
       "      <td>-14.3</td>\n",
       "      <td>-16.7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>280</th>\n",
       "      <td>051329</td>\n",
       "      <td>SUTTER LAKESIDE HOSPITAL</td>\n",
       "      <td>CA</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-0.9</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-17.6</td>\n",
       "      <td>-19.3</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-13.3</td>\n",
       "      <td>-15.2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>281</th>\n",
       "      <td>051332</td>\n",
       "      <td>MARK TWAIN MEDICAL CENTER</td>\n",
       "      <td>CA</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-3.5</td>\n",
       "      <td>...</td>\n",
       "      <td>-10.0</td>\n",
       "      <td>-6.1</td>\n",
       "      <td>-1.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>-18.0</td>\n",
       "      <td>-19.6</td>\n",
       "      <td>-4.2</td>\n",
       "      <td>-14.8</td>\n",
       "      <td>-16.5</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>282 rows × 53 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    Facility ID                                      Facility Name State  \\\n",
       "0        050002                                   ST ROSE HOSPITAL    CA   \n",
       "1        050006                      PROVIDENCE ST JOSEPH HOSPITAL    CA   \n",
       "2        050007                           PENINSULA MEDICAL CENTER    CA   \n",
       "3        050008  CALIFORNIA PACIFIC MEDICAL CTR-DAVIES CAMPUS HOSP    CA   \n",
       "4        050009      PROVIDENCE QUEEN OF THE VALLEY MEDICAL CENTER    CA   \n",
       "..          ...                                                ...   ...   \n",
       "277      051324                             NORTHERN INYO HOSPITAL    CA   \n",
       "278      051325                  MENDOCINO COAST DISTRICT HOSPITAL    CA   \n",
       "279      051328                              TAHOE FOREST HOSPITAL    CA   \n",
       "280      051329                           SUTTER LAKESIDE HOSPITAL    CA   \n",
       "281      051332                          MARK TWAIN MEDICAL CENTER    CA   \n",
       "\n",
       "     HAI_1_SIR  HAI_2_SIR  HAI_3_SIR  HAI_4_SIR  HAI_5_SIR  HAI_6_SIR  \\\n",
       "0       -0.814     -1.057        NaN        NaN        NaN     -0.858   \n",
       "1       -0.652     -0.542     -1.331     -0.962     -0.525     -0.458   \n",
       "2       -0.000     -0.165     -0.527        NaN     -0.338     -0.239   \n",
       "3       -0.944     -0.556        NaN        NaN        NaN     -0.673   \n",
       "4       -0.598     -0.000     -0.000        NaN     -0.968     -0.352   \n",
       "..         ...        ...        ...        ...        ...        ...   \n",
       "277        NaN        NaN        NaN        NaN        NaN        NaN   \n",
       "278        NaN        NaN        NaN        NaN        NaN     -0.592   \n",
       "279        NaN        NaN        NaN        NaN        NaN     -0.000   \n",
       "280        NaN        NaN        NaN        NaN        NaN     -0.000   \n",
       "281        NaN        NaN        NaN        NaN        NaN        NaN   \n",
       "\n",
       "     COMP_HIP_KNEE  ...  OP_35_ADM  OP_35_ED  OP_36  READM_30_AMI  \\\n",
       "0             -2.7  ...        NaN       NaN    NaN         -13.8   \n",
       "1             -3.1  ...       -9.9      -4.7   -0.9         -12.2   \n",
       "2             -2.9  ...       -9.9      -4.8   -0.9         -12.6   \n",
       "3             -3.0  ...        NaN       NaN   -1.0           NaN   \n",
       "4              NaN  ...      -11.7      -7.3   -1.1         -14.1   \n",
       "..             ...  ...        ...       ...    ...           ...   \n",
       "277            NaN  ...      -11.3      -5.4    NaN           NaN   \n",
       "278            NaN  ...      -10.4      -6.7   -1.1           NaN   \n",
       "279           -5.4  ...      -11.3      -6.8   -0.7           NaN   \n",
       "280            NaN  ...        NaN       NaN   -0.9           NaN   \n",
       "281           -3.5  ...      -10.0      -6.1   -1.0           NaN   \n",
       "\n",
       "     READM_30_CABG  READM_30_COPD  READM_30_HF  READM_30_HIP_KNEE  \\\n",
       "0              NaN          -20.6        -22.5               -5.3   \n",
       "1            -10.9          -19.0        -17.4               -4.1   \n",
       "2            -11.2          -17.5        -19.1               -3.8   \n",
       "3              NaN            NaN        -20.7               -4.0   \n",
       "4            -12.5          -17.5        -19.6                NaN   \n",
       "..             ...            ...          ...                ...   \n",
       "277            NaN            NaN        -19.1                NaN   \n",
       "278            NaN          -19.7        -20.7                NaN   \n",
       "279            NaN          -18.9        -19.3               -5.1   \n",
       "280            NaN          -17.6        -19.3                NaN   \n",
       "281            NaN          -18.0        -19.6               -4.2   \n",
       "\n",
       "     READM_30_HOSP_WIDE  READM_30_PN  \n",
       "0                 -16.0        -18.4  \n",
       "1                 -12.9        -15.4  \n",
       "2                 -14.0        -16.2  \n",
       "3                 -14.8        -17.1  \n",
       "4                 -14.3        -15.3  \n",
       "..                  ...          ...  \n",
       "277               -14.9        -16.3  \n",
       "278               -15.3        -16.2  \n",
       "279               -14.3        -16.7  \n",
       "280               -13.3        -15.2  \n",
       "281               -14.8        -16.5  \n",
       "\n",
       "[282 rows x 53 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hq_df = pd.read_csv('all_cms_metrics_ca.csv', dtype={'Facility ID': str})\n",
    "hq_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "37d32f57-2843-46c0-b9e8-413ece5aabbb",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Index(['Facility ID', 'Facility Name', 'State', 'HAI_1_SIR', 'HAI_2_SIR',\n",
      "       'HAI_3_SIR', 'HAI_4_SIR', 'HAI_5_SIR', 'HAI_6_SIR', 'COMP_HIP_KNEE',\n",
      "       'MORT_30_AMI', 'MORT_30_CABG', 'MORT_30_COPD', 'MORT_30_HF',\n",
      "       'MORT_30_PN', 'MORT_30_STK', 'PSI_03', 'PSI_04', 'PSI_06', 'PSI_08',\n",
      "       'PSI_09', 'PSI_10', 'PSI_11', 'PSI_12', 'PSI_13', 'PSI_14', 'PSI_15',\n",
      "       'PSI_90', 'OP_23', 'OP_29', 'SEP_1', 'H_COMP_1_A_P', 'H_COMP_2_A_P',\n",
      "       'H_COMP_3_A_P', 'H_COMP_5_A_P', 'H_COMP_6_Y_P', 'H_COMP_7_SA',\n",
      "       'ePC_07a', 'ePC_07b', 'EDAC_30_AMI', 'EDAC_30_HF', 'EDAC_30_PN',\n",
      "       'OP_32', 'OP_35_ADM', 'OP_35_ED', 'OP_36', 'READM_30_AMI',\n",
      "       'READM_30_CABG', 'READM_30_COPD', 'READM_30_HF', 'READM_30_HIP_KNEE',\n",
      "       'READM_30_HOSP_WIDE', 'READM_30_PN'],\n",
      "      dtype='object')\n"
     ]
    }
   ],
   "source": [
    "print(hq_df.columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "beb4b6a4-c8b1-4afc-9ce4-37e68ad5378f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>HAI_1_SIR</th>\n",
       "      <th>HAI_2_SIR</th>\n",
       "      <th>HAI_3_SIR</th>\n",
       "      <th>HAI_4_SIR</th>\n",
       "      <th>HAI_5_SIR</th>\n",
       "      <th>HAI_6_SIR</th>\n",
       "      <th>COMP_HIP_KNEE</th>\n",
       "      <th>MORT_30_AMI</th>\n",
       "      <th>MORT_30_CABG</th>\n",
       "      <th>MORT_30_COPD</th>\n",
       "      <th>...</th>\n",
       "      <th>OP_35_ADM</th>\n",
       "      <th>OP_35_ED</th>\n",
       "      <th>OP_36</th>\n",
       "      <th>READM_30_AMI</th>\n",
       "      <th>READM_30_CABG</th>\n",
       "      <th>READM_30_COPD</th>\n",
       "      <th>READM_30_HF</th>\n",
       "      <th>READM_30_HIP_KNEE</th>\n",
       "      <th>READM_30_HOSP_WIDE</th>\n",
       "      <th>READM_30_PN</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>210.000000</td>\n",
       "      <td>234.000000</td>\n",
       "      <td>181.000000</td>\n",
       "      <td>54.000000</td>\n",
       "      <td>187.000000</td>\n",
       "      <td>270.000000</td>\n",
       "      <td>135.000000</td>\n",
       "      <td>157.000000</td>\n",
       "      <td>83.000000</td>\n",
       "      <td>187.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>101.000000</td>\n",
       "      <td>101.000000</td>\n",
       "      <td>195.000000</td>\n",
       "      <td>142.000000</td>\n",
       "      <td>83.000000</td>\n",
       "      <td>191.000000</td>\n",
       "      <td>243.000000</td>\n",
       "      <td>140.000000</td>\n",
       "      <td>281.000000</td>\n",
       "      <td>246.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>-0.706029</td>\n",
       "      <td>-0.637628</td>\n",
       "      <td>-0.781481</td>\n",
       "      <td>-1.067148</td>\n",
       "      <td>-0.690246</td>\n",
       "      <td>-0.448985</td>\n",
       "      <td>-3.478519</td>\n",
       "      <td>-12.373248</td>\n",
       "      <td>-2.854217</td>\n",
       "      <td>-9.159893</td>\n",
       "      <td>...</td>\n",
       "      <td>-11.273267</td>\n",
       "      <td>-5.574257</td>\n",
       "      <td>-1.047179</td>\n",
       "      <td>-13.760563</td>\n",
       "      <td>-10.748193</td>\n",
       "      <td>-18.592147</td>\n",
       "      <td>-20.095473</td>\n",
       "      <td>-4.429286</td>\n",
       "      <td>-14.723132</td>\n",
       "      <td>-16.748780</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>0.634907</td>\n",
       "      <td>0.621305</td>\n",
       "      <td>0.647500</td>\n",
       "      <td>0.929482</td>\n",
       "      <td>0.605974</td>\n",
       "      <td>0.390438</td>\n",
       "      <td>0.734378</td>\n",
       "      <td>1.353930</td>\n",
       "      <td>0.779509</td>\n",
       "      <td>1.530706</td>\n",
       "      <td>...</td>\n",
       "      <td>1.538109</td>\n",
       "      <td>0.898182</td>\n",
       "      <td>0.368236</td>\n",
       "      <td>0.879068</td>\n",
       "      <td>0.731247</td>\n",
       "      <td>1.030172</td>\n",
       "      <td>1.259058</td>\n",
       "      <td>0.665652</td>\n",
       "      <td>0.783490</td>\n",
       "      <td>1.185171</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>-4.219000</td>\n",
       "      <td>-5.982000</td>\n",
       "      <td>-2.651000</td>\n",
       "      <td>-3.518000</td>\n",
       "      <td>-3.776000</td>\n",
       "      <td>-3.247000</td>\n",
       "      <td>-6.200000</td>\n",
       "      <td>-16.400000</td>\n",
       "      <td>-6.200000</td>\n",
       "      <td>-18.200000</td>\n",
       "      <td>...</td>\n",
       "      <td>-14.800000</td>\n",
       "      <td>-9.000000</td>\n",
       "      <td>-2.900000</td>\n",
       "      <td>-16.200000</td>\n",
       "      <td>-13.500000</td>\n",
       "      <td>-23.700000</td>\n",
       "      <td>-25.700000</td>\n",
       "      <td>-6.500000</td>\n",
       "      <td>-19.100000</td>\n",
       "      <td>-24.300000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>-0.941250</td>\n",
       "      <td>-0.799500</td>\n",
       "      <td>-1.178000</td>\n",
       "      <td>-1.588750</td>\n",
       "      <td>-0.952000</td>\n",
       "      <td>-0.575750</td>\n",
       "      <td>-4.000000</td>\n",
       "      <td>-13.200000</td>\n",
       "      <td>-3.200000</td>\n",
       "      <td>-9.900000</td>\n",
       "      <td>...</td>\n",
       "      <td>-12.400000</td>\n",
       "      <td>-6.100000</td>\n",
       "      <td>-1.100000</td>\n",
       "      <td>-14.275000</td>\n",
       "      <td>-11.100000</td>\n",
       "      <td>-19.250000</td>\n",
       "      <td>-20.800000</td>\n",
       "      <td>-4.800000</td>\n",
       "      <td>-15.100000</td>\n",
       "      <td>-17.300000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>-0.632000</td>\n",
       "      <td>-0.557500</td>\n",
       "      <td>-0.689000</td>\n",
       "      <td>-0.876000</td>\n",
       "      <td>-0.547000</td>\n",
       "      <td>-0.377000</td>\n",
       "      <td>-3.400000</td>\n",
       "      <td>-12.300000</td>\n",
       "      <td>-2.800000</td>\n",
       "      <td>-9.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>-11.100000</td>\n",
       "      <td>-5.500000</td>\n",
       "      <td>-1.000000</td>\n",
       "      <td>-13.800000</td>\n",
       "      <td>-10.800000</td>\n",
       "      <td>-18.500000</td>\n",
       "      <td>-20.100000</td>\n",
       "      <td>-4.400000</td>\n",
       "      <td>-14.700000</td>\n",
       "      <td>-16.600000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>-0.266250</td>\n",
       "      <td>-0.319750</td>\n",
       "      <td>-0.272000</td>\n",
       "      <td>-0.376750</td>\n",
       "      <td>-0.303000</td>\n",
       "      <td>-0.224000</td>\n",
       "      <td>-3.000000</td>\n",
       "      <td>-11.500000</td>\n",
       "      <td>-2.300000</td>\n",
       "      <td>-8.300000</td>\n",
       "      <td>...</td>\n",
       "      <td>-10.000000</td>\n",
       "      <td>-5.000000</td>\n",
       "      <td>-0.800000</td>\n",
       "      <td>-13.200000</td>\n",
       "      <td>-10.300000</td>\n",
       "      <td>-17.800000</td>\n",
       "      <td>-19.300000</td>\n",
       "      <td>-4.100000</td>\n",
       "      <td>-14.300000</td>\n",
       "      <td>-16.025000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>-0.000000</td>\n",
       "      <td>-0.000000</td>\n",
       "      <td>-0.000000</td>\n",
       "      <td>-0.000000</td>\n",
       "      <td>-0.000000</td>\n",
       "      <td>-0.000000</td>\n",
       "      <td>-1.500000</td>\n",
       "      <td>-8.600000</td>\n",
       "      <td>-1.500000</td>\n",
       "      <td>-5.900000</td>\n",
       "      <td>...</td>\n",
       "      <td>-7.600000</td>\n",
       "      <td>-3.200000</td>\n",
       "      <td>-0.500000</td>\n",
       "      <td>-11.500000</td>\n",
       "      <td>-9.100000</td>\n",
       "      <td>-15.800000</td>\n",
       "      <td>-17.200000</td>\n",
       "      <td>-2.200000</td>\n",
       "      <td>-12.800000</td>\n",
       "      <td>-13.900000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8 rows × 50 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        HAI_1_SIR   HAI_2_SIR   HAI_3_SIR  HAI_4_SIR   HAI_5_SIR   HAI_6_SIR  \\\n",
       "count  210.000000  234.000000  181.000000  54.000000  187.000000  270.000000   \n",
       "mean    -0.706029   -0.637628   -0.781481  -1.067148   -0.690246   -0.448985   \n",
       "std      0.634907    0.621305    0.647500   0.929482    0.605974    0.390438   \n",
       "min     -4.219000   -5.982000   -2.651000  -3.518000   -3.776000   -3.247000   \n",
       "25%     -0.941250   -0.799500   -1.178000  -1.588750   -0.952000   -0.575750   \n",
       "50%     -0.632000   -0.557500   -0.689000  -0.876000   -0.547000   -0.377000   \n",
       "75%     -0.266250   -0.319750   -0.272000  -0.376750   -0.303000   -0.224000   \n",
       "max     -0.000000   -0.000000   -0.000000  -0.000000   -0.000000   -0.000000   \n",
       "\n",
       "       COMP_HIP_KNEE  MORT_30_AMI  MORT_30_CABG  MORT_30_COPD  ...  \\\n",
       "count     135.000000   157.000000     83.000000    187.000000  ...   \n",
       "mean       -3.478519   -12.373248     -2.854217     -9.159893  ...   \n",
       "std         0.734378     1.353930      0.779509      1.530706  ...   \n",
       "min        -6.200000   -16.400000     -6.200000    -18.200000  ...   \n",
       "25%        -4.000000   -13.200000     -3.200000     -9.900000  ...   \n",
       "50%        -3.400000   -12.300000     -2.800000     -9.000000  ...   \n",
       "75%        -3.000000   -11.500000     -2.300000     -8.300000  ...   \n",
       "max        -1.500000    -8.600000     -1.500000     -5.900000  ...   \n",
       "\n",
       "        OP_35_ADM    OP_35_ED       OP_36  READM_30_AMI  READM_30_CABG  \\\n",
       "count  101.000000  101.000000  195.000000    142.000000      83.000000   \n",
       "mean   -11.273267   -5.574257   -1.047179    -13.760563     -10.748193   \n",
       "std      1.538109    0.898182    0.368236      0.879068       0.731247   \n",
       "min    -14.800000   -9.000000   -2.900000    -16.200000     -13.500000   \n",
       "25%    -12.400000   -6.100000   -1.100000    -14.275000     -11.100000   \n",
       "50%    -11.100000   -5.500000   -1.000000    -13.800000     -10.800000   \n",
       "75%    -10.000000   -5.000000   -0.800000    -13.200000     -10.300000   \n",
       "max     -7.600000   -3.200000   -0.500000    -11.500000      -9.100000   \n",
       "\n",
       "       READM_30_COPD  READM_30_HF  READM_30_HIP_KNEE  READM_30_HOSP_WIDE  \\\n",
       "count     191.000000   243.000000         140.000000          281.000000   \n",
       "mean      -18.592147   -20.095473          -4.429286          -14.723132   \n",
       "std         1.030172     1.259058           0.665652            0.783490   \n",
       "min       -23.700000   -25.700000          -6.500000          -19.100000   \n",
       "25%       -19.250000   -20.800000          -4.800000          -15.100000   \n",
       "50%       -18.500000   -20.100000          -4.400000          -14.700000   \n",
       "75%       -17.800000   -19.300000          -4.100000          -14.300000   \n",
       "max       -15.800000   -17.200000          -2.200000          -12.800000   \n",
       "\n",
       "       READM_30_PN  \n",
       "count   246.000000  \n",
       "mean    -16.748780  \n",
       "std       1.185171  \n",
       "min     -24.300000  \n",
       "25%     -17.300000  \n",
       "50%     -16.600000  \n",
       "75%     -16.025000  \n",
       "max     -13.900000  \n",
       "\n",
       "[8 rows x 50 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hq_df.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "feab2c2e-78d3-42ed-9942-c3f352a85a54",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['HAI_1_SIR', 'HAI_2_SIR', 'HAI_3_SIR', 'HAI_4_SIR', 'HAI_5_SIR', 'HAI_6_SIR', 'COMP_HIP_KNEE', 'MORT_30_AMI', 'MORT_30_CABG', 'MORT_30_COPD', 'MORT_30_HF', 'MORT_30_PN', 'MORT_30_STK', 'PSI_03', 'PSI_04', 'PSI_06', 'PSI_08', 'PSI_09', 'PSI_10', 'PSI_11', 'PSI_12', 'PSI_13', 'PSI_14', 'PSI_15', 'PSI_90', 'OP_23', 'OP_29', 'SEP_1', 'H_COMP_1_A_P', 'H_COMP_2_A_P', 'H_COMP_3_A_P', 'H_COMP_5_A_P', 'H_COMP_6_Y_P', 'H_COMP_7_SA', 'ePC_07a', 'ePC_07b', 'EDAC_30_AMI', 'EDAC_30_HF', 'EDAC_30_PN', 'OP_32', 'OP_35_ADM', 'OP_35_ED', 'OP_36', 'READM_30_AMI', 'READM_30_CABG', 'READM_30_COPD', 'READM_30_HF', 'READM_30_HIP_KNEE', 'READM_30_HOSP_WIDE', 'READM_30_PN']\n"
     ]
    }
   ],
   "source": [
    "all_tasks =list(hq_df.columns)\n",
    "for col in ['Facility ID','Facility Name','State']:\n",
    "    all_tasks.remove(col)\n",
    "    \n",
    "print(all_tasks)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dd9d820c-5879-49c5-ac0e-62b5e710276c",
   "metadata": {},
   "source": [
    "# Greedy selection algorithm"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2ff9290c-6602-4fde-9406-4acc386c4567",
   "metadata": {},
   "source": [
    "## Run Greedy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "65d07223-d499-408d-b91d-81a57d1c48b4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Group size: 1\n",
      "['H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_6_Y_P' 'H_COMP_7_SA' 'READM_30_HOSP_WIDE' 'HAI_6_SIR' 'PSI_03'\n",
      " 'PSI_06' 'PSI_08' 'PSI_15' 'PSI_90' 'PSI_09' 'PSI_12' 'SEP_1'\n",
      " 'MORT_30_PN' 'EDAC_30_PN' 'READM_30_PN' 'MORT_30_HF' 'EDAC_30_HF'\n",
      " 'READM_30_HF' 'PSI_14' 'HAI_2_SIR' 'PSI_11' 'PSI_10' 'PSI_13' 'HAI_1_SIR'\n",
      " 'MORT_30_STK' 'OP_36' 'READM_30_COPD' 'HAI_5_SIR' 'MORT_30_COPD' 'OP_32'\n",
      " 'HAI_3_SIR' 'OP_29' 'MORT_30_AMI' 'PSI_04' 'READM_30_AMI'\n",
      " 'READM_30_HIP_KNEE' 'COMP_HIP_KNEE' 'EDAC_30_AMI' 'OP_23' 'OP_35_ADM'\n",
      " 'OP_35_ED' 'MORT_30_CABG' 'READM_30_CABG' 'HAI_4_SIR' 'ePC_07a' 'ePC_07b']\n",
      "|K| = 50\n",
      "Group size: 2\n",
      "['H_COMP_1_A_P' 'READM_30_HOSP_WIDE' 'H_COMP_5_A_P' 'PSI_15' 'PSI_90'\n",
      " 'H_COMP_2_A_P' 'PSI_08' 'EDAC_30_PN' 'PSI_06' 'MORT_30_HF' 'EDAC_30_HF'\n",
      " 'PSI_09' 'H_COMP_7_SA' 'HAI_2_SIR' 'PSI_13' 'READM_30_HF' 'MORT_30_STK'\n",
      " 'PSI_03' 'READM_30_PN' 'PSI_10' 'MORT_30_COPD' 'HAI_3_SIR' 'H_COMP_3_A_P'\n",
      " 'PSI_14' 'OP_29' 'READM_30_HIP_KNEE' 'PSI_12' 'HAI_1_SIR' 'H_COMP_6_Y_P'\n",
      " 'OP_36' 'HAI_5_SIR' 'MORT_30_PN' 'MORT_30_AMI' 'OP_32' 'EDAC_30_AMI'\n",
      " 'MORT_30_CABG' 'READM_30_COPD' 'PSI_11' 'COMP_HIP_KNEE' 'OP_35_ADM'\n",
      " 'PSI_04' 'HAI_6_SIR' 'OP_23' 'OP_35_ED' 'ePC_07a' 'SEP_1']\n",
      "|K| = 46\n",
      "Group size: 3\n",
      "['H_COMP_7_SA' 'PSI_06' 'H_COMP_1_A_P' 'PSI_90' 'READM_30_HOSP_WIDE'\n",
      " 'EDAC_30_PN' 'PSI_08' 'SEP_1' 'READM_30_HF' 'PSI_09' 'HAI_2_SIR' 'OP_36'\n",
      " 'READM_30_COPD' 'HAI_6_SIR' 'PSI_13' 'MORT_30_HF' 'HAI_5_SIR'\n",
      " 'MORT_30_AMI' 'OP_32' 'H_COMP_5_A_P' 'PSI_15' 'MORT_30_STK' 'EDAC_30_AMI'\n",
      " 'MORT_30_COPD' 'COMP_HIP_KNEE' 'PSI_12' 'H_COMP_2_A_P' 'PSI_03'\n",
      " 'MORT_30_CABG' 'MORT_30_PN' 'OP_23' 'HAI_1_SIR' 'OP_35_ADM' 'PSI_11'\n",
      " 'READM_30_PN' 'PSI_14' 'OP_29' 'OP_35_ED' 'HAI_3_SIR' 'HAI_4_SIR']\n",
      "|K| = 40\n",
      "Group size: 4\n",
      "['H_COMP_6_Y_P' 'PSI_09' 'SEP_1' 'READM_30_PN' 'H_COMP_3_A_P' 'MORT_30_PN'\n",
      " 'PSI_06' 'PSI_13' 'EDAC_30_HF' 'HAI_2_SIR' 'PSI_08' 'H_COMP_5_A_P'\n",
      " 'READM_30_HF' 'HAI_3_SIR' 'MORT_30_COPD' 'PSI_10' 'READM_30_HIP_KNEE'\n",
      " 'HAI_1_SIR' 'PSI_15' 'READM_30_COPD' 'OP_32' 'EDAC_30_AMI' 'H_COMP_7_SA'\n",
      " 'EDAC_30_PN' 'READM_30_CABG' 'PSI_14' 'MORT_30_HF' 'MORT_30_STK'\n",
      " 'H_COMP_2_A_P' 'PSI_90' 'PSI_03' 'OP_35_ED']\n",
      "|K| = 32\n",
      "Group size: 5\n",
      "['H_COMP_2_A_P' 'PSI_09' 'EDAC_30_HF' 'H_COMP_3_A_P' 'PSI_11' 'PSI_06'\n",
      " 'READM_30_PN' 'MORT_30_STK' 'PSI_14' 'HAI_1_SIR' 'MORT_30_HF' 'PSI_12'\n",
      " 'READM_30_HOSP_WIDE' 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_PN' 'SEP_1'\n",
      " 'MORT_30_CABG' 'HAI_5_SIR' 'PSI_03' 'OP_29' 'H_COMP_6_Y_P'\n",
      " 'READM_30_COPD' 'HAI_6_SIR' 'OP_32' 'HAI_4_SIR' 'PSI_15']\n",
      "|K| = 27\n",
      "Group size: 6\n",
      "['H_COMP_5_A_P' 'PSI_15' 'EDAC_30_HF' 'PSI_12' 'MORT_30_STK'\n",
      " 'H_COMP_2_A_P' 'PSI_14' 'HAI_2_SIR' 'MORT_30_PN' 'HAI_1_SIR'\n",
      " 'READM_30_HF' 'COMP_HIP_KNEE' 'H_COMP_3_A_P' 'MORT_30_AMI' 'PSI_08'\n",
      " 'OP_35_ED' 'OP_32' 'PSI_11' 'READM_30_HIP_KNEE' 'HAI_5_SIR' 'PSI_03'\n",
      " 'HAI_6_SIR' 'HAI_4_SIR' 'PSI_06']\n",
      "|K| = 24\n",
      "Group size: 7\n",
      "['H_COMP_2_A_P' 'PSI_03' 'EDAC_30_HF' 'PSI_09' 'MORT_30_STK' 'READM_30_PN'\n",
      " 'HAI_2_SIR' 'MORT_30_PN' 'PSI_13' 'H_COMP_1_A_P' 'EDAC_30_AMI' 'PSI_10'\n",
      " 'OP_36' 'PSI_11' 'READM_30_HOSP_WIDE' 'MORT_30_HF' 'COMP_HIP_KNEE'\n",
      " 'PSI_14' 'OP_23' 'HAI_1_SIR']\n",
      "|K| = 20\n",
      "Group size: 8\n",
      "['H_COMP_5_A_P' 'PSI_08' 'EDAC_30_HF' 'PSI_90' 'HAI_2_SIR' 'MORT_30_STK'\n",
      " 'READM_30_PN' 'H_COMP_7_SA' 'PSI_14' 'EDAC_30_AMI' 'OP_29' 'PSI_09'\n",
      " 'SEP_1' 'OP_32' 'PSI_11' 'COMP_HIP_KNEE' 'MORT_30_HF']\n",
      "|K| = 17\n",
      "Group size: 9\n",
      "['H_COMP_7_SA' 'PSI_12' 'PSI_15' 'READM_30_HOSP_WIDE' 'MORT_30_HF' 'OP_36'\n",
      " 'HAI_1_SIR' 'H_COMP_3_A_P' 'MORT_30_AMI' 'PSI_90' 'OP_35_ED' 'HAI_6_SIR'\n",
      " 'MORT_30_COPD' 'PSI_09' 'COMP_HIP_KNEE' 'HAI_5_SIR']\n",
      "|K| = 16\n",
      "Group size: 10\n",
      "['H_COMP_2_A_P' 'PSI_03' 'PSI_11' 'EDAC_30_HF' 'MORT_30_STK' 'OP_32'\n",
      " 'EDAC_30_PN' 'PSI_08' 'PSI_04' 'PSI_09' 'OP_35_ED' 'HAI_3_SIR' 'PSI_15']\n",
      "|K| = 13\n",
      "Group size: 11\n",
      "['H_COMP_2_A_P' 'PSI_08' 'EDAC_30_PN' 'MORT_30_HF' 'PSI_14'\n",
      " 'READM_30_COPD' 'READM_30_AMI' 'PSI_03' 'READM_30_HOSP_WIDE' 'PSI_13'\n",
      " 'MORT_30_CABG' 'HAI_5_SIR' 'HAI_1_SIR']\n",
      "|K| = 13\n",
      "Group size: 12\n",
      "['H_COMP_7_SA' 'PSI_03' 'READM_30_PN' 'PSI_11' 'READM_30_COPD' 'PSI_08'\n",
      " 'READM_30_AMI' 'H_COMP_1_A_P' 'HAI_5_SIR' 'HAI_4_SIR' 'HAI_1_SIR']\n",
      "|K| = 11\n",
      "Group size: 13\n",
      "['H_COMP_1_A_P' 'PSI_06' 'PSI_11' 'MORT_30_HF' 'HAI_5_SIR' 'OP_36'\n",
      " 'READM_30_HOSP_WIDE' 'READM_30_PN' 'READM_30_HIP_KNEE' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG']\n",
      "|K| = 11\n",
      "Group size: 14\n",
      "['EDAC_30_PN' 'PSI_13' 'MORT_30_HF' 'H_COMP_2_A_P' 'MORT_30_STK' 'OP_36'\n",
      " 'H_COMP_6_Y_P' 'PSI_04' 'PSI_90']\n",
      "|K| = 9\n",
      "Group size: 15\n",
      "['EDAC_30_PN' 'HAI_2_SIR' 'MORT_30_STK' 'PSI_13' 'MORT_30_HF'\n",
      " 'H_COMP_2_A_P' 'PSI_14' 'MORT_30_COPD' 'HAI_3_SIR']\n",
      "|K| = 9\n",
      "Group size: 16\n",
      "['SEP_1' 'PSI_09' 'OP_36' 'READM_30_HF' 'HAI_5_SIR' 'PSI_04' 'PSI_14'\n",
      " 'MORT_30_AMI']\n",
      "|K| = 8\n",
      "Group size: 17\n",
      "['H_COMP_7_SA' 'PSI_03' 'MORT_30_COPD' 'EDAC_30_AMI' 'OP_29' 'EDAC_30_HF'\n",
      " 'HAI_3_SIR']\n",
      "|K| = 7\n",
      "Group size: 18\n",
      "['H_COMP_7_SA' 'PSI_03' 'MORT_30_COPD' 'EDAC_30_HF' 'HAI_3_SIR'\n",
      " 'HAI_6_SIR' 'PSI_12' 'HAI_1_SIR']\n",
      "|K| = 8\n",
      "Group size: 19\n",
      "['H_COMP_7_SA' 'PSI_03' 'MORT_30_COPD' 'MORT_30_AMI' 'PSI_11'\n",
      " 'READM_30_HIP_KNEE' 'HAI_2_SIR']\n",
      "|K| = 7\n",
      "Group size: 20\n",
      "['H_COMP_6_Y_P' 'PSI_08' 'HAI_5_SIR' 'MORT_30_STK' 'READM_30_HOSP_WIDE'\n",
      " 'HAI_1_SIR']\n",
      "|K| = 6\n",
      "Group size: 21\n",
      "['PSI_90' 'MORT_30_COPD' 'H_COMP_7_SA' 'MORT_30_AMI' 'PSI_10' 'HAI_2_SIR']\n",
      "|K| = 6\n",
      "Group size: 22\n",
      "['PSI_15' 'H_COMP_1_A_P' 'PSI_04' 'PSI_13' 'PSI_03']\n",
      "|K| = 5\n",
      "Group size: 23\n",
      "['PSI_14' 'EDAC_30_PN' 'PSI_08' 'READM_30_CABG' 'HAI_1_SIR']\n",
      "|K| = 5\n",
      "Group size: 24\n",
      "['PSI_14' 'MORT_30_STK' 'PSI_09' 'HAI_5_SIR' 'SEP_1']\n",
      "|K| = 5\n",
      "Group size: 25\n",
      "['PSI_14' 'MORT_30_HF' 'PSI_11' 'PSI_03' 'HAI_1_SIR']\n",
      "|K| = 5\n",
      "Group size: 26\n",
      "['PSI_14' 'PSI_04' 'H_COMP_5_A_P' 'MORT_30_PN']\n",
      "|K| = 4\n",
      "Group size: 27\n",
      "['MORT_30_HF' 'OP_36' 'HAI_5_SIR' 'PSI_03']\n",
      "|K| = 4\n",
      "Group size: 28\n",
      "['MORT_30_HF' 'OP_32' 'OP_35_ED' 'HAI_1_SIR']\n",
      "|K| = 4\n",
      "Group size: 29\n",
      "['MORT_30_STK' 'H_COMP_6_Y_P' 'PSI_08' 'HAI_1_SIR']\n",
      "|K| = 4\n",
      "Group size: 30\n",
      "['MORT_30_STK' 'H_COMP_6_Y_P' 'PSI_08' 'HAI_1_SIR']\n",
      "|K| = 4\n",
      "Group size: 31\n",
      "['MORT_30_STK' 'H_COMP_6_Y_P' 'HAI_1_SIR']\n",
      "|K| = 3\n",
      "Group size: 32\n",
      "['MORT_30_STK' 'H_COMP_6_Y_P' 'HAI_1_SIR']\n",
      "|K| = 3\n",
      "Group size: 33\n",
      "['MORT_30_STK' 'PSI_04' 'HAI_1_SIR']\n",
      "|K| = 3\n",
      "Group size: 34\n",
      "['MORT_30_STK' 'COMP_HIP_KNEE' 'HAI_1_SIR']\n",
      "|K| = 3\n",
      "Group size: 35\n",
      "['MORT_30_STK' 'PSI_04']\n",
      "|K| = 2\n",
      "Group size: 36\n",
      "['MORT_30_STK' 'HAI_1_SIR']\n",
      "|K| = 2\n",
      "Group size: 37\n",
      "['MORT_30_STK' 'HAI_1_SIR']\n",
      "|K| = 2\n",
      "Group size: 38\n",
      "['MORT_30_STK' 'HAI_1_SIR']\n",
      "|K| = 2\n",
      "Group size: 39\n",
      "['HAI_1_SIR' 'HAI_3_SIR']\n",
      "|K| = 2\n",
      "Group size: 40\n",
      "['HAI_1_SIR' 'HAI_3_SIR']\n",
      "|K| = 2\n",
      "Group size: 41\n",
      "['MORT_30_AMI' 'HAI_1_SIR']\n",
      "|K| = 2\n",
      "Group size: 42\n",
      "['OP_36']\n",
      "|K| = 1\n",
      "Group size: 43\n",
      "['PSI_04']\n",
      "|K| = 1\n",
      "Group size: 44\n",
      "['HAI_3_SIR']\n",
      "|K| = 1\n",
      "Group size: 45\n",
      "['HAI_1_SIR']\n",
      "|K| = 1\n",
      "Group size: 46\n",
      "['HAI_1_SIR']\n",
      "|K| = 1\n",
      "Group size: 47\n",
      "['HAI_1_SIR']\n",
      "|K| = 1\n",
      "Group size: 48\n",
      "['HAI_1_SIR']\n",
      "|K| = 1\n",
      "Group size: 49\n",
      "['HAI_1_SIR']\n",
      "|K| = 1\n"
     ]
    }
   ],
   "source": [
    "outputs_greedy, group_sizes = selection_algorithms.run_greedy_all_gs(hq_df, all_tasks)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a7f37c0b-8248-4eb1-8513-7d366a6b3bf4",
   "metadata": {},
   "source": [
    "## Greedy Augmented"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "id": "075eaacb-e170-4548-854a-919c66dfd306",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Group size: 1\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_1_A_P' 'H_COMP_6_Y_P' 'READM_30_HOSP_WIDE' 'PSI_03'\n",
      " 'PSI_06' 'PSI_08' 'PSI_15' 'PSI_09' 'PSI_12' 'MORT_30_PN' 'EDAC_30_PN'\n",
      " 'READM_30_PN' 'MORT_30_HF' 'EDAC_30_HF' 'READM_30_HF' 'PSI_14' 'PSI_11'\n",
      " 'PSI_10' 'PSI_13' 'MORT_30_STK' 'OP_36' 'READM_30_COPD' 'MORT_30_COPD'\n",
      " 'OP_32' 'OP_29' 'MORT_30_AMI' 'PSI_04' 'READM_30_AMI' 'READM_30_HIP_KNEE'\n",
      " 'COMP_HIP_KNEE' 'EDAC_30_AMI' 'OP_23' 'OP_35_ADM' 'OP_35_ED'\n",
      " 'MORT_30_CABG' 'READM_30_CABG' 'HAI_4_SIR' 'ePC_07a' 'ePC_07b']\n",
      "|K| = 51\n",
      "Group size: 2\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_1_A_P' 'PSI_08' 'PSI_09' 'EDAC_30_PN'\n",
      " 'READM_30_HOSP_WIDE' 'PSI_10' 'PSI_15' 'READM_30_HF' 'PSI_13'\n",
      " 'MORT_30_HF' 'MORT_30_COPD' 'PSI_03' 'MORT_30_STK' 'PSI_14' 'PSI_12'\n",
      " 'READM_30_COPD' 'READM_30_HIP_KNEE' 'READM_30_PN' 'PSI_06' 'OP_36'\n",
      " 'EDAC_30_AMI' 'MORT_30_PN' 'MORT_30_AMI' 'H_COMP_6_Y_P' 'MORT_30_CABG'\n",
      " 'OP_32' 'OP_35_ED' 'COMP_HIP_KNEE' 'PSI_04' 'OP_29' 'OP_35_ADM' 'PSI_11'\n",
      " 'OP_23' 'ePC_07a' 'EDAC_30_HF']\n",
      "|K| = 47\n",
      "Group size: 3\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_7_SA' 'PSI_06' 'MORT_30_HF' 'PSI_12' 'PSI_10'\n",
      " 'PSI_08' 'PSI_15' 'READM_30_HOSP_WIDE' 'OP_36' 'READM_30_HIP_KNEE'\n",
      " 'READM_30_PN' 'MORT_30_STK' 'EDAC_30_AMI' 'READM_30_COPD' 'PSI_11'\n",
      " 'PSI_03' 'OP_29' 'OP_35_ED' 'PSI_14' 'EDAC_30_HF' 'PSI_09'\n",
      " 'COMP_HIP_KNEE' 'PSI_04' 'OP_35_ADM' 'READM_30_HF' 'HAI_4_SIR'\n",
      " 'MORT_30_AMI' 'MORT_30_COPD' 'PSI_13' 'ePC_07a']\n",
      "|K| = 42\n",
      "Group size: 4\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_6_Y_P' 'PSI_15' 'PSI_08' 'READM_30_HF' 'PSI_10'\n",
      " 'EDAC_30_PN' 'PSI_04' 'MORT_30_HF' 'MORT_30_COPD' 'PSI_12'\n",
      " 'READM_30_HIP_KNEE' 'PSI_03' 'READM_30_PN' 'MORT_30_PN' 'PSI_09'\n",
      " 'EDAC_30_AMI' 'EDAC_30_HF' 'MORT_30_STK' 'PSI_13' 'OP_35_ADM'\n",
      " 'MORT_30_AMI' 'PSI_06']\n",
      "|K| = 34\n",
      "Group size: 5\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_2_A_P' 'PSI_15' 'PSI_10' 'MORT_30_COPD'\n",
      " 'READM_30_HOSP_WIDE' 'PSI_03' 'OP_36' 'READM_30_HIP_KNEE' 'OP_35_ED'\n",
      " 'PSI_06' 'READM_30_AMI' 'EDAC_30_HF' 'PSI_08' 'READM_30_CABG' 'OP_35_ADM'\n",
      " 'HAI_4_SIR' 'COMP_HIP_KNEE' 'MORT_30_PN']\n",
      "|K| = 30\n",
      "Group size: 6\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_5_A_P' 'PSI_15' 'READM_30_HF' 'READM_30_HIP_KNEE'\n",
      " 'MORT_30_STK' 'PSI_08' 'READM_30_AMI' 'MORT_30_PN' 'PSI_12' 'READM_30_PN'\n",
      " 'MORT_30_COPD' 'PSI_06' 'HAI_4_SIR' 'EDAC_30_HF' 'PSI_10']\n",
      "|K| = 27\n",
      "Group size: 7\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_2_A_P' 'PSI_15' 'READM_30_HF' 'PSI_13'\n",
      " 'MORT_30_AMI' 'OP_35_ED' 'READM_30_HIP_KNEE' 'MORT_30_PN' 'PSI_12'\n",
      " 'OP_32' 'PSI_04']\n",
      "|K| = 23\n",
      "Group size: 8\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_5_A_P' 'PSI_08' 'READM_30_HF' 'MORT_30_STK'\n",
      " 'PSI_14' 'READM_30_CABG' 'COMP_HIP_KNEE' 'MORT_30_AMI' 'PSI_04']\n",
      "|K| = 21\n",
      "Group size: 9\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_7_SA' 'PSI_10' 'READM_30_HF' 'OP_32' 'MORT_30_CABG'\n",
      " 'MORT_30_HF' 'PSI_08' 'PSI_06' 'COMP_HIP_KNEE']\n",
      "|K| = 21\n",
      "Group size: 10\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_2_A_P' 'PSI_10' 'PSI_08' 'READM_30_HIP_KNEE'\n",
      " 'EDAC_30_AMI' 'OP_36' 'MORT_30_PN']\n",
      "|K| = 19\n",
      "Group size: 11\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_2_A_P' 'PSI_08' 'PSI_14' 'OP_35_ADM' 'MORT_30_HF'\n",
      " 'PSI_11']\n",
      "|K| = 18\n",
      "Group size: 12\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_7_SA' 'PSI_06' 'MORT_30_CABG' 'READM_30_HIP_KNEE']\n",
      "|K| = 16\n",
      "Group size: 13\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_1_A_P' 'PSI_06' 'PSI_08' 'HAI_4_SIR']\n",
      "|K| = 16\n",
      "Group size: 14\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'EDAC_30_PN' 'READM_30_AMI' 'COMP_HIP_KNEE']\n",
      "|K| = 15\n",
      "Group size: 15\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'EDAC_30_PN' 'PSI_08' 'HAI_4_SIR']\n",
      "|K| = 15\n",
      "Group size: 16\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'SEP_1' 'PSI_06' 'HAI_4_SIR']\n",
      "|K| = 15\n",
      "Group size: 17\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_7_SA' 'PSI_06' 'HAI_4_SIR']\n",
      "|K| = 15\n",
      "Group size: 18\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_7_SA' 'MORT_30_CABG' 'COMP_HIP_KNEE']\n",
      "|K| = 15\n",
      "Group size: 19\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_7_SA' 'MORT_30_CABG']\n",
      "|K| = 14\n",
      "Group size: 20\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'H_COMP_6_Y_P' 'MORT_30_CABG']\n",
      "|K| = 14\n",
      "Group size: 21\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'PSI_90' 'HAI_4_SIR']\n",
      "|K| = 14\n",
      "Group size: 22\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 23\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 24\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 25\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 26\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 27\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 28\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 29\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 30\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 31\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 32\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 33\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 34\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 35\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 36\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 37\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 38\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 39\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 40\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 41\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 42\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 43\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 44\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 45\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 46\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 47\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 48\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n",
      "Group size: 49\n",
      "['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "|K| = 12\n"
     ]
    }
   ],
   "source": [
    "outputs_greedy_augmented, group_sizes = selection_algorithms.run_greedy_all_gs(hq_df, all_tasks, starting_tasks=CHC_METRICS)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "77ae9b40-3c0a-46a4-94e6-6dbd6f6ac743",
   "metadata": {},
   "source": [
    "## Min g such that honor roll satisfies PR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "bc22dc84-2256-4a82-b527-fa43391d5b62",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "37"
      ]
     },
     "execution_count": 175,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.weak_pp_loss_fast(20, hq_ranks_df, all_tasks, CHC_METRICS, verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "586a9e34-6235-44db-b396-8d0f2bba9b89",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 174,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.weak_pp_loss_fast(21, hq_ranks_df, all_tasks, CHC_METRICS, verbose=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5dc76577-990e-4bfb-b25c-10f520c0fa6f",
   "metadata": {},
   "source": [
    "# IP for PR"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c14cdc4d-dcdd-403b-b2f3-81e48de62cf1",
   "metadata": {},
   "source": [
    "## Run IP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "id": "6a6b1adf-011e-4923-80b3-dd41b59b54f3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Constructing constraint set for group size 1\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:38:35 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:38:35 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:38:35 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:38:35 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:38:35 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:35 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:38:35 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:38:35 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:38:35 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:38:35 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:38:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:38:38 PM: Finished problem compilation (took 3.132e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:38 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 50.000000 after 0.02 sec. (18.29 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.08 sec. (92.51 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.11 sec. (111.03 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.11 sec. (111.03 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:38:40 PM: Optimal value: 5.000e+01\n",
      "(CVXPY) Apr 25 12:38:40 PM: Compilation took 3.132e+00 seconds\n",
      "(CVXPY) Apr 25 12:38:40 PM: Solver (including time spent in interface) took 1.233e+00 seconds\n",
      "Optimal value: 50.0\n",
      "Variable var590310: value [1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF'\n",
      " 'MORT_30_PN' 'MORT_30_STK' 'PSI_03' 'PSI_04' 'PSI_06' 'PSI_08' 'PSI_09'\n",
      " 'PSI_10' 'PSI_11' 'PSI_12' 'PSI_13' 'PSI_14' 'PSI_15' 'PSI_90' 'OP_23'\n",
      " 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_6_Y_P' 'H_COMP_7_SA' 'ePC_07a' 'ePC_07b'\n",
      " 'EDAC_30_AMI' 'EDAC_30_HF' 'EDAC_30_PN' 'OP_32' 'OP_35_ADM' 'OP_35_ED'\n",
      " 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 2\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:38:40 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:38:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:38:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:38:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:38:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:38:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:38:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:38:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:38:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:38:43 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:38:43 PM: Finished problem compilation (took 2.801e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:43 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 47.000000 after 0.01 sec. (17.89 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 75878 rows and 1 columns.\n",
      "MIP Presolve modified 1995 coefficients.\n",
      "Reduced MIP has 3361 rows, 49 columns, and 47563 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.77 sec. (717.52 ticks)\n",
      "Probing time = 0.01 sec. (4.12 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "MIP Presolve eliminated 1628 rows and 0 columns.\n",
      "MIP Presolve modified 100 coefficients.\n",
      "Reduced MIP has 1733 rows, 49 columns, and 21189 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.12 sec. (133.58 ticks)\n",
      "Probing time = 0.00 sec. (1.82 ticks)\n",
      "Clique table members: 120.\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.04 sec. (21.02 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           47.0000        1.0000            97.87%\n",
      "*     0+    0                           39.0000        1.0000            97.44%\n",
      "      0     0       31.8195    46       39.0000       31.8195      399   18.41%\n",
      "*     0+    0                           37.0000       31.8195            14.00%\n",
      "      0     0       32.4319    46       37.0000      Cuts: 58      438    7.81%\n",
      "      0     0       32.7239    44       37.0000      Cuts: 17      466    7.81%\n",
      "      0     0       32.8612    47       37.0000      Cuts: 20      490    7.81%\n",
      "      0     0       33.0103    44       37.0000      Cuts: 13      520    7.81%\n",
      "      0     0       33.0882    48       37.0000      Cuts: 14      541    7.81%\n",
      "Detecting symmetries...\n",
      "      0     0        cutoff             37.0000       37.0000      541    0.00%\n",
      "Elapsed time = 1.35 sec. (1219.23 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Implied bound cuts applied:  2\n",
      "Zero-half cuts applied:  12\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.35 sec. (1219.30 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.35 sec. (1219.30 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:45 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:38:45 PM: Optimal value: 3.700e+01\n",
      "(CVXPY) Apr 25 12:38:45 PM: Compilation took 2.801e+00 seconds\n",
      "(CVXPY) Apr 25 12:38:45 PM: Solver (including time spent in interface) took 2.028e+00 seconds\n",
      "Optimal value: 37.0\n",
      "Variable var590310: value [ 1.  1.  0.  0.  1.  1.  1.  0.  1.  1.  1.  1.  1.  0.  0.  1.  1.  1.\n",
      "  0.  1.  1.  0.  1.  1.  1.  1.  0.  1.  0.  1.  1.  1.  0.  1.  1. -0.\n",
      "  1.  0.  1.  0.  1.  1.  1.  1.  1.  1.  1.  1.  1.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'COMP_HIP_KNEE'\n",
      " 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF' 'MORT_30_PN' 'MORT_30_STK'\n",
      " 'PSI_06' 'PSI_08' 'PSI_09' 'PSI_11' 'PSI_12' 'PSI_14' 'PSI_15' 'PSI_90'\n",
      " 'OP_23' 'SEP_1' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'ePC_07a' 'EDAC_30_AMI' 'EDAC_30_PN' 'OP_35_ADM' 'OP_35_ED'\n",
      " 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 3\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:38:45 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:38:45 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:38:45 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:38:45 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:38:45 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:45 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:38:45 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:38:45 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:38:45 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:38:45 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:38:49 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:38:49 PM: Finished problem compilation (took 3.418e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:38:49 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 40.000000 after 0.01 sec. (15.56 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 70571 rows and 0 columns.\n",
      "Reduced MIP has 8671 rows, 50 columns, and 180080 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.29 sec. (286.71 ticks)\n",
      "Probing time = 0.02 sec. (1.67 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 8671 rows, 50 columns, and 180080 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.07 sec. (51.03 ticks)\n",
      "Probing time = 0.01 sec. (1.81 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.12 sec. (83.29 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           40.0000        0.0000           100.00%\n",
      "*     0+    0                           32.0000        0.0000           100.00%\n",
      "*     0+    0                           31.0000        0.0000           100.00%\n",
      "*     0+    0                           30.0000        0.0000           100.00%\n",
      "      0     0       16.6667    49       30.0000       16.6667      384   44.44%\n",
      "      0     0       16.8649    49       30.0000      Fract: 1      441   43.78%\n",
      "      0     0       17.0004    49       30.0000      Fract: 1      513   43.33%\n",
      "Detecting symmetries...\n",
      "      0     2       17.0004    49       30.0000       17.0004      513   43.33%\n",
      "Elapsed time = 1.29 sec. (1262.79 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     28    25       22.5511    42       30.0000       18.6694     2335   37.77%\n",
      "*   145+   70                           29.0000       19.3419            33.30%\n",
      "*   177   146      integral     0       28.0000       19.3419     6454   30.92%\n",
      "    379   214        cutoff             28.0000       19.3419    10673   30.92%\n",
      "    768   414        cutoff             28.0000       21.0278    19013   24.90%\n",
      "   1207   666       26.8000    33       28.0000       23.6000    28586   15.71%\n",
      "   1709   822       27.0000    31       28.0000       24.0000    34781   14.29%\n",
      "   2196  1029        cutoff             28.0000       24.3913    44163   12.89%\n",
      "   2741  1198        cutoff             28.0000       24.7368    53401   11.65%\n",
      "   3258  1332       26.4158    32       28.0000       25.0000    62127   10.71%\n",
      "   3808  1414        cutoff             28.0000       25.2500    68084    9.82%\n",
      "   5867  1259       26.7857    31       28.0000       25.9412    98513    7.35%\n",
      "Elapsed time = 15.36 sec. (4373.04 ticks, tree = 1.29 MB, solutions = 6)\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.16 sec. (1253.33 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   18.79 sec. (4067.89 ticks)\n",
      "  Sync time (average)   =    2.87 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   19.94 sec. (5321.22 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:39:09 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:39:09 PM: Optimal value: 2.800e+01\n",
      "(CVXPY) Apr 25 12:39:09 PM: Compilation took 3.418e+00 seconds\n",
      "(CVXPY) Apr 25 12:39:09 PM: Solver (including time spent in interface) took 2.046e+01 seconds\n",
      "Optimal value: 28.0\n",
      "Variable var590310: value [ 1. -0.  0.  1.  1.  0.  0.  1.  0.  1.  0.  1.  1.  0.  0.  1. -0.  1.\n",
      "  0.  1.  1.  1.  0.  1.  1.  1.  0.  1. -0.  1.  1.  1.  0.  0.  1. -0.\n",
      "  0.  0.  1.  1.  0.  1.  0.  1.  1.  0.  1.  1.  1.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'MORT_30_AMI' 'MORT_30_COPD'\n",
      " 'MORT_30_PN' 'MORT_30_STK' 'PSI_06' 'PSI_09' 'PSI_11' 'PSI_12' 'PSI_13'\n",
      " 'PSI_15' 'PSI_90' 'OP_23' 'SEP_1' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'ePC_07a' 'EDAC_30_PN' 'OP_32' 'OP_35_ED' 'READM_30_AMI'\n",
      " 'READM_30_CABG' 'READM_30_HF' 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE']\n",
      "Constructing constraint set for group size 4\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:39:10 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:39:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:39:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:39:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:39:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:39:10 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:39:10 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:39:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:39:10 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:39:10 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:39:13 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:39:13 PM: Finished problem compilation (took 3.134e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:39:13 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 34.000000 after 0.01 sec. (13.63 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 70813 rows and 0 columns.\n",
      "Reduced MIP has 8429 rows, 50 columns, and 179354 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.30 sec. (286.11 ticks)\n",
      "Probing time = 0.01 sec. (1.66 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 8429 rows, 50 columns, and 179354 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (50.73 ticks)\n",
      "Probing time = 0.01 sec. (1.80 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.14 sec. (77.98 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           34.0000        0.0000           100.00%\n",
      "*     0+    0                           26.0000        0.0000           100.00%\n",
      "*     0+    0                           24.0000        0.0000           100.00%\n",
      "      0     0       12.5000    49       24.0000       12.5000      305   47.92%\n",
      "      0     0       12.7020    49       24.0000      Fract: 1      407   47.07%\n",
      "      0     0       12.8694    49       24.0000      Fract: 1      505   46.38%\n",
      "      0     0       12.9130    49       24.0000      Fract: 1      540   46.20%\n",
      "Detecting symmetries...\n",
      "      0     2       12.9130    49       24.0000       12.9130      540   46.20%\n",
      "Elapsed time = 1.39 sec. (1141.95 ticks, tree = 0.02 MB, solutions = 3)\n",
      "     46    32       16.5434    45       24.0000       14.7500     2822   38.54%\n",
      "*   131+   38                           23.0000       14.7539            35.85%\n",
      "    256   179        cutoff             23.0000       14.7539     9446   35.85%\n",
      "*   326+  209                           22.0000       14.7539            32.94%\n",
      "    506   254       17.4958    40       22.0000       14.7539    15668   32.94%\n",
      "    852   477       18.3173    39       22.0000       16.4012    28169   25.45%\n",
      "   1234   688       19.5294    37       22.0000       16.9495    37970   22.96%\n",
      "   1635   845        cutoff             22.0000       17.9218    45622   18.54%\n",
      "*  1755+  873                           21.0000       18.0699            13.95%\n",
      "   1945   679       19.6321    35       21.0000       18.0898    53578   13.86%\n",
      "   2307   703        cutoff             21.0000       18.3282    64533   12.72%\n",
      "   2708   735        cutoff             21.0000       18.5926    72521   11.46%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.27 sec. (1132.60 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   17.24 sec. (3119.75 ticks)\n",
      "  Sync time (average)   =    2.90 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   18.51 sec. (4252.35 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:39:32 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:39:32 PM: Optimal value: 2.100e+01\n",
      "(CVXPY) Apr 25 12:39:32 PM: Compilation took 3.134e+00 seconds\n",
      "(CVXPY) Apr 25 12:39:32 PM: Solver (including time spent in interface) took 1.904e+01 seconds\n",
      "Optimal value: 21.0\n",
      "Variable var590310: value [1. 0. 0. 0. 0. 1. 0. 1. 0. 1. 0. 0. 1. 1. 0. 0. 0. 1. 1. 1. 0. 1. 0. 1.\n",
      " 0. 0. 0. 1. 0. 0. 1. 1. 0. 1. 0. 0. 1. 1. 0. 1. 0. 1. 0. 0. 0. 0. 0. 0.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_6_SIR' 'MORT_30_AMI' 'MORT_30_COPD' 'MORT_30_STK'\n",
      " 'PSI_03' 'PSI_09' 'PSI_10' 'PSI_11' 'PSI_13' 'PSI_15' 'SEP_1'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'EDAC_30_AMI' 'EDAC_30_HF'\n",
      " 'OP_32' 'OP_35_ED' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 5\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:39:32 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:39:32 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:39:32 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:39:32 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:39:32 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:39:32 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:39:32 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:39:32 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:39:32 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:39:32 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:39:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:39:35 PM: Finished problem compilation (took 2.770e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:39:35 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 32.000000 after 0.01 sec. (13.36 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 71054 rows and 0 columns.\n",
      "Reduced MIP has 8188 rows, 50 columns, and 178390 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.35 sec. (285.42 ticks)\n",
      "Probing time = 0.01 sec. (1.65 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 8188 rows, 50 columns, and 178390 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (50.43 ticks)\n",
      "Probing time = 0.01 sec. (1.79 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.60 sec. (80.94 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           32.0000        0.0000           100.00%\n",
      "*     0+    0                           22.0000        0.0000           100.00%\n",
      "*     0+    0                           21.0000        0.0000           100.00%\n",
      "*     0+    0                           20.0000        0.0000           100.00%\n",
      "*     0+    0                           19.0000        0.0000           100.00%\n",
      "      0     0       10.0000    49       19.0000       10.0000      331   47.37%\n",
      "      0     0       10.1905    49       19.0000      Fract: 1      441   46.37%\n",
      "      0     0       10.2330    49       19.0000      Fract: 1      477   46.14%\n",
      "Detecting symmetries...\n",
      "      0     2       10.2330    49       19.0000       11.0036      477   42.09%\n",
      "Elapsed time = 2.05 sec. (1352.90 ticks, tree = 0.02 MB, solutions = 5)\n",
      "     28    25       14.1644    41       19.0000       11.6129     2474   38.88%\n",
      "*   257   168      integral     0       18.0000       12.4000    11335   31.11%\n",
      "    293   183       14.9011    37       18.0000       12.4000    13833   31.11%\n",
      "    541   322        cutoff             18.0000       12.9101    26011   28.28%\n",
      "    790   451        cutoff             18.0000       13.7325    35314   23.71%\n",
      "   1111   574       15.1787    36       18.0000       14.0035    43737   22.20%\n",
      "   1453   709        cutoff             18.0000       14.4285    53316   19.84%\n",
      "   1784   888       16.5337    35       18.0000       14.5639    65579   19.09%\n",
      "   2141  1089       16.2258    37       18.0000       14.6993    79304   18.34%\n",
      "   2542  1290       16.3139    34       18.0000       14.8400    93690   17.56%\n",
      "   4278  1863        cutoff             18.0000       15.3279   138894   14.84%\n",
      "Elapsed time = 21.61 sec. (4462.71 ticks, tree = 1.75 MB, solutions = 6)\n",
      "   6095  2348       16.3090    37       18.0000       15.6438   186785   13.09%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 8188 rows, 50 columns, and 178390 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (42.29 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 8188 rows, 50 columns, and 178390 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (53.00 ticks)\n",
      "Represolve time = 0.13 sec. (121.78 ticks)\n",
      "   6562     0       10.3001    50       18.0000      Fract: 1   212755   12.57%\n",
      "   6562     0       10.3619    50       18.0000      Fract: 1   212849   12.57%\n",
      "   6562     0       10.4068    50       18.0000      Fract: 1   212912   12.57%\n",
      "   6562     0       10.4650    50       18.0000      Fract: 1   212986   12.57%\n",
      "   6562     2       10.4650    50       18.0000       15.7371   212986   12.57%\n",
      "   6568     5       11.9356    48       18.0000       15.7371   213476   12.57%\n",
      "   6896    43        cutoff             18.0000       15.7371   216867   12.57%\n",
      "   8070   767        cutoff             18.0000       15.7371   265471   12.57%\n",
      "   9691  1377        cutoff             18.0000       15.7371   312354   12.57%\n",
      "  11520  1927        cutoff             18.0000       15.7371   363463   12.57%\n",
      "  13369  2243       16.4736    33       18.0000       15.8910   416445   11.72%\n",
      "  15256  2187        cutoff             18.0000       16.1286   460621   10.40%\n",
      "  17154  1800        cutoff             18.0000       16.3094   502719    9.39%\n",
      "Elapsed time = 75.14 sec. (15262.79 ticks, tree = 1.61 MB, solutions = 6)\n",
      "  19003   874        cutoff             18.0000       16.5709   535075    7.94%\n",
      "\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.92 sec. (1343.73 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   80.54 sec. (15179.20 ticks)\n",
      "  Sync time (average)   =   10.08 sec.\n",
      "  Wait time (average)   =    0.08 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   82.45 sec. (16522.93 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:40:58 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:40:58 PM: Optimal value: 1.800e+01\n",
      "(CVXPY) Apr 25 12:40:58 PM: Compilation took 2.770e+00 seconds\n",
      "(CVXPY) Apr 25 12:40:58 PM: Solver (including time spent in interface) took 8.313e+01 seconds\n",
      "Optimal value: 18.0\n",
      "Variable var590310: value [ 1. -0. -0. -0.  0. -0.  0.  0.  1.  1.  0.  1.  0.  1.  1.  0.  0. -0.\n",
      " -0.  1.  1.  1.  0.  1. -0.  1. -0.  0. -0.  1.  1.  0.  0.  0.  0. -0.\n",
      " -0. -0.  1.  0.  0.  1.  1.  1. -0.  0.  0.  0.  1.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_PN' 'PSI_03' 'PSI_04'\n",
      " 'PSI_11' 'PSI_12' 'PSI_13' 'PSI_15' 'OP_23' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'EDAC_30_PN' 'OP_35_ED' 'OP_36' 'READM_30_AMI' 'READM_30_HOSP_WIDE']\n",
      "Constructing constraint set for group size 6\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:40:59 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:40:59 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:40:59 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:40:59 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:40:59 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:40:59 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:40:59 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:40:59 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:40:59 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:40:59 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:41:02 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:41:02 PM: Finished problem compilation (took 3.221e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:41:02 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 28.000000 after 0.01 sec. (12.35 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 71298 rows and 0 columns.\n",
      "Reduced MIP has 7944 rows, 50 columns, and 177170 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.29 sec. (284.60 ticks)\n",
      "Probing time = 0.01 sec. (1.63 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 7944 rows, 50 columns, and 177170 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (49.98 ticks)\n",
      "Probing time = 0.01 sec. (1.76 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.52 sec. (75.64 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           28.0000        0.0000           100.00%\n",
      "*     0+    0                           21.0000        0.0000           100.00%\n",
      "*     0+    0                           20.0000        0.0000           100.00%\n",
      "*     0+    0                           19.0000        0.0000           100.00%\n",
      "*     0+    0                           18.0000        0.0000           100.00%\n",
      "*     0+    0                           17.0000        0.0000           100.00%\n",
      "      0     0        8.3333    49       17.0000        8.3333      260   50.98%\n",
      "      0     0        8.4936    49       17.0000      Fract: 1      387   46.08%\n",
      "      0     0        8.5598    49       17.0000      Fract: 1      484   46.08%\n",
      "*     0+    0                           16.0000        9.1667            42.71%\n",
      "Detecting symmetries...\n",
      "      0     2        8.5598    49       16.0000        9.1667      484   42.71%\n",
      "Elapsed time = 2.14 sec. (1653.63 ticks, tree = 0.02 MB, solutions = 7)\n",
      "     25    22       12.0638    42       16.0000        9.1672     2352   42.71%\n",
      "    296   168       14.7547    30       16.0000        9.9278    12128   37.95%\n",
      "    551   379       14.3046    34       16.0000       10.3824    25450   35.11%\n",
      "    801   497        cutoff             16.0000       10.9695    33712   31.44%\n",
      "   1124   724       13.8307    35       16.0000       11.6544    45950   27.16%\n",
      "   1497   869       12.7235    40       16.0000       12.0848    53911   24.47%\n",
      "   1827  1043       12.9316    39       16.0000       12.1714    62762   23.93%\n",
      "   2236  1276       13.6325    35       16.0000       12.2961    73484   23.15%\n",
      "   2614  1636       14.0484    32       16.0000       12.4819    91670   21.99%\n",
      "   4266  2424       14.2680    25       16.0000       12.8394   130226   19.75%\n",
      "Elapsed time = 17.71 sec. (4763.03 ticks, tree = 2.31 MB, solutions = 7)\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 7944 rows, 50 columns, and 177170 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (41.96 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 7944 rows, 50 columns, and 177170 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (52.54 ticks)\n",
      "Represolve time = 0.15 sec. (121.58 ticks)\n",
      "   4446     0        8.6096    49       16.0000      Fract: 1   148008   19.39%\n",
      "   4446     0        8.7261    49       16.0000      Fract: 1   148112   19.39%\n",
      "   4446     0        8.7550    49       16.0000      Fract: 1   148170   19.39%\n",
      "   4446     2        8.7550    49       16.0000       12.8977   148170   19.39%\n",
      "   4452     5       10.0000    47       16.0000       12.8977   148628   19.39%\n",
      "   4674    37       14.9167    29       16.0000       12.8977   151186   19.39%\n",
      "   5836   738       13.4151    35       16.0000       12.8977   192908   19.39%\n",
      "   7547  1629       14.1544    35       16.0000       12.8977   242909   19.39%\n",
      "   9381  2670       14.1429    33       16.0000       12.9806   301301   18.87%\n",
      "* 10373  3139      integral     0       15.0000       13.1638   327308   12.24%\n",
      "  11255  1468        cutoff             15.0000       13.2658   350125   11.56%\n",
      "\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    2.00 sec. (1644.36 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   48.34 sec. (11656.81 ticks)\n",
      "  Sync time (average)   =    8.03 sec.\n",
      "  Wait time (average)   =    0.07 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   50.34 sec. (13301.17 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:41:54 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:41:54 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 25 12:41:54 PM: Compilation took 3.221e+00 seconds\n",
      "(CVXPY) Apr 25 12:41:54 PM: Solver (including time spent in interface) took 5.109e+01 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var590310: value [ 1.  0.  0. -0.  0. -0.  1.  0.  0.  0.  0.  1.  1.  0.  0.  1. -0.  0.\n",
      "  0.  0.  1.  1.  1.  0.  1.  0. -0.  0.  0.  1.  1.  0.  0.  0. -0. -0.\n",
      "  0.  1.  0.  0. -0.  1. -0.  0.  0.  1.  0. -0. -0.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'COMP_HIP_KNEE' 'MORT_30_PN' 'MORT_30_STK' 'PSI_06' 'PSI_12'\n",
      " 'PSI_13' 'PSI_14' 'PSI_90' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'EDAC_30_HF'\n",
      " 'OP_35_ED' 'READM_30_COPD' 'READM_30_PN']\n",
      "Constructing constraint set for group size 7\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:41:54 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:41:54 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:41:54 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:41:54 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:41:54 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:41:54 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:41:54 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:41:54 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:41:54 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:41:54 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:41:56 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:41:57 PM: Finished problem compilation (took 2.508e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:41:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 26.000000 after 0.01 sec. (11.05 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 71556 rows and 1 columns.\n",
      "Reduced MIP has 7686 rows, 49 columns, and 175416 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.31 sec. (291.22 ticks)\n",
      "Probing time = 0.02 sec. (1.59 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 7686 rows, 49 columns, and 175416 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (48.94 ticks)\n",
      "Probing time = 0.01 sec. (1.72 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.11 sec. (79.48 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           26.0000        0.0000           100.00%\n",
      "*     0+    0                           19.0000        0.0000           100.00%\n",
      "      0     0        7.1429    49       19.0000        7.1429      309   62.41%\n",
      "*     0+    0                           17.0000        7.1429            57.98%\n",
      "      0     0        7.2800    49       17.0000      Fract: 1      395   57.18%\n",
      "      0     0        7.3417    49       17.0000      Fract: 1      488   56.81%\n",
      "*     0+    0                           15.0000        7.3417            51.06%\n",
      "*     0+    0                           14.0000        7.3417            47.56%\n",
      "Detecting symmetries...\n",
      "      0     2        7.3417    49       14.0000        7.7454      488   44.68%\n",
      "Elapsed time = 1.54 sec. (1626.97 ticks, tree = 0.02 MB, solutions = 5)\n",
      "      8    10       11.2205    34       14.0000        7.7454     1363   44.68%\n",
      "    179    77       12.4127    32       14.0000        8.3728     7132   40.19%\n",
      "    461   280       12.1845    33       14.0000        8.6937    20644   37.90%\n",
      "    821   480       12.3706    30       14.0000        9.3001    32527   33.57%\n",
      "   1159   746       10.9665    37       14.0000        9.9533    46564   28.91%\n",
      "   1472   916        cutoff             14.0000       10.3795    55321   25.86%\n",
      "   1600   749       12.3696    30       14.0000       10.3795    46512   25.86%\n",
      "   1727  1063        cutoff             14.0000       10.4381    62725   25.44%\n",
      "   2078  1142       12.0899    34       14.0000       10.5060    66640   24.96%\n",
      "   3714  2250       12.0450    33       14.0000       10.9178   120250   22.02%\n",
      "Elapsed time = 18.07 sec. (5606.02 ticks, tree = 2.25 MB, solutions = 5)\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 7686 rows, 49 columns, and 175416 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (41.53 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 7686 rows, 49 columns, and 175416 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (51.46 ticks)\n",
      "Represolve time = 0.16 sec. (117.63 ticks)\n",
      "   4519     0        7.3702    49       14.0000      Fract: 1   149057   20.70%\n",
      "   4519     0        7.3908    49       14.0000      Fract: 1   149150   20.70%\n",
      "   4519     0        7.4046    49       14.0000      Fract: 1   149244   20.70%\n",
      "   4519     0        7.4253    49       14.0000      Fract: 1   149368   20.70%\n",
      "   4519     2        7.4253    49       14.0000       11.1025   149368   20.70%\n",
      "   4524     6        8.2617    47       14.0000       11.1025   150099   20.70%\n",
      "   4827    42       10.7567    38       14.0000       11.1025   152999   20.70%\n",
      "*  5945   809      integral     0       13.0000       11.1025   200064   14.60%\n",
      "   5969   892       11.6778    30       13.0000       11.1025   204163   14.60%\n",
      "   7603   874        cutoff             13.0000       11.1025   250435   14.60%\n",
      "\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.43 sec. (1617.64 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   40.13 sec. (11269.45 ticks)\n",
      "  Sync time (average)   =    7.06 sec.\n",
      "  Wait time (average)   =    0.08 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   41.56 sec. (12887.10 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:42:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:42:39 PM: Optimal value: 1.300e+01\n",
      "(CVXPY) Apr 25 12:42:39 PM: Compilation took 2.508e+00 seconds\n",
      "(CVXPY) Apr 25 12:42:39 PM: Solver (including time spent in interface) took 4.224e+01 seconds\n",
      "Optimal value: 13.0\n",
      "Variable var590310: value [ 1.  1.  0. -0.  0.  0.  0.  0.  0.  0.  1.  0. -0.  0.  0.  0.  0.  0.\n",
      "  0.  1.  1. -0.  1.  1.  0.  1.  0.  0.  1.  0.  0.  0.  1.  0.  0. -0.\n",
      "  1.  0.  1.  0.  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'MORT_30_HF' 'PSI_11' 'PSI_12' 'PSI_14' 'PSI_15'\n",
      " 'OP_23' 'H_COMP_1_A_P' 'H_COMP_6_Y_P' 'EDAC_30_AMI' 'EDAC_30_PN'\n",
      " 'OP_35_ED']\n",
      "Constructing constraint set for group size 8\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:42:39 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:42:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:42:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:42:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:42:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:42:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:42:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:42:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:42:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:42:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:42:42 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:42:42 PM: Finished problem compilation (took 2.528e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:42:42 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 26.000000 after 0.01 sec. (11.05 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 71810 rows and 1 columns.\n",
      "Reduced MIP has 7432 rows, 49 columns, and 173643 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.30 sec. (290.13 ticks)\n",
      "Probing time = 0.01 sec. (1.55 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 7432 rows, 49 columns, and 173643 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (48.40 ticks)\n",
      "Probing time = 0.01 sec. (1.67 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (78.21 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           26.0000        0.0000           100.00%\n",
      "*     0+    0                           16.0000        0.0000           100.00%\n",
      "      0     0        6.2500    49       16.0000        6.2500      281   60.94%\n",
      "*     0+    0                           13.0000        6.2500            51.92%\n",
      "      0     0        6.3781    49       13.0000      Fract: 1      352   50.94%\n",
      "      0     0        6.4253    49       13.0000      Fract: 1      439   50.57%\n",
      "Detecting symmetries...\n",
      "      0     2        6.4253    49       13.0000        6.6857      439   48.57%\n",
      "Elapsed time = 1.43 sec. (1527.25 ticks, tree = 0.02 MB, solutions = 3)\n",
      "      8     5        7.7583    45       13.0000        6.6857      867   48.57%\n",
      "*   127    87      integral     0       12.0000        7.6585     6608   36.18%\n",
      "    164   118       10.5364    35       12.0000        7.6585     9215   36.18%\n",
      "    408   260       10.4224    29       12.0000        8.3044    20356   30.80%\n",
      "    714   409        9.7130    39       12.0000        9.0018    28778   24.99%\n",
      "   1029   581        cutoff             12.0000        9.1389    37387   23.84%\n",
      "   1390   785       10.8057    29       12.0000        9.2838    48991   22.64%\n",
      "   1703   965       10.6224    34       12.0000        9.3456    57827   22.12%\n",
      "   1735   981       10.7070    29       12.0000        9.3456    58969   22.12%\n",
      "   1738   890        cutoff             12.0000        9.3456    54154   22.12%\n",
      "   3298  1599        cutoff             12.0000        9.7152    94748   19.04%\n",
      "Elapsed time = 17.37 sec. (5405.27 ticks, tree = 1.36 MB, solutions = 4)\n",
      "   5127  2118        cutoff             12.0000       10.0427   131586   16.31%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 7432 rows, 49 columns, and 173643 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (41.07 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 7432 rows, 49 columns, and 173643 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.13 sec. (50.90 ticks)\n",
      "Represolve time = 0.22 sec. (116.04 ticks)\n",
      "   6693     0        6.4600    49       12.0000      Fract: 1   172630   14.47%\n",
      "   6693     0        6.4902    49       12.0000      Fract: 1   172749   14.47%\n",
      "   6693     0        6.5170    49       12.0000      Fract: 1   172833   14.47%\n",
      "   6693     0        6.5337    49       12.0000      Fract: 1   172909   14.47%\n",
      "   6693     2        6.5337    49       12.0000       10.2631   172909   14.47%\n",
      "   6697     4        7.5488    47       12.0000       10.2631   173240   14.47%\n",
      "   7033    38        9.7162    38       12.0000       10.2631   177632   14.47%\n",
      "   8241   749       10.0156    41       12.0000       10.2631   229753   14.47%\n",
      "   9935  1311       10.5704    34       12.0000       10.2631   279504   14.47%\n",
      "  11657  1559       10.5027    34       12.0000       10.2631   324659   14.47%\n",
      "  13286  1334        cutoff             12.0000       10.3782   368518   13.52%\n",
      "\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.33 sec. (1517.54 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   55.98 sec. (14259.59 ticks)\n",
      "  Sync time (average)   =    8.28 sec.\n",
      "  Wait time (average)   =    0.07 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   57.31 sec. (15777.13 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:43:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:43:40 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 25 12:43:40 PM: Compilation took 2.528e+00 seconds\n",
      "(CVXPY) Apr 25 12:43:40 PM: Solver (including time spent in interface) took 5.802e+01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var590310: value [-0.  0.  0. -0.  1.  0. -0. -0.  1.  1.  0. -0.  0.  1.  0. -0. -0. -0.\n",
      "  1. -0.  0.  1. -0.  1.  0.  0. -0.  1. -0.  0.  1.  0. -0.  0.  0. -0.\n",
      " -0.  0.  1.  1.  0. -0. -0. -0.  0. -0.  0. -0.  0.  1.]\n",
      "Tasks: ['HAI_5_SIR' 'MORT_30_CABG' 'MORT_30_COPD' 'PSI_03' 'PSI_10' 'PSI_13'\n",
      " 'PSI_15' 'SEP_1' 'H_COMP_3_A_P' 'EDAC_30_PN' 'OP_32' 'READM_30_PN']\n",
      "Constructing constraint set for group size 9\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:43:40 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:43:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:43:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:43:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:43:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:43:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:43:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:43:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:43:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:43:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:43:42 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:43:43 PM: Finished problem compilation (took 2.435e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:43:43 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 26.000000 after 0.01 sec. (11.04 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 72060 rows and 1 columns.\n",
      "Reduced MIP has 7182 rows, 49 columns, and 171649 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.30 sec. (289.01 ticks)\n",
      "Probing time = 0.01 sec. (1.50 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 7182 rows, 49 columns, and 171649 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (47.71 ticks)\n",
      "Probing time = 0.02 sec. (1.62 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.12 sec. (81.04 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           26.0000        0.0000           100.00%\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "      0     0        5.5556    49       15.0000        5.5556      345   62.96%\n",
      "      0     0        5.6702    49       15.0000      Fract: 1      450   62.20%\n",
      "*     0+    0                           13.0000        5.6702            56.38%\n",
      "      0     0        5.7247    49       13.0000      Fract: 1      549   55.96%\n",
      "*     0+    0                           10.0000        5.7247            42.75%\n",
      "Detecting symmetries...\n",
      "      0     2        5.7247    49       10.0000        6.1322      549   38.68%\n",
      "Elapsed time = 1.64 sec. (1651.97 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     22    19        8.8086    36       10.0000        6.1546     2001   38.45%\n",
      "    274   117        cutoff             10.0000        6.9093    11310   30.91%\n",
      "    634   255        8.7956    33       10.0000        7.7198    24700   22.80%\n",
      "   1039   231        8.9289    32       10.0000        8.3596    39358   16.40%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.48 sec. (1642.25 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    4.89 sec. (1081.36 ticks)\n",
      "  Sync time (average)   =    1.08 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    6.38 sec. (2723.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:43:49 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:43:49 PM: Optimal value: 1.000e+01\n",
      "(CVXPY) Apr 25 12:43:49 PM: Compilation took 2.435e+00 seconds\n",
      "(CVXPY) Apr 25 12:43:49 PM: Solver (including time spent in interface) took 6.900e+00 seconds\n",
      "Optimal value: 10.0\n",
      "Variable var590310: value [ 1.  0. -0. -0.  0. -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  0. -0. -0.\n",
      " -0.  0.  1. -0.  1.  1.  0. -0. -0. -0. -0. -0.  1. -0.  0.  0.  0. -0.\n",
      "  1. -0.  1. -0.  0. -0. -0. -0. -0.  0.  1.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_PN' 'PSI_04' 'PSI_12' 'PSI_14' 'PSI_15'\n",
      " 'H_COMP_3_A_P' 'EDAC_30_AMI' 'EDAC_30_PN' 'READM_30_HF']\n",
      "Constructing constraint set for group size 10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:43:50 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:43:50 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:43:50 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:43:50 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:43:50 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:43:50 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:43:50 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:43:50 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:43:50 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:43:50 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:43:52 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:43:52 PM: Finished problem compilation (took 2.425e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:43:52 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 24.000000 after 0.01 sec. (10.61 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 72317 rows and 1 columns.\n",
      "Reduced MIP has 6925 rows, 49 columns, and 169343 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.29 sec. (287.75 ticks)\n",
      "Probing time = 0.02 sec. (1.44 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 6925 rows, 49 columns, and 169343 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (47.03 ticks)\n",
      "Probing time = 0.02 sec. (1.54 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.13 sec. (76.87 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           24.0000        0.0000           100.00%\n",
      "*     0+    0                           13.0000        0.0000           100.00%\n",
      "      0     0        5.0000    49       13.0000        5.0000      270   61.54%\n",
      "*     0+    0                           12.0000        5.0000            58.33%\n",
      "      0     0        5.1707    49       12.0000      Fract: 1      368   56.91%\n",
      "      0     0        5.2084    49       12.0000      Fract: 1      434   56.60%\n",
      "*     0+    0                           11.0000        5.2084            52.65%\n",
      "*     0+    0                           10.0000        5.2084            47.92%\n",
      "Detecting symmetries...\n",
      "      0     2        5.2084    49       10.0000        5.3349      434   46.65%\n",
      "Elapsed time = 1.45 sec. (1398.85 ticks, tree = 0.02 MB, solutions = 5)\n",
      "     14    13        6.4977    45       10.0000        5.3349     1545   46.65%\n",
      "    236   142        7.6542    31       10.0000        5.9094    11548   40.91%\n",
      "    552   300        cutoff             10.0000        6.1882    21524   38.12%\n",
      "    950   515        7.8317    38       10.0000        6.1882    31047   38.12%\n",
      "   1361   824        8.2796    31       10.0000        6.1882    44885   38.12%\n",
      "   1654   959        8.4489    34       10.0000        6.8563    51164   31.44%\n",
      "   2108  1214        8.5627    26       10.0000        7.5611    62367   24.39%\n",
      "   2543  1367        8.4813    33       10.0000        7.6877    72142   23.12%\n",
      "   3064  1555        cutoff             10.0000        7.7617    83312   22.38%\n",
      "   5006  2295        8.7798    27       10.0000        8.0608   137163   19.39%\n",
      "Elapsed time = 15.28 sec. (4505.07 ticks, tree = 2.14 MB, solutions = 5)\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 6925 rows, 49 columns, and 169343 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (39.99 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 6925 rows, 49 columns, and 169343 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (49.46 ticks)\n",
      "Represolve time = 0.14 sec. (113.34 ticks)\n",
      "   6494     0        5.2251    49       10.0000      Fract: 1   181957   17.28%\n",
      "   6494     0        5.2317    49       10.0000      Fract: 1   182011   17.28%\n",
      "   6494     0        5.2365    49       10.0000      Fract: 1   182069   17.28%\n",
      "   6494     2        5.2365    49       10.0000        8.2723   182069   17.28%\n",
      "   6503     7        6.9021    46       10.0000        8.2723   182825   17.28%\n",
      "   7172   321        7.7470    35       10.0000        8.2723   203754   17.28%\n",
      "   8700  1123        8.4256    29       10.0000        8.2723   252766   17.28%\n",
      "  10716  1566        8.4984    33       10.0000        8.2723   299894   17.28%\n",
      "  12597  1168        cutoff             10.0000        8.4473   355009   15.53%\n",
      "\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.34 sec. (1389.43 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   43.06 sec. (10926.10 ticks)\n",
      "  Sync time (average)   =    6.73 sec.\n",
      "  Wait time (average)   =    0.07 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   44.40 sec. (12315.54 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:44:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:44:37 PM: Optimal value: 1.000e+01\n",
      "(CVXPY) Apr 25 12:44:37 PM: Compilation took 2.425e+00 seconds\n",
      "(CVXPY) Apr 25 12:44:37 PM: Solver (including time spent in interface) took 4.509e+01 seconds\n",
      "Optimal value: 10.0\n",
      "Variable var590310: value [ 1. -0. -0. -0. -0. -0. -0. -0.  1. -0.  1. -0. -0. -0. -0. -0. -0.  1.\n",
      " -0.  1.  1.  0. -0. -0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0.  0. -0.\n",
      " -0. -0. -0.  1. -0.  0. -0. -0. -0.  0. -0.  1. -0.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_CABG' 'MORT_30_HF' 'PSI_09' 'PSI_11' 'PSI_12'\n",
      " 'H_COMP_3_A_P' 'OP_32' 'READM_30_HIP_KNEE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 11\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:44:38 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:44:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:44:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:44:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:44:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:44:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:44:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:44:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:44:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:44:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:44:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:44:40 PM: Finished problem compilation (took 2.563e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:44:40 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 23.000000 after 0.01 sec. (10.35 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 72579 rows and 1 columns.\n",
      "Reduced MIP has 6663 rows, 49 columns, and 166730 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.28 sec. (286.22 ticks)\n",
      "Probing time = 0.01 sec. (1.38 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 6663 rows, 49 columns, and 166730 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (46.26 ticks)\n",
      "Probing time = 0.01 sec. (1.48 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (78.33 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           23.0000        0.0000           100.00%\n",
      "*     0+    0                           12.0000        0.0000           100.00%\n",
      "      0     0        4.5455    49       12.0000        4.5455      283   62.12%\n",
      "      0     0        4.6366    49       12.0000      Fract: 1      377   61.36%\n",
      "      0     0        4.6897    49       12.0000      Fract: 1      459   60.92%\n",
      "*     0+    0                           11.0000        4.6897            57.37%\n",
      "*     0+    0                           10.0000        4.6897            53.10%\n",
      "Detecting symmetries...\n",
      "      0     2        4.6897    49       10.0000        4.7570      459   52.43%\n",
      "Elapsed time = 1.43 sec. (1443.31 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     13     3        5.4545    48       10.0000        4.7570      592   52.43%\n",
      "*   197+   14                            9.0000        5.2700            41.44%\n",
      "    281   125        cutoff              9.0000        5.5323    11091   38.53%\n",
      "    679   370        cutoff              9.0000        5.8666    27652   34.82%\n",
      "   1082   610        7.7962    25        9.0000        6.4941    40966   27.84%\n",
      "   1508   749        cutoff              9.0000        6.6895    49392   25.67%\n",
      "   1607   855        cutoff              9.0000        6.7086    55552   25.46%\n",
      "   1905   983        cutoff              9.0000        6.8137    62433   24.29%\n",
      "   2429  1104        cutoff              9.0000        6.9545    72225   22.73%\n",
      "   2889  1234        cutoff              9.0000        7.1360    87665   20.71%\n",
      "   4937   135        cutoff              9.0000        7.8370   127663   12.92%\n",
      "Elapsed time = 14.54 sec. (4556.47 ticks, tree = 0.09 MB, solutions = 5)\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.31 sec. (1434.09 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   13.36 sec. (3134.66 ticks)\n",
      "  Sync time (average)   =    2.59 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   14.67 sec. (4568.75 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:44:56 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:44:56 PM: Optimal value: 9.000e+00\n",
      "(CVXPY) Apr 25 12:44:56 PM: Compilation took 2.563e+00 seconds\n",
      "(CVXPY) Apr 25 12:44:56 PM: Solver (including time spent in interface) took 1.532e+01 seconds\n",
      "Optimal value: 9.0\n",
      "Variable var590310: value [ 1. -0. -0. -0. -0. -0.  0. -0. -0. -0.  1. -0.  0. -0.  0. -0. -0.  0.\n",
      " -0. -0. -0. -0.  1. -0.  1. -0. -0.  0. -0. -0.  1. -0. -0. -0.  0. -0.\n",
      " -0.  0. -0.  0. -0.  0. -0.  0.  1.  1. -0.  1. -0.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_HF' 'PSI_14' 'PSI_90' 'H_COMP_3_A_P' 'READM_30_CABG'\n",
      " 'READM_30_COPD' 'READM_30_HIP_KNEE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 12\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:44:56 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:44:56 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:44:56 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:44:56 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:44:56 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:44:56 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:44:56 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:44:56 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:44:56 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:44:56 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:44:58 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:44:58 PM: Finished problem compilation (took 2.446e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:44:58 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 21.000000 after 0.01 sec. (9.54 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 72831 rows and 1 columns.\n",
      "Reduced MIP has 6411 rows, 49 columns, and 163964 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.29 sec. (284.53 ticks)\n",
      "Probing time = 0.02 sec. (1.31 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 6411 rows, 49 columns, and 163964 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (45.49 ticks)\n",
      "Probing time = 0.02 sec. (1.39 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (81.76 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           21.0000        0.0000           100.00%\n",
      "*     0+    0                           13.0000        0.0000           100.00%\n",
      "      0     0        4.1667    49       13.0000        4.1667      333   67.95%\n",
      "*     0+    0                           10.0000        4.1667            58.33%\n",
      "      0     0        4.2496    49       10.0000      Fract: 1      426   57.50%\n",
      "      0     0        4.2827    49       10.0000      Fract: 1      488   57.17%\n",
      "*     0+    0                            9.0000        4.2827            52.41%\n",
      "Detecting symmetries...\n",
      "      0     2        4.2827    49        9.0000        4.3130      488   52.08%\n",
      "Elapsed time = 1.38 sec. (1339.85 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     17     9        6.9091    37        9.0000        4.3130     1207   52.08%\n",
      "    295   127        6.3250    36        9.0000        4.9223    10875   45.31%\n",
      "    744   464        6.8493    28        9.0000        5.5637    27747   38.18%\n",
      "   1177   696        cutoff              9.0000        5.6751    37592   36.94%\n",
      "*  1419+  766                            8.0000        6.1988            22.52%\n",
      "   1543   432        6.8870    31        8.0000        6.1988    47857   22.52%\n",
      "   1810   331        cutoff              8.0000        6.1988    54580   22.52%\n",
      "   1976   725        cutoff              8.0000        6.1988    38849   22.52%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.27 sec. (1330.78 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    7.36 sec. (2231.95 ticks)\n",
      "  Sync time (average)   =    1.66 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    8.64 sec. (3562.73 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:08 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:45:08 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 12:45:08 PM: Compilation took 2.446e+00 seconds\n",
      "(CVXPY) Apr 25 12:45:08 PM: Solver (including time spent in interface) took 9.314e+00 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var590310: value [ 1. -0.  0.  0.  0.  0. -0. -0.  0. -0. -0. -0.  0. -0.  1.  1.  0.  0.\n",
      "  0.  0.  1. -0.  0.  0. -0. -0.  0.  0.  0.  0.  1.  0. -0.  0.  0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  1.  0. -0.  0.  1.  1.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'PSI_04' 'PSI_06' 'PSI_12' 'H_COMP_3_A_P' 'OP_36'\n",
      " 'READM_30_HF' 'READM_30_HIP_KNEE']\n",
      "Constructing constraint set for group size 13\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:45:08 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:45:08 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:45:08 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:45:08 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:45:08 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:08 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:45:08 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:45:08 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:45:08 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:45:08 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:45:11 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:45:11 PM: Finished problem compilation (took 2.522e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:11 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 20.000000 after 0.01 sec. (9.28 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 73087 rows and 1 columns.\n",
      "Reduced MIP has 6155 rows, 49 columns, and 160898 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (282.90 ticks)\n",
      "Probing time = 0.01 sec. (1.23 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 6155 rows, 49 columns, and 160898 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (44.63 ticks)\n",
      "Probing time = 0.02 sec. (1.33 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (77.59 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           20.0000        0.0000           100.00%\n",
      "*     0+    0                           13.0000        0.0000           100.00%\n",
      "      0     0        3.8462    49       13.0000        3.8462      313   70.41%\n",
      "*     0+    0                           11.0000        3.8462            65.03%\n",
      "*     0+    0                           10.0000        3.8462            61.54%\n",
      "      0     0        3.9360    49       10.0000      Fract: 1      395   60.64%\n",
      "      0     0        3.9652    49       10.0000      Fract: 1      469   60.35%\n",
      "*     0+    0                            9.0000        3.9652            55.94%\n",
      "Detecting symmetries...\n",
      "      0     2        3.9652    49        9.0000        4.0087      469   55.46%\n",
      "Elapsed time = 1.33 sec. (1344.57 ticks, tree = 0.02 MB, solutions = 5)\n",
      "     10    10        5.0719    41        9.0000        4.0087     1264   55.46%\n",
      "*    54+    9                            8.0000        4.0761            49.05%\n",
      "    214   129        5.9793    31        8.0000        4.0761    10308   49.05%\n",
      "    637   389        6.7305    30        8.0000        4.8504    24972   39.37%\n",
      "   1084   585        6.9971    22        8.0000        4.9596    36390   38.01%\n",
      "   1572   840        6.5468    34        8.0000        5.7683    48083   27.90%\n",
      "   2049  1003        cutoff              8.0000        5.9376    56820   25.78%\n",
      "   2564  1234        cutoff              8.0000        6.0094    72200   24.88%\n",
      "   3104  1372        cutoff              8.0000        6.1136    88332   23.58%\n",
      "   3637  1345        cutoff              8.0000        6.2581   101919   21.77%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.21 sec. (1335.61 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   12.05 sec. (2796.51 ticks)\n",
      "  Sync time (average)   =    2.39 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   13.26 sec. (4132.12 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:25 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:45:25 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 12:45:25 PM: Compilation took 2.522e+00 seconds\n",
      "(CVXPY) Apr 25 12:45:25 PM: Solver (including time spent in interface) took 1.397e+01 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var590310: value [ 0. -0.  1. -0. -0.  0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0.  1. -0.\n",
      "  1. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0.  1. -0. -0. -0.  0. -0.\n",
      " -0. -0.  0.  1. -0. -0. -0.  0. -0. -0.  1. -0. -0. -0.]\n",
      "Tasks: ['HAI_3_SIR' 'MORT_30_STK' 'PSI_08' 'PSI_10' 'PSI_90' 'H_COMP_3_A_P'\n",
      " 'OP_32' 'READM_30_HF']\n",
      "Constructing constraint set for group size 14\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:45:25 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:45:25 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:45:25 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:45:25 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:45:25 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:25 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:45:25 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:45:25 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:45:25 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:45:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:45:28 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:45:28 PM: Finished problem compilation (took 2.443e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:28 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 18.000000 after 0.01 sec. (7.71 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 73348 rows and 1 columns.\n",
      "Reduced MIP has 5894 rows, 49 columns, and 157512 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.30 sec. (280.87 ticks)\n",
      "Probing time = 0.02 sec. (1.16 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 5894 rows, 49 columns, and 157512 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (43.66 ticks)\n",
      "Probing time = 0.02 sec. (1.25 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.11 sec. (77.44 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           18.0000        0.0000           100.00%\n",
      "*     0+    0                           12.0000        0.0000           100.00%\n",
      "      0     0        3.5714    49       12.0000        3.5714      343   70.24%\n",
      "*     0+    0                           10.0000        3.5714            64.29%\n",
      "      0     0        3.6581    49       10.0000      Fract: 1      429   63.42%\n",
      "*     0+    0                            8.0000        3.6581            54.27%\n",
      "      0     0        3.6870    49        8.0000      Fract: 1      518   53.91%\n",
      "Detecting symmetries...\n",
      "      0     2        3.6870    49        8.0000        3.7822      518   52.72%\n",
      "Elapsed time = 1.32 sec. (1278.65 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     26     5        3.8235    46        8.0000        3.7822      753   52.72%\n",
      "*   141    42      integral     0        7.0000        3.8258     3888   45.35%\n",
      "    350    98        cutoff              7.0000        3.9386    14398   43.73%\n",
      "    825    70        4.7053    33        7.0000        3.9426    23781   43.68%\n",
      "   1276    22        cutoff              7.0000        4.9811    36535   28.84%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.21 sec. (1269.84 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    3.57 sec. (1162.81 ticks)\n",
      "  Sync time (average)   =    1.10 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    4.78 sec. (2432.66 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:33 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:45:33 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 12:45:33 PM: Compilation took 2.443e+00 seconds\n",
      "(CVXPY) Apr 25 12:45:33 PM: Solver (including time spent in interface) took 5.291e+00 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var590310: value [ 0. -0. -0. -0.  0.  1. -0.  0.  1.  0.  0.  0.  0.  0.  1. -0.  0.  0.\n",
      " -0.  0.  0.  1.  0. -0.  0. -0.  1.  1. -0.  0. -0.  0.  0.  0.  0. -0.\n",
      " -0. -0.  1. -0. -0. -0.  0.  0. -0. -0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_6_SIR' 'MORT_30_CABG' 'PSI_04' 'PSI_13' 'OP_29' 'SEP_1' 'EDAC_30_PN']\n",
      "Constructing constraint set for group size 15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:45:34 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:45:34 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:45:34 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:45:34 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:45:34 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:34 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:45:34 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:45:34 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:45:34 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:45:34 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:45:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:45:36 PM: Finished problem compilation (took 2.395e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:36 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 17.000000 after 0.01 sec. (7.50 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 73609 rows and 1 columns.\n",
      "Reduced MIP has 5633 rows, 49 columns, and 153865 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (278.71 ticks)\n",
      "Probing time = 0.02 sec. (1.06 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 5633 rows, 49 columns, and 153865 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (42.62 ticks)\n",
      "Probing time = 0.01 sec. (1.16 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.27 sec. (75.30 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           17.0000        0.0000           100.00%\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "      0     0        3.3333    49        9.0000        3.3333      326   62.96%\n",
      "      0     0        3.4031    49        9.0000      Fract: 1      378   62.19%\n",
      "*     0+    0                            8.0000        3.4031            57.46%\n",
      "      0     0        3.4311    49        8.0000      Fract: 1      454   57.11%\n",
      "Detecting symmetries...\n",
      "      0     2        3.4311    49        8.0000        3.5646      454   55.44%\n",
      "Elapsed time = 1.47 sec. (1242.41 ticks, tree = 0.02 MB, solutions = 3)\n",
      "     32    25        5.9512    30        8.0000        3.5823     2406   55.22%\n",
      "*    38+   15                            7.0000        3.5823            48.82%\n",
      "    375   126        5.2311    36        7.0000        3.5823    13746   48.82%\n",
      "    901   388        5.4059    28        7.0000        3.6042    25081   48.51%\n",
      "   1413   729        5.6774    30        7.0000        4.4582    38987   36.31%\n",
      "   1870   838        5.9871    21        7.0000        4.5261    47448   35.34%\n",
      "   2323   778        cutoff              7.0000        5.3230    63070   23.96%\n",
      "   2946   248        cutoff              7.0000        5.6576    72468   19.18%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.36 sec. (1233.96 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    7.54 sec. (1752.36 ticks)\n",
      "  Sync time (average)   =    1.55 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    8.90 sec. (2986.32 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:46 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:45:46 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 12:45:46 PM: Compilation took 2.395e+00 seconds\n",
      "(CVXPY) Apr 25 12:45:46 PM: Solver (including time spent in interface) took 9.605e+00 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var590310: value [-0. -0.  1. -0. -0. -0.  1.  0.  0. -0. -0.  0.  0.  1.  1. -0. -0. -0.\n",
      "  0.  0.  1. -0. -0.  0. -0. -0. -0. -0. -0. -0.  1.  0. -0.  0.  0. -0.\n",
      " -0. -0. -0. -0. -0.  0. -0. -0. -0.  0.  1. -0. -0. -0.]\n",
      "Tasks: ['HAI_3_SIR' 'COMP_HIP_KNEE' 'PSI_03' 'PSI_04' 'PSI_12' 'H_COMP_3_A_P'\n",
      " 'READM_30_HF']\n",
      "Constructing constraint set for group size 16\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:45:46 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:45:46 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:45:46 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:45:46 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:45:46 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:46 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:45:46 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:45:46 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:45:46 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:45:46 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:45:48 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:45:49 PM: Finished problem compilation (took 2.493e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:45:49 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 16.000000 after 0.01 sec. (7.26 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 73862 rows and 1 columns.\n",
      "Reduced MIP has 5380 rows, 49 columns, and 150076 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.28 sec. (276.21 ticks)\n",
      "Probing time = 0.01 sec. (0.99 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 5380 rows, 49 columns, and 150076 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (41.53 ticks)\n",
      "Probing time = 0.01 sec. (1.07 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.11 sec. (73.36 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           16.0000        0.0000           100.00%\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "      0     0        3.1250    49        9.0000        3.1250      292   65.28%\n",
      "*     0+    0                            8.0000        3.1250            60.94%\n",
      "      0     0        3.1938    49        8.0000      Fract: 1      366   60.08%\n",
      "      0     0        3.2110    49        8.0000      Fract: 1      415   59.86%\n",
      "Detecting symmetries...\n",
      "      0     2        3.2110    49        8.0000        3.2110      415   59.86%\n",
      "Elapsed time = 1.21 sec. (1210.26 ticks, tree = 0.02 MB, solutions = 3)\n",
      "*    19+    5                            7.0000        3.3665            51.91%\n",
      "     37    10        5.7340    33        7.0000        3.3675     1347   51.89%\n",
      "    366   186        5.9032    15        7.0000        3.5193    13365   49.72%\n",
      "    986   576        5.2654    29        7.0000        3.8922    26224   44.40%\n",
      "   1596   884        cutoff              7.0000        4.5989    37109   34.30%\n",
      "   2210  1245        5.8569    20        7.0000        4.8380    50682   30.89%\n",
      "   2848  1585        5.7442    27        7.0000        4.9746    65015   28.93%\n",
      "   3503  1805        5.9064    27        7.0000        5.0904    79122   27.28%\n",
      "   4163  2042        5.8981    22        7.0000        5.1577    96441   26.32%\n",
      "   4772  2053        5.8970    21        7.0000        5.2455   107132   25.06%\n",
      "*  5493  1778      integral     0        6.0000        5.3754   126807   10.41%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.11 sec. (1201.95 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   10.22 sec. (2525.36 ticks)\n",
      "  Sync time (average)   =    2.06 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   11.34 sec. (3727.30 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:00 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:00 PM: Optimal value: 6.000e+00\n",
      "(CVXPY) Apr 25 12:46:00 PM: Compilation took 2.493e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:00 PM: Solver (including time spent in interface) took 1.187e+01 seconds\n",
      "Optimal value: 6.0\n",
      "Variable var590310: value [ 0.  0. -0. -0. -0.  0.  0. -0.  0.  0. -0. -0. -0. -0.  1.  0.  0.  0.\n",
      " -0. -0.  1. -0.  0.  1. -0. -0.  0. -0. -0. -0. -0.  0. -0.  1.  0. -0.\n",
      "  1.  0.  1.  0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.]\n",
      "Tasks: ['PSI_04' 'PSI_12' 'PSI_15' 'H_COMP_7_SA' 'EDAC_30_AMI' 'EDAC_30_PN']\n",
      "Constructing constraint set for group size 17\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:01 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:01 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:01 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:01 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:01 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:01 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:01 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:01 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:01 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:01 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:04 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:04 PM: Finished problem compilation (took 2.556e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:04 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 16.000000 after 0.01 sec. (7.25 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 74110 rows and 1 columns.\n",
      "Reduced MIP has 5132 rows, 49 columns, and 146115 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.24 sec. (273.61 ticks)\n",
      "Probing time = 0.01 sec. (0.91 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 5132 rows, 49 columns, and 146115 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (40.38 ticks)\n",
      "Probing time = 0.01 sec. (0.98 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.08 sec. (77.38 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           16.0000        0.0000           100.00%\n",
      "*     0+    0                            8.0000        0.0000           100.00%\n",
      "      0     0        2.9412    49        8.0000        2.9412      335   63.24%\n",
      "      0     0        3.0085    47        8.0000      Fract: 1      389   62.39%\n",
      "      0     0        3.0262    47        8.0000      Fract: 1      449   62.17%\n",
      "*     0+    0                            7.0000        3.0262            56.77%\n",
      "Detecting symmetries...\n",
      "      0     2        3.0262    47        7.0000        3.0262      449   56.77%\n",
      "Elapsed time = 1.17 sec. (1262.24 ticks, tree = 0.02 MB, solutions = 3)\n",
      "*     6+    2                            6.0000        3.0273            49.55%\n",
      "     28    17        3.9828    41        6.0000        3.1571     2432   47.38%\n",
      "    407    99        4.8205    32        6.0000        3.2652    13500   45.58%\n",
      "   1002   231        4.7037    21        6.0000        3.3892    24966   43.51%\n",
      "   1364     7        4.8044    20        6.0000        4.4446    34059   25.92%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.07 sec. (1254.22 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    2.83 sec. (989.53 ticks)\n",
      "  Sync time (average)   =    0.83 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    3.90 sec. (2243.75 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:08 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:08 PM: Optimal value: 6.000e+00\n",
      "(CVXPY) Apr 25 12:46:08 PM: Compilation took 2.556e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:08 PM: Solver (including time spent in interface) took 4.421e+00 seconds\n",
      "Optimal value: 6.0\n",
      "Variable var590310: value [-0.  0. -0. -0. -0. -0. -0. -0. -0. -0.  0. -0. -0. -0.  1. -0. -0. -0.\n",
      " -0.  0.  1. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0.  0. -0.  1.  0. -0.\n",
      "  1. -0.  1. -0.  0. -0. -0. -0. -0. -0.  0. -0. -0. -0.]\n",
      "Tasks: ['PSI_04' 'PSI_12' 'PSI_15' 'H_COMP_7_SA' 'EDAC_30_AMI' 'EDAC_30_PN']\n",
      "Constructing constraint set for group size 18\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:09 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:09 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:09 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:09 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:09 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:09 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:09 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:09 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:09 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:09 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:11 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:11 PM: Finished problem compilation (took 2.515e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:11 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 16.000000 after 0.01 sec. (7.24 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 74369 rows and 1 columns.\n",
      "Reduced MIP has 4873 rows, 49 columns, and 141719 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.27 sec. (270.93 ticks)\n",
      "Probing time = 0.01 sec. (0.82 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 4873 rows, 49 columns, and 141719 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (39.18 ticks)\n",
      "Probing time = 0.02 sec. (0.84 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.12 sec. (82.79 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           16.0000        0.0000           100.00%\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "      0     0        2.7724    49        9.0000        2.7724      440   69.20%\n",
      "*     0+    0                            8.0000        2.7724            65.35%\n",
      "      0     0        2.8046    48        8.0000      Fract: 1      495   64.94%\n",
      "*     0+    0                            7.0000        2.8046            59.93%\n",
      "      0     0        2.8257    47        7.0000      Fract: 1      546   59.63%\n",
      "      0     0        2.8445    48        7.0000    MIRcuts: 1      602   59.36%\n",
      "      0     0        2.8705    47        7.0000    MIRcuts: 1      657   58.99%\n",
      "Detecting symmetries...\n",
      "      0     2        2.8705    47        7.0000        2.8705      657   58.99%\n",
      "Elapsed time = 1.38 sec. (1336.82 ticks, tree = 0.02 MB, solutions = 4)\n",
      "*    29+   12                            6.0000        2.8809            51.99%\n",
      "     86    44        3.0000    35        6.0000        3.0000     5310   50.00%\n",
      "    584   251        4.6984    17        6.0000        3.0000    17763   50.00%\n",
      "   1210   627        4.8484    20        6.0000        3.7450    34584   37.58%\n",
      "   1864   823        5.0000    11        6.0000        3.8513    47188   35.81%\n",
      "   2543   623        cutoff              6.0000        4.5865    60953   23.56%\n",
      "\n",
      "Mixed integer rounding cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.30 sec. (1329.12 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    5.29 sec. (1360.29 ticks)\n",
      "  Sync time (average)   =    1.15 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    6.59 sec. (2689.41 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:18 PM: Optimal value: 6.000e+00\n",
      "(CVXPY) Apr 25 12:46:18 PM: Compilation took 2.515e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:18 PM: Solver (including time spent in interface) took 7.098e+00 seconds\n",
      "Optimal value: 6.0\n",
      "Variable var590310: value [ 1.  0.  0. -0.  0.  0. -0. -0.  0. -0. -0.  0. -0. -0.  0.  0.  1. -0.\n",
      " -0.  0.  0. -0.  0.  0.  1.  0. -0. -0.  1. -0. -0. -0. -0. -0.  0. -0.\n",
      " -0.  0.  0.  0.  1. -0.  0.  1. -0.  0. -0.  0. -0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'PSI_08' 'PSI_90' 'H_COMP_1_A_P' 'OP_35_ADM' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 19\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:19 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:19 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:19 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:19 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:19 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:21 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:21 PM: Finished problem compilation (took 2.546e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:21 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 15.000000 after 0.01 sec. (6.84 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 74619 rows and 1 columns.\n",
      "Reduced MIP has 4623 rows, 49 columns, and 137224 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.29 sec. (268.03 ticks)\n",
      "Probing time = 0.01 sec. (0.74 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 4623 rows, 49 columns, and 137224 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (37.86 ticks)\n",
      "Probing time = 0.01 sec. (0.76 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (78.73 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                            8.0000        0.0000           100.00%\n",
      "      0     0        2.6187    48        8.0000        2.6187      411   67.27%\n",
      "*     0+    0                            7.0000        2.6187            62.59%\n",
      "      0     0        2.6674    48        7.0000      Fract: 1      478   61.89%\n",
      "      0     0        3.0000    37        7.0000    MIRcuts: 1      509   57.14%\n",
      "*     0+    0                            6.0000        3.0000            50.00%\n",
      "Detecting symmetries...\n",
      "      0     2        3.0000    37        6.0000        3.0000      509   50.00%\n",
      "Elapsed time = 1.09 sec. (984.07 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     96    47        4.3928    32        6.0000        3.0462     4802   49.23%\n",
      "    457   221        cutoff              6.0000        3.0787    15637   48.69%\n",
      "*   625+  272                            5.0000        3.6590            26.82%\n",
      "    800    16        cutoff              5.0000        3.6654    23393   26.69%\n",
      "\n",
      "Mixed integer rounding cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.00 sec. (977.62 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    2.27 sec. (748.91 ticks)\n",
      "  Sync time (average)   =    0.58 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    3.27 sec. (1726.53 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:25 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:25 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 25 12:46:25 PM: Compilation took 2.546e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:25 PM: Solver (including time spent in interface) took 3.932e+00 seconds\n",
      "Optimal value: 5.0\n",
      "Variable var590310: value [-0.  0. -0. -0.  0. -0.  0. -0. -0. -0. -0.  0.  0. -0. -0. -0.  0.  0.\n",
      "  0.  0. -0.  1.  0.  1.  0.  0. -0.  0.  0.  0. -0.  1. -0. -0.  0. -0.\n",
      " -0. -0.  0.  0. -0.  1.  0.  1. -0.  0. -0.  0.  0. -0.]\n",
      "Tasks: ['PSI_13' 'PSI_15' 'H_COMP_5_A_P' 'OP_35_ED' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:26 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:28 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:28 PM: Finished problem compilation (took 2.358e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:28 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 15.000000 after 0.00 sec. (6.84 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 74867 rows and 1 columns.\n",
      "Reduced MIP has 4375 rows, 49 columns, and 132518 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.24 sec. (264.93 ticks)\n",
      "Probing time = 0.02 sec. (0.66 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 4375 rows, 49 columns, and 132518 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (36.54 ticks)\n",
      "Probing time = 0.01 sec. (0.67 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.08 sec. (75.48 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                            8.0000        0.0000           100.00%\n",
      "      0     0        2.4981    48        8.0000        2.4981      359   68.77%\n",
      "*     0+    0                            6.0000        2.4981            58.36%\n",
      "      0     0        2.5341    48        6.0000      Fract: 1      407   57.77%\n",
      "      0     0        2.5560    46        6.0000      Fract: 1      457   57.40%\n",
      "      0     0        2.5652    47        6.0000    MIRcuts: 1      496   57.25%\n",
      "Detecting symmetries...\n",
      "      0     2        2.5652    47        6.0000        2.7043      496   54.93%\n",
      "Elapsed time = 1.38 sec. (1302.62 ticks, tree = 0.02 MB, solutions = 3)\n",
      "    104    54        2.7380    39        6.0000        2.7043     5019   54.93%\n",
      "*   116    67      integral     0        5.0000        2.7043     5947   45.91%\n",
      "    527    19        3.8402    22        5.0000        2.9169    15218   41.66%\n",
      "\n",
      "Mixed integer rounding cuts applied:  1\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.28 sec. (1295.45 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.34 sec. (562.33 ticks)\n",
      "  Sync time (average)   =    0.46 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.62 sec. (1857.79 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:31 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:31 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 25 12:46:31 PM: Compilation took 2.358e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:31 PM: Solver (including time spent in interface) took 3.252e+00 seconds\n",
      "Optimal value: 5.0\n",
      "Variable var590310: value [ 0.  0. -0. -0.  0. -0. -0. -0. -0. -0. -0.  1.  0.  0.  0. -0.  0. -0.\n",
      " -0.  0.  0.  1. -0.  1.  0.  0. -0.  0.  0.  0. -0. -0. -0. -0.  0. -0.\n",
      " -0.  0. -0.  0. -0.  1.  0.  1. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['MORT_30_PN' 'PSI_13' 'PSI_15' 'OP_35_ED' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 21\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:32 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:32 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:32 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:32 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:32 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:32 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:32 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:32 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:32 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:32 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:34 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:34 PM: Finished problem compilation (took 2.292e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:34 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 15.000000 after 0.01 sec. (6.83 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 75111 rows and 1 columns.\n",
      "Reduced MIP has 4131 rows, 49 columns, and 127645 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.22 sec. (261.44 ticks)\n",
      "Probing time = 0.01 sec. (0.58 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 4131 rows, 49 columns, and 127645 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (35.25 ticks)\n",
      "Probing time = 0.01 sec. (0.58 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (72.28 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "      0     0        2.3650    48        7.0000        2.3650      357   66.21%\n",
      "*     0+    0                            6.0000        2.3650            60.58%\n",
      "      0     0        2.3966    48        6.0000      Fract: 1      415   60.06%\n",
      "*     0+    0                            5.0000        2.3966            52.07%\n",
      "      0     0        2.5827    40        5.0000    MIRcuts: 1      499   48.35%\n",
      "      0     0        2.6426    34        5.0000    MIRcuts: 1      544   47.15%\n",
      "Detecting symmetries...\n",
      "      0     2        2.6426    34        5.0000        2.6426      544   47.15%\n",
      "Elapsed time = 1.05 sec. (1068.97 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     83    22        3.5044    33        5.0000        3.0000     4088   40.00%\n",
      "    614    11        cutoff              5.0000        3.3424    16538   33.15%\n",
      "\n",
      "Mixed integer rounding cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.95 sec. (1063.16 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.20 sec. (489.80 ticks)\n",
      "  Sync time (average)   =    0.41 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.15 sec. (1552.96 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:37 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 25 12:46:37 PM: Compilation took 2.292e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:37 PM: Solver (including time spent in interface) took 2.806e+00 seconds\n",
      "Optimal value: 5.0\n",
      "Variable var590310: value [ 0.  0. -0. -0.  0. -0. -0.  0. -0. -0.  0. -0.  0. -0. -0.  1.  0.  0.\n",
      "  0.  0. -0. -0.  1. -0.  0. -0. -0.  0.  0.  0. -0.  0.  0.  0.  0. -0.\n",
      " -0.  0.  0. -0.  1. -0. -0. -0.  1.  0.  0.  0.  1. -0.]\n",
      "Tasks: ['PSI_06' 'PSI_14' 'OP_35_ADM' 'READM_30_CABG' 'READM_30_HOSP_WIDE']\n",
      "Constructing constraint set for group size 22\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:38 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:40 PM: Finished problem compilation (took 2.376e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:40 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 15.000000 after 0.01 sec. (6.82 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 75365 rows and 1 columns.\n",
      "Reduced MIP has 3877 rows, 49 columns, and 122318 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (257.35 ticks)\n",
      "Probing time = 0.01 sec. (0.51 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 3877 rows, 49 columns, and 122318 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (33.82 ticks)\n",
      "Probing time = 0.01 sec. (0.53 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.08 sec. (71.92 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "      0     0        2.2528    47        7.0000        2.2528      427   67.82%\n",
      "*     0+    0                            6.0000        2.2528            62.45%\n",
      "      0     0        2.2863    47        6.0000      Fract: 1      479   61.90%\n",
      "      0     0        2.3055    46        6.0000      Fract: 1      531   61.57%\n",
      "      0     0        2.3355    44        6.0000    MIRcuts: 1      579   61.08%\n",
      "      0     0        2.3533    43        6.0000    MIRcuts: 1      609   60.78%\n",
      "*     0+    0                            5.0000        2.3533            52.93%\n",
      "Detecting symmetries...\n",
      "      0     2        2.3533    43        5.0000        2.3533      609   52.93%\n",
      "Elapsed time = 1.02 sec. (1125.82 ticks, tree = 0.02 MB, solutions = 4)\n",
      "    187    22        cutoff              5.0000        2.4771     7787   50.46%\n",
      "    823    46        cutoff              5.0000        2.6738    21773   46.52%\n",
      "\n",
      "Mixed integer rounding cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.93 sec. (1119.54 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.53 sec. (549.44 ticks)\n",
      "  Sync time (average)   =    0.46 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.47 sec. (1668.98 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:43 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:43 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 25 12:46:43 PM: Compilation took 2.376e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:43 PM: Solver (including time spent in interface) took 3.140e+00 seconds\n",
      "Optimal value: 5.0\n",
      "Variable var590310: value [-0.  0. -0. -0. -0.  0. -0. -0. -0.  1. -0.  0. -0. -0.  1. -0.  0. -0.\n",
      "  1.  0. -0. -0. -0.  0.  1.  0. -0.  1. -0.  0. -0.  0. -0. -0.  0. -0.\n",
      " -0. -0. -0. -0. -0.  0. -0.  0. -0.  0. -0.  0. -0. -0.]\n",
      "Tasks: ['MORT_30_COPD' 'PSI_04' 'PSI_10' 'PSI_90' 'SEP_1']\n",
      "Constructing constraint set for group size 23\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:43 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:43 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:43 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:43 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:43 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:43 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:43 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:43 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:43 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:43 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:46 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:46 PM: Finished problem compilation (took 2.324e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:46 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 15.000000 after 0.00 sec. (6.81 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 75599 rows and 1 columns.\n",
      "Reduced MIP has 3643 rows, 49 columns, and 117177 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.25 sec. (253.84 ticks)\n",
      "Probing time = 0.02 sec. (0.47 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 3643 rows, 49 columns, and 117177 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (32.47 ticks)\n",
      "Probing time = 0.01 sec. (0.46 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.09 sec. (74.37 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "      0     0        2.1479    48        7.0000        2.1479      419   69.32%\n",
      "*     0+    0                            6.0000        2.1479            64.20%\n",
      "      0     0        2.1761    46        6.0000      Fract: 1      486   63.73%\n",
      "*     0+    0                            5.0000        2.1761            56.48%\n",
      "      0     0        2.1881    47        5.0000      Fract: 1      544   56.24%\n",
      "      0     0        2.2079    45        5.0000    MIRcuts: 1      584   55.84%\n",
      "Detecting symmetries...\n",
      "      0     2        2.2079    45        5.0000        2.2289      584   55.42%\n",
      "Elapsed time = 1.13 sec. (1151.17 ticks, tree = 0.02 MB, solutions = 4)\n",
      "    209    46        3.1420    30        5.0000        2.2289     6199   55.42%\n",
      "    942   199        3.8612    20        5.0000        2.2289    19498   55.42%\n",
      "*  1345   239      integral     0        4.0000        2.2289    26529   44.28%\n",
      "\n",
      "Mixed integer rounding cuts applied:  1\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.07 sec. (1144.99 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    2.10 sec. (665.39 ticks)\n",
      "  Sync time (average)   =    0.53 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    3.17 sec. (1810.38 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:49 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:49 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 12:46:49 PM: Compilation took 2.324e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:49 PM: Solver (including time spent in interface) took 3.675e+00 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var590310: value [ 0.  0.  0. -0.  0.  0. -0. -0. -0.  0.  0.  0.  0.  0. -0.  0. -0.  0.\n",
      " -0. -0. -0.  1.  1.  0. -0. -0.  0.  0.  0. -0.  0.  0.  0. -0.  0. -0.\n",
      "  1. -0.  0.  0.  0.  0.  0. -0. -0.  0.  1.  0.  0.  0.]\n",
      "Tasks: ['PSI_13' 'PSI_14' 'EDAC_30_AMI' 'READM_30_HF']\n",
      "Constructing constraint set for group size 24\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:50 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:50 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:50 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:50 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:50 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:50 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:50 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:50 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:50 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:50 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:52 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:52 PM: Finished problem compilation (took 2.120e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:52 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 13.000000 after 0.00 sec. (6.13 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 75826 rows and 1 columns.\n",
      "Reduced MIP has 3416 rows, 49 columns, and 111961 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (250.94 ticks)\n",
      "Probing time = 0.01 sec. (0.42 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 3416 rows, 49 columns, and 111961 nonzeros.\n",
      "Reduced MIP has 48 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (31.62 ticks)\n",
      "Probing time = 0.02 sec. (0.43 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.07 sec. (64.83 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           13.0000        0.0000           100.00%\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "      0     0        2.0512    46        7.0000        2.0512      349   70.70%\n",
      "*     0+    0                            6.0000        2.0512            65.81%\n",
      "      0     0        2.0856    46        6.0000      Fract: 1      401   65.24%\n",
      "      0     0        2.1058    42        6.0000    MIRcuts: 1      445   64.90%\n",
      "*     0+    0                            5.0000        2.1058            57.88%\n",
      "Detecting symmetries...\n",
      "      0     2        2.1058    42        5.0000        2.1064      445   57.87%\n",
      "Elapsed time = 0.92 sec. (1014.95 ticks, tree = 0.02 MB, solutions = 4)\n",
      "*     8+    2                            4.0000        2.1235            46.91%\n",
      "     78     4        2.5601    22        4.0000        2.4149     4209   39.63%\n",
      "\n",
      "Mixed integer rounding cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.84 sec. (1009.29 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.44 sec. (274.05 ticks)\n",
      "  Sync time (average)   =    0.22 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.28 sec. (1283.35 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:54 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:54 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 12:46:54 PM: Compilation took 2.120e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:54 PM: Solver (including time spent in interface) took 1.923e+00 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var590310: value [-0. -0. -0. -0. -0. -0. -0. -0. -0. -0.  0. -0. -0. -0.  0. -0. -0. -0.\n",
      "  0.  1. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0.  0. -0.  0.  0. -0.\n",
      "  1. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['PSI_11' 'PSI_14' 'EDAC_30_AMI' 'EDAC_30_PN']\n",
      "Constructing constraint set for group size 25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:55 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:55 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:55 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:55 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:55 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:55 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:55 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:55 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:55 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:55 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:46:57 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:46:57 PM: Finished problem compilation (took 2.129e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 11.000000 after 0.00 sec. (5.07 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 76046 rows and 1 columns.\n",
      "Reduced MIP has 3196 rows, 49 columns, and 106688 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.25 sec. (247.32 ticks)\n",
      "Probing time = 0.01 sec. (0.38 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 3196 rows, 49 columns, and 106688 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (31.28 ticks)\n",
      "Probing time = 0.01 sec. (0.39 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.06 sec. (57.90 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           11.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.9647    45        4.0000        1.9647      302   50.88%\n",
      "      0     0        2.0103    43        4.0000      Fract: 1      353   49.74%\n",
      "      0     0        2.0254    45        4.0000      Fract: 1      391   49.37%\n",
      "Detecting symmetries...\n",
      "      0     2        2.0254    45        4.0000        2.0254      391   49.37%\n",
      "Elapsed time = 0.83 sec. (844.23 ticks, tree = 0.02 MB, solutions = 2)\n",
      "    130     6        2.8775    31        4.0000        2.0581     4034   48.55%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.78 sec. (839.13 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.53 sec. (336.32 ticks)\n",
      "  Sync time (average)   =    0.27 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.31 sec. (1175.45 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:59 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:46:59 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 12:46:59 PM: Compilation took 2.129e+00 seconds\n",
      "(CVXPY) Apr 25 12:46:59 PM: Solver (including time spent in interface) took 1.960e+00 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['MORT_30_COPD' 'MORT_30_STK' 'PSI_13' 'EDAC_30_HF']\n",
      "Constructing constraint set for group size 26\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:46:59 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:46:59 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:46:59 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:46:59 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:46:59 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:46:59 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:46:59 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:46:59 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:46:59 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:46:59 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:01 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:01 PM: Finished problem compilation (took 2.054e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:01 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 11.000000 after 0.00 sec. (5.07 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 76259 rows and 1 columns.\n",
      "Reduced MIP has 2983 rows, 49 columns, and 101368 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (243.77 ticks)\n",
      "Probing time = 0.01 sec. (0.37 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2983 rows, 49 columns, and 101368 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (29.75 ticks)\n",
      "Probing time = 0.01 sec. (0.37 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.06 sec. (57.24 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           11.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.8856    46        4.0000        1.8856      298   52.86%\n",
      "      0     0        1.9106    46        4.0000      Fract: 1      349   52.23%\n",
      "      0     0        1.9285    45        4.0000      Fract: 1      401   51.79%\n",
      "Detecting symmetries...\n",
      "      0     2        1.9285    45        4.0000        1.9285      401   51.79%\n",
      "Elapsed time = 0.77 sec. (821.71 ticks, tree = 0.02 MB, solutions = 2)\n",
      "    183    11        cutoff              4.0000        2.0574     4957   48.57%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.71 sec. (816.41 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.59 sec. (393.53 ticks)\n",
      "  Sync time (average)   =    0.29 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.29 sec. (1209.93 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:03 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:03 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 12:47:03 PM: Compilation took 2.054e+00 seconds\n",
      "(CVXPY) Apr 25 12:47:03 PM: Solver (including time spent in interface) took 1.945e+00 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['MORT_30_COPD' 'MORT_30_STK' 'PSI_13' 'EDAC_30_HF']\n",
      "Constructing constraint set for group size 27\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:03 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:03 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:03 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:03 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:03 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:03 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:03 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:03 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:03 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:04 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:05 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:05 PM: Finished problem compilation (took 1.997e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:05 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 10.000000 after 0.00 sec. (4.85 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 76467 rows and 1 columns.\n",
      "Reduced MIP has 2775 rows, 49 columns, and 95965 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.19 sec. (239.95 ticks)\n",
      "Probing time = 0.00 sec. (0.51 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2775 rows, 49 columns, and 95965 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (28.18 ticks)\n",
      "Probing time = 0.01 sec. (0.51 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.05 sec. (56.20 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           10.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.8075    46        4.0000        1.8075      278   54.81%\n",
      "      0     0        1.8405    41        4.0000      Fract: 1      325   53.99%\n",
      "      0     0        1.8559    44        4.0000      Fract: 1      374   53.60%\n",
      "Detecting symmetries...\n",
      "      0     2        1.8559    44        4.0000        1.8559      374   53.60%\n",
      "Elapsed time = 0.76 sec. (830.03 ticks, tree = 0.02 MB, solutions = 2)\n",
      "    341    10        cutoff              4.0000        2.0403     7455   48.99%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.69 sec. (825.06 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.61 sec. (364.24 ticks)\n",
      "  Sync time (average)   =    0.29 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.30 sec. (1189.31 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:07 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:07 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 12:47:07 PM: Compilation took 1.997e+00 seconds\n",
      "(CVXPY) Apr 25 12:47:07 PM: Solver (including time spent in interface) took 1.812e+00 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  1.  1.  0.  0.  0.  0.  1.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['MORT_30_STK' 'EDAC_30_HF' 'EDAC_30_PN' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 28\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:08 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:08 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:08 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:08 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:08 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:08 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:08 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:08 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:08 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:08 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:10 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:10 PM: Finished problem compilation (took 1.948e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:10 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 10.000000 after 0.00 sec. (4.85 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 76668 rows and 1 columns.\n",
      "Reduced MIP has 2574 rows, 49 columns, and 90543 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (235.88 ticks)\n",
      "Probing time = 0.00 sec. (0.41 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2574 rows, 49 columns, and 90543 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (26.60 ticks)\n",
      "Probing time = 0.01 sec. (0.41 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.05 sec. (52.79 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           10.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.7373    47        4.0000        1.7373      291   56.57%\n",
      "      0     0        1.7756    44        4.0000      Fract: 1      347   55.61%\n",
      "      0     0        1.7870    43        4.0000      Fract: 1      401   55.33%\n",
      "Detecting symmetries...\n",
      "      0     2        1.7870    43        4.0000        1.7927      401   55.18%\n",
      "Elapsed time = 0.89 sec. (776.42 ticks, tree = 0.02 MB, solutions = 2)\n",
      "    177    10        2.7408    27        4.0000        1.8045     4629   54.89%\n",
      "*   452+    7                            3.0000        1.8784            37.39%\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.82 sec. (772.23 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.18 sec. (410.38 ticks)\n",
      "  Sync time (average)   =    0.77 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.00 sec. (1182.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:13 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:47:13 PM: Compilation took 1.948e+00 seconds\n",
      "(CVXPY) Apr 25 12:47:13 PM: Solver (including time spent in interface) took 2.461e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [-0.  0.  0. -0.  0. -0. -0. -0. -0.  0.  0.  0.  0.  0. -0. -0.  0. -0.\n",
      "  1. -0. -0.  0.  0. -0.  0. -0.  0. -0. -0. -0. -0. -0.  0. -0. -0. -0.\n",
      " -0. -0.  0.  0. -0.  0. -0.  1. -0.  0.  0. -0.  1. -0.]\n",
      "Tasks: ['PSI_10' 'READM_30_AMI' 'READM_30_HOSP_WIDE']\n",
      "Constructing constraint set for group size 29\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:13 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:13 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:13 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:13 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:13 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:13 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:13 PM: Finished problem compilation (took 3.691e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:13 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 9.000000 after 0.01 sec. (4.43 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 76864 rows and 1 columns.\n",
      "Reduced MIP has 2378 rows, 49 columns, and 85060 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (232.18 ticks)\n",
      "Probing time = 0.00 sec. (0.38 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2378 rows, 49 columns, and 85060 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (25.02 ticks)\n",
      "Probing time = 0.01 sec. (0.38 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.05 sec. (48.78 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.6712    44        4.0000        1.6712      280   58.22%\n",
      "*     0+    0                            3.0000        1.6712            44.29%\n",
      "      0     0        1.8979    26        3.0000      Fract: 1      392   36.74%\n",
      "      0     0        1.8979    23        3.0000      Fract: 1      424   36.74%\n",
      "Detecting symmetries...\n",
      "      0     2        1.8979    23        3.0000        1.8979      424   36.74%\n",
      "Elapsed time = 0.67 sec. (575.69 ticks, tree = 0.02 MB, solutions = 3)\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.60 sec. (572.57 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.21 sec. (112.85 ticks)\n",
      "  Sync time (average)   =    0.11 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.82 sec. (685.42 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:15 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:15 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:47:15 PM: Compilation took 3.691e-01 seconds\n",
      "(CVXPY) Apr 25 12:47:15 PM: Solver (including time spent in interface) took 1.304e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [ 0. -0. -0. -0. -0. -0.  0.  0. -0. -0.  0. -0.  1.  0.  0. -0. -0. -0.\n",
      " -0. -0.  0. -0.  0. -0. -0. -0.  0.  0. -0. -0.  0.  0.  0. -0. -0. -0.\n",
      "  0. -0. -0.  0. -0. -0.  0.  1. -0.  0.  0. -0.  0.  1.]\n",
      "Tasks: ['MORT_30_STK' 'READM_30_AMI' 'READM_30_PN']\n",
      "Constructing constraint set for group size 30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:15 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:15 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:15 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:15 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:15 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:15 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:15 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:15 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:15 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:15 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:17 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:17 PM: Finished problem compilation (took 2.162e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:17 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 9.000000 after 0.00 sec. (4.43 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 77048 rows and 1 columns.\n",
      "Reduced MIP has 2194 rows, 49 columns, and 79728 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.20 sec. (228.74 ticks)\n",
      "Probing time = 0.01 sec. (0.42 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2194 rows, 49 columns, and 79728 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (23.74 ticks)\n",
      "Probing time = 0.01 sec. (0.42 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.05 sec. (44.39 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.6087    43        3.0000        1.6087      264   46.38%\n",
      "      0     0        1.6456    42        3.0000      Fract: 1      329   45.15%\n",
      "      0     0        1.7383    31        3.0000      Fract: 1      421   42.06%\n",
      "Detecting symmetries...\n",
      "      0     2        1.7383    31        3.0000        1.7617      421   41.28%\n",
      "Elapsed time = 0.64 sec. (593.25 ticks, tree = 0.02 MB, solutions = 2)\n",
      "\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.60 sec. (590.26 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.23 sec. (139.04 ticks)\n",
      "  Sync time (average)   =    0.15 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.83 sec. (729.30 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:19 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:19 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:47:19 PM: Compilation took 2.162e+00 seconds\n",
      "(CVXPY) Apr 25 12:47:19 PM: Solver (including time spent in interface) took 1.327e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['MORT_30_STK' 'PSI_13' 'EDAC_30_HF']\n",
      "Constructing constraint set for group size 31\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:19 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:19 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:19 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:19 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:19 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:21 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:21 PM: Finished problem compilation (took 1.906e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:21 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 8.000000 after 0.00 sec. (4.01 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 77235 rows and 1 columns.\n",
      "Reduced MIP has 2007 rows, 49 columns, and 74123 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (203.35 ticks)\n",
      "Probing time = 0.00 sec. (0.39 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2007 rows, 49 columns, and 74123 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (22.09 ticks)\n",
      "Probing time = 0.00 sec. (0.39 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.03 sec. (41.67 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            8.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.5518    44        3.0000        1.5518      262   48.27%\n",
      "      0     0        1.5957    39        3.0000      Fract: 1      302   46.81%\n",
      "      0     0        1.8720    20        3.0000      Fract: 1      340   37.60%\n",
      "Detecting symmetries...\n",
      "      0     2        1.8720    20        3.0000        1.8720      340   37.60%\n",
      "Elapsed time = 0.52 sec. (487.00 ticks, tree = 0.02 MB, solutions = 2)\n",
      "\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.47 sec. (484.49 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.18 sec. (78.12 ticks)\n",
      "  Sync time (average)   =    0.10 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.65 sec. (562.62 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:22 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:22 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:47:22 PM: Compilation took 1.906e+00 seconds\n",
      "(CVXPY) Apr 25 12:47:22 PM: Solver (including time spent in interface) took 1.271e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.]\n",
      "Tasks: ['MORT_30_STK' 'EDAC_30_PN' 'READM_30_HIP_KNEE']\n",
      "Constructing constraint set for group size 32\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:23 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:23 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:23 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:23 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:23 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:47:24 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:47:25 PM: Finished problem compilation (took 1.968e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:25 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 7.000000 after 0.00 sec. (3.82 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 77411 rows and 1 columns.\n",
      "Reduced MIP has 1831 rows, 49 columns, and 68670 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (199.54 ticks)\n",
      "Probing time = 0.01 sec. (0.31 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1831 rows, 49 columns, and 68670 nonzeros.\n",
      "Reduced MIP has 49 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (20.51 ticks)\n",
      "Probing time = 0.01 sec. (0.31 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.03 sec. (37.59 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.4991    42        3.0000        1.4991      244   50.03%\n",
      "      0     0        1.5283    41        3.0000      Fract: 1      295   49.06%\n",
      "      0     0        2.0000    15        3.0000      Fract: 1      339   33.33%\n",
      "Detecting symmetries...\n",
      "      0     2        2.0000    15        3.0000        2.0000      339   33.33%\n",
      "Elapsed time = 0.58 sec. (531.61 ticks, tree = 0.02 MB, solutions = 2)\n",
      "\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.55 sec. (529.53 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.14 sec. (59.73 ticks)\n",
      "  Sync time (average)   =    0.07 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.69 sec. (589.26 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:26 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:47:26 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:47:26 PM: Compilation took 1.968e+00 seconds\n",
      "(CVXPY) Apr 25 12:47:26 PM: Solver (including time spent in interface) took 1.315e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  1.  1.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['MORT_30_STK' 'PSI_03' 'PSI_04']\n",
      "Constructing constraint set for group size 33\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:47:26 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:47:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:47:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:47:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:47:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:47:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:47:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:47:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:47:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:47:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:11 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:11 PM: Finished problem compilation (took 2.246e+02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:11 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 6.000000 after 0.00 sec. (3.12 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 77590 rows and 2 columns.\n",
      "Reduced MIP has 1652 rows, 48 columns, and 61944 nonzeros.\n",
      "Reduced MIP has 48 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.22 sec. (198.79 ticks)\n",
      "Probing time = 0.01 sec. (0.27 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1652 rows, 48 columns, and 61944 nonzeros.\n",
      "Reduced MIP has 48 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (18.52 ticks)\n",
      "Probing time = 0.01 sec. (0.27 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.08 sec. (31.56 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.4548    42        3.0000        1.4548      218   51.51%\n",
      "      0     0        1.4884    32        3.0000      Fract: 1      269   50.39%\n",
      "      0     0        1.5491    24        3.0000      Fract: 1      363   48.36%\n",
      "Detecting symmetries...\n",
      "      0     2        1.5491    24        3.0000        1.8201      363   39.33%\n",
      "Elapsed time = 0.99 sec. (454.20 ticks, tree = 0.02 MB, solutions = 2)\n",
      "\n",
      "Lift and project cuts applied:  1\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.90 sec. (452.15 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.25 sec. (98.91 ticks)\n",
      "  Sync time (average)   =    0.12 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.15 sec. (551.06 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:13 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:51:13 PM: Compilation took 2.246e+02 seconds\n",
      "(CVXPY) Apr 25 12:51:13 PM: Solver (including time spent in interface) took 1.841e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  1.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['MORT_30_STK' 'PSI_04' 'OP_23']\n",
      "Constructing constraint set for group size 34\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:13 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:13 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:13 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:13 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:13 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:17 PM: Finished problem compilation (took 3.106e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:17 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 6.000000 after 0.01 sec. (3.11 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 77770 rows and 3 columns.\n",
      "Reduced MIP has 1472 rows, 47 columns, and 55159 nonzeros.\n",
      "Reduced MIP has 47 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.44 sec. (195.05 ticks)\n",
      "Probing time = 0.00 sec. (0.32 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1472 rows, 47 columns, and 55159 nonzeros.\n",
      "Reduced MIP has 47 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (16.54 ticks)\n",
      "Probing time = 0.01 sec. (0.32 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.05 sec. (25.73 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.4033    39        3.0000        1.4033      189   53.22%\n",
      "      0     0        1.4414    33        3.0000      Fract: 1      233   51.95%\n",
      "      0     0        2.0000    10        3.0000      Fract: 1      262   33.33%\n",
      "Detecting symmetries...\n",
      "      0     2        2.0000    10        3.0000        2.0000      262   33.33%\n",
      "Elapsed time = 0.96 sec. (421.86 ticks, tree = 0.02 MB, solutions = 2)\n",
      "\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.91 sec. (420.35 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.18 sec. (35.95 ticks)\n",
      "  Sync time (average)   =    0.09 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.09 sec. (456.30 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:18 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 12:51:18 PM: Compilation took 3.106e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:18 PM: Solver (including time spent in interface) took 1.698e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var590310: value [ 1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  1.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.\n",
      "  0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_STK' 'PSI_04']\n",
      "Constructing constraint set for group size 35\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:19 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:19 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:19 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:19 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:19 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:22 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:22 PM: Finished problem compilation (took 2.658e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:22 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 6.000000 after 0.00 sec. (3.11 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 77957 rows and 6 columns.\n",
      "Reduced MIP has 1285 rows, 44 columns, and 46758 nonzeros.\n",
      "Reduced MIP has 44 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (209.18 ticks)\n",
      "Probing time = 0.00 sec. (0.26 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1285 rows, 44 columns, and 46758 nonzeros.\n",
      "Reduced MIP has 44 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (13.96 ticks)\n",
      "Probing time = 0.00 sec. (0.26 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.03 sec. (22.82 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.3623    35        2.0000        1.3623      205   31.88%\n",
      "      0     0        cutoff              2.0000        1.3623      205   31.88%\n",
      "Elapsed time = 0.31 sec. (264.67 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.31 sec. (264.67 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.31 sec. (264.67 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:23 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:23 PM: Compilation took 2.658e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:23 PM: Solver (including time spent in interface) took 8.296e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [ 1.  0.  0.  0.  0.  0.  0.  0. -0.  0.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_STK']\n",
      "Constructing constraint set for group size 36\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:23 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:23 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:23 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:23 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:23 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:26 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:26 PM: Finished problem compilation (took 3.157e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:26 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 6.000000 after 0.00 sec. (3.10 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 78118 rows and 6 columns.\n",
      "Reduced MIP has 1124 rows, 44 columns, and 41492 nonzeros.\n",
      "Reduced MIP has 44 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.20 sec. (204.16 ticks)\n",
      "Probing time = 0.00 sec. (0.18 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1124 rows, 44 columns, and 41492 nonzeros.\n",
      "Reduced MIP has 44 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (12.35 ticks)\n",
      "Probing time = 0.00 sec. (0.18 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.02 sec. (20.38 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.3228    36        2.0000        1.3228      189   33.86%\n",
      "      0     0        cutoff              2.0000        1.3228      189   33.86%\n",
      "Elapsed time = 0.28 sec. (253.77 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.29 sec. (253.77 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.29 sec. (253.77 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:27 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:27 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:27 PM: Compilation took 3.157e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:27 PM: Solver (including time spent in interface) took 8.338e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [ 1.  0.  0.  0.  0.  0.  0.  0. -0.  0.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_STK']\n",
      "Constructing constraint set for group size 37\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:27 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:27 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:27 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:27 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:27 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:27 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:27 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:27 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:27 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:28 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:30 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:30 PM: Finished problem compilation (took 2.980e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:30 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 5.000000 after 0.00 sec. (3.01 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79086 rows and 6 columns.\n",
      "Reduced MIP has 156 rows, 44 columns, and 5397 nonzeros.\n",
      "Reduced MIP has 44 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.48 sec. (193.36 ticks)\n",
      "Probing time = 0.00 sec. (0.07 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 156 rows, 44 columns, and 5397 nonzeros.\n",
      "Reduced MIP has 44 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (1.99 ticks)\n",
      "Probing time = 0.00 sec. (0.07 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (3.55 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            5.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.2785    36        2.0000        1.2785      145   36.08%\n",
      "      0     0        cutoff              2.0000        1.2785      145   36.08%\n",
      "Elapsed time = 0.53 sec. (204.17 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.53 sec. (204.17 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.53 sec. (204.17 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:32 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:32 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:32 PM: Compilation took 2.980e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:32 PM: Solver (including time spent in interface) took 1.078e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [ 1.  0.  0.  0.  0.  0.  0.  0. -0.  0.  0.  0.  1.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'MORT_30_STK']\n",
      "Constructing constraint set for group size 38\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:32 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:32 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:32 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:32 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:32 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:32 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:32 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:32 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:32 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:32 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:34 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:34 PM: Finished problem compilation (took 2.109e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:34 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 4.000000 after 0.00 sec. (2.78 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79092 rows and 7 columns.\n",
      "Reduced MIP has 150 rows, 43 columns, and 5216 nonzeros.\n",
      "Reduced MIP has 43 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.42 sec. (187.35 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 150 rows, 43 columns, and 5216 nonzeros.\n",
      "Reduced MIP has 43 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (2.12 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (2.58 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.2354    30        2.0000        1.2354      111   38.23%\n",
      "      0     0        cutoff              2.0000        1.2354      111   38.23%\n",
      "Elapsed time = 0.45 sec. (197.00 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.45 sec. (197.00 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.45 sec. (197.00 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:35 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:35 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:35 PM: Compilation took 2.109e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:35 PM: Solver (including time spent in interface) took 1.118e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [ 0.  0.  0.  0.  0.  0. -0.  0. -0.  0.  0.  0.  0.  1.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  1.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['PSI_03' 'OP_36']\n",
      "Constructing constraint set for group size 39\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:36 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:36 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:36 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:36 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:36 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:36 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:38 PM: Finished problem compilation (took 2.360e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:38 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 3.000000 after 0.00 sec. (2.12 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79106 rows and 8 columns.\n",
      "Reduced MIP has 136 rows, 42 columns, and 4787 nonzeros.\n",
      "Reduced MIP has 42 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.43 sec. (180.41 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 136 rows, 42 columns, and 4787 nonzeros.\n",
      "Reduced MIP has 42 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (1.97 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (2.04 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.1964    31        2.0000        1.1964       87   40.18%\n",
      "      0     0        cutoff              2.0000        1.1964       87   40.18%\n",
      "Elapsed time = 0.47 sec. (188.59 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.48 sec. (188.59 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.48 sec. (188.59 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:39 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:39 PM: Compilation took 2.360e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:39 PM: Solver (including time spent in interface) took 1.197e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [ 1.  0.  1. -0.  0.  0. -0.  0. -0.  0.  0.  0.  0.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_3_SIR']\n",
      "Constructing constraint set for group size 40\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:40 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:42 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:43 PM: Finished problem compilation (took 2.744e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:43 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 3.000000 after 0.00 sec. (2.12 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79128 rows and 9 columns.\n",
      "Reduced MIP has 114 rows, 41 columns, and 3998 nonzeros.\n",
      "Reduced MIP has 41 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.50 sec. (189.83 ticks)\n",
      "Probing time = 0.00 sec. (0.05 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 114 rows, 41 columns, and 3998 nonzeros.\n",
      "Reduced MIP has 41 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (1.54 ticks)\n",
      "Probing time = 0.00 sec. (0.05 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (1.59 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.1611    29        2.0000        1.1611       79   41.94%\n",
      "      0     0        cutoff              2.0000        1.1611       79   41.94%\n",
      "Elapsed time = 0.53 sec. (196.85 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.53 sec. (196.86 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.53 sec. (196.86 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:44 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:44 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:44 PM: Compilation took 2.744e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:44 PM: Solver (including time spent in interface) took 1.238e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [ 1.  0.  1. -0.  0.  0. -0.  0. -0.  0.  0.  0.  0.  0.  0. -0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_3_SIR']\n",
      "Constructing constraint set for group size 41\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:45 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:45 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:45 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:45 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:45 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:45 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:45 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:45 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:45 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:45 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:47 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:47 PM: Finished problem compilation (took 2.286e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:47 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 3.000000 after 0.00 sec. (2.11 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79173 rows and 21 columns.\n",
      "Reduced MIP has 69 rows, 29 columns, and 1765 nonzeros.\n",
      "Reduced MIP has 29 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.36 sec. (181.14 ticks)\n",
      "Probing time = 0.00 sec. (0.02 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 69 rows, 29 columns, and 1765 nonzeros.\n",
      "Reduced MIP has 29 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (0.71 ticks)\n",
      "Probing time = 0.00 sec. (0.02 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (0.63 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.1121    25        2.0000        1.1121       47   44.40%\n",
      "      0     0        cutoff              2.0000        1.1121       47   44.40%\n",
      "Elapsed time = 0.40 sec. (185.61 ticks, tree = 0.01 MB, solutions = 1)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.40 sec. (185.61 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.40 sec. (185.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:48 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:48 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 12:51:48 PM: Compilation took 2.286e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:48 PM: Solver (including time spent in interface) took 9.215e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var590310: value [-0. -0.  1. -0.  0. -0. -0.  1. -0. -0.  0. -0.  0.  0.  0. -0.  0. -0.\n",
      "  0.  0.  0.  0. -0. -0. -0. -0.  0.  0.  0.  0.  0.  0.  0.  0. -0. -0.\n",
      " -0.  0.  0.  0.  0. -0.  0.  0. -0. -0.  0.  0. -0.  0.]\n",
      "Tasks: ['HAI_3_SIR' 'MORT_30_AMI']\n",
      "Constructing constraint set for group size 42\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:49 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:49 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:49 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:49 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:49 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:49 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:49 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:49 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:49 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:49 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:51 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:51 PM: Finished problem compilation (took 2.163e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:51 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 3.000000 after 0.00 sec. (2.11 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.33 sec. (153.27 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.34 sec. (155.61 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.34 sec. (155.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:52 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:52 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:51:52 PM: Compilation took 2.163e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:52 PM: Solver (including time spent in interface) took 8.629e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [-0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['OP_36']\n",
      "Constructing constraint set for group size 43\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:53 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:53 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:53 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:53 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:53 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:53 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:53 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:53 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:53 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:53 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:55 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:55 PM: Finished problem compilation (took 2.655e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:55 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 2.000000 after 0.00 sec. (1.73 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.29 sec. (150.35 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.30 sec. (152.31 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.30 sec. (152.31 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:56 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:51:56 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:51:56 PM: Compilation took 2.655e+00 seconds\n",
      "(CVXPY) Apr 25 12:51:56 PM: Solver (including time spent in interface) took 8.291e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [-0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['MORT_30_STK']\n",
      "Constructing constraint set for group size 44\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:51:57 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:51:57 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:51:57 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:51:57 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:51:57 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:57 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:51:57 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:51:57 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:51:57 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:51:57 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:51:59 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:51:59 PM: Finished problem compilation (took 2.277e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:51:59 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 2.000000 after 0.00 sec. (1.73 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.23 sec. (149.00 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.23 sec. (150.96 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.23 sec. (150.96 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:00 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:52:00 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:52:00 PM: Compilation took 2.277e+00 seconds\n",
      "(CVXPY) Apr 25 12:52:00 PM: Solver (including time spent in interface) took 7.668e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [-0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_3_SIR']\n",
      "Constructing constraint set for group size 45\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:52:01 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:52:01 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:52:01 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:52:01 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:52:01 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:01 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:52:01 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:52:01 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:52:01 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:52:01 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:52:03 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:52:03 PM: Finished problem compilation (took 2.289e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:03 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 1.000000 after 0.00 sec. (1.28 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.20 sec. (152.95 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.22 sec. (154.46 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.22 sec. (154.46 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:04 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:52:04 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:52:04 PM: Compilation took 2.289e+00 seconds\n",
      "(CVXPY) Apr 25 12:52:04 PM: Solver (including time spent in interface) took 8.801e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR']\n",
      "Constructing constraint set for group size 46\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:52:05 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:52:05 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:52:05 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:52:05 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:52:05 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:05 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:52:05 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:52:05 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:52:05 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:52:05 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:52:07 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:52:07 PM: Finished problem compilation (took 1.909e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:07 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 1.000000 after 0.00 sec. (1.28 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.15 sec. (154.50 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (156.01 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.16 sec. (156.01 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:08 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:52:08 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:52:08 PM: Compilation took 1.909e+00 seconds\n",
      "(CVXPY) Apr 25 12:52:08 PM: Solver (including time spent in interface) took 8.198e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR']\n",
      "Constructing constraint set for group size 47\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:52:08 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:52:08 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:52:08 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:52:08 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:52:08 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:08 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:52:08 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:52:08 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:52:08 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:52:08 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:52:09 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:52:10 PM: Finished problem compilation (took 1.614e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:10 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 1.000000 after 0.00 sec. (1.28 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.11 sec. (162.48 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (163.99 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (163.99 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:10 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:52:10 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:52:10 PM: Compilation took 1.614e+00 seconds\n",
      "(CVXPY) Apr 25 12:52:10 PM: Solver (including time spent in interface) took 7.716e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR']\n",
      "Constructing constraint set for group size 48\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:52:11 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:52:11 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:52:11 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:52:11 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:52:11 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:11 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:52:11 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:52:11 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:52:11 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:52:11 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:52:12 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:52:13 PM: Finished problem compilation (took 1.649e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:13 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 1.000000 after 0.00 sec. (1.28 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.10 sec. (167.96 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.11 sec. (169.47 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.11 sec. (169.47 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:52:13 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:52:13 PM: Compilation took 1.649e+00 seconds\n",
      "(CVXPY) Apr 25 12:52:13 PM: Solver (including time spent in interface) took 6.089e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR']\n",
      "Constructing constraint set for group size 49\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 12:52:14 PM: Your problem has 50 variables, 79242 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 12:52:14 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 12:52:14 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 12:52:14 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 12:52:14 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:14 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 12:52:14 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 12:52:14 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 12:52:14 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 12:52:14 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 12:52:15 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 12:52:16 PM: Finished problem compilation (took 1.531e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:16 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "Found incumbent of value 1.000000 after 0.00 sec. (1.35 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79242 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.09 sec. (174.74 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.10 sec. (176.32 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.10 sec. (176.32 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 12:52:16 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 12:52:16 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 12:52:16 PM: Compilation took 1.531e+00 seconds\n",
      "(CVXPY) Apr 25 12:52:16 PM: Solver (including time spent in interface) took 6.142e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var590310: value [1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR']\n"
     ]
    }
   ],
   "source": [
    "hq_ranks_df = selection_algorithms.scores_to_ranks(hq_df, all_tasks)\n",
    "group_sizes = range(1, len(all_tasks))\n",
    "outputs_pr = selection_algorithms.solve_lp_pr(hq_ranks_df, all_tasks, group_sizes=group_sizes)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7ffa4e5a-753c-44e8-b3b2-22c5ab3bb9b6",
   "metadata": {},
   "source": [
    "## IP Augmented"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "1488864f-1962-49b4-8496-cb421289b7a1",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Constructing constraint set for group size 1\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:17:55 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:17:55 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:17:55 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:17:55 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:17:55 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:17:55 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:17:55 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:17:55 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:17:55 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:17:55 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:17:58 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:17:58 PM: Finished problem compilation (took 2.597e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:17:58 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n",
      "Found incumbent of value 50.000000 after 0.01 sec. (18.30 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.07 sec. (92.51 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.09 sec. (111.03 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.09 sec. (111.03 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:17:58 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:17:58 PM: Optimal value: 5.000e+01\n",
      "(CVXPY) Apr 24 11:17:58 PM: Compilation took 2.597e+00 seconds\n",
      "(CVXPY) Apr 24 11:17:58 PM: Solver (including time spent in interface) took 6.268e-01 seconds\n",
      "Optimal value: 50.0\n",
      "Variable var423709: value [1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF'\n",
      " 'MORT_30_PN' 'MORT_30_STK' 'PSI_03' 'PSI_04' 'PSI_06' 'PSI_08' 'PSI_09'\n",
      " 'PSI_10' 'PSI_11' 'PSI_12' 'PSI_13' 'PSI_14' 'PSI_15' 'PSI_90' 'OP_23'\n",
      " 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_6_Y_P' 'H_COMP_7_SA' 'ePC_07a' 'ePC_07b'\n",
      " 'EDAC_30_AMI' 'EDAC_30_HF' 'EDAC_30_PN' 'OP_32' 'OP_35_ADM' 'OP_35_ED'\n",
      " 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 2\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:17:59 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:17:59 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:17:59 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:17:59 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:17:59 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:17:59 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:17:59 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:17:59 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:17:59 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:17:59 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:02 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:02 PM: Finished problem compilation (took 3.528e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:02 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n",
      "Found incumbent of value 47.000000 after 0.01 sec. (17.89 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 78307 rows and 13 columns.\n",
      "MIP Presolve modified 7383 coefficients.\n",
      "Reduced MIP has 936 rows, 37 columns, and 8651 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.42 sec. (429.46 ticks)\n",
      "Probing time = 0.00 sec. (2.42 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "MIP Presolve eliminated 251 rows and 0 columns.\n",
      "MIP Presolve modified 185 coefficients.\n",
      "Reduced MIP has 685 rows, 37 columns, and 5651 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (10.35 ticks)\n",
      "Probing time = 0.00 sec. (1.55 ticks)\n",
      "Clique table members: 83.\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.02 sec. (7.80 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           47.0000       13.0000            72.34%\n",
      "*     0+    0                           40.0000       13.0000            67.50%\n",
      "      0     0       35.1667    35       40.0000       35.1667      192   12.08%\n",
      "*     0+    0                           39.0000       35.1667             9.83%\n",
      "      0     0       36.0000    34       39.0000      Cuts: 32      219    7.69%\n",
      "      0     0       36.0000    35       39.0000      Cuts: 16      234    7.69%\n",
      "      0     0       36.0000    28       39.0000       Cuts: 4      250    7.69%\n",
      "      0     0       36.0000    33       39.0000      Cuts: 37      283    7.69%\n",
      "      0     0        cutoff             39.0000       39.0000      283    0.00%\n",
      "Elapsed time = 0.67 sec. (550.20 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Clique cuts applied:  1\n",
      "Implied bound cuts applied:  4\n",
      "Zero-half cuts applied:  10\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.69 sec. (550.22 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.69 sec. (550.22 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:04 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:04 PM: Optimal value: 3.900e+01\n",
      "(CVXPY) Apr 24 11:18:04 PM: Compilation took 3.528e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:04 PM: Solver (including time spent in interface) took 1.499e+00 seconds\n",
      "Optimal value: 39.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1.  1.  0.  1.  1.  1.  1.  1.  0. -0.  1.  1.  1.\n",
      "  0.  1.  1.  0.  1.  1.  1.  1.  0.  1.  1.  1.  1.  1.  0.  1.  1. -0.\n",
      "  1.  0.  1.  0.  1.  1.  1.  1.  1.  1.  1.  1.  1.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF' 'MORT_30_PN'\n",
      " 'MORT_30_STK' 'PSI_06' 'PSI_08' 'PSI_09' 'PSI_11' 'PSI_12' 'PSI_14'\n",
      " 'PSI_15' 'PSI_90' 'OP_23' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'ePC_07a' 'EDAC_30_AMI'\n",
      " 'EDAC_30_PN' 'OP_35_ADM' 'OP_35_ED' 'OP_36' 'READM_30_AMI'\n",
      " 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF' 'READM_30_HIP_KNEE'\n",
      " 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 3\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:05 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:05 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:05 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:05 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:05 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:05 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:05 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:05 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:05 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:05 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:08 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:08 PM: Finished problem compilation (took 3.028e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:08 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n",
      "Found incumbent of value 40.000000 after 0.02 sec. (15.56 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 74747 rows and 13 columns.\n",
      "Reduced MIP has 4496 rows, 37 columns, and 78107 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (242.00 ticks)\n",
      "Probing time = 0.01 sec. (1.25 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 4496 rows, 37 columns, and 78107 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (23.64 ticks)\n",
      "Probing time = 0.01 sec. (1.25 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.05 sec. (32.26 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           40.0000       12.0000            70.00%\n",
      "*     0+    0                           34.0000       12.0000            64.71%\n",
      "      0     0       24.6667    37       34.0000       24.6667      217   27.45%\n",
      "*     0+    0                           32.0000       24.6667            22.92%\n",
      "*     0+    0                           30.0000       24.6667            17.78%\n",
      "      0     0        cutoff             30.0000       30.0000      250    0.00%\n",
      "Elapsed time = 0.97 sec. (1175.31 ticks, tree = 0.01 MB, solutions = 4)\n",
      "\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.99 sec. (1175.54 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.99 sec. (1175.54 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:09 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:09 PM: Optimal value: 3.000e+01\n",
      "(CVXPY) Apr 24 11:18:09 PM: Compilation took 3.028e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:09 PM: Solver (including time spent in interface) took 1.688e+00 seconds\n",
      "Optimal value: 30.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  1.  1.  0.  0.  1.  0.  1.  0.  0.  1.  0.  1.\n",
      "  1.  0.  1.  0.  1.  0.  1.  0.  0.  1.  1.  1.  1.  1. -0.  1.  1. -0.\n",
      "  1.  1.  0.  1.  0.  1.  0. -0.  1.  1.  0.  0.  1.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_HF' 'MORT_30_STK' 'PSI_06'\n",
      " 'PSI_09' 'PSI_10' 'PSI_12' 'PSI_14' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P'\n",
      " 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'ePC_07a'\n",
      " 'EDAC_30_AMI' 'EDAC_30_HF' 'OP_32' 'OP_35_ED' 'READM_30_CABG'\n",
      " 'READM_30_COPD' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 4\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:10 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:10 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:10 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:10 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:10 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:13 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:13 PM: Finished problem compilation (took 2.838e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:13 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n",
      "Found incumbent of value 35.000000 after 0.01 sec. (13.88 ticks)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 78889 rows and 13 columns.\n",
      "Reduced MIP has 354 rows, 37 columns, and 3598 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.24 sec. (205.00 ticks)\n",
      "Probing time = 0.00 sec. (0.17 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 354 rows, 37 columns, and 3598 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (1.32 ticks)\n",
      "Probing time = 0.00 sec. (0.17 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.02 sec. (4.69 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           35.0000       12.0000            65.71%\n",
      "*     0+    0                           29.0000       12.0000            58.62%\n",
      "      0     0       21.5000    36       29.0000       21.5000      158   25.86%\n",
      "*     0+    0                           26.0000       21.5000            17.31%\n",
      "      0     0       21.7024    36       26.0000      Cuts: 15      196   16.53%\n",
      "      0     0       21.9073    36       26.0000       Cuts: 2      237   15.74%\n",
      "      0     0       21.9547    36       26.0000   ZeroHalf: 3      258   15.56%\n",
      "      0     0       21.9701    36       26.0000   ZeroHalf: 1      271   15.50%\n",
      "      0     0       21.9742    36       26.0000   ZeroHalf: 1      282   15.48%\n",
      "Detecting symmetries...\n",
      "      0     0       21.9795    36       26.0000   ZeroHalf: 1      296   15.46%\n",
      "      0     0       21.9826    36       26.0000   ZeroHalf: 1      311   15.45%\n",
      "      0     0       21.9915    36       26.0000   ZeroHalf: 1      330   15.42%\n",
      "      0     0       21.9956    36       26.0000   ZeroHalf: 1      348   15.40%\n",
      "      0     0       22.0002    36       26.0000   ZeroHalf: 1      367   15.38%\n",
      "      0     0       22.0015    36       26.0000   ZeroHalf: 1      385   15.38%\n",
      "      0     0       22.0055    36       26.0000   ZeroHalf: 1      409   15.36%\n",
      "      0     0       22.0065    36       26.0000   ZeroHalf: 1      418   15.36%\n",
      "*     0+    0                           25.0000       22.0065            11.97%\n",
      "      0     0        cutoff             25.0000       25.0000      418    0.00%\n",
      "Elapsed time = 0.42 sec. (311.06 ticks, tree = 0.01 MB, solutions = 4)\n",
      "\n",
      "Zero-half cuts applied:  12\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.43 sec. (311.06 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.43 sec. (311.06 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:14 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:14 PM: Optimal value: 2.500e+01\n",
      "(CVXPY) Apr 24 11:18:14 PM: Compilation took 2.838e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:14 PM: Solver (including time spent in interface) took 1.177e+00 seconds\n",
      "Optimal value: 25.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  0.  0.  1.  1. -0.  1.  1. -0. -0. -0.  1.  1.\n",
      "  1.  0.  1. -0. -0.  1.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1.  0. -0.\n",
      " -0. -0.  1.  1. -0.  0. -0. -0.  0. -0.  0.  0.  1.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_PN' 'MORT_30_STK' 'PSI_08'\n",
      " 'PSI_09' 'PSI_10' 'PSI_12' 'PSI_15' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P'\n",
      " 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'EDAC_30_PN'\n",
      " 'OP_32' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for group size 5\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:15 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:15 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:15 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:15 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:15 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:15 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:15 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:15 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:15 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:15 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:18 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:19 PM: Finished problem compilation (took 3.837e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:19 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79024 rows and 13 columns.\n",
      "Reduced MIP has 219 rows, 37 columns, and 2132 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.27 sec. (169.12 ticks)\n",
      "Found incumbent of value 33.000000 after 0.29 sec. (188.46 ticks)\n",
      "Probing time = 0.00 sec. (0.10 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 219 rows, 37 columns, and 2132 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.82 ticks)\n",
      "Probing time = 0.00 sec. (0.10 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (1.96 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           33.0000       12.0000            63.64%\n",
      "*     0+    0                           27.0000       12.0000            55.56%\n",
      "      0     0       19.6000    37       27.0000       19.6000       88   27.41%\n",
      "*     0+    0                           25.0000       19.6000            21.60%\n",
      "      0     0       19.7476    36       25.0000       Cuts: 4      115   21.01%\n",
      "*     0+    0                           24.0000       19.7476            17.72%\n",
      "      0     0       19.8367    36       24.0000       Cuts: 2      142   17.35%\n",
      "      0     0       19.8487    36       24.0000   ZeroHalf: 1      154   17.30%\n",
      "      0     0       19.8588    36       24.0000   ZeroHalf: 2      165   17.26%\n",
      "      0     0       19.8734    35       24.0000   ZeroHalf: 1      184   17.19%\n",
      "Detecting symmetries...\n",
      "      0     0       19.8786    36       24.0000   ZeroHalf: 1      198   17.17%\n",
      "*     0+    0                           23.0000       19.8786            13.57%\n",
      "      0     0       19.8825    36       23.0000   ZeroHalf: 2      210   13.55%\n",
      "      0     0       19.8854    36       23.0000   ZeroHalf: 1      226   13.54%\n",
      "      0     0       19.8901    36       23.0000   ZeroHalf: 1      244   13.52%\n",
      "      0     0       19.8962    35       23.0000   ZeroHalf: 1      255   13.49%\n",
      "      0     0       19.9076    36       23.0000   ZeroHalf: 1      272   13.45%\n",
      "      0     0       19.9132    36       23.0000   ZeroHalf: 1      286   13.42%\n",
      "      0     0       19.9154    36       23.0000   ZeroHalf: 1      295   13.41%\n",
      "      0     0       19.9207    36       23.0000   ZeroHalf: 1      312   13.39%\n",
      "      0     0       19.9263    36       23.0000   ZeroHalf: 1      331   13.36%\n",
      "      0     0       19.9369    36       23.0000   ZeroHalf: 1      345   13.32%\n",
      "      0     0       19.9425    35       23.0000   ZeroHalf: 1      367   13.29%\n",
      "      0     0       19.9479    35       23.0000   ZeroHalf: 1      382   13.27%\n",
      "      0     0       19.9516    36       23.0000   ZeroHalf: 1      395   13.25%\n",
      "      0     0        cutoff             23.0000       23.0000      395    0.00%\n",
      "Elapsed time = 0.43 sec. (262.32 ticks, tree = 0.01 MB, solutions = 5)\n",
      "\n",
      "Zero-half cuts applied:  12\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.43 sec. (262.32 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.43 sec. (262.32 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:20 PM: Optimal value: 2.300e+01\n",
      "(CVXPY) Apr 24 11:18:20 PM: Compilation took 3.837e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:20 PM: Solver (including time spent in interface) took 9.925e-01 seconds\n",
      "Optimal value: 23.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1. -0.  0.  0.  1.  0.  1.  1.  0. -0. -0.  0.  1.\n",
      "  1. -0. -0. -0.  1.  0.  1.  1.  0.  1.  1.  1.  1.  1. -0.  1.  0. -0.\n",
      "  1. -0.  0.  0.  0. -0.  0. -0.  1.  0.  1.  0. -0.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_COPD' 'MORT_30_PN' 'MORT_30_STK' 'PSI_09' 'PSI_10' 'PSI_14'\n",
      " 'PSI_90' 'OP_23' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA' 'EDAC_30_AMI' 'READM_30_CABG' 'READM_30_HF'\n",
      " 'READM_30_PN']\n",
      "Constructing constraint set for group size 6\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:20 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:20 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:20 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:20 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:20 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:20 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:20 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:20 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:20 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:20 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:23 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:23 PM: Finished problem compilation (took 3.048e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:23 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79102 rows and 13 columns.\n",
      "Reduced MIP has 141 rows, 37 columns, and 1348 nonzeros.\n",
      "Reduced MIP has 37 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.23 sec. (162.28 ticks)\n",
      "Found incumbent of value 30.000000 after 0.25 sec. (180.74 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 141 rows, 37 columns, and 1348 nonzeros.\n",
      "Reduced MIP has 37 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.56 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (1.37 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           30.0000       12.0000            60.00%\n",
      "*     0+    0                           24.0000       12.0000            50.00%\n",
      "*     0+    0                           23.0000       12.0000            47.83%\n",
      "*     0+    0                           22.0000       12.0000            45.45%\n",
      "      0     0       18.1898    36       22.0000       18.1898       77   17.32%\n",
      "      0     0       18.2982    35       22.0000   ZeroHalf: 1       93   16.83%\n",
      "      0     0       18.3488    35       22.0000      Fract: 1      119   16.60%\n",
      "*     0+    0                           21.0000       18.3488            12.62%\n",
      "      0     0       18.3787    35       21.0000   ZeroHalf: 1      142   12.48%\n",
      "      0     0       18.4068    35       21.0000   ZeroHalf: 1      162   12.35%\n",
      "      0     0       18.4208    35       21.0000   ZeroHalf: 1      176   12.28%\n",
      "Detecting symmetries...\n",
      "      0     0       18.4274    35       21.0000   ZeroHalf: 1      193   12.25%\n",
      "      0     0       18.4293    34       21.0000   ZeroHalf: 1      203   12.24%\n",
      "      0     0       18.4347    35       21.0000   ZeroHalf: 1      217   12.22%\n",
      "      0     0       18.4359    35       21.0000   ZeroHalf: 1      230   12.21%\n",
      "      0     0       18.4371    34       21.0000   ZeroHalf: 1      241   12.20%\n",
      "      0     0        cutoff             21.0000       21.0000      241    0.00%\n",
      "Elapsed time = 0.33 sec. (213.01 ticks, tree = 0.01 MB, solutions = 5)\n",
      "\n",
      "Zero-half cuts applied:  9\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.33 sec. (213.01 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.33 sec. (213.01 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:24 PM: Optimal value: 2.100e+01\n",
      "(CVXPY) Apr 24 11:18:24 PM: Compilation took 3.048e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:24 PM: Solver (including time spent in interface) took 1.021e+00 seconds\n",
      "Optimal value: 21.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1.  1. -0. -0. -0.  1.  0.  0. -0.  1.  1.  0.  0.\n",
      "  1.  0. -0. -0.  0. -0.  1.  0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  1.  0. -0. -0. -0.  1.  0. -0.  0.  1. -0.  0. -0.  1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_HF' 'PSI_04' 'PSI_06' 'PSI_10' 'PSI_90' 'SEP_1'\n",
      " 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA'\n",
      " 'EDAC_30_AMI' 'OP_35_ED' 'READM_30_COPD' 'READM_30_PN']\n",
      "Constructing constraint set for group size 7\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:25 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:25 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:25 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:25 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:25 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:25 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:25 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:25 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:25 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:25 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:28 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:28 PM: Finished problem compilation (took 3.295e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:28 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79135 rows and 13 columns.\n",
      "Reduced MIP has 108 rows, 37 columns, and 1085 nonzeros.\n",
      "Reduced MIP has 37 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.19 sec. (158.96 ticks)\n",
      "Found incumbent of value 29.000000 after 0.20 sec. (177.15 ticks)\n",
      "Probing time = 0.00 sec. (0.05 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 108 rows, 37 columns, and 1085 nonzeros.\n",
      "Reduced MIP has 37 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.47 ticks)\n",
      "Probing time = 0.00 sec. (0.05 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (1.21 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           29.0000       12.0000            58.62%\n",
      "*     0+    0                           23.0000       12.0000            47.83%\n",
      "*     0+    0                           21.0000       12.0000            42.86%\n",
      "*     0+    0                           20.0000       12.0000            40.00%\n",
      "      0     0       17.2058    34       20.0000       17.2058       74   13.97%\n",
      "      0     0       17.3054    32       20.0000       Cuts: 2       96   13.47%\n",
      "      0     0       17.3377    31       20.0000      Fract: 1      126   13.31%\n",
      "      0     0       17.3561    33       20.0000   ZeroHalf: 1      143   13.22%\n",
      "      0     0       17.3614    33       20.0000   ZeroHalf: 1      155   13.19%\n",
      "      0     0       17.3727    29       20.0000       Cuts: 2      172   13.14%\n",
      "Detecting symmetries...\n",
      "      0     0       17.3794    28       20.0000   ZeroHalf: 1      182   13.10%\n",
      "      0     0       17.3819    30       20.0000   ZeroHalf: 1      192   13.09%\n",
      "      0     0       17.3948    31       20.0000   ZeroHalf: 1      205   13.03%\n",
      "      0     0       17.4055    30       20.0000   ZeroHalf: 1      220   12.97%\n",
      "      0     0       17.4142    31       20.0000   ZeroHalf: 1      229   12.93%\n",
      "      0     0       17.4167    30       20.0000   ZeroHalf: 1      236   12.92%\n",
      "      0     0       17.4188    31       20.0000   ZeroHalf: 1      249   12.91%\n",
      "      0     0       17.4240    30       20.0000   ZeroHalf: 1      261   12.88%\n",
      "*     0+    0                           19.0000       17.4240             8.29%\n",
      "      0     0       17.4284    31       19.0000   ZeroHalf: 1      272    8.27%\n",
      "      0     0       17.4325    32       19.0000   ZeroHalf: 1      286    8.25%\n",
      "      0     0       17.4359    33       19.0000   ZeroHalf: 1      297    8.23%\n",
      "      0     0       17.4368    30       19.0000   ZeroHalf: 1      305    8.23%\n",
      "      0     0        cutoff             19.0000       19.0000      305    0.00%\n",
      "Elapsed time = 0.30 sec. (211.53 ticks, tree = 0.01 MB, solutions = 5)\n",
      "\n",
      "Zero-half cuts applied:  11\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.30 sec. (211.54 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.30 sec. (211.54 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:29 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:29 PM: Optimal value: 1.900e+01\n",
      "(CVXPY) Apr 24 11:18:29 PM: Compilation took 3.295e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:29 PM: Solver (including time spent in interface) took 9.781e-01 seconds\n",
      "Optimal value: 19.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1.  0.  0. -0.  0.  1. -0.  0. -0.  0.  0. -0.  0.\n",
      "  1. -0.  1. -0.  1. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1.  0. -0.\n",
      "  0. -0. -0. -0.  0.  0.  1. -0.  1.  0.  1. -0. -0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'MORT_30_HF'\n",
      " 'PSI_10' 'PSI_12' 'PSI_14' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'OP_36' 'READM_30_CABG'\n",
      " 'READM_30_HF']\n",
      "Constructing constraint set for group size 8\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:30 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:30 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:30 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:30 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:30 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:30 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:30 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:30 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:30 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:30 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:33 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:33 PM: Finished problem compilation (took 3.407e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:33 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79170 rows and 14 columns.\n",
      "Reduced MIP has 73 rows, 36 columns, and 736 nonzeros.\n",
      "Reduced MIP has 36 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (157.27 ticks)\n",
      "Found incumbent of value 27.000000 after 0.19 sec. (175.83 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 73 rows, 36 columns, and 736 nonzeros.\n",
      "Reduced MIP has 36 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.33 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.86 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           27.0000       12.0000            55.56%\n",
      "*     0+    0                           22.0000       12.0000            45.45%\n",
      "*     0+    0                           20.0000       12.0000            40.00%\n",
      "*     0+    0                           18.0000       12.0000            33.33%\n",
      "*     0+    0                           17.0000       12.0000            29.41%\n",
      "      0     0       16.1984    29       17.0000       16.1984       71    4.72%\n",
      "      0     0        cutoff             17.0000       16.1984       71    4.72%\n",
      "Elapsed time = 0.23 sec. (177.45 ticks, tree = 0.01 MB, solutions = 5)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.23 sec. (177.45 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.23 sec. (177.45 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:34 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:34 PM: Optimal value: 1.700e+01\n",
      "(CVXPY) Apr 24 11:18:34 PM: Compilation took 3.407e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:34 PM: Solver (including time spent in interface) took 9.351e-01 seconds\n",
      "Optimal value: 17.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  1.  0.  1.  0.  0.  0.  0.  1.  0.  0.  0.  0.\n",
      "  1.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1.  0.  1. -0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_CABG' 'PSI_03' 'PSI_10' 'PSI_90' 'SEP_1'\n",
      " 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA'\n",
      " 'READM_30_HF']\n",
      "Constructing constraint set for group size 9\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:34 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:34 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:34 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:34 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:34 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:34 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:34 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:34 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:34 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:34 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:37 PM: Finished problem compilation (took 2.886e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:37 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79183 rows and 14 columns.\n",
      "Reduced MIP has 60 rows, 36 columns, and 651 nonzeros.\n",
      "Reduced MIP has 36 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.20 sec. (156.36 ticks)\n",
      "Found incumbent of value 25.000000 after 0.21 sec. (175.07 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 60 rows, 36 columns, and 651 nonzeros.\n",
      "Reduced MIP has 36 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.27 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.67 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           25.0000       12.0000            52.00%\n",
      "*     0+    0                           19.0000       12.0000            36.84%\n",
      "*     0+    0                           18.0000       12.0000            33.33%\n",
      "*     0+    0                           17.0000       12.0000            29.41%\n",
      "      0     0       15.7727    28       17.0000       15.7727       63    7.22%\n",
      "      0     0        cutoff             17.0000       17.0000       79    0.00%\n",
      "Elapsed time = 0.27 sec. (178.03 ticks, tree = 0.01 MB, solutions = 4)\n",
      "\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.27 sec. (178.03 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.27 sec. (178.03 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:38 PM: Optimal value: 1.700e+01\n",
      "(CVXPY) Apr 24 11:18:38 PM: Compilation took 2.886e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:38 PM: Solver (including time spent in interface) took 8.049e-01 seconds\n",
      "Optimal value: 17.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  1.  0.  1.  0.  0.  0.  0.  1.  0.  0.  0.  0.\n",
      "  1.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1.  0.  1. -0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_CABG' 'PSI_03' 'PSI_10' 'PSI_90' 'SEP_1'\n",
      " 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA'\n",
      " 'READM_30_HF']\n",
      "Constructing constraint set for group size 10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:39 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:41 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:41 PM: Finished problem compilation (took 2.595e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:41 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79196 rows and 15 columns.\n",
      "Reduced MIP has 47 rows, 35 columns, and 523 nonzeros.\n",
      "Reduced MIP has 35 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (155.56 ticks)\n",
      "Found incumbent of value 22.000000 after 0.22 sec. (173.91 ticks)\n",
      "Probing time = 0.00 sec. (0.02 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 47 rows, 35 columns, and 523 nonzeros.\n",
      "Reduced MIP has 35 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.22 ticks)\n",
      "Probing time = 0.00 sec. (0.02 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.46 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           22.0000       12.0000            45.45%\n",
      "*     0+    0                           19.0000       12.0000            36.84%\n",
      "*     0+    0                           18.0000       12.0000            33.33%\n",
      "*     0+    0                           17.0000       12.0000            29.41%\n",
      "      0     0       15.2336    24       17.0000       15.2336       52   10.39%\n",
      "      0     0       15.3152    23       17.0000      Fract: 1       69    6.76%\n",
      "      0     0       15.3869    23       17.0000      Fract: 1       87    6.76%\n",
      "      0     0       15.3964    19       17.0000   ZeroHalf: 1       96    6.76%\n",
      "      0     0       15.4409    19       17.0000   ZeroHalf: 1      108    6.76%\n",
      "      0     0       15.4624    23       17.0000   ZeroHalf: 1      120    6.76%\n",
      "Detecting symmetries...\n",
      "      0     0        cutoff             17.0000       17.0000      120    0.00%\n",
      "Elapsed time = 0.30 sec. (180.39 ticks, tree = 0.01 MB, solutions = 4)\n",
      "\n",
      "Zero-half cuts applied:  3\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.30 sec. (180.39 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.30 sec. (180.39 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:42 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:42 PM: Optimal value: 1.700e+01\n",
      "(CVXPY) Apr 24 11:18:42 PM: Compilation took 2.595e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:42 PM: Solver (including time spent in interface) took 9.430e-01 seconds\n",
      "Optimal value: 17.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  1.  0.  1.  1.  0.  0.  0.  0.  0.  1.  0.  0.\n",
      "  1.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1.  0.  1. -0. -0.\n",
      "  0. -0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_CABG' 'MORT_30_COPD' 'PSI_06' 'PSI_10' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 11\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:43 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:43 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:43 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:43 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:43 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:43 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:43 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:43 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:43 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:43 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:45 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:45 PM: Finished problem compilation (took 2.743e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:45 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79207 rows and 16 columns.\n",
      "Reduced MIP has 36 rows, 34 columns, and 409 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.17 sec. (154.84 ticks)\n",
      "Found incumbent of value 22.000000 after 0.18 sec. (172.99 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 36 rows, 34 columns, and 409 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.16 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.30 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           22.0000       12.0000            45.45%\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "      0     0       14.6962    18       15.0000       14.6962       45    2.03%\n",
      "      0     0        cutoff             15.0000       14.6962       45    2.03%\n",
      "Elapsed time = 0.20 sec. (173.77 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.21 sec. (173.77 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.21 sec. (173.77 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:46 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:46 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 11:18:46 PM: Compilation took 2.743e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:46 PM: Solver (including time spent in interface) took 8.833e-01 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.\n",
      "  1.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  0. -0.  0.  0.  0.  1.  0.  1.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_10'\n",
      " 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA' 'OP_35_ED' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 12\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:47 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:47 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:47 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:47 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:47 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:47 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:47 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:47 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:47 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:47 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:50 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:50 PM: Finished problem compilation (took 2.799e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:50 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79219 rows and 19 columns.\n",
      "Reduced MIP has 24 rows, 31 columns, and 282 nonzeros.\n",
      "Reduced MIP has 31 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.15 sec. (154.16 ticks)\n",
      "Found incumbent of value 20.000000 after 0.17 sec. (171.65 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 24 rows, 31 columns, and 282 nonzeros.\n",
      "Reduced MIP has 31 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.11 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.20 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           20.0000       12.0000            40.00%\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "      0     0       14.3784    12       15.0000       14.3784       43    4.14%\n",
      "      0     0        cutoff             15.0000       14.3784       43    4.14%\n",
      "Elapsed time = 0.20 sec. (172.24 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.20 sec. (172.24 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.20 sec. (172.24 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:51 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:51 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 11:18:51 PM: Compilation took 2.799e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:51 PM: Solver (including time spent in interface) took 8.817e-01 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  1.  0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  1.  0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  0. -0.  0.  0.  0.  0. -0.  1.  0. -0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'PSI_04' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 13\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:51 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:51 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:51 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:51 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:51 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:51 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:51 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:51 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:51 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:52 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:54 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:54 PM: Finished problem compilation (took 2.737e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:54 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79221 rows and 20 columns.\n",
      "Reduced MIP has 22 rows, 30 columns, and 275 nonzeros.\n",
      "Reduced MIP has 30 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (153.83 ticks)\n",
      "Found incumbent of value 19.000000 after 0.20 sec. (171.03 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 22 rows, 30 columns, and 275 nonzeros.\n",
      "Reduced MIP has 30 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.11 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (0.17 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           19.0000       12.0000            36.84%\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "      0     0       14.1593    14       15.0000       14.1593       36    5.60%\n",
      "      0     0        cutoff             15.0000       14.1593       36    5.60%\n",
      "Elapsed time = 0.22 sec. (171.58 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.22 sec. (171.58 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.22 sec. (171.58 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:55 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:18:55 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 11:18:55 PM: Compilation took 2.737e+00 seconds\n",
      "(CVXPY) Apr 24 11:18:55 PM: Solver (including time spent in interface) took 7.672e-01 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1.  0.  0.  0.  0.  0.  0.  1.  0.  0.  0.  1.  0.\n",
      "  0. -0.  0.  0.  1.  0.  1.  0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  0. -0.  0.  0.  0.  0. -0.  0.  0. -0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'MORT_30_STK'\n",
      " 'PSI_08' 'PSI_14' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 14\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:18:56 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:18:56 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:18:56 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:18:56 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:18:56 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:56 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:18:56 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:18:56 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:18:56 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:18:56 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:18:58 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:18:59 PM: Finished problem compilation (took 3.054e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:18:59 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79225 rows and 25 columns.\n",
      "Reduced MIP has 18 rows, 25 columns, and 203 nonzeros.\n",
      "Reduced MIP has 25 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (153.87 ticks)\n",
      "Found incumbent of value 18.000000 after 0.19 sec. (170.72 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 18 rows, 25 columns, and 203 nonzeros.\n",
      "Reduced MIP has 25 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.08 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.09 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           18.0000       12.0000            33.33%\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "      0     0       14.0370    12       15.0000       14.0370       24    6.42%\n",
      "      0     0        cutoff             15.0000       14.0370       24    6.42%\n",
      "Elapsed time = 0.22 sec. (171.14 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.22 sec. (171.14 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.22 sec. (171.14 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:00 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:00 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 11:19:00 PM: Compilation took 3.054e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:00 PM: Solver (including time spent in interface) took 9.103e-01 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var423709: value [ 1.  1.  1.  1.  1.  1.  0.  0.  0. -0.  0.  0.  0.  0.  0.  0.  1.  0.\n",
      "  0. -0.  0. -0.  0.  0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  0. -0.  0. -0.  0.  0. -0.  1.  0. -0.  0.  0. -0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'PSI_08' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA' 'READM_30_AMI']\n",
      "Constructing constraint set for group size 15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:00 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:00 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:00 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:00 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:00 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:00 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:00 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:00 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:00 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:00 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:03 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:03 PM: Finished problem compilation (took 3.258e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:03 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79230 rows and 33 columns.\n",
      "Reduced MIP has 13 rows, 17 columns, and 116 nonzeros.\n",
      "Reduced MIP has 17 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.19 sec. (166.08 ticks)\n",
      "Found incumbent of value 15.000000 after 0.20 sec. (183.12 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 0 rows and 2 columns.\n",
      "Reduced MIP has 13 rows, 15 columns, and 106 nonzeros.\n",
      "Reduced MIP has 15 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.06 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 13 rows, 15 columns, and 106 nonzeros.\n",
      "Reduced MIP has 15 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (0.04 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (0.04 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "*     0+    0                           14.0000       12.0000            14.29%\n",
      "      0     0       13.5000     3       14.0000       13.5000       14    3.57%\n",
      "      0     0        cutoff             14.0000       13.5000       14    3.57%\n",
      "Elapsed time = 0.23 sec. (183.64 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.23 sec. (183.64 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.23 sec. (183.64 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:04 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:04 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 24 11:19:04 PM: Compilation took 3.258e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:04 PM: Solver (including time spent in interface) took 7.967e-01 seconds\n",
      "Optimal value: 14.0\n",
      "Variable var423709: value [ 1.  1.  1.  1.  1.  1.  0.  0.  0. -0.  0. -0.  0. -0. -0.  0.  1.  0.\n",
      "  0. -0. -0.  0.  0.  0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0.  0. -0.  0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'PSI_08' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 16\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:05 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:05 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:05 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:05 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:05 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:05 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:05 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:05 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:05 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:05 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:09 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:09 PM: Finished problem compilation (took 3.904e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:09 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79232 rows and 37 columns.\n",
      "Reduced MIP has 11 rows, 13 columns, and 91 nonzeros.\n",
      "Reduced MIP has 13 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.23 sec. (153.15 ticks)\n",
      "Found incumbent of value 15.000000 after 0.26 sec. (169.89 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 11 rows, 13 columns, and 91 nonzeros.\n",
      "Reduced MIP has 13 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.04 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.04 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "*     0+    0                           14.0000       12.0000            14.29%\n",
      "      0     0       13.4375     8       14.0000       13.4375       16    4.02%\n",
      "      0     0        cutoff             14.0000       13.4375       16    4.02%\n",
      "Elapsed time = 0.29 sec. (170.17 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.29 sec. (170.18 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.29 sec. (170.18 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:10 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:10 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 24 11:19:10 PM: Compilation took 3.904e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:10 PM: Solver (including time spent in interface) took 8.461e-01 seconds\n",
      "Optimal value: 14.0\n",
      "Variable var423709: value [ 1.  1.  1.  0.  1.  1. -0.  1.  1. -0. -0. -0.  0. -0. -0.  0.  0.  0.\n",
      "  0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  0. -0. -0. -0.  0.  0.  0.  0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'MORT_30_AMI'\n",
      " 'MORT_30_CABG' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 17\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:10 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:10 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:10 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:10 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:10 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:14 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:14 PM: Finished problem compilation (took 3.832e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:14 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79234 rows and 40 columns.\n",
      "Reduced MIP has 9 rows, 10 columns, and 63 nonzeros.\n",
      "Reduced MIP has 10 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.16 sec. (147.50 ticks)\n",
      "Found incumbent of value 14.000000 after 0.17 sec. (164.44 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 9 rows, 10 columns, and 63 nonzeros.\n",
      "Reduced MIP has 10 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.03 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (0.02 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           14.0000       12.0000            14.29%\n",
      "      0     0       13.4000     6       14.0000       13.4000       11    4.29%\n",
      "      0     0        cutoff             14.0000       13.4000       11    4.29%\n",
      "Elapsed time = 0.20 sec. (164.68 ticks, tree = 0.01 MB, solutions = 1)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.21 sec. (164.68 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.21 sec. (164.68 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:15 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:15 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 24 11:19:15 PM: Compilation took 3.832e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:15 PM: Solver (including time spent in interface) took 7.787e-01 seconds\n",
      "Optimal value: 14.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'MORT_30_AMI'\n",
      " 'MORT_30_CABG' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 18\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:16 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:16 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:16 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:16 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:16 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:16 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:16 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:16 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:16 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:16 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:19 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:20 PM: Finished problem compilation (took 3.880e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:20 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79237 rows and 43 columns.\n",
      "Reduced MIP has 6 rows, 7 columns, and 29 nonzeros.\n",
      "Reduced MIP has 7 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.19 sec. (160.81 ticks)\n",
      "Found incumbent of value 14.000000 after 0.21 sec. (177.46 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 2 rows and 2 columns.\n",
      "Reduced MIP has 4 rows, 5 columns, and 14 nonzeros.\n",
      "Reduced MIP has 5 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.02 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "MIP Presolve eliminated 0 rows and 1 columns.\n",
      "Reduced MIP has 4 rows, 4 columns, and 12 nonzeros.\n",
      "Reduced MIP has 4 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.01 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (0.01 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           14.0000       12.0000            14.29%\n",
      "      0     0       13.3333     4       14.0000       13.3333        4    4.76%\n",
      "      0     0        cutoff             14.0000       13.3333        4    4.76%\n",
      "Elapsed time = 0.23 sec. (177.82 ticks, tree = 0.01 MB, solutions = 1)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.24 sec. (177.82 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.24 sec. (177.82 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:20 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 24 11:19:20 PM: Compilation took 3.880e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:20 PM: Solver (including time spent in interface) took 9.682e-01 seconds\n",
      "Optimal value: 14.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0.  1. -0.  1. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG' 'MORT_30_HF' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P'\n",
      " 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 19\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:21 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:21 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:21 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:21 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:21 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:21 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:21 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:21 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:21 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:24 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:24 PM: Finished problem compilation (took 3.190e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:24 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.19 sec. (147.61 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.21 sec. (164.20 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.21 sec. (164.20 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:25 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:25 PM: Optimal value: 1.300e+01\n",
      "(CVXPY) Apr 24 11:19:25 PM: Compilation took 3.190e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:25 PM: Solver (including time spent in interface) took 1.094e+00 seconds\n",
      "Optimal value: 13.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:26 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:29 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:29 PM: Finished problem compilation (took 3.398e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:29 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.16 sec. (155.46 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.18 sec. (172.07 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.18 sec. (172.07 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:30 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:30 PM: Optimal value: 1.300e+01\n",
      "(CVXPY) Apr 24 11:19:30 PM: Compilation took 3.398e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:30 PM: Solver (including time spent in interface) took 8.563e-01 seconds\n",
      "Optimal value: 13.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 21\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:31 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:31 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:31 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:31 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:31 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:31 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:31 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:31 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:31 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:31 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:33 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:33 PM: Finished problem compilation (took 2.548e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:33 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.17 sec. (108.22 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.19 sec. (125.03 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.19 sec. (125.03 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:34 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:34 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:19:34 PM: Compilation took 2.548e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:34 PM: Solver (including time spent in interface) took 7.374e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 22\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:34 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:35 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:35 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:35 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:35 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:35 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:35 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:35 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:35 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:35 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:38 PM: Finished problem compilation (took 3.440e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:38 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.14 sec. (107.51 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.17 sec. (124.31 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.17 sec. (124.31 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:39 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:19:39 PM: Compilation took 3.440e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:39 PM: Solver (including time spent in interface) took 8.190e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 23\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:39 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:42 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:42 PM: Finished problem compilation (took 2.804e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:42 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.13 sec. (106.93 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (123.73 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.16 sec. (123.73 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:43 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:43 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:19:43 PM: Compilation took 2.804e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:43 PM: Solver (including time spent in interface) took 8.720e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 24\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:43 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:43 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:43 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:43 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:43 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:43 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:43 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:43 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:43 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:43 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:46 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:46 PM: Finished problem compilation (took 2.670e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:46 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.14 sec. (106.36 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (122.64 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.16 sec. (122.64 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:47 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:47 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:19:47 PM: Compilation took 2.670e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:47 PM: Solver (including time spent in interface) took 8.325e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:47 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:47 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:47 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:47 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:47 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:47 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:47 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:47 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:47 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:47 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:51 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:51 PM: Finished problem compilation (took 3.524e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:51 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.18 sec. (105.62 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.21 sec. (121.82 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.21 sec. (121.82 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:52 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:52 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:19:52 PM: Compilation took 3.524e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:52 PM: Solver (including time spent in interface) took 9.441e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 26\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:52 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:52 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:52 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:52 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:52 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:52 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:52 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:52 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:52 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:52 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:55 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:55 PM: Finished problem compilation (took 2.909e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:55 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.11 sec. (105.04 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.13 sec. (121.22 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.13 sec. (121.22 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:56 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:19:56 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:19:56 PM: Compilation took 2.909e+00 seconds\n",
      "(CVXPY) Apr 24 11:19:56 PM: Solver (including time spent in interface) took 6.536e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 27\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:19:56 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:19:56 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:19:56 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:19:56 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:19:56 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:56 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:19:56 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:19:56 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:19:56 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:19:56 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:19:59 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:19:59 PM: Finished problem compilation (took 2.980e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:19:59 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (104.42 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.14 sec. (120.26 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.14 sec. (120.26 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:00 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:00 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:00 PM: Compilation took 2.980e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:00 PM: Solver (including time spent in interface) took 8.501e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 28\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:01 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:01 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:01 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:01 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:01 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:01 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:01 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:01 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:01 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:01 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:03 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:04 PM: Finished problem compilation (took 2.649e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:04 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.17 sec. (103.75 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.19 sec. (119.61 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.19 sec. (119.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:04 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:04 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:04 PM: Compilation took 2.649e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:04 PM: Solver (including time spent in interface) took 7.465e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 29\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:05 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:05 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:05 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:05 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:05 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:05 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:05 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:05 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:05 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:05 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:08 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:08 PM: Finished problem compilation (took 3.129e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:08 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (103.15 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.13 sec. (118.49 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.13 sec. (118.49 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:09 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:09 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:09 PM: Compilation took 3.129e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:09 PM: Solver (including time spent in interface) took 6.430e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:09 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:09 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:09 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:09 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:09 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:09 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:09 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:09 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:09 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:09 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:12 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:12 PM: Finished problem compilation (took 2.800e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:12 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.13 sec. (102.55 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.15 sec. (118.14 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.15 sec. (118.14 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:13 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:13 PM: Compilation took 2.800e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:13 PM: Solver (including time spent in interface) took 6.828e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 31\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:13 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:13 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:13 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:13 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:13 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:16 PM: Finished problem compilation (took 2.814e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:16 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.14 sec. (101.88 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (117.20 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.16 sec. (117.20 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:17 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:17 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:17 PM: Compilation took 2.814e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:17 PM: Solver (including time spent in interface) took 8.595e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 32\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:18 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:18 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:18 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:18 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:18 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:18 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:18 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:18 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:18 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:18 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:20 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:20 PM: Finished problem compilation (took 2.927e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:20 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.10 sec. (101.25 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (116.57 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (116.57 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:21 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:21 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:21 PM: Compilation took 2.927e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:21 PM: Solver (including time spent in interface) took 8.150e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 33\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:22 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:22 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:22 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:22 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:22 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:24 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:24 PM: Finished problem compilation (took 2.270e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:24 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (100.65 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.15 sec. (116.44 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.15 sec. (116.44 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:25 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:25 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:25 PM: Compilation took 2.270e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:25 PM: Solver (including time spent in interface) took 8.276e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 34\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:26 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:28 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:28 PM: Finished problem compilation (took 2.581e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:28 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.10 sec. (99.86 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (115.55 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (115.55 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:29 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:29 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:29 PM: Compilation took 2.581e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:29 PM: Solver (including time spent in interface) took 6.260e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 35\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:30 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:30 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:30 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:30 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:30 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:30 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:30 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:30 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:30 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:30 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:32 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:32 PM: Finished problem compilation (took 2.364e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:32 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.13 sec. (99.39 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (115.05 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.16 sec. (115.05 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:33 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:33 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:33 PM: Compilation took 2.364e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:33 PM: Solver (including time spent in interface) took 7.955e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 36\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:34 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:34 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:34 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:34 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:34 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:34 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:34 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:34 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:34 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:34 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:36 PM: Finished problem compilation (took 2.734e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:36 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (98.68 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.15 sec. (114.29 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.15 sec. (114.29 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:37 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:37 PM: Compilation took 2.734e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:37 PM: Solver (including time spent in interface) took 8.429e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 37\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:38 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:41 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:41 PM: Finished problem compilation (took 2.678e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:41 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (97.93 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.15 sec. (113.65 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.15 sec. (113.65 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:42 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:42 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:42 PM: Compilation took 2.678e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:42 PM: Solver (including time spent in interface) took 8.491e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 38\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:42 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:42 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:42 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:42 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:42 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:42 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:42 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:42 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:42 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:42 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:44 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:44 PM: Finished problem compilation (took 1.975e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:44 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (97.19 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.14 sec. (112.75 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.14 sec. (112.75 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:45 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:45 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:45 PM: Compilation took 1.975e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:45 PM: Solver (including time spent in interface) took 8.789e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 39\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:46 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:46 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:46 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:46 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:46 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:46 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:46 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:46 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:46 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:46 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:48 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:49 PM: Finished problem compilation (took 2.504e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:49 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.15 sec. (96.40 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.17 sec. (113.15 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.17 sec. (113.15 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:49 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:49 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:49 PM: Compilation took 2.504e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:49 PM: Solver (including time spent in interface) took 7.391e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 40\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:50 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:50 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:50 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:50 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:50 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:50 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:50 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:50 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:50 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:50 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:53 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:53 PM: Finished problem compilation (took 2.686e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:53 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.13 sec. (95.70 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.15 sec. (112.41 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.15 sec. (112.41 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:54 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:54 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:54 PM: Compilation took 2.686e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:54 PM: Solver (including time spent in interface) took 8.653e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 41\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:55 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:55 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:55 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:55 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:55 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:55 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:55 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:55 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:55 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:55 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:20:57 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:20:57 PM: Finished problem compilation (took 2.476e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.10 sec. (94.94 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (111.61 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (111.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:58 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:20:58 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:20:58 PM: Compilation took 2.476e+00 seconds\n",
      "(CVXPY) Apr 24 11:20:58 PM: Solver (including time spent in interface) took 6.313e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 42\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:20:58 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:20:58 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:20:58 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:20:58 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:20:58 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:20:58 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:20:58 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:20:58 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:20:58 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:20:58 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:01 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:01 PM: Finished problem compilation (took 2.260e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:01 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.11 sec. (94.25 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.13 sec. (110.89 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.13 sec. (110.89 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:01 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:01 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:01 PM: Compilation took 2.260e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:01 PM: Solver (including time spent in interface) took 6.227e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 43\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:02 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:02 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:02 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:02 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:02 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:02 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:02 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:02 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:02 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:02 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:05 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:05 PM: Finished problem compilation (took 2.591e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:05 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.13 sec. (93.53 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (110.01 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.16 sec. (110.01 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:05 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:05 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:05 PM: Compilation took 2.591e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:05 PM: Solver (including time spent in interface) took 7.188e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 44\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:06 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:06 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:06 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:06 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:06 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:06 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:06 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:06 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:06 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:06 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:08 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:08 PM: Finished problem compilation (took 2.174e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:08 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.11 sec. (92.86 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (109.30 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (109.30 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:09 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:09 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:09 PM: Compilation took 2.174e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:09 PM: Solver (including time spent in interface) took 7.709e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 45\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:10 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:10 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:10 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:10 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:10 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:12 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:12 PM: Finished problem compilation (took 2.654e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:12 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.14 sec. (92.17 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.17 sec. (111.01 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.17 sec. (111.01 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:13 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:13 PM: Compilation took 2.654e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:13 PM: Solver (including time spent in interface) took 9.288e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 46\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:14 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:14 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:14 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:14 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:14 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:14 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:14 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:14 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:14 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:14 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:16 PM: Finished problem compilation (took 2.187e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:16 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.10 sec. (91.47 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (109.95 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (109.95 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:17 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:17 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:17 PM: Compilation took 2.187e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:17 PM: Solver (including time spent in interface) took 7.894e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 47\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:18 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:18 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:18 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:18 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:18 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:18 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:18 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:18 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:18 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:18 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:20 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:20 PM: Finished problem compilation (took 2.169e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:20 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.11 sec. (90.81 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (108.94 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.12 sec. (108.94 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:20 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:20 PM: Compilation took 2.169e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:20 PM: Solver (including time spent in interface) took 6.745e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 48\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:22 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:22 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:22 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:22 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:22 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:24 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:24 PM: Finished problem compilation (took 2.461e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:24 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.07 sec. (90.20 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.10 sec. (108.01 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.10 sec. (108.01 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:25 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:25 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:25 PM: Compilation took 2.461e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:25 PM: Solver (including time spent in interface) took 7.752e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for group size 49\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:21:25 PM: Your problem has 50 variables, 79243 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:21:25 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:21:25 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:21:25 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:21:25 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:25 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 11:21:25 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 11:21:25 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:21:25 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 11:21:25 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 11:21:27 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 11:21:28 PM: Finished problem compilation (took 2.221e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:28 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 79243 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.12 sec. (90.02 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.15 sec. (107.74 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.15 sec. (107.74 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:21:28 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:21:28 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 24 11:21:28 PM: Compilation took 2.221e+00 seconds\n",
      "(CVXPY) Apr 24 11:21:28 PM: Solver (including time spent in interface) took 8.225e-01 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var423709: value [ 1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n"
     ]
    }
   ],
   "source": [
    "group_sizes = range(1, len(all_tasks))\n",
    "outputs_pr_augmented = selection_algorithms.solve_lp_pr(hq_ranks_df, all_tasks, group_sizes=group_sizes, cplex_params={'timelimit': 300}, starting_tasks=CHC_METRICS)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a6d020a1-5afb-4516-8e6b-6f468592973d",
   "metadata": {},
   "source": [
    "## Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 290,
   "id": "61697d1d-56f4-47e3-a532-777e6f5e36c0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plt.rcdefaults()\n",
    "plt.figure(figsize=(5,4))\n",
    "group_sizes = range(1, len(all_tasks))\n",
    "n = len(all_tasks)\n",
    "m = len(hq_df)\n",
    "upper_bounds = [( (n / g) * math.log(m)) for g in group_sizes]\n",
    "lower_bounds = [math.floor(n / g) for g in group_sizes]\n",
    "\n",
    "glim=21\n",
    "plt.scatter(group_sizes, outputs_greedy, label='Greedy', color='b')\n",
    "plt.scatter(group_sizes, outputs_pr, label='IP', color='orange', s=25)\n",
    "plt.scatter(group_sizes[:glim], outputs_greedy_augmented[:glim], label='Greedy augmented', marker='x', color='blue', linewidth=0.75)\n",
    "plt.scatter(group_sizes[:glim], outputs_pr_augmented[:glim], label='IP augmented', marker='x', color='orange', linewidth=0.75)\n",
    "plt.plot(group_sizes, upper_bounds, color='black', label='Upper bound', linestyle=':')\n",
    "plt.plot(group_sizes, lower_bounds, color='grey', label=r'Lower bound', linestyle=':')\n",
    "plt.axhline(12, color='red', label='Size of existing subset')\n",
    "plt.axvline(glim, color='red', linestyle='--', label=\"Min $g$ for  \\n existing subset\")\n",
    "plt.xlabel(r'Group size $g$', fontsize=12)\n",
    "plt.xticks(fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "plt.ylabel(r'Selected subset size $|K|$', fontsize=12)\n",
    "plt.ylim((0,60))\n",
    "# plt.legend()\n",
    "plt.savefig('pr_hospital.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0f17ce5f-f951-4f02-b536-a5c0a123ee49",
   "metadata": {},
   "source": [
    "# IP for PP"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7303c58e-aa52-46d2-8bf0-0df0dddaab22",
   "metadata": {},
   "source": [
    "## Run IP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "b1f053b3-a0e0-4f3c-a1bc-9edb8ed0a604",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Constructing program parameters\n",
      "Constructing constraint set for epsilon 0.00\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:29:52 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:29:52 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:29:52 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:29:52 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:29:52 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:29:52 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:29:52 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:29:52 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:29:52 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:29:52 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:30:04 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:30:04 PM: Finished problem compilation (took 1.231e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:30:04 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158485 rows and 50 columns.\n",
      "MIP Presolve modified 150305 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 1.27 sec. (1522.78 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.40 sec. (1638.48 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.40 sec. (1638.48 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:30:07 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 02:30:07 PM: Optimal value: 5.000e+01\n",
      "(CVXPY) Apr 24 02:30:07 PM: Compilation took 1.231e+01 seconds\n",
      "(CVXPY) Apr 24 02:30:07 PM: Solver (including time spent in interface) took 3.268e+00 seconds\n",
      "Optimal value: 50.0\n",
      "Variable var90820: value [1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF'\n",
      " 'MORT_30_PN' 'MORT_30_STK' 'PSI_03' 'PSI_04' 'PSI_06' 'PSI_08' 'PSI_09'\n",
      " 'PSI_10' 'PSI_11' 'PSI_12' 'PSI_13' 'PSI_14' 'PSI_15' 'PSI_90' 'OP_23'\n",
      " 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_6_Y_P' 'H_COMP_7_SA' 'ePC_07a' 'ePC_07b'\n",
      " 'EDAC_30_AMI' 'EDAC_30_HF' 'EDAC_30_PN' 'OP_32' 'OP_35_ADM' 'OP_35_ED'\n",
      " 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.05\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:30:08 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:30:08 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:30:08 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:30:08 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:30:08 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:30:08 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:30:08 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:30:08 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:30:08 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:30:08 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:30:20 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:30:21 PM: Finished problem compilation (took 1.296e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:30:21 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 140891 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 140891 rows and 0 columns.\n",
      "MIP Presolve modified 327344 coefficients.\n",
      "Reduced MIP has 17594 rows, 50 columns, and 879700 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 22.80 sec. (85350.72 ticks)\n",
      "Found incumbent of value 48.000000 after 23.06 sec. (85582.72 ticks)\n",
      "Probing time = 0.02 sec. (8.24 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 17594 rows, 50 columns, and 879700 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.40 sec. (269.02 ticks)\n",
      "Probing time = 0.03 sec. (8.24 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.49 sec. (300.60 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           48.0000        0.0000           100.00%\n",
      "*     0+    0                           47.0000        0.0000           100.00%\n",
      "*     0+    0                           46.0000        0.0000           100.00%\n",
      "      0     0        1.0000    49       46.0000        1.0000      154   97.83%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000    48       46.0000        1.0000      154   97.83%\n",
      "Elapsed time = 28.46 sec. (90297.50 ticks, tree = 0.02 MB, solutions = 3)\n",
      "      2     4        1.0000    48       46.0000        1.0000      556   97.83%\n",
      "      3     5        1.0000    47       46.0000        1.0000      850   97.83%\n",
      "      9     9       14.2857    46       46.0000        1.0000     1966   97.83%\n",
      "     15    10       18.1818    45       46.0000        1.0000     2161   97.83%\n",
      "     25     8       16.9488    45       46.0000       14.2857     2428   68.94%\n",
      "     32    19       26.6230    43       46.0000       14.2857     6723   68.94%\n",
      "     42    32       32.0100    39       46.0000       16.9516     9284   63.15%\n",
      "     61    21       29.1485    41       46.0000       16.9516     8096   63.15%\n",
      "     85    51    infeasible             46.0000       16.9987    14273   63.05%\n",
      "    221   134       40.9398    27       46.0000       16.9987    25708   63.05%\n",
      "Elapsed time = 48.29 sec. (93896.41 ticks, tree = 1.35 MB, solutions = 3)\n",
      "    383   212       40.4383    28       46.0000       18.1818    36814   60.47%\n",
      "    538   324       41.6321    25       46.0000       18.4583    52693   59.87%\n",
      "    708   380       34.0159    35       46.0000       19.9736    60800   56.58%\n",
      "    948   491       42.4563    24       46.0000       23.0769    74079   49.83%\n",
      "   1134   618       28.7463    40       46.0000       23.1071    89959   49.77%\n",
      "   1383   728       35.2941    35       46.0000       24.9782   102280   45.70%\n",
      "   1612   812       38.2449    32       46.0000       26.6667   108713   42.03%\n",
      "   1854   938       34.0233    36       46.0000       27.0000   121204   41.30%\n",
      "   2134  1146       39.9993    26       46.0000       27.2727   140988   40.71%\n",
      "   2410  1380       43.5897    12       46.0000       28.0000   161842   39.13%\n",
      "Elapsed time = 128.82 sec. (103470.08 ticks, tree = 2.74 MB, solutions = 3)\n",
      "   2683  1428       30.0616    40       46.0000       28.8394   169403   37.31%\n",
      "   2985  1562       42.9068    16       46.0000       29.0575   182672   36.83%\n",
      "   3283  1692       43.1193    14       46.0000       29.1209   193435   36.69%\n",
      "   3584  1830    infeasible             46.0000       29.5773   208860   35.70%\n",
      "   3895  2021       33.6718    36       46.0000       29.8870   228254   35.03%\n",
      "   4148  2078       38.9057    31       46.0000       30.5131   232810   33.67%\n",
      "   4347  2326       41.6284    22       46.0000       30.5812   256094   33.52%\n",
      "   4585  2371       42.2656    20       46.0000       30.8535   264223   32.93%\n",
      "   4885  2476       41.4056    21       46.0000       31.0971   273752   32.40%\n",
      "   5240  2666       38.4457    29       46.0000       31.3868   290495   31.77%\n",
      "Elapsed time = 204.75 sec. (113026.62 ticks, tree = 5.79 MB, solutions = 3)\n",
      "   5596  2844    infeasible             46.0000       31.6800   304297   31.13%\n",
      "   5951  3029       39.9579    28       46.0000       31.7017   321867   31.08%\n",
      "   6301  3057       41.6203    22       46.0000       32.0559   325677   30.31%\n",
      "   6515  3271       39.9399    27       46.0000       32.1106   342583   30.19%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 685491 coefficients.\n",
      "Reduced MIP has 17594 rows, 50 columns, and 879700 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.42 sec. (351.31 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 17594 rows, 50 columns, and 879700 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.41 sec. (280.46 ticks)\n",
      "Represolve time = 1.07 sec. (790.26 ticks)\n",
      "   6560     0        4.4139    49       46.0000       Cuts: 2   361328   29.60%\n",
      "   6560     0        4.6027    49       46.0000      Cuts: 67   361429   29.60%\n",
      "   6560     0        4.8949    49       46.0000      Cuts: 57   361536   29.60%\n",
      "   6560     0        5.0820    49       46.0000      Cuts: 58   361676   29.60%\n",
      "   6560     0        5.1304    49       46.0000      Cuts: 42   361737   29.60%\n",
      "   6560     2        5.1304    49       46.0000       32.3852   361737   29.60%\n",
      "   6561     3        5.1869    48       46.0000       32.3852   361915   29.60%\n",
      "   6562     4        5.5417    47       46.0000       32.3852   362133   29.60%\n",
      "   6564     4       15.0000    47       46.0000       32.3852   362325   29.60%\n",
      "   6565     6       15.0000    47       46.0000       32.3852   362654   29.60%\n",
      "   6567     5       15.6295    46       46.0000       32.3852   362509   29.60%\n",
      "Elapsed time = 264.76 sec. (135294.49 ticks, tree = 0.02 MB, solutions = 3)\n",
      "   6595    16       38.8902    33       46.0000       32.3852   365807   29.60%\n",
      "   6779    57    infeasible             46.0000       32.3852   374876   29.60%\n",
      "   6912    98        cutoff             46.0000       32.3852   385525   29.60%\n",
      "   7093   152       33.0167    37       46.0000       32.3852   395558   29.60%\n",
      "   7296   251       39.9262    29       46.0000       32.3852   409601   29.60%\n",
      "\n",
      "Cover cuts applied:  3\n",
      "Mixed integer rounding cuts applied:  13\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   27.81 sec. (90243.20 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  272.57 sec. (50331.79 ticks)\n",
      "  Sync time (average)   =   50.19 sec.\n",
      "  Wait time (average)   =    0.36 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.38 sec. (140575.00 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:35:23 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 02:35:23 PM: Optimal value: 4.600e+01\n",
      "(CVXPY) Apr 24 02:35:23 PM: Compilation took 1.296e+01 seconds\n",
      "(CVXPY) Apr 24 02:35:23 PM: Solver (including time spent in interface) took 3.023e+02 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/serenawang/anaconda3/envs/python310/lib/python3.10/site-packages/cvxpy/problems/problem.py:1504: UserWarning: Solution may be inaccurate. Try another solver, adjusting the solver settings, or solve with verbose=True for more information.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal value: 46.0\n",
      "Variable var90820: value [1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_COPD' 'MORT_30_HF' 'MORT_30_PN'\n",
      " 'PSI_03' 'PSI_04' 'PSI_06' 'PSI_08' 'PSI_09' 'PSI_10' 'PSI_11' 'PSI_12'\n",
      " 'PSI_13' 'PSI_14' 'PSI_15' 'PSI_90' 'OP_23' 'OP_29' 'SEP_1'\n",
      " 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_5_A_P' 'H_COMP_6_Y_P' 'H_COMP_7_SA'\n",
      " 'ePC_07a' 'ePC_07b' 'EDAC_30_AMI' 'EDAC_30_PN' 'OP_32' 'OP_35_ADM'\n",
      " 'OP_35_ED' 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD'\n",
      " 'READM_30_HF' 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:35:23 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:35:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:35:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:35:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:35:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:35:23 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:35:23 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:35:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:35:23 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:35:23 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:35:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:35:36 PM: Finished problem compilation (took 1.276e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:35:36 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 141713 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 141713 rows and 0 columns.\n",
      "MIP Presolve modified 277213 coefficients.\n",
      "Reduced MIP has 16772 rows, 50 columns, and 838600 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 16.84 sec. (58323.36 ticks)\n",
      "Found incumbent of value 43.000000 after 17.09 sec. (58546.36 ticks)\n",
      "Probing time = 0.02 sec. (7.86 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 16772 rows, 50 columns, and 838600 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.37 sec. (253.30 ticks)\n",
      "Probing time = 0.02 sec. (7.86 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.39 sec. (268.88 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           43.0000        0.0000           100.00%\n",
      "*     0+    0                           39.0000        0.0000           100.00%\n",
      "*     0+    0                           36.0000        0.0000           100.00%\n",
      "      0     0        1.0000    44       36.0000        1.0000      107   97.22%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000    36       36.0000        1.0000      107   97.22%\n",
      "Elapsed time = 22.23 sec. (62731.44 ticks, tree = 0.02 MB, solutions = 3)\n",
      "      1     3        1.0000    42       36.0000        1.0000      388   97.22%\n",
      "      3     4        1.0000    44       36.0000        1.0000      658   97.22%\n",
      "      6     8        9.0000    42       36.0000        1.0000     1596   97.22%\n",
      "     13    13        9.0000    42       36.0000        1.0000     2995   97.22%\n",
      "     25    21        9.0000    41       36.0000        1.0000     4298   97.22%\n",
      "     51    31       15.0000    38       36.0000        1.0000     6072   97.22%\n",
      "     66    49       12.5000    39       36.0000        1.0000     8870   97.22%\n",
      "     89    63       12.2161    37       36.0000        9.0000    12435   75.00%\n",
      "    113    86       17.9491    39       36.0000        9.0000    16442   75.00%\n",
      "    221   156       14.1926    37       36.0000        9.0000    26882   75.00%\n",
      "Elapsed time = 43.00 sec. (66174.15 ticks, tree = 3.09 MB, solutions = 3)\n",
      "    378   261       14.5879    39       36.0000        9.0000    42058   75.00%\n",
      "    523   349       11.1111    40       36.0000        9.0000    53447   75.00%\n",
      "    683   478    infeasible             36.0000        9.0000    72552   75.00%\n",
      "*   731+  450                           34.0000       10.2974            69.71%\n",
      "    864   544       14.2857    40       34.0000       10.5993    81210   68.83%\n",
      "   1042   617    infeasible             34.0000       11.1111    90570   67.32%\n",
      "   1265   661       13.0897    40       34.0000       11.1111    95058   67.32%\n",
      "   1451   874    infeasible             34.0000       11.1111   117799   67.32%\n",
      "   1636  1033       15.5293    39       34.0000       12.0000   134572   64.71%\n",
      "   1841  1170       27.9769    27       34.0000       12.5642   148001   63.05%\n",
      "   2071  1288       27.4827    26       34.0000       12.7848   161066   62.40%\n",
      "Elapsed time = 130.46 sec. (75749.67 ticks, tree = 4.09 MB, solutions = 4)\n",
      "   2284  1442       16.6360    37       34.0000       12.7848   176711   62.40%\n",
      "   2385  1564       23.5476    34       34.0000       12.7848   188809   62.40%\n",
      "   2405  1492       32.3077    13       34.0000       13.2338   181449   61.08%\n",
      "   2511  1669       20.7446    31       34.0000       13.2375   196261   61.07%\n",
      "   2697  1816       26.8483    21       34.0000       13.3148   208556   60.84%\n",
      "   2951  1721       16.9784    36       34.0000       13.3994   199978   60.59%\n",
      "   3182  1960       14.6329    36       34.0000       13.4076   221489   60.57%\n",
      "   3419  2175       32.3045    16       34.0000       13.5974   241734   60.01%\n",
      "   3655  2346       19.0324    35       34.0000       13.6364   257682   59.89%\n",
      "   3954  2305        cutoff             34.0000       13.6364   252784   59.89%\n",
      "Elapsed time = 252.75 sec. (94561.42 ticks, tree = 6.41 MB, solutions = 4)\n",
      "   4221  2565       32.1429    13       34.0000       13.9741   278924   58.90%\n",
      "   4452  2679       27.3130    29       34.0000       13.9916   289467   58.85%\n",
      "   4545  2787       14.2857    41       34.0000       13.9916   296229   58.85%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 345321 coefficients.\n",
      "Reduced MIP has 16772 rows, 50 columns, and 838600 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.35 sec. (301.66 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 16772 rows, 50 columns, and 838600 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.41 sec. (266.92 ticks)\n",
      "Represolve time = 0.97 sec. (721.62 ticks)\n",
      "   4546     0        1.4631    43       34.0000       Cuts: 3   335960   58.82%\n",
      "   4546     0        3.0000    40       34.0000       Cuts: 5   336008   58.82%\n",
      "   4546     0        3.0000    47       34.0000      Cuts: 42   336087   58.82%\n",
      "   4546     0        3.3927    46       34.0000      Fract: 1   336367   58.82%\n",
      "   4546     0        3.4162    48       34.0000     Cuts: 144   336446   58.82%\n",
      "   4546     0        3.4445    49       34.0000     Cuts: 156   336515   58.82%\n",
      "   4546     2        3.4445    49       34.0000       14.0000   336515   58.82%\n",
      "   4547     3        3.4500    48       34.0000       14.0000   336543   58.82%\n",
      "   4548     4        3.4606    46       34.0000       14.0000   336604   58.82%\n",
      "   4549     5        3.4713    44       34.0000       14.0000   336738   58.82%\n",
      "   4550     3        9.0000    47       34.0000       14.0000   336847   58.82%\n",
      "\n",
      "Cover cuts applied:  14\n",
      "Flow cuts applied:  3\n",
      "Mixed integer rounding cuts applied:  18\n",
      "Gomory fractional cuts applied:  3\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   21.57 sec. (62687.19 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  278.59 sec. (54802.16 ticks)\n",
      "  Sync time (average)   =   34.65 sec.\n",
      "  Wait time (average)   =    0.40 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.16 sec. (117489.35 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:40:38 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 02:40:38 PM: Optimal value: 3.400e+01\n",
      "(CVXPY) Apr 24 02:40:38 PM: Compilation took 1.276e+01 seconds\n",
      "(CVXPY) Apr 24 02:40:38 PM: Solver (including time spent in interface) took 3.022e+02 seconds\n",
      "Optimal value: 34.0\n",
      "Variable var90820: value [0. 1. 0. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 0. 1. 0. 1.\n",
      " 0. 0. 1. 1. 1. 1. 0. 1. 1. 0. 0. 1. 1. 1. 1. 1. 1. 0. 0. 0. 1. 1. 0. 0.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_2_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'COMP_HIP_KNEE'\n",
      " 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_HF' 'MORT_30_PN' 'MORT_30_STK'\n",
      " 'PSI_03' 'PSI_04' 'PSI_08' 'PSI_09' 'PSI_10' 'PSI_11' 'PSI_13' 'PSI_15'\n",
      " 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_6_Y_P' 'ePC_07b' 'EDAC_30_AMI' 'EDAC_30_HF' 'EDAC_30_PN' 'OP_32'\n",
      " 'OP_35_ADM' 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HOSP_WIDE'\n",
      " 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:40:38 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:40:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:40:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:40:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:40:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:40:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:40:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:40:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:40:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:40:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:40:51 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:40:52 PM: Finished problem compilation (took 1.361e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:40:52 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 142386 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 142386 rows and 0 columns.\n",
      "MIP Presolve modified 309128 coefficients.\n",
      "Reduced MIP has 16099 rows, 50 columns, and 804950 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 21.01 sec. (70025.84 ticks)\n",
      "Found incumbent of value 38.000000 after 21.26 sec. (70246.95 ticks)\n",
      "Probing time = 0.02 sec. (7.54 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 16099 rows, 50 columns, and 804950 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.36 sec. (246.22 ticks)\n",
      "Probing time = 0.02 sec. (7.54 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.36 sec. (250.83 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           38.0000        0.0000           100.00%\n",
      "*     0+    0                           29.0000        0.0000           100.00%\n",
      "*     0+    0                           28.0000        0.0000           100.00%\n",
      "*     0+    0                           27.0000        0.0000           100.00%\n",
      "      0     0        1.0000    37       27.0000        1.0000       87   96.30%\n",
      "      0     0        1.0000    26       27.0000       Cuts: 2       91   96.30%\n",
      "      0     0        1.0000    25       27.0000      Cuts: 25      121   96.30%\n",
      "      0     0        1.6393    35       27.0000      Cuts: 19      240   93.93%\n",
      "      0     0        1.6393    34       27.0000   MIRcuts: 25      265   93.93%\n",
      "Detecting symmetries...\n",
      "      0     2        1.6393    26       27.0000        1.6393      265   93.93%\n",
      "Elapsed time = 32.15 sec. (80000.50 ticks, tree = 0.02 MB, solutions = 4)\n",
      "      2     4        1.6393    38       27.0000        1.6393      631   93.93%\n",
      "      3     5        1.6393    34       27.0000        1.6393      865   93.93%\n",
      "      8     9        1.6393    36       27.0000        1.6393     1495   93.93%\n",
      "     13    10        8.1798    43       27.0000        1.6393     1643   93.93%\n",
      "     37    25        8.0650    37       27.0000        1.6393     4383   93.93%\n",
      "     53    32        5.8824    41       27.0000        1.6393     5701   93.93%\n",
      "     67    63        5.8824    40       27.0000        1.6393     9599   93.93%\n",
      "     89    72        5.8824    41       27.0000        1.6393    11294   93.93%\n",
      "    122    71       11.2376    36       27.0000        1.6393    10923   93.93%\n",
      "    255   193       16.5923    27       27.0000        1.6393    27402   93.93%\n",
      "Elapsed time = 52.69 sec. (83365.58 ticks, tree = 1.17 MB, solutions = 4)\n",
      "    455   361       17.6704    25       27.0000        1.6393    42923   93.93%\n",
      "    664   482       10.5263    36       27.0000        1.6393    53364   93.93%\n",
      "    856   682       15.7210    30       27.0000        5.8824    73355   78.21%\n",
      "   1081   807        9.5510    33       27.0000        5.8824    86030   78.21%\n",
      "   1268   876       11.6209    31       27.0000        5.9776    91725   77.86%\n",
      "   1508  1102        9.9703    35       27.0000        6.1407   114121   77.26%\n",
      "   1805  1271       13.2409    29       27.0000        6.6369   130386   75.42%\n",
      "*  1989+ 1350                           26.0000        7.5386            71.01%\n",
      "   2054  1431    infeasible             26.0000        8.0000   143557   69.23%\n",
      "   2302  1506    infeasible             26.0000        8.0000   150838   69.23%\n",
      "   2553  1823       12.9415    32       26.0000        8.3814   177455   67.76%\n",
      "Elapsed time = 133.01 sec. (92940.23 ticks, tree = 3.59 MB, solutions = 5)\n",
      "   2902  1961       13.2124    30       26.0000        8.4114   187543   67.65%\n",
      "   3194  2314       11.2980    35       26.0000        8.6778   208904   66.62%\n",
      "   3424  2398       21.4286    17       26.0000        8.6957   214904   66.56%\n",
      "   3499  2472       18.0820    22       26.0000        8.6957   220210   66.56%\n",
      "*  3535+ 2487                           25.0000        8.6957            65.22%\n",
      "   3535  2154       12.4639    30       25.0000        8.6957   198034   65.22%\n",
      "   3618  2580       15.6815    27       25.0000        8.7198   227838   65.12%\n",
      "   3846  2652       13.0306    30       25.0000        8.7348   232674   65.06%\n",
      "   4101  2866       11.1806    37       25.0000        8.7871   247482   64.85%\n",
      "   4335  2979       18.1662    22       25.0000        8.7871   256936   64.85%\n",
      "   4474  2996       15.7154    30       25.0000        8.8623   258491   64.55%\n",
      "Elapsed time = 215.87 sec. (108516.26 ticks, tree = 5.93 MB, solutions = 7)\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 619548 coefficients.\n",
      "Reduced MIP has 16099 rows, 50 columns, and 804950 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.37 sec. (320.53 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 16099 rows, 50 columns, and 804950 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.38 sec. (255.91 ticks)\n",
      "Represolve time = 0.99 sec. (729.92 ticks)\n",
      "   4487     2        1.6429    29       25.0000        9.0955   281346   63.62%\n",
      "   4488     3        1.6429    29       25.0000        9.0955   281399   63.62%\n",
      "   4489     4        1.6429    34       25.0000        9.0955   281624   63.62%\n",
      "   4490     5        1.6429    37       25.0000        9.0955   281776   63.62%\n",
      "   4492     4        6.0000    46       25.0000        9.0955   281748   63.62%\n",
      "   4516    23        6.0294    41       25.0000        9.0955   284152   63.62%\n",
      "   4600    33        6.0000    39       25.0000        9.0955   286325   63.62%\n",
      "   4777   145       17.1555    26       25.0000        9.0955   300099   63.62%\n",
      "   5006   329       17.8326    24       25.0000        9.0955   317564   63.62%\n",
      "   5208   447       18.3564    23       25.0000        9.0955   328726   63.62%\n",
      "Elapsed time = 276.47 sec. (125616.09 ticks, tree = 1.47 MB, solutions = 7)\n",
      "   5468   604    infeasible             25.0000        9.0955   342860   63.62%\n",
      "   5755   821        9.9794    33       25.0000        9.0955   358957   63.62%\n",
      "   6002  1025       13.2157    29       25.0000        9.0955   375503   63.62%\n",
      "\n",
      "Cover cuts applied:  137\n",
      "Flow cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   31.51 sec. (79951.48 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  268.78 sec. (48852.68 ticks)\n",
      "  Sync time (average)   =   44.59 sec.\n",
      "  Wait time (average)   =    0.32 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.29 sec. (128804.16 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:45:54 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 02:45:54 PM: Optimal value: 2.500e+01\n",
      "(CVXPY) Apr 24 02:45:54 PM: Compilation took 1.361e+01 seconds\n",
      "(CVXPY) Apr 24 02:45:54 PM: Solver (including time spent in interface) took 3.023e+02 seconds\n",
      "Optimal value: 25.0\n",
      "Variable var90820: value [0. 1. 0. 0. 1. 0. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 1. 0. 0. 1. 1. 0. 1. 0.\n",
      " 0. 0. 0. 1. 0. 0. 1. 1. 0. 1. 0. 1. 1. 1. 1. 1. 0. 1. 0. 0. 0. 0. 0. 0.\n",
      " 1. 0.]\n",
      "Tasks: ['HAI_2_SIR' 'HAI_5_SIR' 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG'\n",
      " 'MORT_30_COPD' 'MORT_30_HF' 'MORT_30_STK' 'PSI_03' 'PSI_04' 'PSI_08'\n",
      " 'PSI_11' 'PSI_12' 'PSI_14' 'SEP_1' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'ePC_07b' 'EDAC_30_AMI' 'EDAC_30_HF' 'EDAC_30_PN' 'OP_32'\n",
      " 'OP_35_ED' 'READM_30_HOSP_WIDE']\n",
      "Constructing constraint set for epsilon 0.20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:45:55 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:45:55 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:45:55 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:45:55 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:45:55 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:45:55 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:45:55 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:45:55 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:45:55 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:45:55 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:46:07 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:46:07 PM: Finished problem compilation (took 1.267e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:46:07 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 143477 rows and 0 columns.\n",
      "MIP Presolve modified 155074 coefficients.\n",
      "Reduced MIP has 15008 rows, 50 columns, and 750400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 1.19 sec. (1263.78 ticks)\n",
      "Found incumbent of value 34.000000 after 1.42 sec. (1476.73 ticks)\n",
      "Probing time = 0.02 sec. (7.03 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 15008 rows, 50 columns, and 750400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.32 sec. (229.00 ticks)\n",
      "Probing time = 0.02 sec. (7.03 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.32 sec. (216.24 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           34.0000        0.0000           100.00%\n",
      "*     0+    0                           25.0000        0.0000           100.00%\n",
      "*     0+    0                           22.0000        0.0000           100.00%\n",
      "*     0+    0                           20.0000        0.0000           100.00%\n",
      "      0     0        1.0000    19       20.0000        1.0000      295   95.00%\n",
      "      0     0        2.1739    21       20.0000      Cuts: 80      396   89.13%\n",
      "      0     0        2.1739    21       20.0000      Cuts: 52      429   89.13%\n",
      "      0     0        2.1739    22       20.0000      Cuts: 31      451   89.13%\n",
      "*     0+    0                           19.0000        2.1739            88.56%\n",
      "      0     0  -1.00000e+75     0       19.0000        2.1739      451   88.56%\n",
      "Detecting symmetries...\n",
      "      0     2        2.1739    22       19.0000        2.1739      451   88.56%\n",
      "Elapsed time = 7.70 sec. (6880.71 ticks, tree = 0.02 MB, solutions = 5)\n",
      "      4     6        2.1739    29       19.0000        2.1739      793   88.56%\n",
      "      9     9        4.5455    42       19.0000        2.1739     1431   88.56%\n",
      "     15    14        2.1739    34       19.0000        2.1739     2657   88.56%\n",
      "     28    22        4.5455    39       19.0000        2.1739     3472   88.56%\n",
      "     51    31        6.6667    29       19.0000        2.1739     5466   88.56%\n",
      "     68    11        5.9718    35       19.0000        2.1739     2092   88.56%\n",
      "     95    82        4.5455    37       19.0000        2.1739    11665   88.56%\n",
      "    139    91        7.0009    39       19.0000        2.1739    12474   88.56%\n",
      "    168   149        9.3750    22       19.0000        2.1739    19218   88.56%\n",
      "    330   288        7.7034    31       19.0000        2.1739    32887   88.56%\n",
      "Elapsed time = 29.56 sec. (10193.26 ticks, tree = 0.64 MB, solutions = 5)\n",
      "    615   415        6.7818    35       19.0000        2.1739    42462   88.56%\n",
      "    831   641        9.2462    25       19.0000        4.5455    59396   76.08%\n",
      "   1167   869        cutoff             19.0000        4.5455    76965   76.08%\n",
      "   1484  1036        8.3333    20       19.0000        4.5455    88378   76.08%\n",
      "   1599  1198        6.2421    38       19.0000        4.5455   101200   76.08%\n",
      "   1600   892       13.7500    19       19.0000        4.5455    77986   76.08%\n",
      "   1632  1228       16.3636    24       19.0000        4.5455   103078   76.08%\n",
      "   1856  1129        7.2627    37       19.0000        4.5455    94994   76.08%\n",
      "   2128  1341       14.4118    16       19.0000        4.5455   110387   76.08%\n",
      "   2509  1427       15.2893    17       19.0000        4.5455   116836   76.08%\n",
      "Elapsed time = 159.57 sec. (29854.57 ticks, tree = 2.24 MB, solutions = 5)\n",
      "   2867  1904       12.2529    20       19.0000        4.5455   146933   76.08%\n",
      "   3223  2121        9.8740    28       19.0000        6.4386   159407   66.11%\n",
      "   3600  2477       10.9785    24       19.0000        6.6488   180979   65.01%\n",
      "   3924  2666       10.7143    23       19.0000        6.6667   193868   64.91%\n",
      "   4314  2654       11.9048    17       19.0000        6.6667   192808   64.91%\n",
      "   4622  2992       10.5404    25       19.0000        6.6667   212453   64.91%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 347667 coefficients.\n",
      "Reduced MIP has 15008 rows, 50 columns, and 750400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.31 sec. (274.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 15008 rows, 50 columns, and 750400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.33 sec. (238.40 ticks)\n",
      "Represolve time = 0.85 sec. (647.02 ticks)\n",
      "   4678     0        2.1818    30       19.0000      Cuts: 61   244821   64.71%\n",
      "   4678     0        2.1818    24       19.0000       Cuts: 8   244851   64.71%\n",
      "   4678     0        2.1818    22       19.0000      Cuts: 19   244874   64.71%\n",
      "   4678     2        2.1818    21       19.0000        6.7056   244874   64.71%\n",
      "   4679     3        2.2727    20       19.0000        6.7056   244929   64.71%\n",
      "   4688    11        5.0000    31       19.0000        6.7056   245337   64.71%\n",
      "   4691    13        8.0000    24       19.0000        6.7056   245407   64.71%\n",
      "Elapsed time = 224.59 sec. (46031.97 ticks, tree = 0.02 MB, solutions = 5)\n",
      "   4703    21        5.0000    34       19.0000        6.7056   245730   64.71%\n",
      "   4765    48        5.0000    32       19.0000        6.7056   248568   64.71%\n",
      "   4943    84        4.1518    28       19.0000        6.7056   252206   64.71%\n",
      "   5302   241        8.0000    27       19.0000        6.7056   262119   64.71%\n",
      "   5647   563        9.1427    25       19.0000        6.7056   280300   64.71%\n",
      "   6052   808       15.9091    12       19.0000        6.7056   295716   64.71%\n",
      "   6422  1076        9.0000    30       19.0000        6.7056   308491   64.71%\n",
      "   6761  1373       11.1282    22       19.0000        6.7056   325795   64.71%\n",
      "   7092  1597       10.0126    24       19.0000        6.7056   340397   64.71%\n",
      "\n",
      "Cover cuts applied:  332\n",
      "Flow cuts applied:  1\n",
      "Mixed integer rounding cuts applied:  2\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    7.12 sec. (6839.63 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  293.25 sec. (48218.21 ticks)\n",
      "  Sync time (average)   =   33.98 sec.\n",
      "  Wait time (average)   =    0.31 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.38 sec. (55057.84 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:51:10 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 02:51:10 PM: Optimal value: 1.900e+01\n",
      "(CVXPY) Apr 24 02:51:10 PM: Compilation took 1.267e+01 seconds\n",
      "(CVXPY) Apr 24 02:51:10 PM: Solver (including time spent in interface) took 3.023e+02 seconds\n",
      "Optimal value: 19.0\n",
      "Variable var90820: value [1. 0. 1. 0. 1. 0. 0. 1. 1. 0. 0. 1. 0. 0. 0. 0. 0. 1. 1. 0. 0. 0. 0. 0.\n",
      " 1. 1. 1. 1. 1. 0. 0. 1. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 1. 0. 0. 0. 0. 1.\n",
      " 0. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'MORT_30_AMI' 'MORT_30_CABG'\n",
      " 'MORT_30_PN' 'PSI_09' 'PSI_10' 'PSI_90' 'OP_23' 'OP_29' 'SEP_1'\n",
      " 'H_COMP_1_A_P' 'H_COMP_5_A_P' 'ePC_07a' 'OP_35_ADM' 'OP_36'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:51:10 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:51:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:51:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:51:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:51:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:51:10 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:51:10 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:51:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:51:10 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:51:10 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:51:23 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:51:23 PM: Finished problem compilation (took 1.336e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:51:23 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 144257 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 144257 rows and 0 columns.\n",
      "MIP Presolve modified 440046 coefficients.\n",
      "Reduced MIP has 14228 rows, 50 columns, and 711400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 34.23 sec. (111791.18 ticks)\n",
      "Found incumbent of value 28.000000 after 34.45 sec. (112000.35 ticks)\n",
      "Probing time = 0.01 sec. (6.67 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 14228 rows, 50 columns, and 711400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.31 sec. (217.90 ticks)\n",
      "Probing time = 0.02 sec. (6.67 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.27 sec. (194.40 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           28.0000        0.0000           100.00%\n",
      "*     0+    0                           17.0000        0.0000           100.00%\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "      0     0        1.0000    16       15.0000        1.0000      240   93.33%\n",
      "      0     0        1.0000    16       15.0000      Cuts: 32      263   93.33%\n",
      "      0     0        1.0000    23       15.0000      Cuts: 28      350   93.33%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000    15       15.0000        1.0000      350   93.33%\n",
      "Elapsed time = 41.95 sec. (119315.02 ticks, tree = 0.02 MB, solutions = 3)\n",
      "      3     5        1.0000    26       15.0000        1.0000      632   93.33%\n",
      "      7     5        4.0000    35       15.0000        1.0000      813   93.33%\n",
      "     18    16        4.0000    26       15.0000        1.0000     2740   93.33%\n",
      "     41    25        5.4054    29       15.0000        1.0000     3191   93.33%\n",
      "     72    64        8.1081    17       15.0000        1.0000     7357   93.33%\n",
      "    124    76        6.0606    18       15.0000        1.0000     8565   93.33%\n",
      "    182   149        8.5714    14       15.0000        1.0000    12570   93.33%\n",
      "    246   198        6.0606    19       15.0000        1.0000    17244   93.33%\n",
      "    288   225        7.3171    14       15.0000        1.0000    18649   93.33%\n",
      "    569   490       11.6279    14       15.0000        1.0000    31224   93.33%\n",
      "Elapsed time = 59.63 sec. (122485.32 ticks, tree = 12.31 MB, solutions = 3)\n",
      "    967   736        9.5541    15       15.0000        1.0000    41722   93.33%\n",
      "   1310   979        6.3294    21       15.0000        4.0000    49731   73.33%\n",
      "   1543  1258        8.8888    18       15.0000        4.0000    61547   73.33%\n",
      "   1821  1402        9.8576    18       15.0000        4.0000    66656   73.33%\n",
      "   2209  1617       11.4286    14       15.0000        4.0000    73426   73.33%\n",
      "   2571  2031        6.1375    26       15.0000        4.0000    88834   73.33%\n",
      "   2912  2308       10.2564    13       15.0000        4.0000    97652   73.33%\n",
      "   3273  2627       13.3333     5       15.0000        4.0000   108086   73.33%\n",
      "   3522  2867       10.2564    13       15.0000        4.0000   120451   73.33%\n",
      "   3884  3127        cutoff             15.0000        4.0000   129224   73.33%\n",
      "Elapsed time = 115.21 sec. (132046.96 ticks, tree = 258.96 MB, solutions = 3)\n",
      "   4274  3254        6.6399    27       15.0000        4.8780   134030   67.48%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 554217 coefficients.\n",
      "Reduced MIP has 14228 rows, 50 columns, and 711400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.33 sec. (283.93 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 14228 rows, 50 columns, and 711400 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.33 sec. (226.43 ticks)\n",
      "Represolve time = 1.04 sec. (630.86 ticks)\n",
      "   4530     0        2.0000    16       15.0000      Fract: 1   150538   67.48%\n",
      "   4530     0        2.0000    21       15.0000      Cuts: 34   150592   67.48%\n",
      "   4530     0        2.0000    19       15.0000      Cuts: 94   150637   67.48%\n",
      "   4530     0        2.0000    18       15.0000       Cuts: 9   150653   67.48%\n",
      "   4530     0        2.0000    18       15.0000      Cuts: 15   150666   67.48%\n",
      "   4530     2        2.0000    18       15.0000        4.8780   150666   67.48%\n",
      "   4539    11        2.1429    17       15.0000        4.8780   150881   67.48%\n",
      "   4543    15        2.1429    21       15.0000        4.8780   151049   67.48%\n",
      "   4556    26        6.5000    20       15.0000        4.8780   152352   67.48%\n",
      "   4686    32        6.6667    23       15.0000        4.8780   153524   67.48%\n",
      "   5026   241        7.5961    25       15.0000        4.8780   165680   67.48%\n",
      "   5396   561        9.0000    19       15.0000        4.8780   179256   67.48%\n",
      "   5892   837        9.6549    17       15.0000        4.8780   191048   67.48%\n",
      "   6437  1263        9.3872    21       15.0000        4.8780   206253   67.48%\n",
      "Elapsed time = 188.10 sec. (152305.81 ticks, tree = 9.50 MB, solutions = 3)\n",
      "   6908  1669        8.0117    21       15.0000        4.8780   221808   67.48%\n",
      "   7265  2203       13.0000    11       15.0000        4.8780   245947   67.48%\n",
      "   7618  2466       13.8709     6       15.0000        4.8780   257727   67.48%\n",
      "   8025  2699       13.2742    16       15.0000        4.8780   268890   67.48%\n",
      "   8523  3069       11.6667    14       15.0000        4.8780   285592   67.48%\n",
      "   9071  3454       13.2418    14       15.0000        4.8780   299822   67.48%\n",
      "   9568  3732        7.7332    28       15.0000        5.3103   311094   64.60%\n",
      "  10055  4269        7.1156    29       15.0000        5.3591   332569   64.27%\n",
      "  10460  4622        8.3733    24       15.0000        5.4633   345894   63.58%\n",
      "  10985  4818       13.6674    10       15.0000        5.6921   354208   62.05%\n",
      "Elapsed time = 262.69 sec. (161856.68 ticks, tree = 15.25 MB, solutions = 3)\n",
      "  11502  5383       13.1747    11       15.0000        6.0000   375162   60.00%\n",
      "  11982  5666       11.4286    12       15.0000        6.0000   386843   60.00%\n",
      "  12545  6133        9.4784    18       15.0000        6.2124   402696   58.58%\n",
      "  12980  6631       10.8000    15       15.0000        6.3257   419266   57.83%\n",
      "  13354  6846        cutoff             15.0000        6.3889   426966   57.41%\n",
      "  13687  7065       11.0028    17       15.0000        6.5000   434315   56.67%\n",
      "\n",
      "Cover cuts applied:  674\n",
      "Flow cuts applied:  18\n",
      "Mixed integer rounding cuts applied:  8\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   41.40 sec. (119279.64 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  258.85 sec. (49402.04 ticks)\n",
      "  Sync time (average)   =   48.04 sec.\n",
      "  Wait time (average)   =    0.32 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.26 sec. (168681.69 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:56:26 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 02:56:26 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 02:56:26 PM: Compilation took 1.336e+01 seconds\n",
      "(CVXPY) Apr 24 02:56:26 PM: Solver (including time spent in interface) took 3.023e+02 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var90820: value [1. 0. 0. 1. 0. 1. 1. 0. 1. 1. 0. 0. 1. 1. 0. 0. 0. 0. 0. 0. 1. 1. 0. 0.\n",
      " 0. 0. 1. 1. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0.\n",
      " 1. 0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_4_SIR' 'HAI_6_SIR' 'COMP_HIP_KNEE' 'MORT_30_CABG'\n",
      " 'MORT_30_COPD' 'MORT_30_STK' 'PSI_03' 'PSI_12' 'PSI_13' 'OP_29' 'SEP_1'\n",
      " 'H_COMP_2_A_P' 'OP_35_ADM' 'READM_30_HOSP_WIDE']\n",
      "Constructing constraint set for epsilon 0.30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 02:56:26 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 02:56:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 02:56:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 02:56:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 02:56:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:56:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 02:56:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 02:56:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 02:56:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 02:56:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 02:56:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 02:56:40 PM: Finished problem compilation (took 1.377e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 02:56:40 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 145490 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 145490 rows and 0 columns.\n",
      "MIP Presolve modified 612487 coefficients.\n",
      "Reduced MIP has 12995 rows, 50 columns, and 649750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 43.06 sec. (143326.95 ticks)\n",
      "Found incumbent of value 25.000000 after 43.27 sec. (143526.21 ticks)\n",
      "Probing time = 0.02 sec. (6.09 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 12995 rows, 50 columns, and 649750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.31 sec. (197.41 ticks)\n",
      "Probing time = 0.02 sec. (6.09 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.26 sec. (160.45 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           25.0000        0.0000           100.00%\n",
      "*     0+    0                           16.0000        0.0000           100.00%\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                           12.0000        0.0000           100.00%\n",
      "      0     0        1.0000    16       12.0000        1.0000      205   91.67%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000    13       12.0000        1.0000      205   91.67%\n",
      "Elapsed time = 47.59 sec. (146716.19 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     27    21        4.0000    15       12.0000        1.0000      753   91.67%\n",
      "     64    26        5.2632    19       12.0000        1.0000     1249   91.67%\n",
      "*   123+   10                           11.0000        1.0000            90.91%\n",
      "    133   111        4.0000    25       11.0000        1.0000     7954   90.91%\n",
      "    221   176        4.0000    15       11.0000        1.0000    10545   90.91%\n",
      "    354   229        4.0000    16       11.0000        1.0000    12351   90.91%\n",
      "    484   338        8.3333    13       11.0000        1.0000    14490   90.91%\n",
      "    627   474        7.5000    13       11.0000        1.0000    18199   90.91%\n",
      "    802   641        5.5556    15       11.0000        1.0000    23052   90.91%\n",
      "    951   724        5.8824    14       11.0000        1.0000    25407   90.91%\n",
      "   1501  1082        7.0400    17       11.0000        4.0000    35356   63.64%\n",
      "Elapsed time = 64.74 sec. (149838.29 ticks, tree = 69.21 MB, solutions = 5)\n",
      "   1606   889        5.0511    21       11.0000        4.0000    30004   63.64%\n",
      "   1709  1208        7.8947    10       11.0000        4.0000    39003   63.64%\n",
      "   2065  1354        8.0357    12       11.0000        4.0000    42196   63.64%\n",
      "   2553  1570        7.0268    17       11.0000        4.0000    48125   63.64%\n",
      "   3125  2040        6.7814    16       11.0000        4.0000    62400   63.64%\n",
      "   3794  2559        6.8966    13       11.0000        4.0000    77438   63.64%\n",
      "   4399  2780        5.5556    14       11.0000        4.0000    82871   63.64%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 322065 coefficients.\n",
      "Reduced MIP has 12995 rows, 50 columns, and 649750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.27 sec. (238.95 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 12995 rows, 50 columns, and 649750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.32 sec. (206.70 ticks)\n",
      "Represolve time = 0.97 sec. (555.47 ticks)\n",
      "   4642     0        1.0000    18       11.0000     Covers: 2   103532   63.64%\n",
      "   4642     0        1.0000    17       11.0000      Cuts: 18   103566   63.64%\n",
      "   4642     0        1.4706    25       11.0000       Cuts: 5   103652   63.64%\n",
      "   4642     0        1.4706    20       11.0000      Cuts: 58   103684   63.64%\n",
      "   4642     0        1.4706    16       11.0000      Cuts: 26   103705   63.64%\n",
      "   4642     0        1.4706    14       11.0000      Cuts: 12   103722   63.64%\n",
      "   4642     0        1.4706    16       11.0000      Cuts: 34   103756   63.64%\n",
      "   4642     2        1.4706    16       11.0000        4.0000   103756   63.64%\n",
      "   4652     6        4.0000    15       11.0000        4.0000   103877   63.64%\n",
      "   4695    29        6.0000    13       11.0000        4.0000   104498   63.64%\n",
      "Elapsed time = 145.28 sec. (173698.16 ticks, tree = 0.33 MB, solutions = 5)\n",
      "   4814   122        5.0000    16       11.0000        4.0000   110555   63.64%\n",
      "   5328   400        6.7203    16       11.0000        4.0000   117445   63.64%\n",
      "   5992   882        5.0581    20       11.0000        4.0000   128508   63.64%\n",
      "   6795  1522        5.0000    24       11.0000        4.0000   144651   63.64%\n",
      "   7351  1983        5.4829    18       11.0000        4.0000   158107   63.64%\n",
      "   7940  2326        8.1416    15       11.0000        4.0000   167428   63.64%\n",
      "   8561  2868        6.6253    16       11.0000        4.0000   181405   63.64%\n",
      "   9236  3338        7.2052    16       11.0000        4.0000   192310   63.64%\n",
      "   9880  3683        6.5879    19       11.0000        4.5279   201746   58.84%\n",
      "  10373  4334       10.0000     9       11.0000        4.6890   221365   57.37%\n",
      "Elapsed time = 205.04 sec. (183262.10 ticks, tree = 224.35 MB, solutions = 5)\n",
      "  11102  4648        6.8571    14       11.0000        4.8000   229444   56.36%\n",
      "  11797  5354        6.0000    16       11.0000        5.0000   247385   54.55%\n",
      "  12515  5706        6.8571    14       11.0000        5.0000   255651   54.55%\n",
      "  13235  6280        7.0042    16       11.0000        5.0000   269377   54.55%\n",
      "  13869  6727        9.5371    14       11.0000        5.0021   280974   54.53%\n",
      "  14636  7356        9.4024     8       11.0000        5.0521   297873   54.07%\n",
      "  15201  7774        6.8205    17       11.0000        5.1548   306241   53.14%\n",
      "  15689  8093       10.0000     9       11.0000        5.2220   315373   52.53%\n",
      "  16180  8498       10.0000     9       11.0000        5.2593   325143   52.19%\n",
      "  16710  8727        6.3333    18       11.0000        5.3333   330809   51.52%\n",
      "Elapsed time = 257.62 sec. (192819.47 ticks, tree = 376.76 MB, solutions = 5)\n",
      "  17421  9197        6.6000    13       11.0000        5.3333   342588   51.52%\n",
      "  18189  9812        8.1203    19       11.0000        5.3333   356351   51.52%\n",
      "  18764 10137        6.4252    18       11.0000        5.3333   363544   51.52%\n",
      "  19307 10577        6.6056    18       11.0000        5.3333   376540   51.52%\n",
      "  20091 10941        6.8923    19       11.0000        5.3763   384559   51.12%\n",
      "  20684 11420        7.9110    12       11.0000        5.4018   394656   50.89%\n",
      "  21332 11877        8.5937    10       11.0000        5.4804   404308   50.18%\n",
      "  22008 12139        7.2000    12       11.0000        5.5652   411188   49.41%\n",
      "\n",
      "Cover cuts applied:  636\n",
      "Mixed integer rounding cuts applied:  6\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   47.10 sec. (146700.53 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  253.01 sec. (54988.95 ticks)\n",
      "  Sync time (average)   =   36.80 sec.\n",
      "  Wait time (average)   =    0.25 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.11 sec. (201689.48 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:01:42 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 03:01:42 PM: Optimal value: 1.100e+01\n",
      "(CVXPY) Apr 24 03:01:42 PM: Compilation took 1.377e+01 seconds\n",
      "(CVXPY) Apr 24 03:01:42 PM: Solver (including time spent in interface) took 3.020e+02 seconds\n",
      "Optimal value: 11.0\n",
      "Variable var90820: value [0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 0. 1. 0. 0. 1. 0. 0. 0. 0. 0. 0. 1.\n",
      " 0. 0. 1. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 1.\n",
      " 0. 1.]\n",
      "Tasks: ['HAI_5_SIR' 'MORT_30_HF' 'PSI_03' 'PSI_08' 'PSI_15' 'OP_29'\n",
      " 'H_COMP_1_A_P' 'EDAC_30_AMI' 'OP_35_ADM' 'READM_30_HIP_KNEE'\n",
      " 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.35\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:01:42 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:01:43 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:01:43 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:01:43 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:01:43 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:01:43 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:01:43 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:01:43 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:01:43 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:01:43 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:01:56 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:01:57 PM: Finished problem compilation (took 1.447e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:01:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 146338 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 146338 rows and 0 columns.\n",
      "MIP Presolve modified 474883 coefficients.\n",
      "Reduced MIP has 12147 rows, 50 columns, and 607350 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 25.43 sec. (87374.87 ticks)\n",
      "Found incumbent of value 21.000000 after 25.65 sec. (87572.11 ticks)\n",
      "Probing time = 0.02 sec. (5.69 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 12147 rows, 50 columns, and 607350 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (186.26 ticks)\n",
      "Probing time = 0.02 sec. (5.69 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.22 sec. (136.44 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           21.0000        0.0000           100.00%\n",
      "*     0+    0                           11.0000        0.0000           100.00%\n",
      "*     0+    0                           10.0000        0.0000           100.00%\n",
      "      0     0        1.0000    13       10.0000        1.0000      103   90.00%\n",
      "      0     0        1.0000    12       10.0000      Cuts: 75      123   90.00%\n",
      "      0     0        1.0000    12       10.0000      Cuts: 47      132   90.00%\n",
      "      0     0        1.0323    18       10.0000      Cuts: 14      193   89.68%\n",
      "      0     0        1.0323    15       10.0000      Cuts: 83      219   89.68%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0323    15       10.0000        1.0323      219   89.68%\n",
      "Elapsed time = 31.93 sec. (93180.96 ticks, tree = 0.02 MB, solutions = 3)\n",
      "      7     9        3.0000    21       10.0000        1.0323      733   89.68%\n",
      "*    11+    4                            9.0000        1.0323            88.53%\n",
      "     24    22        3.0000    15        9.0000        1.0323     1262   88.53%\n",
      "     95    52        5.1282    14        9.0000        1.0323     2556   88.53%\n",
      "    215   169        3.0000    14        9.0000        1.0323     5807   88.53%\n",
      "    368   246        7.0175     8        9.0000        1.0753     7770   88.05%\n",
      "    544   384        cutoff              9.0000        1.0753    11254   88.05%\n",
      "    714   482        3.0000    14        9.0000        1.0753    14606   88.05%\n",
      "    863   662        6.3492    11        9.0000        1.0753    18940   88.05%\n",
      "   1078   728        cutoff              9.0000        2.7992    20744   68.90%\n",
      "   1599  1140        4.6512    13        9.0000        3.0000    30043   66.67%\n",
      "Elapsed time = 48.17 sec. (96424.33 ticks, tree = 33.44 MB, solutions = 5)\n",
      "   1689  1235        4.5244    20        9.0000        3.0000    32001   66.67%\n",
      "   2100  1442        7.5000    11        9.0000        3.0000    36695   66.67%\n",
      "   2724  1880        5.1471    14        9.0000        3.0000    47587   66.67%\n",
      "   3365  2365        5.1282    15        9.0000        3.0000    61812   66.67%\n",
      "   4011  2839        5.2075    20        9.0000        3.0000    75066   66.67%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 468996 coefficients.\n",
      "Reduced MIP has 12147 rows, 50 columns, and 607350 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.33 sec. (241.84 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 12147 rows, 50 columns, and 607350 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.29 sec. (193.23 ticks)\n",
      "Represolve time = 0.89 sec. (538.17 ticks)\n",
      "   4488     0        2.0000    15        9.0000     Cuts: 120    89904   66.67%\n",
      "   4488     0        2.0000    15        9.0000     Cuts: 236    89958   66.67%\n",
      "   4488     0        2.0000    13        9.0000     Covers: 5    89970   66.67%\n",
      "   4488     0        2.0000    13        9.0000      Cuts: 54    89976   66.67%\n",
      "   4488     2        2.0000    12        9.0000        3.0000    89976   66.67%\n",
      "   4503    11        3.0000    15        9.0000        3.0000    90087   66.67%\n",
      "   4549    34        3.0000    17        9.0000        3.0000    91304   66.67%\n",
      "   5068   439        6.0000    11        9.0000        3.0000   104002   66.67%\n",
      "   6012   894        4.3952    21        9.0000        3.0000   115954   66.67%\n",
      "Elapsed time = 103.63 sec. (113810.25 ticks, tree = 9.31 MB, solutions = 5)\n",
      "   7117  1710        7.5136     9        9.0000        3.0000   132542   66.67%\n",
      "   7981  2437        7.3333     9        9.0000        3.0000   150519   66.67%\n",
      "   8865  3064        7.0588     8        9.0000        3.9386   165987   56.24%\n",
      "   9817  3832        6.2252    19        9.0000        4.0635   184852   54.85%\n",
      "  10637  4365        7.8058     8        9.0000        4.3431   198317   51.74%\n",
      "  11317  4820        6.0000    13        9.0000        4.5000   210611   50.00%\n",
      "  12117  5314    infeasible              9.0000        4.5609   222290   49.32%\n",
      "  13020  5896        6.0000    13        9.0000        4.5971   237658   48.92%\n",
      "  13799  6458        7.5112    11        9.0000        4.6667   251605   48.15%\n",
      "  14645  6777        8.0000     9        9.0000        4.6667   261807   48.15%\n",
      "Elapsed time = 170.20 sec. (123355.68 ticks, tree = 17.58 MB, solutions = 5)\n",
      "  15608  7528        8.0000     9        9.0000        4.7461   280711   47.27%\n",
      "  16506  8138        6.1737    16        9.0000        4.8765   294630   45.82%\n",
      "  17363  8802        7.5000     8        9.0000        4.9575   311418   44.92%\n",
      "  18227  9299        cutoff              9.0000        5.0000   323616   44.44%\n",
      "  19147  9709        5.0245    16        9.0000        5.0000   334375   44.44%\n",
      "  19981 10433        7.5836    13        9.0000        5.0000   353584   44.44%\n",
      "  20776 10799        7.5556    10        9.0000        5.0000   364261   44.44%\n",
      "  21665 11326        6.5475    15        9.0000        5.0000   378108   44.44%\n",
      "  22456 11976        7.0000    12        9.0000        5.0000   393920   44.44%\n",
      "  23432 12527        6.0000    22        9.0000        5.0000   407699   44.44%\n",
      "Elapsed time = 239.35 sec. (132896.44 ticks, tree = 27.05 MB, solutions = 5)\n",
      "  24313 13282        6.1329    18        9.0000        5.0000   427706   44.44%\n",
      "  25165 13811        5.7598    21        9.0000        5.0389   439798   44.01%\n",
      "  26117 14380        7.0000    11        9.0000        5.1000   453427   43.33%\n",
      "  27037 14923        6.0913    19        9.0000        5.1379   466950   42.91%\n",
      "* 27178+15162                            8.0000        5.1441            35.70%\n",
      "  27851 10323        5.8964    27        8.0000        5.1697   481967   35.38%\n",
      "  28657 10716        6.7182    14        8.0000        5.2153   497370   34.81%\n",
      "  29421 11091        7.0000    13        8.0000        5.2574   511171   34.28%\n",
      "  30101 11333        6.4793    18        8.0000        5.2692   520554   34.14%\n",
      "  30788 11639        6.7884    10        8.0000        5.3169   530966   33.54%\n",
      "\n",
      "Cover cuts applied:  1740\n",
      "Flow cuts applied:  5\n",
      "Mixed integer rounding cuts applied:  3\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   31.41 sec. (93151.57 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  268.90 sec. (49158.08 ticks)\n",
      "  Sync time (average)   =   48.15 sec.\n",
      "  Wait time (average)   =    0.25 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.32 sec. (142309.65 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:06:59 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 03:06:59 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 24 03:06:59 PM: Compilation took 1.447e+01 seconds\n",
      "(CVXPY) Apr 24 03:06:59 PM: Solver (including time spent in interface) took 3.023e+02 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var90820: value [ 0.  0.  0. -0. -0. -0. -0. -0. -0. -0.  0. -0.  1. -0.  0.  0. -0.  1.\n",
      " -0. -0. -0. -0.  1. -0. -0.  0. -0.  0. -0. -0. -0.  1.  0. -0.  1. -0.\n",
      "  0. -0.  1.  1. -0. -0. -0.  0.  1. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['MORT_30_STK' 'PSI_09' 'PSI_14' 'H_COMP_5_A_P' 'ePC_07a' 'EDAC_30_PN'\n",
      " 'OP_32' 'READM_30_CABG']\n",
      "Constructing constraint set for epsilon 0.40\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:07:00 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:07:00 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:07:00 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:07:00 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:07:00 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:07:00 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:07:00 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:07:00 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:07:00 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:07:00 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:07:14 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:07:14 PM: Finished problem compilation (took 1.448e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:07:14 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 147622 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 147622 rows and 0 columns.\n",
      "MIP Presolve modified 430701 coefficients.\n",
      "Reduced MIP has 10863 rows, 50 columns, and 543150 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 23.39 sec. (80137.20 ticks)\n",
      "Found incumbent of value 18.000000 after 23.61 sec. (80323.58 ticks)\n",
      "Probing time = 0.01 sec. (5.09 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 10863 rows, 50 columns, and 543150 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (165.91 ticks)\n",
      "Probing time = 0.02 sec. (5.09 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.22 sec. (110.36 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           18.0000        0.0000           100.00%\n",
      "*     0+    0                           10.0000        0.0000           100.00%\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "*     0+    0                            8.0000        0.0000           100.00%\n",
      "      0     0        1.0000    13        8.0000        1.0000       66   87.50%\n",
      "      0     0        1.1628    12        8.0000      Fract: 1       95   85.47%\n",
      "      0     0        1.1852    18        8.0000      Cuts: 41      176   85.18%\n",
      "      0     0        1.7200    11        8.0000      Cuts: 90      199   78.50%\n",
      "      0     0        1.7200    11        8.0000      Cuts: 25      209   78.50%\n",
      "*     0+    0                            7.0000        1.7200            75.43%\n",
      "Detecting symmetries...\n",
      "      0     2        1.7200     9        7.0000        1.7200      209   75.43%\n",
      "Elapsed time = 28.87 sec. (86255.63 ticks, tree = 0.02 MB, solutions = 5)\n",
      "     59    35        4.5455     9        7.0000        1.7200      910   75.43%\n",
      "    283   174        3.0000    10        7.0000        1.7544     3664   74.94%\n",
      "    693   492        5.5556     4        7.0000        1.7544     9038   74.94%\n",
      "   1074   743    infeasible              7.0000        2.0000    14408   71.43%\n",
      "   1426   938        4.0816     9        7.0000        3.0000    18017   57.14%\n",
      "   1643  1110        4.0659    14        7.0000        3.0000    21239   57.14%\n",
      "   1837  1256        4.8936    12        7.0000        3.0000    23651   57.14%\n",
      "   2203  1428        4.0201    12        7.0000        3.0000    26223   57.14%\n",
      "   2474  1723        4.5455     9        7.0000        3.0000    30713   57.14%\n",
      "   3881  2764        4.3478    10        7.0000        3.0000    47777   57.14%\n",
      "Elapsed time = 43.75 sec. (89363.97 ticks, tree = 3.60 MB, solutions = 5)\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 325125 coefficients.\n",
      "Reduced MIP has 10863 rows, 50 columns, and 543150 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.23 sec. (205.57 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 10863 rows, 50 columns, and 543150 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (165.74 ticks)\n",
      "Represolve time = 0.69 sec. (464.05 ticks)\n",
      "   4431     0        2.0000    10        7.0000     Cuts: 131    56177   57.14%\n",
      "   4431     0        2.0000    12        7.0000      Cuts: 83    56211   57.14%\n",
      "   4431     0        2.0000    12        7.0000     Cuts: 195    56240   57.14%\n",
      "   4431     0        2.0000    12        7.0000     Cuts: 178    56251   57.14%\n",
      "   4431     0        2.0000    10        7.0000     Cuts: 150    56267   57.14%\n",
      "   4431     2        2.0000    10        7.0000        3.0000    56267   57.14%\n",
      "   4456     6        3.0000    14        7.0000        3.0000    56394   57.14%\n",
      "   4737   192        5.3081    13        7.0000        3.0000    63842   57.14%\n",
      "   5638   762        4.6667     9        7.0000        3.0000    78261   57.14%\n",
      "   6888  1584        cutoff              7.0000        3.0000    92276   57.14%\n",
      "   7898  2225        4.3094    21        7.0000        3.0000   105796   57.14%\n",
      "   9084  3039        5.0000    11        7.0000        3.5016   124199   49.98%\n",
      "  10371  3756        cutoff              7.0000        3.9101   140414   44.14%\n",
      "  11821  4608        5.4118    10        7.0000        4.0000   161512   42.86%\n",
      "  13222  5246        5.8333    10        7.0000        4.2683   176543   39.02%\n",
      "Elapsed time = 108.76 sec. (105248.26 ticks, tree = 9.50 MB, solutions = 5)\n",
      "  14544  5903        5.2696    19        7.0000        4.3940   191824   37.23%\n",
      "  16122  6588        5.5714     9        7.0000        4.5000   206873   35.71%\n",
      "  17561  7291        5.8057     8        7.0000        4.5000   224152   35.71%\n",
      "  18950  7762        6.0000    11        7.0000        4.5775   236019   34.61%\n",
      "  20466  8450        5.5075    15        7.0000        4.6667   252860   33.33%\n",
      "  21730  9057        6.0000     8        7.0000        4.6667   266664   33.33%\n",
      "  23014  9697        cutoff              7.0000        4.6667   282723   33.33%\n",
      "  24545 10395        cutoff              7.0000        4.6667   299976   33.33%\n",
      "  25839 11060        5.5705    15        7.0000        4.6667   317814   33.33%\n",
      "  27198 11424        5.6413    15        7.0000        4.7469   333914   32.19%\n",
      "Elapsed time = 179.16 sec. (114789.56 ticks, tree = 17.77 MB, solutions = 5)\n",
      "  28458 11647        cutoff              7.0000        4.8643   346882   30.51%\n",
      "  29958 12196        5.2699    19        7.0000        5.0000   362493   28.57%\n",
      "  31293 12701        5.5714    14        7.0000        5.0000   375676   28.57%\n",
      "  32670 13274        6.0000     8        7.0000        5.0000   389441   28.57%\n",
      "  33972 14117        6.0000    11        7.0000        5.0000   411503   28.57%\n",
      "  35094 14351        5.5714    11        7.0000        5.0000   419237   28.57%\n",
      "  36436 14822        6.0000    10        7.0000        5.0000   432404   28.57%\n",
      "  37616 15627        6.0000    10        7.0000        5.0000   458351   28.57%\n",
      "  38850 15915        5.7143    10        7.0000        5.0000   469083   28.57%\n",
      "  39985 16060        cutoff              7.0000        5.0000   487106   28.57%\n",
      "Elapsed time = 250.30 sec. (124335.45 ticks, tree = 24.40 MB, solutions = 5)\n",
      "  40917 15933        cutoff              7.0000        5.0481   496428   27.88%\n",
      "  41898 15557        5.5714     7        7.0000        5.1282   513476   26.74%\n",
      "  42822 15163        cutoff              7.0000        5.2198   527100   25.43%\n",
      "  43744 14717        cutoff              7.0000        5.2500   538976   25.00%\n",
      "  44669 14445        cutoff              7.0000        5.2645   545162   24.79%\n",
      "  45527 14068        cutoff              7.0000        5.3165   554231   24.05%\n",
      "  46414 13479        5.9760     8        7.0000        5.3680   567363   23.31%\n",
      "  47071 13232        6.0000     7        7.0000        5.4000   572616   22.86%\n",
      "\n",
      "Cover cuts applied:  1816\n",
      "Flow cuts applied:  15\n",
      "Mixed integer rounding cuts applied:  18\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   28.45 sec. (86230.29 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  271.88 sec. (46969.56 ticks)\n",
      "  Sync time (average)   =   39.33 sec.\n",
      "  Wait time (average)   =    0.23 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.33 sec. (133199.84 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:12:16 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 03:12:16 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 24 03:12:16 PM: Compilation took 1.448e+01 seconds\n",
      "(CVXPY) Apr 24 03:12:16 PM: Solver (including time spent in interface) took 3.023e+02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var90820: value [ 1. -0. -0.  1. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0.  1. -0.  1. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_4_SIR' 'MORT_30_COPD' 'PSI_90' 'OP_29' 'H_COMP_1_A_P'\n",
      " 'OP_36']\n",
      "Constructing constraint set for epsilon 0.45\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:12:17 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:12:17 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:12:17 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:12:17 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:12:17 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:12:17 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:12:17 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:12:17 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:12:17 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:12:17 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:12:30 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:12:31 PM: Finished problem compilation (took 1.412e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:12:31 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 148490 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 148490 rows and 0 columns.\n",
      "MIP Presolve modified 811831 coefficients.\n",
      "Reduced MIP has 9995 rows, 50 columns, and 499750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 44.09 sec. (156965.21 ticks)\n",
      "Found incumbent of value 17.000000 after 44.28 sec. (157147.10 ticks)\n",
      "Probing time = 0.01 sec. (4.68 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 9995 rows, 50 columns, and 499750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.22 sec. (152.62 ticks)\n",
      "Probing time = 0.04 sec. (4.68 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.20 sec. (103.54 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           17.0000        0.0000           100.00%\n",
      "*     0+    0                            9.0000        0.0000           100.00%\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "      0     0        1.0000    10        6.0000        1.0000       44   83.33%\n",
      "      0     0        1.0969    12        6.0000       Cuts: 5       76   81.72%\n",
      "      0     0        1.2221    12        6.0000      Cuts: 80      132   79.63%\n",
      "      0     0        1.2221    11        6.0000      Cuts: 98      144   79.63%\n",
      "      0     0        1.2221    10        6.0000     Cuts: 127      155   79.63%\n",
      "Detecting symmetries...\n",
      "      0     2        1.2221    10        6.0000        1.2221      155   79.63%\n",
      "Elapsed time = 48.16 sec. (160855.37 ticks, tree = 0.02 MB, solutions = 4)\n",
      "     65    45        4.9180     5        6.0000        1.2221      844   79.63%\n",
      "    190    91        5.0000     9        6.0000        1.2221     2475   79.63%\n",
      "    357   150        4.0816    10        6.0000        1.3749     6531   77.09%\n",
      "    593   219        4.5467    10        6.0000        1.3749     8661   77.09%\n",
      "    809   293        4.4369     6        6.0000        1.4383    11267   76.03%\n",
      "    965   367        1.5206    14        6.0000        1.4383    14113   76.03%\n",
      "   1173   439        3.2213    16        6.0000        1.4383    17108   76.03%\n",
      "   1360   521        4.0000    13        6.0000        3.0000    19377   50.00%\n",
      "   1508   577        4.3956    10        6.0000        3.0000    21342   50.00%\n",
      "   1600   312        cutoff              6.0000        3.0000    12555   50.00%\n",
      "Elapsed time = 64.45 sec. (164244.93 ticks, tree = 0.52 MB, solutions = 4)\n",
      "   1787   680        4.0816    11        6.0000        3.0000    23897   50.00%\n",
      "   2509   977        cutoff              6.0000        3.0000    32965   50.00%\n",
      "   3615  1502        4.3552    15        6.0000        3.1209    46725   47.98%\n",
      "   4841  2201        5.0000    11        6.0000        3.3166    64774   44.72%\n",
      "   6300  2676        4.8402    15        6.0000        3.5072    78339   41.55%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 356745 coefficients.\n",
      "Reduced MIP has 9995 rows, 50 columns, and 499750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.25 sec. (195.22 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 9995 rows, 50 columns, and 499750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.25 sec. (153.14 ticks)\n",
      "Represolve time = 0.66 sec. (431.88 ticks)\n",
      "   6728     0        1.2500    12        6.0000       Cuts: 7    87241   37.78%\n",
      "   6728     0        1.2857    11        6.0000      Cuts: 20    87266   37.78%\n",
      "   6728     0        2.0000     9        6.0000      Cuts: 22    87280   37.78%\n",
      "   6728     0        2.0000     9        6.0000      Cuts: 51    87290   37.78%\n",
      "   6728     0        2.0000    10        6.0000      Cuts: 40    87295   37.78%\n",
      "   6728     0        2.0000     8        6.0000       Cuts: 5    87303   37.78%\n",
      "   6728     2        2.0000     8        6.0000        3.7333    87303   37.78%\n",
      "   6905   136        4.0000     9        6.0000        3.7333    89563   37.78%\n",
      "   7842   658        4.0000     8        6.0000        3.7333    99515   37.78%\n",
      "   9726  1743        cutoff              6.0000        3.7333   115565   37.78%\n",
      "  11155  2440        cutoff              6.0000        3.7333   128933   37.78%\n",
      "Elapsed time = 121.28 sec. (177282.70 ticks, tree = 2.88 MB, solutions = 4)\n",
      "  12149  3078        cutoff              6.0000        3.7333   145255   37.78%\n",
      "  13409  3633        3.9437     9        6.0000        3.7333   162352   37.78%\n",
      "  14909  3939        cutoff              6.0000        3.7705   174744   37.16%\n",
      "\n",
      "Performing restart 2\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 9995 rows, 50 columns, and 499750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.15 sec. (118.20 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 9995 rows, 50 columns, and 499750 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.24 sec. (153.14 ticks)\n",
      "Represolve time = 0.55 sec. (358.59 ticks)\n",
      "  15125     0        2.0000     9        6.0000      Fract: 1   181523   34.97%\n",
      "  15125     0        2.0000     9        6.0000      Cuts: 40   181529   34.97%\n",
      "  15125     0        2.0000     9        6.0000      Cuts: 76   181534   34.97%\n",
      "  15125     0        2.0000     9        6.0000       Cuts: 6   181537   34.97%\n",
      "  15125     0        2.0000     9        6.0000       Cuts: 4   181539   34.97%\n",
      "  15125     2        2.0000     9        6.0000        3.9021   181539   34.97%\n",
      "  15539   188        5.0000     7        6.0000        3.9021   187249   34.97%\n",
      "  16255   470        4.2857     9        6.0000        3.9021   196686   34.97%\n",
      "  17224   751        cutoff              6.0000        3.9021   206354   34.97%\n",
      "  18399  1413        cutoff              6.0000        3.9021   223662   34.97%\n",
      "  19491  1837        cutoff              6.0000        3.9021   237546   34.97%\n",
      "  20657  2129    infeasible              6.0000        3.9021   249417   34.97%\n",
      "Elapsed time = 181.19 sec. (189903.19 ticks, tree = 2.48 MB, solutions = 4)\n",
      "  21401  2272        4.8000     9        6.0000        4.0000   259478   33.33%\n",
      "  22190  2401        4.8777    15        6.0000        4.0000   272467   33.33%\n",
      "  23037  2465        cutoff              6.0000        4.0000   288925   33.33%\n",
      "  23841  2436        4.8000     9        6.0000        4.1969   300900   30.05%\n",
      "  24687  2307        cutoff              6.0000        4.2915   309306   28.48%\n",
      "  25617  1562        cutoff              6.0000        4.4891   322987   25.18%\n",
      "  26622  1021        cutoff              6.0000        4.8462   327056   19.23%\n",
      "  27504   145        cutoff              6.0000        5.0000   340431   16.67%\n",
      "\n",
      "Cover cuts applied:  2078\n",
      "Flow cuts applied:  24\n",
      "Mixed integer rounding cuts applied:  2\n",
      "Gomory fractional cuts applied:  3\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   47.85 sec. (160834.76 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  182.95 sec. (37187.48 ticks)\n",
      "  Sync time (average)   =   45.11 sec.\n",
      "  Wait time (average)   =    0.42 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  230.81 sec. (198022.25 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:16:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:16:24 PM: Optimal value: 6.000e+00\n",
      "(CVXPY) Apr 24 03:16:24 PM: Compilation took 1.412e+01 seconds\n",
      "(CVXPY) Apr 24 03:16:24 PM: Solver (including time spent in interface) took 2.327e+02 seconds\n",
      "Optimal value: 6.0\n",
      "Variable var90820: value [1. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0.\n",
      " 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_4_SIR' 'MORT_30_COPD' 'PSI_12' 'H_COMP_1_A_P'\n",
      " 'READM_30_HF']\n",
      "Constructing constraint set for epsilon 0.50\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:16:24 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:16:24 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:16:24 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:16:24 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:16:24 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:16:24 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:16:24 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:16:24 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:16:24 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:16:24 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:16:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:16:38 PM: Finished problem compilation (took 1.399e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:16:38 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 149772 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 149772 rows and 0 columns.\n",
      "MIP Presolve modified 649299 coefficients.\n",
      "Reduced MIP has 8713 rows, 50 columns, and 435650 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 19.04 sec. (65272.30 ticks)\n",
      "Found incumbent of value 14.000000 after 19.23 sec. (65445.99 ticks)\n",
      "Probing time = 0.02 sec. (4.07 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 8713 rows, 50 columns, and 435650 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.19 sec. (132.68 ticks)\n",
      "Probing time = 0.01 sec. (4.07 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.18 sec. (79.08 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           14.0000        0.0000           100.00%\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "      0     0        1.0000     9        6.0000        1.0000       34   83.33%\n",
      "      0     0        1.0000    12        6.0000     Cuts: 154      115   83.33%\n",
      "      0     0        1.3462    12        6.0000     Cuts: 135      153   77.56%\n",
      "      0     0        1.3462    11        6.0000      Cuts: 33      156   77.56%\n",
      "*     0+    0                            5.0000        1.3462            73.08%\n",
      "      0     0  -1.00000e+75     0        5.0000        1.3462      156   73.08%\n",
      "Detecting symmetries...\n",
      "      0     2        1.3462    11        5.0000        1.3462      156   73.08%\n",
      "Elapsed time = 22.44 sec. (68230.30 ticks, tree = 0.02 MB, solutions = 3)\n",
      "     52    21        cutoff              5.0000        1.5000     1278   70.00%\n",
      "    253   136        3.0000     7        5.0000        2.0000     4490   60.00%\n",
      "    638   375        2.5641     9        5.0000        2.0000     7920   60.00%\n",
      "   1100   607        cutoff              5.0000        2.0000    10492   60.00%\n",
      "   1446   838        3.2258     8        5.0000        2.0900    13905   58.20%\n",
      "   1562   907        3.1010    26        5.0000        2.0979    15261   58.04%\n",
      "   1584   920        2.2222    12        5.0000        2.0979    15501   58.04%\n",
      "   1599   935        3.2857    14        5.0000        2.0979    15704   58.04%\n",
      "   1600   634        3.4483     8        5.0000        2.0979    11206   58.04%\n",
      "   2269  1143        3.7037     5        5.0000        2.1531    18233   56.94%\n",
      "Elapsed time = 36.88 sec. (72263.09 ticks, tree = 5.99 MB, solutions = 3)\n",
      "   3871  1993    infeasible              5.0000        2.3256    32370   53.49%\n",
      "   5285  2715        cutoff              5.0000        3.0000    44862   40.00%\n",
      "   6282  2843        cutoff              5.0000        3.2258    53152   35.48%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 297024 coefficients.\n",
      "Reduced MIP has 8713 rows, 50 columns, and 435650 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.23 sec. (168.80 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 8713 rows, 50 columns, and 435650 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (132.70 ticks)\n",
      "Represolve time = 0.69 sec. (375.84 ticks)\n",
      "   6636     0        1.4556     9        5.0000       Cuts: 3    62874   34.29%\n",
      "   6636     0        1.7333     9        5.0000      Cuts: 36    62881   34.29%\n",
      "   6636     0        1.7333     9        5.0000      Cuts: 51    62889   34.29%\n",
      "   6636     0        2.0000     9        5.0000      Cuts: 17    62893   34.29%\n",
      "   6636     0        2.0000     9        5.0000       Cuts: 5    62895   34.29%\n",
      "   6636     2        2.0000     9        5.0000        3.2857    62895   34.29%\n",
      "   6749    31        3.1429    12        5.0000        3.2857    64997   34.29%\n",
      "   7240   236        4.0000    10        5.0000        3.2857    71806   34.29%\n",
      "   8386   736        3.2759    18        5.0000        3.2857    85167   34.29%\n",
      "   9647  1232        4.0000     7        5.0000        3.2857    97967   34.29%\n",
      "  11093  1850        cutoff              5.0000        3.2857   117769   34.29%\n",
      "  12375   967        cutoff              5.0000        3.8355   128665   23.29%\n",
      "Elapsed time = 88.47 sec. (83009.34 ticks, tree = 1.38 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  1010\n",
      "Flow cuts applied:  7\n",
      "Mixed integer rounding cuts applied:  2\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   22.15 sec. (68222.00 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   69.09 sec. (15459.64 ticks)\n",
      "  Sync time (average)   =   16.91 sec.\n",
      "  Wait time (average)   =    0.16 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   91.24 sec. (83681.65 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:18:11 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:18:11 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 24 03:18:11 PM: Compilation took 1.399e+01 seconds\n",
      "(CVXPY) Apr 24 03:18:11 PM: Solver (including time spent in interface) took 9.334e+01 seconds\n",
      "Optimal value: 5.0\n",
      "Variable var90820: value [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0.\n",
      " 0. 0. 0. 1. 0. 1. 0. 0. 0. 0. 0. 0. 1. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['PSI_11' 'SEP_1' 'H_COMP_2_A_P' 'EDAC_30_AMI' 'OP_32']\n",
      "Constructing constraint set for epsilon 0.55\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:18:11 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:18:11 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:18:11 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:18:11 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:18:11 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:18:11 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:18:11 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:18:11 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:18:11 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:18:11 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:18:23 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:18:24 PM: Finished problem compilation (took 1.218e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:18:24 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 150628 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 150628 rows and 0 columns.\n",
      "MIP Presolve modified 506347 coefficients.\n",
      "Reduced MIP has 7857 rows, 50 columns, and 392850 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 7.37 sec. (26381.35 ticks)\n",
      "Found incumbent of value 12.000000 after 7.54 sec. (26551.43 ticks)\n",
      "Probing time = 0.01 sec. (3.66 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 7857 rows, 50 columns, and 392850 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.15 sec. (120.11 ticks)\n",
      "Probing time = 0.02 sec. (3.67 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.16 sec. (72.22 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           12.0000        0.0000           100.00%\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            5.0000        0.0000           100.00%\n",
      "      0     0        1.0000     9        5.0000        1.0000       33   80.00%\n",
      "      0     0        1.0000     7        5.0000     Cuts: 223       82   80.00%\n",
      "      0     0        1.0000     7        5.0000      Cuts: 56      132   80.00%\n",
      "      0     0        1.0000     8        5.0000      Cuts: 68      151   80.00%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     8        5.0000        1.0000      151   80.00%\n",
      "Elapsed time = 9.07 sec. (27596.68 ticks, tree = 0.02 MB, solutions = 3)\n",
      "     45    17        2.0000     7        5.0000        1.0381      624   79.24%\n",
      "    318   113        3.0769     9        5.0000        1.0830     4646   78.34%\n",
      "    722   198        4.0000     5        5.0000        1.5000     7159   70.00%\n",
      "   1075   292        cutoff              5.0000        1.5000     9758   70.00%\n",
      "   1275   366        3.1561    11        5.0000        1.5000    12250   70.00%\n",
      "   1472   421        cutoff              5.0000        1.5000    13590   70.00%\n",
      "   1597   487        2.0270    10        5.0000        1.5000    14695   70.00%\n",
      "   1600   259        3.4091     8        5.0000        1.5000     8860   70.00%\n",
      "   1641   503        3.1746     8        5.0000        1.5000    15010   70.00%\n",
      "   2969   764        3.1746     5        5.0000        2.0000    19552   60.00%\n",
      "Elapsed time = 22.49 sec. (31495.05 ticks, tree = 0.60 MB, solutions = 3)\n",
      "   4596  1398        4.0000     5        5.0000        2.5316    34347   49.37%\n",
      "*  5788  1727      integral     0        4.0000        2.8124    44058   29.69%\n",
      "\n",
      "Cover cuts applied:  903\n",
      "Flow cuts applied:  4\n",
      "Mixed integer rounding cuts applied:  1\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    8.81 sec. (27587.95 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   23.52 sec. (5800.69 ticks)\n",
      "  Sync time (average)   =    5.81 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   32.34 sec. (33388.65 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:18:58 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:18:58 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 24 03:18:58 PM: Compilation took 1.218e+01 seconds\n",
      "(CVXPY) Apr 24 03:18:58 PM: Solver (including time spent in interface) took 3.412e+01 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var90820: value [ 0.  0.  0.  0.  0.  0.  0.  0.  0.  0. -0.  1.  0.  0.  0.  0. -0. -0.\n",
      "  0. -0.  0. -0.  0. -0.  1.  0.  0.  0.  1. -0.  0.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  1. -0.  0.  0.  0. -0. -0.]\n",
      "Tasks: ['MORT_30_PN' 'PSI_90' 'H_COMP_1_A_P' 'READM_30_AMI']\n",
      "Constructing constraint set for epsilon 0.60\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:18:58 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:18:58 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:18:58 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:18:58 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:18:58 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:18:58 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:18:58 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:18:58 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:18:58 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:18:58 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:19:12 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:19:12 PM: Finished problem compilation (took 1.459e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:19:12 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 151927 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 151927 rows and 0 columns.\n",
      "MIP Presolve modified 524477 coefficients.\n",
      "Reduced MIP has 6558 rows, 50 columns, and 327900 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 7.17 sec. (22173.69 ticks)\n",
      "Found incumbent of value 10.000000 after 7.35 sec. (22335.07 ticks)\n",
      "Probing time = 0.02 sec. (3.06 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 6558 rows, 50 columns, and 327900 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.15 sec. (100.14 ticks)\n",
      "Probing time = 0.01 sec. (3.06 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.13 sec. (61.30 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           10.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.0000     8        4.0000        1.0000       25   75.00%\n",
      "      0     0        1.0000     7        4.0000     Cuts: 132       64   75.00%\n",
      "      0     0        1.0000     8        4.0000      Cuts: 89      125   75.00%\n",
      "      0     0        1.0000     7        4.0000     Cuts: 105      128   75.00%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     7        4.0000        1.0000      128   75.00%\n",
      "Elapsed time = 8.72 sec. (23135.67 ticks, tree = 0.02 MB, solutions = 2)\n",
      "    109    33        2.0000     7        4.0000        1.0000     1417   75.00%\n",
      "    548   113        2.7355    29        4.0000        1.0638     5444   73.40%\n",
      "    852   146        2.9412     5        4.0000        1.3333     7420   66.67%\n",
      "   1274   237        1.6484     7        4.0000        1.3333    10179   66.67%\n",
      "   1740   214        2.7778     4        4.0000        1.6484    12513   58.79%\n",
      "   2416   299        2.9412     6        4.0000        2.0000    16424   50.00%\n",
      "\n",
      "Cover cuts applied:  495\n",
      "Mixed integer rounding cuts applied:  5\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    8.50 sec. (23129.27 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    7.77 sec. (1677.56 ticks)\n",
      "  Sync time (average)   =    2.80 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   16.27 sec. (24806.83 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:19:31 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:19:31 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 24 03:19:31 PM: Compilation took 1.459e+01 seconds\n",
      "(CVXPY) Apr 24 03:19:31 PM: Solver (including time spent in interface) took 1.813e+01 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var90820: value [0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_5_SIR' 'H_COMP_1_A_P' 'EDAC_30_AMI' 'OP_36']\n",
      "Constructing constraint set for epsilon 0.65\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:19:31 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:19:31 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:19:31 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:19:31 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:19:31 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:19:31 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:19:31 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:19:31 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:19:31 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:19:31 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:19:46 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:19:47 PM: Finished problem compilation (took 1.562e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:19:47 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 152780 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 152780 rows and 0 columns.\n",
      "MIP Presolve modified 860808 coefficients.\n",
      "Reduced MIP has 5705 rows, 50 columns, and 285250 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 11.77 sec. (42199.52 ticks)\n",
      "Found incumbent of value 7.000000 after 11.94 sec. (42357.03 ticks)\n",
      "Probing time = 0.02 sec. (2.66 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 5705 rows, 50 columns, and 285250 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.12 sec. (87.08 ticks)\n",
      "Probing time = 0.01 sec. (2.66 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.11 sec. (49.90 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            7.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.0000     6        4.0000        1.0000       22   75.00%\n",
      "      0     0        1.0000     6        4.0000      Cuts: 93       42   75.00%\n",
      "      0     0        1.0000     7        4.0000     Cuts: 107       71   75.00%\n",
      "*     0+    0                            3.0000        1.0000            66.67%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     7        3.0000        1.0000       71   66.67%\n",
      "Elapsed time = 12.91 sec. (42936.99 ticks, tree = 0.02 MB, solutions = 3)\n",
      "    382    98    infeasible              3.0000        1.5000     1875   50.00%\n",
      "\n",
      "Cover cuts applied:  9\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   12.75 sec. (42931.67 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.24 sec. (410.76 ticks)\n",
      "  Sync time (average)   =    0.45 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   13.99 sec. (43342.42 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:03 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:20:03 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 03:20:03 PM: Compilation took 1.562e+01 seconds\n",
      "(CVXPY) Apr 24 03:20:03 PM: Solver (including time spent in interface) took 1.597e+01 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var90820: value [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 1. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['H_COMP_5_A_P' 'EDAC_30_AMI' 'EDAC_30_PN']\n",
      "Constructing constraint set for epsilon 0.70\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:20:03 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:20:03 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:20:03 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:20:03 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:20:03 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:03 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:20:03 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:20:03 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:20:03 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:20:03 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:20:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:20:17 PM: Finished problem compilation (took 1.370e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:17 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 154042 rows and 0 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 154042 rows and 0 columns.\n",
      "MIP Presolve modified 1019764 coefficients.\n",
      "Reduced MIP has 4443 rows, 50 columns, and 222150 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 5.25 sec. (18307.25 ticks)\n",
      "Found incumbent of value 6.000000 after 5.40 sec. (18456.03 ticks)\n",
      "Probing time = 0.01 sec. (2.07 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 4443 rows, 50 columns, and 222150 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.11 sec. (68.00 ticks)\n",
      "Probing time = 0.01 sec. (2.07 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.08 sec. (30.49 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.0000     4        3.0000        1.0000       11   66.67%\n",
      "      0     0        1.0000     5        3.0000      Cuts: 64       27   66.67%\n",
      "      0     0        1.0000     5        3.0000      Cuts: 66       42   66.67%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     5        3.0000        1.0000       42   66.67%\n",
      "Elapsed time = 6.17 sec. (18876.57 ticks, tree = 0.02 MB, solutions = 3)\n",
      "    378     8        cutoff              3.0000        1.5000     1269   50.00%\n",
      "\n",
      "Cover cuts applied:  11\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    6.02 sec. (18872.60 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.95 sec. (376.91 ticks)\n",
      "  Sync time (average)   =    0.44 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    6.98 sec. (19249.51 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:25 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:20:25 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 03:20:25 PM: Compilation took 1.370e+01 seconds\n",
      "(CVXPY) Apr 24 03:20:25 PM: Solver (including time spent in interface) took 8.833e+00 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var90820: value [1. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR' 'COMP_HIP_KNEE' 'H_COMP_1_A_P']\n",
      "Constructing constraint set for epsilon 0.75\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:20:26 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:20:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:20:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:20:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:20:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:20:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:20:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:20:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:20:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:20:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:20:40 PM: Finished problem compilation (took 1.406e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:40 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 154861 rows and 0 columns.\n",
      "MIP Presolve modified 1474398 coefficients.\n",
      "Reduced MIP has 3624 rows, 50 columns, and 181200 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.80 sec. (735.63 ticks)\n",
      "Found incumbent of value 6.000000 after 1.00 sec. (880.08 ticks)\n",
      "Probing time = 0.01 sec. (1.68 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 3624 rows, 50 columns, and 181200 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.08 sec. (56.31 ticks)\n",
      "Probing time = 0.03 sec. (1.68 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.06 sec. (25.20 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.0000     5        3.0000        1.0000        7   66.67%\n",
      "      0     0        1.0000     5        3.0000      Cuts: 48       19   66.67%\n",
      "      0     0        1.0000     5        3.0000      Cuts: 28       31   66.67%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     5        3.0000        1.0000       31   66.67%\n",
      "Elapsed time = 1.64 sec. (1214.86 ticks, tree = 0.02 MB, solutions = 2)\n",
      "*   414   111      integral     0        2.0000        1.0000      966   50.00%\n",
      "\n",
      "Gomory fractional cuts applied:  3\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.51 sec. (1211.82 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.52 sec. (147.72 ticks)\n",
      "  Sync time (average)   =    0.14 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.03 sec. (1359.54 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:44 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:20:44 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 03:20:44 PM: Compilation took 1.406e+01 seconds\n",
      "(CVXPY) Apr 24 03:20:44 PM: Solver (including time spent in interface) took 4.191e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var90820: value [-0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['PSI_04' 'H_COMP_1_A_P']\n",
      "Constructing constraint set for epsilon 0.80\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:20:44 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:20:44 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:20:44 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:20:44 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:20:44 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:44 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:20:44 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:20:44 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:20:44 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:20:44 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:20:56 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:20:57 PM: Finished problem compilation (took 1.270e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:20:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 156023 rows and 0 columns.\n",
      "MIP Presolve modified 1122735 coefficients.\n",
      "Reduced MIP has 2462 rows, 50 columns, and 123100 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.64 sec. (651.36 ticks)\n",
      "Found incumbent of value 5.000000 after 0.77 sec. (788.19 ticks)\n",
      "Probing time = 0.01 sec. (1.14 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2462 rows, 50 columns, and 123100 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (38.39 ticks)\n",
      "Probing time = 0.01 sec. (1.14 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.04 sec. (14.45 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            5.0000        0.0000           100.00%\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "      0     0        1.0000     3        3.0000        1.0000        8   66.67%\n",
      "      0     0        1.0000     3        3.0000       Cuts: 8       14   66.67%\n",
      "      0     0        1.0000     4        3.0000      Cuts: 13       20   66.67%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     4        3.0000        1.0000       20   66.67%\n",
      "Elapsed time = 1.23 sec. (1001.00 ticks, tree = 0.02 MB, solutions = 2)\n",
      "*   290   149      integral     0        2.0000        1.0000      892   50.00%\n",
      "\n",
      "Cover cuts applied:  4\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.15 sec. (998.78 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.46 sec. (174.97 ticks)\n",
      "  Sync time (average)   =    0.17 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.61 sec. (1173.76 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:00 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:21:00 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 03:21:00 PM: Compilation took 1.270e+01 seconds\n",
      "(CVXPY) Apr 24 03:21:00 PM: Solver (including time spent in interface) took 3.376e+00 seconds\n",
      "Optimal value: 1.9999999999999996\n",
      "Variable var90820: value [-0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['PSI_04' 'H_COMP_1_A_P']\n",
      "Constructing constraint set for epsilon 0.85\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:21:00 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:21:00 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:21:00 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:21:00 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:21:00 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:00 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:21:00 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:21:00 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:21:00 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:21:01 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:21:15 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:21:16 PM: Finished problem compilation (took 1.528e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:16 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 156732 rows and 0 columns.\n",
      "MIP Presolve modified 895659 coefficients.\n",
      "Reduced MIP has 1753 rows, 50 columns, and 87650 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.65 sec. (616.60 ticks)\n",
      "Found incumbent of value 4.000000 after 0.79 sec. (749.50 ticks)\n",
      "Probing time = 0.00 sec. (1.45 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1753 rows, 50 columns, and 87650 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (26.28 ticks)\n",
      "Probing time = 0.00 sec. (1.45 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.04 sec. (10.43 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     4        2.0000        1.0000        7   50.00%\n",
      "      0     0        cutoff              2.0000                    106    0.00%\n",
      "Elapsed time = 1.04 sec. (871.90 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.05 sec. (871.90 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.05 sec. (871.90 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:19 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:21:19 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 03:21:19 PM: Compilation took 1.528e+01 seconds\n",
      "(CVXPY) Apr 24 03:21:19 PM: Solver (including time spent in interface) took 3.192e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var90820: value [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 1.\n",
      " 0. 0.]\n",
      "Tasks: ['READM_30_COPD' 'READM_30_HIP_KNEE']\n",
      "Constructing constraint set for epsilon 0.90\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:21:19 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:21:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:21:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:21:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:21:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:19 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:21:19 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:21:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:21:19 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:21:19 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:21:34 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:21:35 PM: Finished problem compilation (took 1.581e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:35 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 157701 rows and 0 columns.\n",
      "MIP Presolve modified 516862 coefficients.\n",
      "Reduced MIP has 784 rows, 50 columns, and 39200 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.54 sec. (560.42 ticks)\n",
      "Found incumbent of value 4.000000 after 0.67 sec. (687.02 ticks)\n",
      "Probing time = 0.00 sec. (0.63 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 784 rows, 50 columns, and 39200 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (13.93 ticks)\n",
      "Probing time = 0.01 sec. (0.63 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (4.35 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     3        2.0000        1.0000        5   50.00%\n",
      "      0     0        cutoff              2.0000                    103    0.00%\n",
      "Elapsed time = 0.78 sec. (745.46 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.79 sec. (745.46 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.79 sec. (745.46 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:21:38 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 03:21:38 PM: Compilation took 1.581e+01 seconds\n",
      "(CVXPY) Apr 24 03:21:38 PM: Solver (including time spent in interface) took 2.670e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var90820: value [0. 0. 1. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_3_SIR' 'HAI_4_SIR']\n",
      "Constructing constraint set for epsilon 0.95\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 03:21:38 PM: Your problem has 50 variables, 158485 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 03:21:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 03:21:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 03:21:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 03:21:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 03:21:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 03:21:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 03:21:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 03:21:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 03:21:56 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 03:21:57 PM: Finished problem compilation (took 1.892e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158227 rows and 0 columns.\n",
      "MIP Presolve modified 240765 coefficients.\n",
      "Reduced MIP has 258 rows, 50 columns, and 12900 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.47 sec. (522.94 ticks)\n",
      "Found incumbent of value 3.000000 after 0.59 sec. (646.44 ticks)\n",
      "Probing time = 0.01 sec. (0.19 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 258 rows, 50 columns, and 12900 nonzeros.\n",
      "Reduced MIP has 50 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (4.91 ticks)\n",
      "Probing time = 0.00 sec. (0.19 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (1.33 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            3.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     3        2.0000        1.0000        4   50.00%\n",
      "      0     0        cutoff              2.0000                     84    0.00%\n",
      "Elapsed time = 0.64 sec. (665.13 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.66 sec. (665.13 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.66 sec. (665.13 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 03:21:59 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 03:21:59 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 03:21:59 PM: Compilation took 1.892e+01 seconds\n",
      "(CVXPY) Apr 24 03:21:59 PM: Solver (including time spent in interface) took 2.476e+00 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var90820: value [0. 1. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_2_SIR' 'HAI_3_SIR']\n"
     ]
    }
   ],
   "source": [
    "outputs = selection_algorithms.solve_lp_pp(hq_ranks_df, all_tasks, epsilons=np.arange(0, 1, 0.05), cplex_params={'timelimit': 300})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "ef7c33a5-8d02-4654-8ebc-f6466fabf2d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[50.0, 46.0, 34.0, 25.0, 19.0, 15.0, 11.0, 8.0, 7.0, 6.0, 5.0, 4.0, 4.0, 3.0, 3.0, 2.0, 1.9999999999999996, 2.0, 2.0, 2.0]\n"
     ]
    }
   ],
   "source": [
    "print(outputs)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "10fa45cb-3b27-41ce-90bd-db38c34d3b9c",
   "metadata": {},
   "source": [
    "## Min epsilon s.t. honor roll satisfies PP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "95955e4d-68ef-48b8-ae2d-6dbdf9e2c597",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.strong_pp_loss_fast(0.7, hq_ranks_df, all_tasks, CHC_METRICS, verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "98bf1b78-a3a2-4f9d-a31b-5cc04cf51baa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "45"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.strong_pp_loss_fast(0.65, hq_ranks_df, all_tasks, CHC_METRICS, verbose=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "be4a080c-c01a-4775-9ad0-6ab69b04f445",
   "metadata": {},
   "source": [
    "## IP Augmented"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "3c8adfb9-d62c-4b7e-94ff-47b901f1b46e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Constructing program parameters\n",
      "Constructing constraint set for epsilon 0.00\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:40:21 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:40:21 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:40:21 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:40:21 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:40:21 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:40:21 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:40:21 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:40:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:40:21 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:40:21 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:40:34 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:40:34 PM: Finished problem compilation (took 1.342e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:40:34 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158486 rows and 50 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.57 sec. (497.78 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.70 sec. (613.48 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.70 sec. (613.48 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:40:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:40:37 PM: Optimal value: 5.000e+01\n",
      "(CVXPY) Apr 24 05:40:37 PM: Compilation took 1.342e+01 seconds\n",
      "(CVXPY) Apr 24 05:40:37 PM: Solver (including time spent in interface) took 2.587e+00 seconds\n",
      "Optimal value: 50.0\n",
      "Variable var296980: value [1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF'\n",
      " 'MORT_30_PN' 'MORT_30_STK' 'PSI_03' 'PSI_04' 'PSI_06' 'PSI_08' 'PSI_09'\n",
      " 'PSI_10' 'PSI_11' 'PSI_12' 'PSI_13' 'PSI_14' 'PSI_15' 'PSI_90' 'OP_23'\n",
      " 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_6_Y_P' 'H_COMP_7_SA' 'ePC_07a' 'ePC_07b'\n",
      " 'EDAC_30_AMI' 'EDAC_30_HF' 'EDAC_30_PN' 'OP_32' 'OP_35_ADM' 'OP_35_ED'\n",
      " 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.05\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:40:37 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:40:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:40:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:40:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:40:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:40:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:40:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:40:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:40:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:40:37 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:40:51 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:40:52 PM: Finished problem compilation (took 1.465e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:40:52 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 141513 rows and 12 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 141515 rows and 12 columns.\n",
      "MIP Presolve modified 429476 coefficients.\n",
      "Reduced MIP has 16971 rows, 38 columns, and 640278 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 48.29 sec. (152835.18 ticks)\n",
      "Found incumbent of value 48.000000 after 48.51 sec. (153037.99 ticks)\n",
      "Probing time = 0.02 sec. (6.03 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 16971 rows, 38 columns, and 640278 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.34 sec. (186.47 ticks)\n",
      "Probing time = 0.02 sec. (6.03 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.36 sec. (221.07 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           48.0000       12.0000            75.00%\n",
      "*     0+    0                           47.0000       12.0000            74.47%\n",
      "      0     0       40.0000    29       47.0000       40.0000      281   14.89%\n",
      "      0     0       40.0000    22       47.0000       Cuts: 4      288   14.89%\n",
      "      0     0       40.0000    22       47.0000      Cuts: 21      305   14.89%\n",
      "      0     0       40.0000    22       47.0000    MIRcuts: 2      307   14.89%\n",
      "*     0+    0                           46.0000       40.0000            13.04%\n",
      "Detecting symmetries...\n",
      "      0     2       40.0000    22       46.0000       40.0000      307   13.04%\n",
      "Elapsed time = 54.91 sec. (158240.84 ticks, tree = 0.02 MB, solutions = 3)\n",
      "      5     6       40.0397    27       46.0000       40.0000      624   13.04%\n",
      "     35    20       43.0000    13       46.0000       40.0000     1238   13.04%\n",
      "     81    45       43.0000    12       46.0000       40.0000     2521   13.04%\n",
      "    164    77       40.0574    24       46.0000       40.0000     4842   13.04%\n",
      "    275   120       43.0000    12       46.0000       40.0000     7072   13.04%\n",
      "    379   168       42.5404    15       46.0000       40.0000     9684   13.04%\n",
      "    486   206       42.1053    19       46.0000       40.0000    12039   13.04%\n",
      "    592   253       41.0000    22       46.0000       40.0000    14198   13.04%\n",
      "    722   256       42.8923    19       46.0000       40.0000    15170   13.04%\n",
      "   1078   451        cutoff             46.0000       40.0000    25545   13.04%\n",
      "Elapsed time = 74.67 sec. (161396.77 ticks, tree = 1.14 MB, solutions = 3)\n",
      "   1594   650       44.9786    12       46.0000       41.0000    34437   10.87%\n",
      "   2091   808       44.9438    10       46.0000       41.9355    46110    8.84%\n",
      "   2677   907       44.9288     9       46.0000       42.0872    52775    8.51%\n",
      "   3193  1016       44.0000    10       46.0000       43.0000    63986    6.52%\n",
      "   3556  1119       43.0000    17       46.0000       43.0000    72352    6.52%\n",
      "   4151  1231        cutoff             46.0000       43.0000    78802    6.52%\n",
      "   4709  1174    infeasible             46.0000       43.5897    85185    5.24%\n",
      "   5293  1102       45.0000     8       46.0000       44.0000    92192    4.35%\n",
      "   5852   899    infeasible             46.0000       44.0000   102826    4.35%\n",
      "   6478   619    infeasible             46.0000       44.2797   109813    3.74%\n",
      "Elapsed time = 138.65 sec. (170949.83 ticks, tree = 0.72 MB, solutions = 3)\n",
      "   7201   480       45.0000     8       46.0000       44.8052   111441    2.60%\n",
      "   7884   111       45.0000     8       46.0000       45.0000   119349    2.17%\n",
      "\n",
      "Cover cuts applied:  1554\n",
      "Mixed integer rounding cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   54.47 sec. (158202.54 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   96.10 sec. (15419.84 ticks)\n",
      "  Sync time (average)   =   23.99 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  150.57 sec. (173622.38 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:43:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:43:24 PM: Optimal value: 4.600e+01\n",
      "(CVXPY) Apr 24 05:43:24 PM: Compilation took 1.465e+01 seconds\n",
      "(CVXPY) Apr 24 05:43:24 PM: Solver (including time spent in interface) took 1.526e+02 seconds\n",
      "Optimal value: 46.0\n",
      "Variable var296980: value [1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 0. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 1. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF'\n",
      " 'MORT_30_PN' 'PSI_03' 'PSI_04' 'PSI_06' 'PSI_08' 'PSI_09' 'PSI_10'\n",
      " 'PSI_11' 'PSI_12' 'PSI_13' 'PSI_14' 'PSI_15' 'PSI_90' 'OP_23' 'OP_29'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'ePC_07a' 'ePC_07b' 'EDAC_30_PN' 'OP_32' 'OP_35_ADM'\n",
      " 'OP_35_ED' 'OP_36' 'READM_30_AMI' 'READM_30_CABG' 'READM_30_COPD'\n",
      " 'READM_30_HF' 'READM_30_HIP_KNEE' 'READM_30_HOSP_WIDE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:43:25 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:43:25 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:43:25 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:43:25 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:43:25 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:43:25 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:43:25 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:43:25 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:43:25 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:43:25 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:43:41 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:43:41 PM: Finished problem compilation (took 1.671e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:43:41 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 142749 rows and 12 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 142762 rows and 12 columns.\n",
      "MIP Presolve modified 308440 coefficients.\n",
      "Reduced MIP has 15724 rows, 38 columns, and 594184 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 15.93 sec. (48059.22 ticks)\n",
      "Found incumbent of value 42.000000 after 16.15 sec. (48253.79 ticks)\n",
      "Probing time = 0.03 sec. (5.56 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 15724 rows, 38 columns, and 594184 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.28 sec. (172.98 ticks)\n",
      "Probing time = 0.02 sec. (5.57 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.25 sec. (173.67 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           42.0000       12.0000            71.43%\n",
      "*     0+    0                           40.0000       12.0000            70.00%\n",
      "*     0+    0                           38.0000       12.0000            68.42%\n",
      "      0     0       33.0000    14       38.0000       33.0000      442   13.16%\n",
      "      0     0       33.0000    10       38.0000       Cuts: 8      448   13.16%\n",
      "      0     0       33.0000    10       38.0000      Cuts: 20      469   13.16%\n",
      "      0     0       33.0000    11       38.0000      Cuts: 14      484   13.16%\n",
      "Detecting symmetries...\n",
      "      0     2       33.0000    11       38.0000       33.0000      484   13.16%\n",
      "Elapsed time = 21.23 sec. (52755.38 ticks, tree = 0.02 MB, solutions = 3)\n",
      "     30    20       33.0000    12       38.0000       33.0000      702   13.16%\n",
      "    145   107       33.0000    12       38.0000       33.0000     2516   13.16%\n",
      "*   206+  113                           37.0000       33.0000            10.81%\n",
      "    291   163        cutoff             37.0000       33.0000     4348   10.81%\n",
      "    450   270    infeasible             37.0000       33.0000     7023   10.81%\n",
      "    580   319       33.1797    15       37.0000       33.0000     8790   10.81%\n",
      "    765   442       33.0000    10       37.0000       33.0000    12209   10.81%\n",
      "*   946+  451                           36.0000       33.0000             8.33%\n",
      "    946   507    infeasible             36.0000       33.0000    13854    8.33%\n",
      "   1147   575       34.5401    14       36.0000       33.0000    16082    8.33%\n",
      "   1340   656       33.0000    10       36.0000       33.0000    18172    8.33%\n",
      "   2004  1008    infeasible             36.0000       33.0000    26033    8.33%\n",
      "Elapsed time = 38.23 sec. (55869.43 ticks, tree = 2.70 MB, solutions = 5)\n",
      "   2554  1288       33.0000    14       36.0000       33.0000    31569    8.33%\n",
      "   2564  1059       33.0000    11       36.0000       33.0000    26849    8.33%\n",
      "   2668  1342       33.2798    14       36.0000       33.0000    33017    8.33%\n",
      "   3169  1381       35.0000    11       36.0000       33.0000    34641    8.33%\n",
      "   3974  1598       34.0000     7       36.0000       33.0000    40088    8.33%\n",
      "   4752  2094    infeasible             36.0000       33.0000    54100    8.33%\n",
      "   5504  2510       35.0000     9       36.0000       33.0000    65293    8.33%\n",
      "   6238  2821       33.0000    10       36.0000       33.0000    73498    8.33%\n",
      "   6771  3202       34.5109    12       36.0000       33.0000    83004    8.33%\n",
      "   7228  3340       33.0000    13       36.0000       33.0000    86416    8.33%\n",
      "Elapsed time = 110.25 sec. (70733.26 ticks, tree = 8.85 MB, solutions = 5)\n",
      "   7724  3552       33.1349    15       36.0000       33.0000    92164    8.33%\n",
      "   8244  3837        cutoff             36.0000       33.0000   100641    8.33%\n",
      "   8796  4053        cutoff             36.0000       33.0000   107590    8.33%\n",
      "   9357  4321       35.0000     8       36.0000       33.0000   115487    8.33%\n",
      "   9971  4497    infeasible             36.0000       33.0000   121596    8.33%\n",
      "  10555  4907       33.6538    12       36.0000       33.0000   134581    8.33%\n",
      "  11157  5170        cutoff             36.0000       33.0000   143530    8.33%\n",
      "  11837  5390        cutoff             36.0000       33.0000   152505    8.33%\n",
      "  12351  5652       34.0631    17       36.0000       33.0000   162512    8.33%\n",
      "  12982  5816       35.0000    10       36.0000       33.0000   169243    8.33%\n",
      "Elapsed time = 167.28 sec. (80286.48 ticks, tree = 13.42 MB, solutions = 5)\n",
      "  13284  5896       33.0000    12       36.0000       33.0000   171400    8.33%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 184 rows and 0 columns.\n",
      "MIP Presolve modified 419133 coefficients.\n",
      "Reduced MIP has 15540 rows, 38 columns, and 587192 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.28 sec. (235.40 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 15540 rows, 38 columns, and 587192 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.45 sec. (181.23 ticks)\n",
      "Represolve time = 1.02 sec. (534.74 ticks)\n",
      "  13285     0       33.0000    12       36.0000       Cuts: 3   181492    8.33%\n",
      "  13285     0       33.0000    11       36.0000       Cuts: 3   181515    8.33%\n",
      "  13285     0       33.0000    10       36.0000      Cuts: 20   181535    8.33%\n",
      "  13285     0       33.0000     9       36.0000      Fract: 1   181547    8.33%\n",
      "  13285     2       33.0000     9       36.0000       33.0000   181547    8.33%\n",
      "  13356    50       33.0000    13       36.0000       33.0000   182191    8.33%\n",
      "  13814   306       34.8214     7       36.0000       33.0000   188598    8.33%\n",
      "  14473   662        cutoff             36.0000       33.0000   195675    8.33%\n",
      "  15144  1019       35.0000    11       36.0000       33.0000   202705    8.33%\n",
      "  15840  1401       33.6220    14       36.0000       33.0000   210865    8.33%\n",
      "  16390  1593       35.0000     7       36.0000       33.0000   217090    8.33%\n",
      "  17111  1974       35.0000     9       36.0000       33.0000   226333    8.33%\n",
      "  17722  2291       33.0000    14       36.0000       33.0000   233209    8.33%\n",
      "Elapsed time = 222.79 sec. (145545.61 ticks, tree = 3.87 MB, solutions = 5)\n",
      "  18349  2559       33.1169    18       36.0000       33.0000   239589    8.33%\n",
      "  19085  3024       33.0000    13       36.0000       33.0000   251759    8.33%\n",
      "  19768  3283       34.0000     9       36.0000       33.0000   258037    8.33%\n",
      "  20463  3679        cutoff             36.0000       33.0000   268251    8.33%\n",
      "  21006  4018       33.3876    15       36.0000       33.0000   280132    8.33%\n",
      "  21564  4270       35.0000    16       36.0000       33.0000   288575    8.33%\n",
      "  22190  4597       35.0000     8       36.0000       33.0000   297648    8.33%\n",
      "  22848  4921       35.0000    10       36.0000       33.0000   306264    8.33%\n",
      "  23433  5215        cutoff             36.0000       33.0000   315342    8.33%\n",
      "  23837  5398       34.0000    11       36.0000       33.0000   321346    8.33%\n",
      "Elapsed time = 277.87 sec. (155105.34 ticks, tree = 11.49 MB, solutions = 5)\n",
      "  23968  5488       33.5368    16       36.0000       33.0000   324918    8.33%\n",
      "  24095  5529       33.3961    19       36.0000       33.0000   326116    8.33%\n",
      "  24418  5620       33.8402    17       36.0000       33.0000   328921    8.33%\n",
      "  24949  5893       34.0007    12       36.0000       33.0000   338049    8.33%\n",
      "  25508  6069       33.9726    12       36.0000       33.0000   343450    8.33%\n",
      "\n",
      "Cover cuts applied:  510\n",
      "Mixed integer rounding cuts applied:  12\n",
      "Gomory fractional cuts applied:  8\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   20.78 sec. (52725.85 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  279.56 sec. (108105.60 ticks)\n",
      "  Sync time (average)   =   50.29 sec.\n",
      "  Wait time (average)   =    0.28 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  300.34 sec. (160831.46 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:48:44 PM: Problem status: optimal_inaccurate\n",
      "(CVXPY) Apr 24 05:48:44 PM: Optimal value: 3.600e+01\n",
      "(CVXPY) Apr 24 05:48:44 PM: Compilation took 1.671e+01 seconds\n",
      "(CVXPY) Apr 24 05:48:44 PM: Solver (including time spent in interface) took 3.021e+02 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/serenawang/anaconda3/envs/python310/lib/python3.10/site-packages/cvxpy/problems/problem.py:1504: UserWarning: Solution may be inaccurate. Try another solver, adjusting the solver settings, or solve with verbose=True for more information.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal value: 36.0\n",
      "Variable var296980: value [1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 0. 1. 0. 1. 1. 0. 1. 1. 1. 0. 0. 1. 0. 1.\n",
      " 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 0. 1. 1. 0. 1. 1. 0. 0. 1. 0. 1. 1. 1.\n",
      " 0. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_PN' 'PSI_03'\n",
      " 'PSI_04' 'PSI_08' 'PSI_09' 'PSI_10' 'PSI_13' 'PSI_15' 'PSI_90' 'OP_23'\n",
      " 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA' 'ePC_07a' 'EDAC_30_AMI' 'EDAC_30_HF' 'OP_32'\n",
      " 'OP_35_ADM' 'READM_30_AMI' 'READM_30_COPD' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:48:44 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:48:44 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:48:44 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:48:44 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:48:44 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:48:44 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:48:44 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:48:44 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:48:44 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:48:44 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:48:57 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:48:58 PM: Finished problem compilation (took 1.406e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:48:58 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 144152 rows and 12 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 144171 rows and 12 columns.\n",
      "MIP Presolve modified 458203 coefficients.\n",
      "Reduced MIP has 14315 rows, 38 columns, and 541480 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 27.17 sec. (94732.33 ticks)\n",
      "Found incumbent of value 37.000000 after 27.40 sec. (94921.41 ticks)\n",
      "Probing time = 0.02 sec. (5.08 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 14315 rows, 38 columns, and 541480 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.23 sec. (157.42 ticks)\n",
      "Probing time = 0.02 sec. (5.08 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.23 sec. (152.86 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           37.0000       12.0000            67.57%\n",
      "*     0+    0                           32.0000       12.0000            62.50%\n",
      "*     0+    0                           31.0000       12.0000            61.29%\n",
      "*     0+    0                           30.0000       12.0000            60.00%\n",
      "      0     0       28.0000    12       30.0000       28.0000      220    6.67%\n",
      "      0     0       28.0000     8       30.0000       Cuts: 3      228    6.67%\n",
      "      0     0       28.0000    10       30.0000      Cuts: 13      241    6.67%\n",
      "      0     0       28.0000     7       30.0000       Cuts: 2      247    6.67%\n",
      "      0     0       28.0000     8       30.0000      Cuts: 15      255    6.67%\n",
      "Detecting symmetries...\n",
      "      0     2       28.0000     8       30.0000       28.0000      255    6.67%\n",
      "Elapsed time = 31.17 sec. (98279.94 ticks, tree = 0.02 MB, solutions = 4)\n",
      "*    20+    8                           29.0000       28.0000             3.45%\n",
      "     69    32       28.0000     7       29.0000       28.0000      458    3.45%\n",
      "    248   158    infeasible             29.0000       28.0000     1404    3.45%\n",
      "    474   261       28.0000     4       29.0000       28.0000     2643    3.45%\n",
      "    723   381       28.0000     7       29.0000       28.0000     3931    3.45%\n",
      "    960   472    infeasible             29.0000       28.0000     5578    3.45%\n",
      "   1209   538       28.0000     8       29.0000       28.0000     6912    3.45%\n",
      "   1443   608       28.0000     7       29.0000       28.0000     8241    3.45%\n",
      "   1585   638       28.0000     8       29.0000       28.0000     9358    3.45%\n",
      "   1607   612    infeasible             29.0000       28.0000     8334    3.45%\n",
      "   2522   760    infeasible             29.0000       28.0000    11408    3.45%\n",
      "Elapsed time = 44.01 sec. (104796.19 ticks, tree = 0.79 MB, solutions = 6)\n",
      "*  2724   849      integral     0       28.0000       28.0000    13699    0.00%\n",
      "   2918   640       28.0000     3       28.0000       28.0000     9315    0.00%\n",
      "\n",
      "Cover cuts applied:  782\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   30.78 sec. (98254.42 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   14.95 sec. (8138.28 ticks)\n",
      "  Sync time (average)   =    4.47 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   45.73 sec. (106392.70 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:49:46 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:49:46 PM: Optimal value: 2.800e+01\n",
      "(CVXPY) Apr 24 05:49:46 PM: Compilation took 1.406e+01 seconds\n",
      "(CVXPY) Apr 24 05:49:46 PM: Solver (including time spent in interface) took 4.755e+01 seconds\n",
      "Optimal value: 28.0\n",
      "Variable var296980: value [ 1.  1.  1. -0.  1.  1. -0. -0.  1.  1. -0.  1.  1. -0. -0. -0. -0.  1.\n",
      "  1. -0. -0.  1. -0. -0.  1.  1. -0.  1.  1.  1.  1.  1. -0.  1.  1. -0.\n",
      "  1. -0.  1.  1. -0.  1. -0.  1. -0. -0.  1.  1. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_PN' 'MORT_30_STK' 'PSI_09'\n",
      " 'PSI_10' 'PSI_13' 'PSI_90' 'OP_23' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'ePC_07a' 'EDAC_30_AMI'\n",
      " 'EDAC_30_PN' 'OP_32' 'OP_35_ED' 'READM_30_AMI' 'READM_30_HF'\n",
      " 'READM_30_HIP_KNEE']\n",
      "Constructing constraint set for epsilon 0.20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:49:46 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:49:46 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:49:46 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:49:46 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:49:46 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:49:46 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:49:46 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:49:46 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:49:46 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:49:46 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:49:57 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:49:58 PM: Finished problem compilation (took 1.199e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:49:58 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 146128 rows and 12 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 146132 rows and 12 columns.\n",
      "MIP Presolve modified 502327 coefficients.\n",
      "Reduced MIP has 12354 rows, 38 columns, and 468102 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 14.65 sec. (54991.77 ticks)\n",
      "Found incumbent of value 33.000000 after 14.85 sec. (55169.72 ticks)\n",
      "Probing time = 0.02 sec. (4.34 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 12354 rows, 38 columns, and 468102 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (135.96 ticks)\n",
      "Probing time = 0.02 sec. (4.34 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.19 sec. (105.14 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           33.0000       12.0000            63.64%\n",
      "*     0+    0                           25.0000       12.0000            52.00%\n",
      "      0     0       24.0000     8       25.0000       24.0000       88    4.00%\n",
      "      0     0       24.0000     9       25.0000      Cuts: 12      111    4.00%\n",
      "      0     0       24.0000     7       25.0000      Cuts: 17      118    4.00%\n",
      "*     0+    0                           24.0000       24.0000             0.00%\n",
      "      0     0        cutoff             24.0000       24.0000      125    0.00%\n",
      "Elapsed time = 15.98 sec. (55991.43 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  7\n",
      "Flow cuts applied:  1\n",
      "Mixed integer rounding cuts applied:  3\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   16.03 sec. (55992.79 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   16.03 sec. (55992.79 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:50:16 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:50:16 PM: Optimal value: 2.400e+01\n",
      "(CVXPY) Apr 24 05:50:16 PM: Compilation took 1.199e+01 seconds\n",
      "(CVXPY) Apr 24 05:50:16 PM: Solver (including time spent in interface) took 1.802e+01 seconds\n",
      "Optimal value: 24.0\n",
      "Variable var296980: value [ 1.  1.  1.  1.  1.  1. -0.  1.  1.  1. -0.  1. -0. -0. -0. -0. -0. -0.\n",
      "  1. -0.  0. -0. -0. -0.  1. -0.  1.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      "  1. -0.  1. -0.  1. -0. -0. -0. -0. -0.  1.  1. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_PN' 'PSI_10'\n",
      " 'PSI_90' 'OP_29' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA' 'EDAC_30_AMI' 'EDAC_30_PN' 'OP_35_ADM'\n",
      " 'READM_30_HF' 'READM_30_HIP_KNEE']\n",
      "Constructing constraint set for epsilon 0.25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:50:16 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:50:16 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:50:16 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:50:16 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:50:16 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:50:16 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:50:16 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:50:16 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:50:16 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:50:16 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:50:29 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:50:29 PM: Finished problem compilation (took 1.329e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:50:29 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 149009 rows and 12 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 149011 rows and 12 columns.\n",
      "MIP Presolve modified 880583 coefficients.\n",
      "Reduced MIP has 9475 rows, 38 columns, and 359225 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 23.59 sec. (94886.96 ticks)\n",
      "Found incumbent of value 28.000000 after 23.79 sec. (95051.57 ticks)\n",
      "Probing time = 0.02 sec. (3.24 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 9475 rows, 38 columns, and 359225 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.18 sec. (103.56 ticks)\n",
      "Probing time = 0.02 sec. (3.24 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.15 sec. (67.74 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           28.0000       12.0000            57.14%\n",
      "*     0+    0                           22.0000       12.0000            45.45%\n",
      "      0     0        cutoff             22.0000       22.0000       61    0.00%\n",
      "      0     0        cutoff             22.0000       22.0000       61    0.00%\n",
      "Elapsed time = 24.35 sec. (95321.69 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   24.38 sec. (95322.73 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   24.38 sec. (95322.73 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:50:56 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:50:56 PM: Optimal value: 2.200e+01\n",
      "(CVXPY) Apr 24 05:50:56 PM: Compilation took 1.329e+01 seconds\n",
      "(CVXPY) Apr 24 05:50:56 PM: Solver (including time spent in interface) took 2.610e+01 seconds\n",
      "Optimal value: 22.0\n",
      "Variable var296980: value [1. 1. 1. 0. 1. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 1. 0.\n",
      " 1. 1. 0. 1. 1. 1. 1. 1. 0. 1. 0. 0. 0. 0. 0. 1. 0. 1. 1. 0. 1. 1. 1. 1.\n",
      " 0. 0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_13'\n",
      " 'PSI_14' 'PSI_90' 'OP_23' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA' 'OP_32' 'OP_35_ED' 'OP_36'\n",
      " 'READM_30_CABG' 'READM_30_COPD' 'READM_30_HF' 'READM_30_HIP_KNEE']\n",
      "Constructing constraint set for epsilon 0.30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:50:56 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:50:56 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:50:56 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:50:56 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:50:56 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:50:56 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:50:56 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:50:56 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:50:56 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:50:56 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:51:07 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:51:07 PM: Finished problem compilation (took 1.161e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:07 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 152852 rows and 12 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 152852 rows and 12 columns.\n",
      "MIP Presolve modified 850870 coefficients.\n",
      "Reduced MIP has 5634 rows, 38 columns, and 213828 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 10.29 sec. (39502.24 ticks)\n",
      "Found incumbent of value 25.000000 after 10.58 sec. (39647.51 ticks)\n",
      "Probing time = 0.02 sec. (1.87 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 5634 rows, 38 columns, and 213828 nonzeros.\n",
      "Reduced MIP has 38 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.11 sec. (61.81 ticks)\n",
      "Probing time = 0.01 sec. (1.87 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.10 sec. (37.17 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           25.0000       12.0000            52.00%\n",
      "*     0+    0                           20.0000       12.0000            40.00%\n",
      "      0     0        cutoff             20.0000       20.0000       18    0.00%\n",
      "      0     0        cutoff             20.0000       20.0000       18    0.00%\n",
      "Elapsed time = 10.95 sec. (39804.43 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =   10.98 sec. (39805.05 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   10.98 sec. (39805.05 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:51:20 PM: Optimal value: 2.000e+01\n",
      "(CVXPY) Apr 24 05:51:20 PM: Compilation took 1.161e+01 seconds\n",
      "(CVXPY) Apr 24 05:51:20 PM: Solver (including time spent in interface) took 1.263e+01 seconds\n",
      "Optimal value: 20.0\n",
      "Variable var296980: value [1. 1. 1. 0. 1. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 1. 0. 0. 1. 1. 1. 1. 1. 0. 1. 0. 0. 0. 0. 1. 1. 0. 1. 1. 0. 1. 1. 0. 1.\n",
      " 0. 1.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA' 'EDAC_30_PN' 'OP_32' 'OP_35_ED' 'OP_36' 'READM_30_CABG'\n",
      " 'READM_30_COPD' 'READM_30_HIP_KNEE' 'READM_30_PN']\n",
      "Constructing constraint set for epsilon 0.35\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:51:20 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:51:20 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:51:20 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:51:20 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:51:20 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:21 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:51:21 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:51:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:51:21 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:51:21 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:51:32 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:51:32 PM: Finished problem compilation (took 1.172e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:32 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Presolve has eliminated 155926 rows and 13 columns...\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 155926 rows and 13 columns.\n",
      "MIP Presolve modified 593292 coefficients.\n",
      "Reduced MIP has 2560 rows, 37 columns, and 94318 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 3.51 sec. (11746.99 ticks)\n",
      "Found incumbent of value 22.000000 after 3.64 sec. (11879.77 ticks)\n",
      "Probing time = 0.01 sec. (1.54 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2560 rows, 37 columns, and 94318 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (28.50 ticks)\n",
      "Probing time = 0.01 sec. (1.54 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.03 sec. (13.36 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           22.0000       12.0000            45.45%\n",
      "*     0+    0                           19.0000       12.0000            36.84%\n",
      "      0     0       18.4615     1       19.0000       18.4615        9    2.83%\n",
      "      0     0        cutoff             19.0000       18.4615        9    2.83%\n",
      "Elapsed time = 3.86 sec. (11990.14 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    3.86 sec. (11990.41 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    3.86 sec. (11990.41 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:51:38 PM: Optimal value: 1.900e+01\n",
      "(CVXPY) Apr 24 05:51:38 PM: Compilation took 1.172e+01 seconds\n",
      "(CVXPY) Apr 24 05:51:38 PM: Solver (including time spent in interface) took 5.791e+00 seconds\n",
      "Optimal value: 19.0\n",
      "Variable var296980: value [ 1.  1.  1.  0.  1.  1.  0.  0.  1.  1.  1.  1.  1.  1.  1.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1.  0.  1.  0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF' 'MORT_30_PN' 'MORT_30_STK'\n",
      " 'PSI_03' 'PSI_04' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for epsilon 0.40\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:51:38 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:51:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:51:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:51:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:51:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:51:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:51:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:51:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:51:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:51:51 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:51:52 PM: Finished problem compilation (took 1.355e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:52 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 157577 rows and 13 columns.\n",
      "MIP Presolve modified 193110 coefficients.\n",
      "Reduced MIP has 909 rows, 37 columns, and 33597 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.79 sec. (1312.17 ticks)\n",
      "Found incumbent of value 19.000000 after 0.96 sec. (1436.25 ticks)\n",
      "Probing time = 0.00 sec. (0.55 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 909 rows, 37 columns, and 33597 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (11.87 ticks)\n",
      "Probing time = 0.01 sec. (0.55 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (4.35 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           19.0000       12.0000            36.84%\n",
      "*     0+    0                           18.0000       12.0000            33.33%\n",
      "      0     0       17.1429     1       18.0000       17.1429        8    4.76%\n",
      "      0     0        cutoff             18.0000       17.1429        8    4.76%\n",
      "Elapsed time = 1.04 sec. (1476.68 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    1.07 sec. (1476.78 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.07 sec. (1476.78 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:55 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:51:55 PM: Optimal value: 1.800e+01\n",
      "(CVXPY) Apr 24 05:51:55 PM: Compilation took 1.355e+01 seconds\n",
      "(CVXPY) Apr 24 05:51:55 PM: Solver (including time spent in interface) took 3.015e+00 seconds\n",
      "Optimal value: 18.0\n",
      "Variable var296980: value [ 1.  1.  1.  0.  1.  1.  1.  1.  1.  1.  1.  1.  0.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1.  0.  1.  0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'MORT_30_HF'\n",
      " 'MORT_30_PN' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for epsilon 0.45\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:51:55 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:51:55 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:51:55 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:51:55 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:51:55 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:51:55 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:51:55 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:51:55 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:51:55 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:51:55 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:52:09 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:52:10 PM: Finished problem compilation (took 1.477e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:10 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158040 rows and 13 columns.\n",
      "MIP Presolve modified 250908 coefficients.\n",
      "Reduced MIP has 446 rows, 37 columns, and 16271 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.74 sec. (1214.00 ticks)\n",
      "Found incumbent of value 17.000000 after 0.86 sec. (1337.65 ticks)\n",
      "Probing time = 0.01 sec. (0.27 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 446 rows, 37 columns, and 16271 nonzeros.\n",
      "Reduced MIP has 36 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (5.83 ticks)\n",
      "Probing time = 0.00 sec. (0.27 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (1.98 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           17.0000       12.0000            29.41%\n",
      "*     0+    0                           16.0000       12.0000            25.00%\n",
      "      0     0        cutoff             16.0000       16.0000        4    0.00%\n",
      "      0     0        cutoff             16.0000       16.0000        4    0.00%\n",
      "Elapsed time = 0.92 sec. (1361.30 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.92 sec. (1361.35 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.92 sec. (1361.35 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:52:13 PM: Optimal value: 1.600e+01\n",
      "(CVXPY) Apr 24 05:52:13 PM: Compilation took 1.477e+01 seconds\n",
      "(CVXPY) Apr 24 05:52:13 PM: Solver (including time spent in interface) took 2.719e+00 seconds\n",
      "Optimal value: 16.0\n",
      "Variable var296980: value [ 1.  1.  1.  0.  1.  1.  1.  1.  1.  1.  0.  0.  0.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  1.  0.  0.  1.  1.  1.  1.  1.  0.  1.  0. -0.\n",
      "  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_CABG' 'MORT_30_COPD' 'PSI_90'\n",
      " 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P'\n",
      " 'H_COMP_7_SA']\n",
      "Constructing constraint set for epsilon 0.50\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:52:13 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:52:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:52:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:52:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:52:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:13 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:52:13 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:52:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:52:13 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:52:13 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:52:25 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:52:26 PM: Finished problem compilation (took 1.274e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:26 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158372 rows and 24 columns.\n",
      "MIP Presolve modified 361007 coefficients.\n",
      "Reduced MIP has 114 rows, 26 columns, and 2817 nonzeros.\n",
      "Reduced MIP has 23 binaries, 3 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.67 sec. (892.00 ticks)\n",
      "Found incumbent of value 16.000000 after 0.78 sec. (1012.97 ticks)\n",
      "Probing time = 0.00 sec. (0.12 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 114 rows, 26 columns, and 2817 nonzeros.\n",
      "Reduced MIP has 23 binaries, 3 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (1.12 ticks)\n",
      "Probing time = 0.00 sec. (0.12 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.31 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           16.0000       12.0000            25.00%\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "      0     0        cutoff             15.0000       15.0000        4    0.00%\n",
      "      0     0        cutoff             15.0000       15.0000        4    0.00%\n",
      "Elapsed time = 0.80 sec. (1016.27 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.82 sec. (1016.28 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.82 sec. (1016.28 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:28 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:52:28 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 05:52:28 PM: Compilation took 1.274e+01 seconds\n",
      "(CVXPY) Apr 24 05:52:28 PM: Solver (including time spent in interface) took 2.723e+00 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var296980: value [ 1.  1.  1.  0.  1.  1.  1.  1. -0.  1.  0.  0.  0.  0. -0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  0.  1. -0.  0.  1.  1.  1.  1.  1.  0.  1. -0.  0.\n",
      "  0.  0.  0. -0. -0. -0. -0.  0. -0. -0.  0. -0.  0.  0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'MORT_30_AMI' 'MORT_30_COPD' 'PSI_90' 'SEP_1'\n",
      " 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for epsilon 0.55\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:52:29 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:52:29 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:52:29 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:52:29 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:52:29 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:29 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:52:29 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:52:29 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:52:29 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:52:29 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:52:41 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:52:42 PM: Finished problem compilation (took 1.297e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:42 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158442 rows and 33 columns.\n",
      "MIP Presolve modified 352120 coefficients.\n",
      "Reduced MIP has 44 rows, 17 columns, and 637 nonzeros.\n",
      "Reduced MIP has 15 binaries, 2 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.51 sec. (666.77 ticks)\n",
      "Found incumbent of value 15.000000 after 0.62 sec. (788.79 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 44 rows, 17 columns, and 637 nonzeros.\n",
      "Reduced MIP has 15 binaries, 2 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.33 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.00 sec. (0.08 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000       12.0000            20.00%\n",
      "      0     0        cutoff             15.0000                      1    0.00%\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.64 sec. (789.73 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.64 sec. (789.73 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:44 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:52:44 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 24 05:52:44 PM: Compilation took 1.297e+01 seconds\n",
      "(CVXPY) Apr 24 05:52:44 PM: Solver (including time spent in interface) took 2.589e+00 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var296980: value [ 1.  1.  1.  1.  1.  1. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0.  0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'MORT_30_AMI' 'MORT_30_CABG' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P'\n",
      " 'H_COMP_2_A_P' 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for epsilon 0.60\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:52:44 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:52:44 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:52:44 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:52:44 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:52:44 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:45 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:52:45 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:52:45 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:52:45 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:52:45 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:52:56 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:52:57 PM: Finished problem compilation (took 1.254e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:52:57 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158473 rows and 37 columns.\n",
      "MIP Presolve modified 362768 coefficients.\n",
      "Reduced MIP has 13 rows, 13 columns, and 138 nonzeros.\n",
      "Reduced MIP has 12 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.55 sec. (695.11 ticks)\n",
      "Found incumbent of value 14.000000 after 0.66 sec. (816.23 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 5 rows and 3 columns.\n",
      "MIP Presolve modified 24 coefficients.\n",
      "Reduced MIP has 8 rows, 10 columns, and 60 nonzeros.\n",
      "Reduced MIP has 9 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.07 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 8 rows, 10 columns, and 60 nonzeros.\n",
      "Reduced MIP has 9 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.03 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "MIP emphasis: balance optimality and feasibility.\n",
      "MIP search method: dynamic search.\n",
      "Parallel mode: deterministic, using up to 16 threads.\n",
      "Root relaxation solution time = 0.01 sec. (0.01 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           14.0000       12.0000            14.29%\n",
      "      0     0        cutoff             14.0000                      1    0.00%\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.81 sec. (816.99 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.81 sec. (816.99 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:53:00 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:53:00 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 24 05:53:00 PM: Compilation took 1.254e+01 seconds\n",
      "(CVXPY) Apr 24 05:53:00 PM: Solver (including time spent in interface) took 2.486e+00 seconds\n",
      "Optimal value: 14.0\n",
      "Variable var296980: value [ 1.  1.  1.  1.  1.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'COMP_HIP_KNEE' 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P'\n",
      " 'H_COMP_3_A_P' 'H_COMP_5_A_P' 'H_COMP_7_SA']\n",
      "Constructing constraint set for epsilon 0.65\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 05:53:00 PM: Your problem has 50 variables, 158486 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 05:53:00 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 05:53:00 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 05:53:00 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 05:53:00 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:53:00 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 24 05:53:00 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 24 05:53:00 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 05:53:00 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 24 05:53:00 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 24 05:53:13 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 24 05:53:14 PM: Finished problem compilation (took 1.417e+01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:53:14 PM: Invoking solver CPLEX  to obtain a solution.\n",
      "Version identifier: 22.1.1.0 | 2022-11-28 | 9160aff4d\n",
      "CPXPARAM_Read_DataCheck                          1\n",
      "CPXPARAM_TimeLimit                               300\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Warning:  Non-integral bounds for integer variables rounded.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 158486 rows and 50 columns.\n",
      "MIP Presolve modified 562718 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.52 sec. (528.72 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.64 sec. (650.70 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.00 sec. (0.00 ticks)\n",
      "  Sync time (average)   =    0.00 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.64 sec. (650.70 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 05:53:17 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 05:53:17 PM: Optimal value: 1.300e+01\n",
      "(CVXPY) Apr 24 05:53:17 PM: Compilation took 1.417e+01 seconds\n",
      "(CVXPY) Apr 24 05:53:17 PM: Solver (including time spent in interface) took 2.543e+00 seconds\n",
      "Optimal value: 13.0\n",
      "Variable var296980: value [ 1.  1.  1.  1.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0.  1. -0. -0.  1.  1.  1.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.]\n",
      "Tasks: ['HAI_1_SIR' 'HAI_2_SIR' 'HAI_3_SIR' 'HAI_4_SIR' 'HAI_5_SIR' 'HAI_6_SIR'\n",
      " 'PSI_90' 'SEP_1' 'H_COMP_1_A_P' 'H_COMP_2_A_P' 'H_COMP_3_A_P'\n",
      " 'H_COMP_5_A_P' 'H_COMP_7_SA']\n"
     ]
    }
   ],
   "source": [
    "outputs_augmented = selection_algorithms.solve_lp_pp(hq_ranks_df, all_tasks, epsilons=np.arange(0, 0.7, 0.05), cplex_params={'timelimit': 300}, starting_tasks=CHC_METRICS)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e53c70a8-a823-4547-becf-350770f07916",
   "metadata": {},
   "source": [
    "## Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 293,
   "id": "58e52503-fc09-4897-b4a6-653798ea6991",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/s_/ycjsvp3d07b2h09m_hw3bkyr0000gn/T/ipykernel_32104/2787173053.py:6: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  upper_bounds = [( (2 / eps**2) * math.log(m)) for eps in epsilons]\n",
      "/var/folders/s_/ycjsvp3d07b2h09m_hw3bkyr0000gn/T/ipykernel_32104/2787173053.py:7: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  lower_bounds = [( (1 / (288 * eps**2)) * math.log(m)) for eps in epsilons]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5,4))\n",
    "epsilons = np.arange(0, 1, 0.05)\n",
    "\n",
    "n = len(all_tasks)\n",
    "m = len(hq_df)\n",
    "upper_bounds = [( (2 / eps**2) * math.log(m)) for eps in epsilons]\n",
    "lower_bounds = [( (1 / (288 * eps**2)) * math.log(m)) for eps in epsilons]\n",
    "\n",
    "epslim=0.7\n",
    "epsilim_index = np.where(abs(epsilons-epslim) < 0.001)[0][0]\n",
    "existing_size=12\n",
    "plt.scatter(epsilons, outputs, label='IP', color='orange')\n",
    "plt.scatter(epsilons[:epsilim_index], outputs_augmented[:epsilim_index], label='IP augmented', marker='x', color='brown', linewidth=0.75)\n",
    "plt.plot(epsilons, upper_bounds, color='black', label='Upper bound', linestyle=':')\n",
    "plt.plot(epsilons, lower_bounds, color='grey', label=r'Lower bound', linestyle=':')\n",
    "plt.axhline(existing_size, color='red', label='Size of existing subset')\n",
    "plt.axvline(epslim, color='red', linestyle='--', label=\"Min $\\epsilon$ for  \\n existing subset\")\n",
    "plt.xlabel(r'Tolerance $\\epsilon$', fontsize=12)\n",
    "plt.xticks(fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "plt.ylabel(r'Selected subset size $|K|$', fontsize=12)\n",
    "plt.ylim((0,n+10))\n",
    "# plt.legend(fontsize=12)\n",
    "plt.savefig('pp_hospital.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "b15e2de1-69a0-4d82-b404-994cfe974261",
   "metadata": {},
   "outputs": [],
   "source": [
    "our_metrics_pp = ['HAI_5_SIR', 'MORT_30_HF', 'PSI_03', 'PSI_08', 'PSI_15', 'OP_29', 'H_COMP_1_A_P', 'EDAC_30_AMI', 'OP_35_ADM', 'READM_30_HIP_KNEE','READM_30_PN']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "c8217701-5eae-4b11-8a8f-e768fc401738",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>HAI_5_SIR</th>\n",
       "      <th>MORT_30_HF</th>\n",
       "      <th>PSI_03</th>\n",
       "      <th>PSI_08</th>\n",
       "      <th>PSI_15</th>\n",
       "      <th>OP_29</th>\n",
       "      <th>H_COMP_1_A_P</th>\n",
       "      <th>EDAC_30_AMI</th>\n",
       "      <th>OP_35_ADM</th>\n",
       "      <th>READM_30_HIP_KNEE</th>\n",
       "      <th>READM_30_PN</th>\n",
       "      <th>num_above_0.5</th>\n",
       "      <th>num_below_0.1</th>\n",
       "      <th>total_nonan</th>\n",
       "      <th>Facility Name</th>\n",
       "      <th>ratio_above_0.5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.727273</td>\n",
       "      <td>0.777778</td>\n",
       "      <td>0.940520</td>\n",
       "      <td>0.962825</td>\n",
       "      <td>0.966292</td>\n",
       "      <td>0.761364</td>\n",
       "      <td>0.868794</td>\n",
       "      <td>0.716535</td>\n",
       "      <td>0.831683</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.703252</td>\n",
       "      <td>11</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>PENINSULA MEDICAL CENTER</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.522634</td>\n",
       "      <td>0.565056</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>0.517045</td>\n",
       "      <td>0.737589</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.524390</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>PROVIDENCE LITTLE CO OF MARY MED CTR SAN PEDRO</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83</th>\n",
       "      <td>0.566845</td>\n",
       "      <td>0.341564</td>\n",
       "      <td>0.977695</td>\n",
       "      <td>0.836431</td>\n",
       "      <td>0.820225</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.737589</td>\n",
       "      <td>0.700787</td>\n",
       "      <td>0.732673</td>\n",
       "      <td>0.757143</td>\n",
       "      <td>0.813008</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>PROVIDENCE ST. JUDE MEDICAL CENTER</td>\n",
       "      <td>0.909091</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>180</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.152263</td>\n",
       "      <td>0.665428</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.801498</td>\n",
       "      <td>0.687500</td>\n",
       "      <td>0.801418</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.603960</td>\n",
       "      <td>0.757143</td>\n",
       "      <td>0.784553</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>SUTTER AUBURN FAITH HOSPITAL</td>\n",
       "      <td>0.888889</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.353909</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.820225</td>\n",
       "      <td>0.517045</td>\n",
       "      <td>0.737589</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.772277</td>\n",
       "      <td>0.942857</td>\n",
       "      <td>0.849593</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>SUTTER SOLANO MEDICAL CENTER</td>\n",
       "      <td>0.888889</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>209</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.695473</td>\n",
       "      <td>0.892193</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.295880</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.801418</td>\n",
       "      <td>0.897638</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.979675</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>MEMORIALCARE SADDLEBACK MEDICAL CENTER</td>\n",
       "      <td>0.875000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>133</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.576208</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.164794</td>\n",
       "      <td>0.642045</td>\n",
       "      <td>0.592199</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.600000</td>\n",
       "      <td>0.930894</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>SUTTER TRACY COMMUNITY HOSPITAL</td>\n",
       "      <td>0.875000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>92</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.777778</td>\n",
       "      <td>0.107807</td>\n",
       "      <td>0.836431</td>\n",
       "      <td>0.801498</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.868794</td>\n",
       "      <td>0.992126</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.992857</td>\n",
       "      <td>0.991870</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>SEQUOIA HOSPITAL</td>\n",
       "      <td>0.875000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.633745</td>\n",
       "      <td>0.550186</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>0.642045</td>\n",
       "      <td>0.592199</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.321138</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>DOCTORS HOSPITAL OF MANTECA</td>\n",
       "      <td>0.857143</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>281</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.633745</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.244318</td>\n",
       "      <td>0.904255</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.772277</td>\n",
       "      <td>0.650000</td>\n",
       "      <td>0.565041</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>MARK TWAIN MEDICAL CENTER</td>\n",
       "      <td>0.833333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>200</th>\n",
       "      <td>0.673797</td>\n",
       "      <td>0.205761</td>\n",
       "      <td>0.988848</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.988764</td>\n",
       "      <td>0.687500</td>\n",
       "      <td>0.737589</td>\n",
       "      <td>0.811024</td>\n",
       "      <td>0.435644</td>\n",
       "      <td>0.914286</td>\n",
       "      <td>0.621951</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>EISENHOWER MEDICAL CENTER</td>\n",
       "      <td>0.818182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>117</th>\n",
       "      <td>0.796791</td>\n",
       "      <td>0.522634</td>\n",
       "      <td>0.710037</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.692884</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.868794</td>\n",
       "      <td>0.921260</td>\n",
       "      <td>0.673267</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.178862</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>PROVIDENCE HOLY CROSS MEDICAL CENTER</td>\n",
       "      <td>0.818182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>114</th>\n",
       "      <td>0.636364</td>\n",
       "      <td>0.942387</td>\n",
       "      <td>0.739777</td>\n",
       "      <td>0.981413</td>\n",
       "      <td>0.992509</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.592199</td>\n",
       "      <td>0.779528</td>\n",
       "      <td>0.198020</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.394309</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>RONALD REAGAN UCLA MEDICAL CENTER</td>\n",
       "      <td>0.800000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>0.481283</td>\n",
       "      <td>0.847737</td>\n",
       "      <td>0.892193</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>0.687500</td>\n",
       "      <td>0.134752</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.658537</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>SAINT FRANCIS MEDICAL CENTER</td>\n",
       "      <td>0.777778</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.777778</td>\n",
       "      <td>0.550186</td>\n",
       "      <td>0.334572</td>\n",
       "      <td>0.692884</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.592199</td>\n",
       "      <td>0.866142</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.658537</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>ALTA BATES SUMMIT MEDICAL CENTER</td>\n",
       "      <td>0.777778</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>93</th>\n",
       "      <td>0.550802</td>\n",
       "      <td>0.403292</td>\n",
       "      <td>0.795539</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.767790</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.400709</td>\n",
       "      <td>0.976378</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.792857</td>\n",
       "      <td>0.703252</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>PALMDALE REGIONAL MEDICAL CENTER</td>\n",
       "      <td>0.777778</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.452675</td>\n",
       "      <td>0.527881</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>0.113636</td>\n",
       "      <td>0.801418</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.831683</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.784553</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>SUTTER DAVIS HOSPITAL</td>\n",
       "      <td>0.750000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>142</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.633745</td>\n",
       "      <td>0.144981</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>0.517045</td>\n",
       "      <td>0.475177</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.891089</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.747967</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>PIONEERS MEMORIAL HEALTHCARE DISTRICT</td>\n",
       "      <td>0.750000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>226</th>\n",
       "      <td>0.427807</td>\n",
       "      <td>0.835391</td>\n",
       "      <td>0.494424</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.910112</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.932624</td>\n",
       "      <td>0.181102</td>\n",
       "      <td>0.633663</td>\n",
       "      <td>0.757143</td>\n",
       "      <td>0.565041</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>KECK HOSPITAL OF USC</td>\n",
       "      <td>0.727273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.197861</td>\n",
       "      <td>0.962963</td>\n",
       "      <td>0.739777</td>\n",
       "      <td>0.936803</td>\n",
       "      <td>0.943820</td>\n",
       "      <td>0.642045</td>\n",
       "      <td>0.868794</td>\n",
       "      <td>0.795276</td>\n",
       "      <td>0.297030</td>\n",
       "      <td>0.178571</td>\n",
       "      <td>0.621951</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>UC SAN DIEGO HEALTH HILLCREST - HILLCREST MED CTR</td>\n",
       "      <td>0.727273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>157</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.419753</td>\n",
       "      <td>0.866171</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.951311</td>\n",
       "      <td>0.267045</td>\n",
       "      <td>0.737589</td>\n",
       "      <td>0.448819</td>\n",
       "      <td>0.940594</td>\n",
       "      <td>0.600000</td>\n",
       "      <td>0.890244</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>COMMUNITY MEMORIAL HOSPITAL - VENTURA</td>\n",
       "      <td>0.727273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>124</th>\n",
       "      <td>0.631016</td>\n",
       "      <td>0.555556</td>\n",
       "      <td>0.457249</td>\n",
       "      <td>0.907063</td>\n",
       "      <td>0.164794</td>\n",
       "      <td>0.642045</td>\n",
       "      <td>0.868794</td>\n",
       "      <td>0.881890</td>\n",
       "      <td>0.356436</td>\n",
       "      <td>0.757143</td>\n",
       "      <td>0.813008</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>SUTTER SANTA ROSA REGIONAL HOSPITAL</td>\n",
       "      <td>0.727273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>205</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.539033</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.400709</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.565041</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>UCI HEALTH - PLACENTIA LINDA</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.251029</td>\n",
       "      <td>0.631970</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.602996</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.737589</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.792857</td>\n",
       "      <td>0.321138</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>CALIFORNIA PACIFIC MEDICAL CTR-DAVIES CAMPUS HOSP</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>241</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.716049</td>\n",
       "      <td>0.397770</td>\n",
       "      <td>0.836431</td>\n",
       "      <td>0.820225</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.670213</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.221429</td>\n",
       "      <td>0.565041</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>CEDAR-SINAI MARINA DEL REY HOSPITAL</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>237</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.777778</td>\n",
       "      <td>0.527881</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.543071</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.170213</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.422764</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>MONTEREY PARK HOSPITAL</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>227</th>\n",
       "      <td>0.775401</td>\n",
       "      <td>0.633745</td>\n",
       "      <td>0.364312</td>\n",
       "      <td>0.334572</td>\n",
       "      <td>0.801498</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.592199</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.813008</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>SOUTHWEST HEALTHCARE RANCHO SPRINGS HOSPITAL</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>216</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.493827</td>\n",
       "      <td>0.739777</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.801498</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.400709</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.658537</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>PALOMAR MEDICAL CENTER POWAY</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.888889</td>\n",
       "      <td>0.739777</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.460674</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.251773</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.524390</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>PARADISE VALLEY HOSPITAL</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>164</th>\n",
       "      <td>0.764706</td>\n",
       "      <td>0.493827</td>\n",
       "      <td>0.710037</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.741573</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.475177</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.747967</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>KAISER FOUNDATION HOSPITAL - SACRAMENTO</td>\n",
       "      <td>0.714286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>0.283422</td>\n",
       "      <td>0.736626</td>\n",
       "      <td>0.505576</td>\n",
       "      <td>0.111524</td>\n",
       "      <td>0.981273</td>\n",
       "      <td>0.363636</td>\n",
       "      <td>0.801418</td>\n",
       "      <td>0.905512</td>\n",
       "      <td>0.524752</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.967480</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>PROVIDENCE ST. JOSEPH HOSPITAL</td>\n",
       "      <td>0.700000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>0.823529</td>\n",
       "      <td>0.251029</td>\n",
       "      <td>0.665428</td>\n",
       "      <td>0.836431</td>\n",
       "      <td>0.198502</td>\n",
       "      <td>0.153409</td>\n",
       "      <td>0.868794</td>\n",
       "      <td>0.842520</td>\n",
       "      <td>0.990099</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.890244</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>HOAG MEMORIAL HOSPITAL PRESBYTERIAN</td>\n",
       "      <td>0.700000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>230</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.864198</td>\n",
       "      <td>0.914498</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.692884</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.319149</td>\n",
       "      <td>0.787402</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.278571</td>\n",
       "      <td>0.130081</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>DESERT VALLEY HOSPITAL</td>\n",
       "      <td>0.700000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>132</th>\n",
       "      <td>0.588235</td>\n",
       "      <td>0.279835</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.112360</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.801418</td>\n",
       "      <td>0.858268</td>\n",
       "      <td>0.910891</td>\n",
       "      <td>0.107143</td>\n",
       "      <td>0.987805</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>SUTTER ROSEVILLE MEDICAL CENTER</td>\n",
       "      <td>0.700000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>0.133690</td>\n",
       "      <td>0.716049</td>\n",
       "      <td>0.446097</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.741573</td>\n",
       "      <td>0.642045</td>\n",
       "      <td>0.592199</td>\n",
       "      <td>0.984252</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.321138</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>ST MARY MEDICAL CENTER</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>201</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.633745</td>\n",
       "      <td>0.680297</td>\n",
       "      <td>0.684015</td>\n",
       "      <td>0.692884</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.191489</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.178862</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>LA PALMA INTERCOMMUNITY HOSPITAL</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>188</th>\n",
       "      <td>0.320856</td>\n",
       "      <td>0.790123</td>\n",
       "      <td>0.836431</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.711610</td>\n",
       "      <td>0.363636</td>\n",
       "      <td>0.251773</td>\n",
       "      <td>0.606299</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.524390</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>SUTTER DELTA MEDICAL CENTER</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>0.545455</td>\n",
       "      <td>0.917695</td>\n",
       "      <td>0.814126</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.741573</td>\n",
       "      <td>0.142045</td>\n",
       "      <td>0.475177</td>\n",
       "      <td>0.511811</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.199187</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>ADVENTIST HEALTH WHITE MEMORIAL</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75</th>\n",
       "      <td>0.689840</td>\n",
       "      <td>0.604938</td>\n",
       "      <td>0.126394</td>\n",
       "      <td>0.144981</td>\n",
       "      <td>0.644195</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.932624</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>KAISER FOUNDATION HOSPITAL FONTANA/ONTARIO</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>101</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.847584</td>\n",
       "      <td>0.334572</td>\n",
       "      <td>0.865169</td>\n",
       "      <td>0.454545</td>\n",
       "      <td>0.904255</td>\n",
       "      <td>0.826772</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.942857</td>\n",
       "      <td>0.922764</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>FRENCH HOSPITAL MEDICAL CENTER</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>111</th>\n",
       "      <td>NaN</td>\n",
       "      <td>0.205761</td>\n",
       "      <td>0.788104</td>\n",
       "      <td>0.762082</td>\n",
       "      <td>0.243446</td>\n",
       "      <td>0.761364</td>\n",
       "      <td>0.904255</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.891089</td>\n",
       "      <td>0.407143</td>\n",
       "      <td>0.849593</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>MARSHALL MEDICAL CENTER</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>262</th>\n",
       "      <td>0.684492</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.115242</td>\n",
       "      <td>0.553903</td>\n",
       "      <td>0.543071</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.400709</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.565041</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>KAISER FOUNDATION HOSPITAL - SAN LEANDRO</td>\n",
       "      <td>0.666667</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     HAI_5_SIR  MORT_30_HF    PSI_03    PSI_08    PSI_15     OP_29  \\\n",
       "2     0.727273    0.777778  0.940520  0.962825  0.966292  0.761364   \n",
       "38         NaN    0.522634  0.565056  0.684015  0.602996  0.517045   \n",
       "83    0.566845    0.341564  0.977695  0.836431  0.820225  1.000000   \n",
       "180        NaN    0.152263  0.665428  0.684015  0.801498  0.687500   \n",
       "47         NaN    0.353909  0.762082  0.762082  0.820225  0.517045   \n",
       "209   1.000000    0.695473  0.892193  0.553903  0.295880       NaN   \n",
       "133        NaN    0.666667  0.576208  0.684015  0.164794  0.642045   \n",
       "92         NaN    0.777778  0.107807  0.836431  0.801498       NaN   \n",
       "58         NaN    0.633745  0.550186  0.553903  0.602996  0.642045   \n",
       "281        NaN    0.633745       NaN       NaN       NaN  0.244318   \n",
       "200   0.673797    0.205761  0.988848  0.553903  0.988764  0.687500   \n",
       "117   0.796791    0.522634  0.710037  0.684015  0.692884  1.000000   \n",
       "114   0.636364    0.942387  0.739777  0.981413  0.992509  1.000000   \n",
       "50    0.481283    0.847737  0.892193  0.762082  0.602996  0.687500   \n",
       "19    1.000000    0.777778  0.550186  0.334572  0.692884       NaN   \n",
       "93    0.550802    0.403292  0.795539  0.684015  0.767790       NaN   \n",
       "192        NaN    0.452675  0.527881  0.553903  0.602996  0.113636   \n",
       "142        NaN    0.633745  0.144981  0.553903  0.602996  0.517045   \n",
       "226   0.427807    0.835391  0.494424  0.553903  0.910112  1.000000   \n",
       "10    0.197861    0.962963  0.739777  0.936803  0.943820  0.642045   \n",
       "157   1.000000    0.419753  0.866171  0.684015  0.951311  0.267045   \n",
       "124   0.631016    0.555556  0.457249  0.907063  0.164794  0.642045   \n",
       "205        NaN    0.222222  0.539033  0.553903  0.602996  1.000000   \n",
       "3          NaN    0.251029  0.631970  0.762082  0.602996       NaN   \n",
       "241        NaN    0.716049  0.397770  0.836431  0.820225       NaN   \n",
       "237        NaN    0.777778  0.527881  0.553903  0.543071  1.000000   \n",
       "227   0.775401    0.633745  0.364312  0.334572  0.801498       NaN   \n",
       "216        NaN    0.493827  0.739777  0.684015  0.801498  1.000000   \n",
       "9     1.000000    0.888889  0.739777  0.684015  0.460674       NaN   \n",
       "164   0.764706    0.493827  0.710037  0.684015  0.741573       NaN   \n",
       "30    0.283422    0.736626  0.505576  0.111524  0.981273  0.363636   \n",
       "96    0.823529    0.251029  0.665428  0.836431  0.198502  0.153409   \n",
       "230   1.000000    0.864198  0.914498  0.762082  0.692884  1.000000   \n",
       "132   0.588235    0.279835  1.000000  0.553903  0.112360       NaN   \n",
       "88    0.133690    0.716049  0.446097  0.684015  0.741573  0.642045   \n",
       "201        NaN    0.633745  0.680297  0.684015  0.692884       NaN   \n",
       "188   0.320856    0.790123  0.836431  0.762082  0.711610  0.363636   \n",
       "49    0.545455    0.917695  0.814126  0.762082  0.741573  0.142045   \n",
       "75    0.689840    0.604938  0.126394  0.144981  0.644195       NaN   \n",
       "101        NaN    0.222222  0.847584  0.334572  0.865169  0.454545   \n",
       "111        NaN    0.205761  0.788104  0.762082  0.243446  0.761364   \n",
       "262   0.684492         NaN  0.115242  0.553903  0.543071       NaN   \n",
       "\n",
       "     H_COMP_1_A_P  EDAC_30_AMI  OP_35_ADM  READM_30_HIP_KNEE  READM_30_PN  \\\n",
       "2        0.868794     0.716535   0.831683           0.900000     0.703252   \n",
       "38       0.737589          NaN        NaN                NaN     0.524390   \n",
       "83       0.737589     0.700787   0.732673           0.757143     0.813008   \n",
       "180      0.801418          NaN   0.603960           0.757143     0.784553   \n",
       "47       0.737589          NaN   0.772277           0.942857     0.849593   \n",
       "209      0.801418     0.897638        NaN                NaN     0.979675   \n",
       "133      0.592199          NaN        NaN           0.600000     0.930894   \n",
       "92       0.868794     0.992126        NaN           0.992857     0.991870   \n",
       "58       0.592199          NaN        NaN                NaN     0.321138   \n",
       "281      0.904255          NaN   0.772277           0.650000     0.565041   \n",
       "200      0.737589     0.811024   0.435644           0.914286     0.621951   \n",
       "117      0.868794     0.921260   0.673267           0.142857     0.178862   \n",
       "114      0.592199     0.779528   0.198020                NaN     0.394309   \n",
       "50       0.134752     1.000000        NaN                NaN     0.658537   \n",
       "19       0.592199     0.866142        NaN           0.142857     0.658537   \n",
       "93       0.400709     0.976378        NaN           0.792857     0.703252   \n",
       "192      0.801418          NaN   0.831683                NaN     0.784553   \n",
       "142      0.475177          NaN   0.891089                NaN     0.747967   \n",
       "226      0.932624     0.181102   0.633663           0.757143     0.565041   \n",
       "10       0.868794     0.795276   0.297030           0.178571     0.621951   \n",
       "157      0.737589     0.448819   0.940594           0.600000     0.890244   \n",
       "124      0.868794     0.881890   0.356436           0.757143     0.813008   \n",
       "205      0.400709          NaN        NaN                NaN     0.565041   \n",
       "3        0.737589          NaN        NaN           0.792857     0.321138   \n",
       "241      0.670213          NaN        NaN           0.221429     0.565041   \n",
       "237      0.170213          NaN        NaN                NaN     0.422764   \n",
       "227      0.592199          NaN        NaN                NaN     0.813008   \n",
       "216      0.400709          NaN        NaN                NaN     0.658537   \n",
       "9        0.251773          NaN        NaN                NaN     0.524390   \n",
       "164      0.475177          NaN        NaN                NaN     0.747967   \n",
       "30       0.801418     0.905512   0.524752                NaN     0.967480   \n",
       "96       0.868794     0.842520   0.990099                NaN     0.890244   \n",
       "230      0.319149     0.787402        NaN           0.278571     0.130081   \n",
       "132      0.801418     0.858268   0.910891           0.107143     0.987805   \n",
       "88       0.592199     0.984252        NaN                NaN     0.321138   \n",
       "201      0.191489          NaN        NaN                NaN     0.178862   \n",
       "188      0.251773     0.606299        NaN                NaN     0.524390   \n",
       "49       0.475177     0.511811        NaN                NaN     0.199187   \n",
       "75       0.932624          NaN        NaN                NaN          NaN   \n",
       "101      0.904255     0.826772        NaN           0.942857     0.922764   \n",
       "111      0.904255          NaN   0.891089           0.407143     0.849593   \n",
       "262      0.400709          NaN        NaN                NaN     0.565041   \n",
       "\n",
       "     num_above_0.5  num_below_0.1  total_nonan  \\\n",
       "2               11              0           11   \n",
       "38               7              0            7   \n",
       "83              10              0           11   \n",
       "180              8              0            9   \n",
       "47               8              0            9   \n",
       "209              7              0            8   \n",
       "133              7              0            8   \n",
       "92               7              0            8   \n",
       "58               6              0            7   \n",
       "281              5              0            6   \n",
       "200              9              0           11   \n",
       "117              9              0           11   \n",
       "114              8              0           10   \n",
       "50               7              0            9   \n",
       "19               7              0            9   \n",
       "93               7              0            9   \n",
       "192              6              0            8   \n",
       "142              6              0            8   \n",
       "226              8              0           11   \n",
       "10               8              0           11   \n",
       "157              8              0           11   \n",
       "124              8              0           11   \n",
       "205              5              0            7   \n",
       "3                5              0            7   \n",
       "241              5              0            7   \n",
       "237              5              0            7   \n",
       "227              5              0            7   \n",
       "216              5              0            7   \n",
       "9                5              0            7   \n",
       "164              5              0            7   \n",
       "30               7              0           10   \n",
       "96               7              0           10   \n",
       "230              7              0           10   \n",
       "132              7              0           10   \n",
       "88               6              0            9   \n",
       "201              4              0            6   \n",
       "188              6              0            9   \n",
       "49               6              0            9   \n",
       "75               4              0            6   \n",
       "101              6              0            9   \n",
       "111              6              0            9   \n",
       "262              4              0            6   \n",
       "\n",
       "                                         Facility Name  ratio_above_0.5  \n",
       "2                             PENINSULA MEDICAL CENTER         1.000000  \n",
       "38      PROVIDENCE LITTLE CO OF MARY MED CTR SAN PEDRO         1.000000  \n",
       "83                  PROVIDENCE ST. JUDE MEDICAL CENTER         0.909091  \n",
       "180                       SUTTER AUBURN FAITH HOSPITAL         0.888889  \n",
       "47                        SUTTER SOLANO MEDICAL CENTER         0.888889  \n",
       "209             MEMORIALCARE SADDLEBACK MEDICAL CENTER         0.875000  \n",
       "133                    SUTTER TRACY COMMUNITY HOSPITAL         0.875000  \n",
       "92                                    SEQUOIA HOSPITAL         0.875000  \n",
       "58                         DOCTORS HOSPITAL OF MANTECA         0.857143  \n",
       "281                          MARK TWAIN MEDICAL CENTER         0.833333  \n",
       "200                          EISENHOWER MEDICAL CENTER         0.818182  \n",
       "117               PROVIDENCE HOLY CROSS MEDICAL CENTER         0.818182  \n",
       "114                  RONALD REAGAN UCLA MEDICAL CENTER         0.800000  \n",
       "50                        SAINT FRANCIS MEDICAL CENTER         0.777778  \n",
       "19                    ALTA BATES SUMMIT MEDICAL CENTER         0.777778  \n",
       "93                    PALMDALE REGIONAL MEDICAL CENTER         0.777778  \n",
       "192                              SUTTER DAVIS HOSPITAL         0.750000  \n",
       "142              PIONEERS MEMORIAL HEALTHCARE DISTRICT         0.750000  \n",
       "226                               KECK HOSPITAL OF USC         0.727273  \n",
       "10   UC SAN DIEGO HEALTH HILLCREST - HILLCREST MED CTR         0.727273  \n",
       "157              COMMUNITY MEMORIAL HOSPITAL - VENTURA         0.727273  \n",
       "124                SUTTER SANTA ROSA REGIONAL HOSPITAL         0.727273  \n",
       "205                       UCI HEALTH - PLACENTIA LINDA         0.714286  \n",
       "3    CALIFORNIA PACIFIC MEDICAL CTR-DAVIES CAMPUS HOSP         0.714286  \n",
       "241                CEDAR-SINAI MARINA DEL REY HOSPITAL         0.714286  \n",
       "237                             MONTEREY PARK HOSPITAL         0.714286  \n",
       "227       SOUTHWEST HEALTHCARE RANCHO SPRINGS HOSPITAL         0.714286  \n",
       "216                       PALOMAR MEDICAL CENTER POWAY         0.714286  \n",
       "9                             PARADISE VALLEY HOSPITAL         0.714286  \n",
       "164            KAISER FOUNDATION HOSPITAL - SACRAMENTO         0.714286  \n",
       "30                      PROVIDENCE ST. JOSEPH HOSPITAL         0.700000  \n",
       "96                 HOAG MEMORIAL HOSPITAL PRESBYTERIAN         0.700000  \n",
       "230                             DESERT VALLEY HOSPITAL         0.700000  \n",
       "132                    SUTTER ROSEVILLE MEDICAL CENTER         0.700000  \n",
       "88                              ST MARY MEDICAL CENTER         0.666667  \n",
       "201                   LA PALMA INTERCOMMUNITY HOSPITAL         0.666667  \n",
       "188                        SUTTER DELTA MEDICAL CENTER         0.666667  \n",
       "49                     ADVENTIST HEALTH WHITE MEMORIAL         0.666667  \n",
       "75          KAISER FOUNDATION HOSPITAL FONTANA/ONTARIO         0.666667  \n",
       "101                     FRENCH HOSPITAL MEDICAL CENTER         0.666667  \n",
       "111                            MARSHALL MEDICAL CENTER         0.666667  \n",
       "262           KAISER FOUNDATION HOSPITAL - SAN LEANDRO         0.666667  "
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Hospitals chosen according to LITE set\n",
    "hospitals_from_ours = choose_hospitals(hq_df, our_metrics_pp, min_ratio=0.66, max_below_10pct=0, nonan_min=6)\n",
    "hospitals_from_ours"
   ]
  }
 ],
 "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
