{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "3510ae81",
   "metadata": {},
   "source": [
    "# Description \n",
    "This notebook loads HELM data and runs algorithms for positional representation and positional proportionality.\n",
    "\n",
    "Before running this notebook: download HELM tables as HTML files from these pages (accuracy metric tab):\n",
    "* helm_classic_core_table.html: https://crfm.stanford.edu/helm/classic/latest/#/leaderboard/core_scenarios\n",
    "* helm_classic_targeted_table.html: https://crfm.stanford.edu/helm/classic/latest/#/leaderboard/targeted_evaluations\n",
    "* helm_lite_table.html: https://crfm.stanford.edu/helm/lite/latest/#/leaderboard/core_scenarios"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "787ba24c",
   "metadata": {
    "tags": []
   },
   "source": [
    "# Imports and Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "60aeb84a",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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": 3,
   "id": "6e928056",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Helpers\n",
    "\n",
    "def load_df_from_html_table(input_html_file):\n",
    "    \"\"\"Loads data from text file containing html table. Returns a Pandas dataframe.\"\"\"\n",
    "    html = open(input_html_file,'r')\n",
    "    output_df = pd.read_html(html)[0]\n",
    "    return output_df.replace('-', np.nan)\n",
    "\n",
    "def get_voter_columns(input_df):\n",
    "    \"\"\"Returns list of all column names for tasks, aka voter columns\"\"\"\n",
    "    cols = list(input_df.columns)\n",
    "    cols.remove('Model')\n",
    "    cols.remove('Mean win rate')\n",
    "    return cols "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3c6ea5af",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Macros\n",
    "HELM_CANDIDATES_COLUMN = 'Model'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b4982ee",
   "metadata": {},
   "source": [
    "# Load HELM Lite data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "f2d26b7c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of voter columns: 10\n"
     ]
    }
   ],
   "source": [
    "lite_df = load_df_from_html_table('helm_lite_table.html')\n",
    "lite_voter_columns = get_voter_columns(lite_df)\n",
    "print(\"Number of voter columns:\", len(lite_voter_columns))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ea22f140",
   "metadata": {},
   "source": [
    "# Load HELM Classic data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "eaa042a2",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of voter columns: 16\n"
     ]
    }
   ],
   "source": [
    "classic_core_df = load_df_from_html_table('helm_classic_core_table.html')\n",
    "classic_core_voter_columns = get_voter_columns(classic_core_df)\n",
    "print(\"Number of voter columns:\", len(classic_core_voter_columns))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "daa45581",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of voter columns: 23\n"
     ]
    }
   ],
   "source": [
    "classic_targeted_df = load_df_from_html_table('helm_classic_targeted_table.html')\n",
    "classic_targeted_voter_columns = get_voter_columns(classic_targeted_df)\n",
    "print(\"Number of voter columns:\", len(classic_targeted_voter_columns))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "22af3057",
   "metadata": {},
   "source": [
    "## Combine HELM classic core and targeted evaluation scenarios"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "09db78b4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['GSM8K - EM', 'MATH (chain-of-thoughts) - ...', 'WikiFact - EM', 'ICE - BPB', 'Synthetic reasoning (abstra...', 'The Pile - BPB', 'HumanEval (Code) - pass@1', 'OpenbookQA - EM', 'MATH - Equivalent', 'Synthetic reasoning (natura...', 'TruthfulQA - EM', 'MS MARCO (regular) - RR@10', 'TwitterAAE - BPB', 'LSAT - EM', 'BoolQ - EM', 'BBQ - EM', 'XSUM - ROUGE-2', 'LegalSupport - EM', 'IMDB - EM', 'QuAC - F1', 'Dyck - EM', 'Entity matching - EM', 'Data imputation - EM', 'MMLU - EM', 'BLiMP - EM', 'CNN/DailyMail - ROUGE-2', 'MS MARCO (TREC) - NDCG@10', 'bAbI - EM', 'NarrativeQA - F1', 'HellaSwag - EM', 'RAFT - EM', 'NaturalQuestions (open) - F1', 'CivilComments - EM', 'NaturalQuestions (closed) - F1']\n"
     ]
    }
   ],
   "source": [
    "classic_all_voter_columns = list(classic_core_columns_set.union(classic_targeted_columns_set))\n",
    "print(classic_all_voter_columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "358f0525",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Join classic core and targeted columns\n",
    "classic_all_df = classic_core_df.merge(classic_targeted_df, how='inner', on=HELM_CANDIDATES_COLUMN, suffixes=(None, '_targeted'))\n",
    "classic_all_df = classic_all_df[['Model', 'Mean win rate'] + classic_all_voter_columns]\n",
    "classic_all_df[classic_all_voter_columns] = classic_all_df[classic_all_voter_columns].apply(pd.to_numeric)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "id": "4c427f60",
   "metadata": {},
   "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>Model</th>\n",
       "      <th>MMLU - EM_borda_score</th>\n",
       "      <th>MMLU - EM_borda_score_norm</th>\n",
       "      <th>BoolQ - EM_borda_score</th>\n",
       "      <th>BoolQ - EM_borda_score_norm</th>\n",
       "      <th>NarrativeQA - F1_borda_score</th>\n",
       "      <th>NarrativeQA - F1_borda_score_norm</th>\n",
       "      <th>NaturalQuestions (closed) - F1_borda_score</th>\n",
       "      <th>NaturalQuestions (closed) - F1_borda_score_norm</th>\n",
       "      <th>NaturalQuestions (open) - F1_borda_score</th>\n",
       "      <th>...</th>\n",
       "      <th>XSUM - ROUGE-2_borda_score_norm</th>\n",
       "      <th>IMDB - EM_borda_score</th>\n",
       "      <th>IMDB - EM_borda_score_norm</th>\n",
       "      <th>CivilComments - EM_borda_score</th>\n",
       "      <th>CivilComments - EM_borda_score_norm</th>\n",
       "      <th>RAFT - EM_borda_score</th>\n",
       "      <th>RAFT - EM_borda_score_norm</th>\n",
       "      <th>mean_win_rate</th>\n",
       "      <th>total_borda_score</th>\n",
       "      <th>mean_win_rate_rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Llama 2 (70B)</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>65.0</td>\n",
       "      <td>0.984848</td>\n",
       "      <td>65.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>66.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>54.0</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>62.5</td>\n",
       "      <td>0.946970</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>0.942855</td>\n",
       "      <td>619.5</td>\n",
       "      <td>67.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>LLaMA (65B)</td>\n",
       "      <td>64.0</td>\n",
       "      <td>0.969697</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>64.0</td>\n",
       "      <td>0.984615</td>\n",
       "      <td>65.0</td>\n",
       "      <td>0.984848</td>\n",
       "      <td>52.0</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>65.0</td>\n",
       "      <td>0.984848</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>55.0</td>\n",
       "      <td>0.833333</td>\n",
       "      <td>0.909930</td>\n",
       "      <td>598.0</td>\n",
       "      <td>66.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>text-davinci-002</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>53.5</td>\n",
       "      <td>0.823077</td>\n",
       "      <td>57.0</td>\n",
       "      <td>0.863636</td>\n",
       "      <td>62.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.804878</td>\n",
       "      <td>47.5</td>\n",
       "      <td>0.719697</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>0.904312</td>\n",
       "      <td>775.0</td>\n",
       "      <td>65.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Mistral v0.1 (7B)</td>\n",
       "      <td>62.0</td>\n",
       "      <td>0.939394</td>\n",
       "      <td>62.0</td>\n",
       "      <td>0.939394</td>\n",
       "      <td>50.0</td>\n",
       "      <td>0.769231</td>\n",
       "      <td>53.0</td>\n",
       "      <td>0.803030</td>\n",
       "      <td>60.0</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>65.0</td>\n",
       "      <td>0.984848</td>\n",
       "      <td>58.0</td>\n",
       "      <td>0.878788</td>\n",
       "      <td>56.5</td>\n",
       "      <td>0.856061</td>\n",
       "      <td>0.881853</td>\n",
       "      <td>579.5</td>\n",
       "      <td>64.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Cohere Command beta (52.4B)</td>\n",
       "      <td>50.0</td>\n",
       "      <td>0.757576</td>\n",
       "      <td>58.0</td>\n",
       "      <td>0.878788</td>\n",
       "      <td>62.5</td>\n",
       "      <td>0.961538</td>\n",
       "      <td>54.0</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>64.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.865854</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>52.5</td>\n",
       "      <td>0.795455</td>\n",
       "      <td>46.0</td>\n",
       "      <td>0.696970</td>\n",
       "      <td>0.872345</td>\n",
       "      <td>737.5</td>\n",
       "      <td>62.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 36 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                         Model  MMLU - EM_borda_score  \\\n",
       "0                Llama 2 (70B)                   63.0   \n",
       "1                  LLaMA (65B)                   64.0   \n",
       "2             text-davinci-002                   60.0   \n",
       "3            Mistral v0.1 (7B)                   62.0   \n",
       "4  Cohere Command beta (52.4B)                   50.0   \n",
       "\n",
       "   MMLU - EM_borda_score_norm  BoolQ - EM_borda_score  \\\n",
       "0                    0.954545                    65.0   \n",
       "1                    0.969697                    61.0   \n",
       "2                    0.909091                    63.0   \n",
       "3                    0.939394                    62.0   \n",
       "4                    0.757576                    58.0   \n",
       "\n",
       "   BoolQ - EM_borda_score_norm  NarrativeQA - F1_borda_score  \\\n",
       "0                     0.984848                          65.0   \n",
       "1                     0.924242                          64.0   \n",
       "2                     0.954545                          53.5   \n",
       "3                     0.939394                          50.0   \n",
       "4                     0.878788                          62.5   \n",
       "\n",
       "   NarrativeQA - F1_borda_score_norm  \\\n",
       "0                           1.000000   \n",
       "1                           0.984615   \n",
       "2                           0.823077   \n",
       "3                           0.769231   \n",
       "4                           0.961538   \n",
       "\n",
       "   NaturalQuestions (closed) - F1_borda_score  \\\n",
       "0                                        66.0   \n",
       "1                                        65.0   \n",
       "2                                        57.0   \n",
       "3                                        53.0   \n",
       "4                                        54.0   \n",
       "\n",
       "   NaturalQuestions (closed) - F1_borda_score_norm  \\\n",
       "0                                         1.000000   \n",
       "1                                         0.984848   \n",
       "2                                         0.863636   \n",
       "3                                         0.803030   \n",
       "4                                         0.818182   \n",
       "\n",
       "   NaturalQuestions (open) - F1_borda_score  ...  \\\n",
       "0                                      54.0  ...   \n",
       "1                                      52.0  ...   \n",
       "2                                      62.0  ...   \n",
       "3                                      60.0  ...   \n",
       "4                                      64.0  ...   \n",
       "\n",
       "   XSUM - ROUGE-2_borda_score_norm  IMDB - EM_borda_score  \\\n",
       "0                              NaN                   62.5   \n",
       "1                              NaN                   65.0   \n",
       "2                         0.804878                   47.5   \n",
       "3                              NaN                   65.0   \n",
       "4                         0.865854                   61.0   \n",
       "\n",
       "   IMDB - EM_borda_score_norm  CivilComments - EM_borda_score  \\\n",
       "0                    0.946970                            60.0   \n",
       "1                    0.984848                            61.0   \n",
       "2                    0.719697                            63.0   \n",
       "3                    0.984848                            58.0   \n",
       "4                    0.924242                            52.5   \n",
       "\n",
       "   CivilComments - EM_borda_score_norm  RAFT - EM_borda_score  \\\n",
       "0                             0.909091                   60.0   \n",
       "1                             0.924242                   55.0   \n",
       "2                             0.954545                   61.0   \n",
       "3                             0.878788                   56.5   \n",
       "4                             0.795455                   46.0   \n",
       "\n",
       "   RAFT - EM_borda_score_norm  mean_win_rate  total_borda_score  \\\n",
       "0                    0.909091       0.942855              619.5   \n",
       "1                    0.833333       0.909930              598.0   \n",
       "2                    0.924242       0.904312              775.0   \n",
       "3                    0.856061       0.881853              579.5   \n",
       "4                    0.696970       0.872345              737.5   \n",
       "\n",
       "   mean_win_rate_rank  \n",
       "0                67.0  \n",
       "1                66.0  \n",
       "2                65.0  \n",
       "3                64.0  \n",
       "4                62.0  \n",
       "\n",
       "[5 rows x 36 columns]"
      ]
     },
     "execution_count": 121,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classic_core_tournament_scores_df = build_borda_scores_df(classic_core_df, \n",
    "                                             voter_columns_cardinal=classic_core_voter_columns, \n",
    "                                             candidates_column = HELM_CANDIDATES_COLUMN, \n",
    "                                             tiebreak='average')\n",
    "classic_core_tournament_scores_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "36472d98",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SignificanceResult(statistic=0.9941177488296513, pvalue=1.342662263961258e-32)"
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Our borda calculation is very close in kendall tau distance to their Mean win rate.\n",
    "kendalltau(classic_core_tournament_scores_df['mean_win_rate_rank'], classic_core_df['Mean win rate'].rank())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "id": "7b53714a",
   "metadata": {},
   "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>Model</th>\n",
       "      <th>The Pile - BPB_borda_score</th>\n",
       "      <th>The Pile - BPB_borda_score_norm</th>\n",
       "      <th>TwitterAAE - BPB_borda_score</th>\n",
       "      <th>TwitterAAE - BPB_borda_score_norm</th>\n",
       "      <th>ICE - BPB_borda_score</th>\n",
       "      <th>ICE - BPB_borda_score_norm</th>\n",
       "      <th>BLiMP - EM_borda_score</th>\n",
       "      <th>BLiMP - EM_borda_score_norm</th>\n",
       "      <th>NaturalQuestions (closed) - F1_borda_score</th>\n",
       "      <th>...</th>\n",
       "      <th>LegalSupport - EM_borda_score_norm</th>\n",
       "      <th>Data imputation - EM_borda_score</th>\n",
       "      <th>Data imputation - EM_borda_score_norm</th>\n",
       "      <th>Entity matching - EM_borda_score</th>\n",
       "      <th>Entity matching - EM_borda_score_norm</th>\n",
       "      <th>BBQ - EM_borda_score</th>\n",
       "      <th>BBQ - EM_borda_score_norm</th>\n",
       "      <th>mean_win_rate</th>\n",
       "      <th>total_borda_score</th>\n",
       "      <th>mean_win_rate_rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Palmyra X (43B)</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>NaN</td>\n",
       "      <td>64.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.941176</td>\n",
       "      <td>48.5</td>\n",
       "      <td>0.734848</td>\n",
       "      <td>66.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>39.0</td>\n",
       "      <td>0.95122</td>\n",
       "      <td>0.908311</td>\n",
       "      <td>952.5</td>\n",
       "      <td>70.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>text-davinci-003</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.161290</td>\n",
       "      <td>13.0</td>\n",
       "      <td>0.419355</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.322581</td>\n",
       "      <td>16.5</td>\n",
       "      <td>0.532258</td>\n",
       "      <td>62.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.926471</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>62.0</td>\n",
       "      <td>0.939394</td>\n",
       "      <td>40.0</td>\n",
       "      <td>0.97561</td>\n",
       "      <td>0.844422</td>\n",
       "      <td>1099.5</td>\n",
       "      <td>66.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Llama 2 (70B)</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>NaN</td>\n",
       "      <td>66.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.757353</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>27.0</td>\n",
       "      <td>0.409091</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.895024</td>\n",
       "      <td>903.5</td>\n",
       "      <td>69.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>text-davinci-002</td>\n",
       "      <td>6.0</td>\n",
       "      <td>0.193548</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.290323</td>\n",
       "      <td>7.0</td>\n",
       "      <td>0.225806</td>\n",
       "      <td>12.0</td>\n",
       "      <td>0.387097</td>\n",
       "      <td>57.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>41.0</td>\n",
       "      <td>1.00000</td>\n",
       "      <td>0.800838</td>\n",
       "      <td>1048.5</td>\n",
       "      <td>63.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>LLaMA (65B)</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>NaN</td>\n",
       "      <td>65.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.816176</td>\n",
       "      <td>47.0</td>\n",
       "      <td>0.712121</td>\n",
       "      <td>54.0</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.868462</td>\n",
       "      <td>876.0</td>\n",
       "      <td>68.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 50 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "              Model  The Pile - BPB_borda_score  \\\n",
       "0   Palmyra X (43B)                         NaN   \n",
       "1  text-davinci-003                         5.0   \n",
       "2     Llama 2 (70B)                         NaN   \n",
       "3  text-davinci-002                         6.0   \n",
       "4       LLaMA (65B)                         NaN   \n",
       "\n",
       "   The Pile - BPB_borda_score_norm  TwitterAAE - BPB_borda_score  \\\n",
       "0                              NaN                           NaN   \n",
       "1                         0.161290                          13.0   \n",
       "2                              NaN                           NaN   \n",
       "3                         0.193548                           9.0   \n",
       "4                              NaN                           NaN   \n",
       "\n",
       "   TwitterAAE - BPB_borda_score_norm  ICE - BPB_borda_score  \\\n",
       "0                                NaN                    NaN   \n",
       "1                           0.419355                   10.0   \n",
       "2                                NaN                    NaN   \n",
       "3                           0.290323                    7.0   \n",
       "4                                NaN                    NaN   \n",
       "\n",
       "   ICE - BPB_borda_score_norm  BLiMP - EM_borda_score  \\\n",
       "0                         NaN                     NaN   \n",
       "1                    0.322581                    16.5   \n",
       "2                         NaN                     NaN   \n",
       "3                    0.225806                    12.0   \n",
       "4                         NaN                     NaN   \n",
       "\n",
       "   BLiMP - EM_borda_score_norm  NaturalQuestions (closed) - F1_borda_score  \\\n",
       "0                          NaN                                        64.0   \n",
       "1                     0.532258                                        62.0   \n",
       "2                          NaN                                        66.0   \n",
       "3                     0.387097                                        57.0   \n",
       "4                          NaN                                        65.0   \n",
       "\n",
       "   ...  LegalSupport - EM_borda_score_norm  Data imputation - EM_borda_score  \\\n",
       "0  ...                            0.941176                              48.5   \n",
       "1  ...                            0.926471                              61.0   \n",
       "2  ...                            0.757353                              60.0   \n",
       "3  ...                            0.911765                              63.0   \n",
       "4  ...                            0.816176                              47.0   \n",
       "\n",
       "   Data imputation - EM_borda_score_norm  Entity matching - EM_borda_score  \\\n",
       "0                               0.734848                              66.0   \n",
       "1                               0.924242                              62.0   \n",
       "2                               0.909091                              27.0   \n",
       "3                               0.954545                              63.0   \n",
       "4                               0.712121                              54.0   \n",
       "\n",
       "   Entity matching - EM_borda_score_norm  BBQ - EM_borda_score  \\\n",
       "0                               1.000000                  39.0   \n",
       "1                               0.939394                  40.0   \n",
       "2                               0.409091                   NaN   \n",
       "3                               0.954545                  41.0   \n",
       "4                               0.818182                   NaN   \n",
       "\n",
       "   BBQ - EM_borda_score_norm  mean_win_rate  total_borda_score  \\\n",
       "0                    0.95122       0.908311              952.5   \n",
       "1                    0.97561       0.844422             1099.5   \n",
       "2                        NaN       0.895024              903.5   \n",
       "3                    1.00000       0.800838             1048.5   \n",
       "4                        NaN       0.868462              876.0   \n",
       "\n",
       "   mean_win_rate_rank  \n",
       "0                70.0  \n",
       "1                66.0  \n",
       "2                69.0  \n",
       "3                63.0  \n",
       "4                68.0  \n",
       "\n",
       "[5 rows x 50 columns]"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classic_targeted_tournament_scores_df = build_borda_scores_df(classic_targeted_df, \n",
    "                                             voter_columns_cardinal=classic_targeted_voter_columns, \n",
    "                                             candidates_column = HELM_CANDIDATES_COLUMN, \n",
    "                                             tiebreak='average')\n",
    "classic_targeted_tournament_scores_df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "45669f02",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SignificanceResult(statistic=0.8788569250357876, pvalue=5.4364267253069e-27)"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kendalltau(classic_targeted_tournament_scores_df['mean_win_rate_rank'], classic_targeted_df['Mean win rate'].rank())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "0c5f98bc",
   "metadata": {},
   "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>Model</th>\n",
       "      <th>MMLU - EM_borda_score</th>\n",
       "      <th>MMLU - EM_borda_score_norm</th>\n",
       "      <th>LSAT - EM_borda_score</th>\n",
       "      <th>LSAT - EM_borda_score_norm</th>\n",
       "      <th>ICE - BPB_borda_score</th>\n",
       "      <th>ICE - BPB_borda_score_norm</th>\n",
       "      <th>bAbI - EM_borda_score</th>\n",
       "      <th>bAbI - EM_borda_score_norm</th>\n",
       "      <th>TruthfulQA - EM_borda_score</th>\n",
       "      <th>...</th>\n",
       "      <th>QuAC - F1_borda_score_norm</th>\n",
       "      <th>Data imputation - EM_borda_score</th>\n",
       "      <th>Data imputation - EM_borda_score_norm</th>\n",
       "      <th>Entity matching - EM_borda_score</th>\n",
       "      <th>Entity matching - EM_borda_score_norm</th>\n",
       "      <th>MATH - Equivalent_borda_score</th>\n",
       "      <th>MATH - Equivalent_borda_score_norm</th>\n",
       "      <th>mean_win_rate</th>\n",
       "      <th>total_borda_score</th>\n",
       "      <th>mean_win_rate_rank</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Llama 2 (70B)</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>66.0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>62.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.953846</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>27.0</td>\n",
       "      <td>0.409091</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>0.910320</td>\n",
       "      <td>1319.0</td>\n",
       "      <td>67.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>LLaMA (65B)</td>\n",
       "      <td>64.0</td>\n",
       "      <td>0.969697</td>\n",
       "      <td>43.5</td>\n",
       "      <td>0.659091</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>64.0</td>\n",
       "      <td>0.969697</td>\n",
       "      <td>61.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.769231</td>\n",
       "      <td>47.0</td>\n",
       "      <td>0.712121</td>\n",
       "      <td>54.0</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>0.877792</td>\n",
       "      <td>1272.0</td>\n",
       "      <td>66.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>text-davinci-002</td>\n",
       "      <td>60.0</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>55.5</td>\n",
       "      <td>0.840909</td>\n",
       "      <td>7.0</td>\n",
       "      <td>0.225806</td>\n",
       "      <td>61.0</td>\n",
       "      <td>0.924242</td>\n",
       "      <td>65.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.923077</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>63.0</td>\n",
       "      <td>0.954545</td>\n",
       "      <td>0.832342</td>\n",
       "      <td>1569.5</td>\n",
       "      <td>63.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Mistral v0.1 (7B)</td>\n",
       "      <td>62.0</td>\n",
       "      <td>0.939394</td>\n",
       "      <td>43.5</td>\n",
       "      <td>0.659091</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>59.0</td>\n",
       "      <td>0.893939</td>\n",
       "      <td>59.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.830769</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.621212</td>\n",
       "      <td>64.0</td>\n",
       "      <td>0.969697</td>\n",
       "      <td>58.0</td>\n",
       "      <td>0.878788</td>\n",
       "      <td>0.860553</td>\n",
       "      <td>1247.0</td>\n",
       "      <td>65.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Cohere Command beta (52.4B)</td>\n",
       "      <td>50.0</td>\n",
       "      <td>0.757576</td>\n",
       "      <td>55.5</td>\n",
       "      <td>0.840909</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0.645161</td>\n",
       "      <td>38.0</td>\n",
       "      <td>0.575758</td>\n",
       "      <td>43.0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.876923</td>\n",
       "      <td>34.5</td>\n",
       "      <td>0.522727</td>\n",
       "      <td>16.0</td>\n",
       "      <td>0.242424</td>\n",
       "      <td>45.0</td>\n",
       "      <td>0.681818</td>\n",
       "      <td>0.751814</td>\n",
       "      <td>1349.0</td>\n",
       "      <td>57.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 72 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                         Model  MMLU - EM_borda_score  \\\n",
       "0                Llama 2 (70B)                   63.0   \n",
       "1                  LLaMA (65B)                   64.0   \n",
       "2             text-davinci-002                   60.0   \n",
       "3            Mistral v0.1 (7B)                   62.0   \n",
       "4  Cohere Command beta (52.4B)                   50.0   \n",
       "\n",
       "   MMLU - EM_borda_score_norm  LSAT - EM_borda_score  \\\n",
       "0                    0.954545                   61.0   \n",
       "1                    0.969697                   43.5   \n",
       "2                    0.909091                   55.5   \n",
       "3                    0.939394                   43.5   \n",
       "4                    0.757576                   55.5   \n",
       "\n",
       "   LSAT - EM_borda_score_norm  ICE - BPB_borda_score  \\\n",
       "0                    0.924242                    NaN   \n",
       "1                    0.659091                    NaN   \n",
       "2                    0.840909                    7.0   \n",
       "3                    0.659091                    NaN   \n",
       "4                    0.840909                   20.0   \n",
       "\n",
       "   ICE - BPB_borda_score_norm  bAbI - EM_borda_score  \\\n",
       "0                         NaN                   66.0   \n",
       "1                         NaN                   64.0   \n",
       "2                    0.225806                   61.0   \n",
       "3                         NaN                   59.0   \n",
       "4                    0.645161                   38.0   \n",
       "\n",
       "   bAbI - EM_borda_score_norm  TruthfulQA - EM_borda_score  ...  \\\n",
       "0                    1.000000                         62.0  ...   \n",
       "1                    0.969697                         61.0  ...   \n",
       "2                    0.924242                         65.0  ...   \n",
       "3                    0.893939                         59.0  ...   \n",
       "4                    0.575758                         43.0  ...   \n",
       "\n",
       "   QuAC - F1_borda_score_norm  Data imputation - EM_borda_score  \\\n",
       "0                    0.953846                              60.0   \n",
       "1                    0.769231                              47.0   \n",
       "2                    0.923077                              63.0   \n",
       "3                    0.830769                              41.0   \n",
       "4                    0.876923                              34.5   \n",
       "\n",
       "   Data imputation - EM_borda_score_norm  Entity matching - EM_borda_score  \\\n",
       "0                               0.909091                              27.0   \n",
       "1                               0.712121                              54.0   \n",
       "2                               0.954545                              63.0   \n",
       "3                               0.621212                              64.0   \n",
       "4                               0.522727                              16.0   \n",
       "\n",
       "   Entity matching - EM_borda_score_norm  MATH - Equivalent_borda_score  \\\n",
       "0                               0.409091                           61.0   \n",
       "1                               0.818182                           60.0   \n",
       "2                               0.954545                           63.0   \n",
       "3                               0.969697                           58.0   \n",
       "4                               0.242424                           45.0   \n",
       "\n",
       "   MATH - Equivalent_borda_score_norm  mean_win_rate  total_borda_score  \\\n",
       "0                            0.924242       0.910320             1319.0   \n",
       "1                            0.909091       0.877792             1272.0   \n",
       "2                            0.954545       0.832342             1569.5   \n",
       "3                            0.878788       0.860553             1247.0   \n",
       "4                            0.681818       0.751814             1349.0   \n",
       "\n",
       "   mean_win_rate_rank  \n",
       "0                67.0  \n",
       "1                66.0  \n",
       "2                63.0  \n",
       "3                65.0  \n",
       "4                57.0  \n",
       "\n",
       "[5 rows x 72 columns]"
      ]
     },
     "execution_count": 113,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classic_all_borda_scores_df = build_borda_scores_df(classic_all_df, \n",
    "                                             voter_columns_cardinal=classic_all_voter_columns, \n",
    "                                             candidates_column = HELM_CANDIDATES_COLUMN, \n",
    "                                             tiebreak='average')\n",
    "classic_all_borda_scores_df.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7e331532",
   "metadata": {},
   "source": [
    "## Find overlapping columns between Lite and All"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "d5fba872",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'GSM8K - EM',\n",
       " 'MMLU - EM',\n",
       " 'NarrativeQA - F1',\n",
       " 'NaturalQuestions (closed) - F1',\n",
       " 'NaturalQuestions (open) - F1',\n",
       " 'OpenbookQA - EM'}"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Some, but not all, lite columns are included in classic columns.\n",
    "lite_columns_set = set(lite_voter_columns)\n",
    "classic_all_columns_set = set(classic_all_voter_columns)\n",
    "lite_columns_set.intersection(classic_all_columns_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "e7f6714d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'GSM8K - EM',\n",
       " 'LegalBench - EM',\n",
       " 'MATH - Equivalent (CoT)',\n",
       " 'MMLU - EM',\n",
       " 'MedQA - EM',\n",
       " 'NarrativeQA - F1',\n",
       " 'NaturalQuestions (closed) - F1',\n",
       " 'NaturalQuestions (open) - F1',\n",
       " 'OpenbookQA - EM',\n",
       " 'WMT 2014 - BLEU-4'}"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lite_columns_set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "c9373ccf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7\n"
     ]
    }
   ],
   "source": [
    "# Add back Math equivalent column.\n",
    "classic_lite_equiv_columns = list(lite_columns_set.intersection(classic_all_columns_set)) + ['MATH - Equivalent'] #, 'LSAT - EM', 'LegalSupport - EM']\n",
    "print(len(classic_lite_equiv_columns))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "241ae68f-1530-4c61-a3f5-f4d5eb0c2705",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['GSM8K - EM',\n",
       " 'MMLU - EM',\n",
       " 'OpenbookQA - EM',\n",
       " 'NarrativeQA - F1',\n",
       " 'NaturalQuestions (open) - F1',\n",
       " 'NaturalQuestions (closed) - F1',\n",
       " 'MATH - Equivalent']"
      ]
     },
     "execution_count": 75,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classic_lite_equiv_columns"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c1a5f10-6686-46bb-90e6-4e3a97f504c9",
   "metadata": {},
   "source": [
    "# Greedy selection algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "965ea03f-a4c0-48c2-96dc-e09966d754a8",
   "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>MMLU - EM</th>\n",
       "      <th>BoolQ - EM</th>\n",
       "      <th>NarrativeQA - F1</th>\n",
       "      <th>NaturalQuestions (closed) - F1</th>\n",
       "      <th>NaturalQuestions (open) - F1</th>\n",
       "      <th>QuAC - F1</th>\n",
       "      <th>HellaSwag - EM</th>\n",
       "      <th>OpenbookQA - EM</th>\n",
       "      <th>TruthfulQA - EM</th>\n",
       "      <th>MS MARCO (regular) - RR@10</th>\n",
       "      <th>MS MARCO (TREC) - NDCG@10</th>\n",
       "      <th>CNN/DailyMail - ROUGE-2</th>\n",
       "      <th>XSUM - ROUGE-2</th>\n",
       "      <th>IMDB - EM</th>\n",
       "      <th>CivilComments - EM</th>\n",
       "      <th>RAFT - EM</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>12.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>5.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.5</td>\n",
       "      <td>7.0</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>3.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>14.0</td>\n",
       "      <td>16.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>6.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>12.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>7.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>12.5</td>\n",
       "      <td>10.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>7.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>19.5</td>\n",
       "      <td>4.0</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>5.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>16.0</td>\n",
       "      <td>14.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>12.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>8.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>10.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>17.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>13.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>6.0</td>\n",
       "      <td>24.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.5</td>\n",
       "      <td>6.5</td>\n",
       "      <td>6.0</td>\n",
       "      <td>14.5</td>\n",
       "      <td>21.0</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>62</th>\n",
       "      <td>66.0</td>\n",
       "      <td>63.0</td>\n",
       "      <td>56.0</td>\n",
       "      <td>61.0</td>\n",
       "      <td>58.0</td>\n",
       "      <td>55.0</td>\n",
       "      <td>29.0</td>\n",
       "      <td>29.0</td>\n",
       "      <td>59.0</td>\n",
       "      <td>29.0</td>\n",
       "      <td>26.0</td>\n",
       "      <td>36.0</td>\n",
       "      <td>36.0</td>\n",
       "      <td>63.0</td>\n",
       "      <td>49.0</td>\n",
       "      <td>61.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>63</th>\n",
       "      <td>52.0</td>\n",
       "      <td>65.0</td>\n",
       "      <td>61.0</td>\n",
       "      <td>63.0</td>\n",
       "      <td>63.0</td>\n",
       "      <td>61.0</td>\n",
       "      <td>30.0</td>\n",
       "      <td>31.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>27.0</td>\n",
       "      <td>38.0</td>\n",
       "      <td>38.0</td>\n",
       "      <td>64.0</td>\n",
       "      <td>61.0</td>\n",
       "      <td>56.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>59.0</td>\n",
       "      <td>62.0</td>\n",
       "      <td>60.0</td>\n",
       "      <td>62.0</td>\n",
       "      <td>60.0</td>\n",
       "      <td>60.0</td>\n",
       "      <td>31.0</td>\n",
       "      <td>30.0</td>\n",
       "      <td>42.5</td>\n",
       "      <td>30.0</td>\n",
       "      <td>31.0</td>\n",
       "      <td>34.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>55.0</td>\n",
       "      <td>50.0</td>\n",
       "      <td>62.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>65</th>\n",
       "      <td>63.0</td>\n",
       "      <td>64.0</td>\n",
       "      <td>63.0</td>\n",
       "      <td>67.0</td>\n",
       "      <td>66.0</td>\n",
       "      <td>62.0</td>\n",
       "      <td>32.0</td>\n",
       "      <td>32.0</td>\n",
       "      <td>34.5</td>\n",
       "      <td>28.0</td>\n",
       "      <td>28.0</td>\n",
       "      <td>23.0</td>\n",
       "      <td>37.0</td>\n",
       "      <td>59.0</td>\n",
       "      <td>60.0</td>\n",
       "      <td>63.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66</th>\n",
       "      <td>59.0</td>\n",
       "      <td>59.0</td>\n",
       "      <td>62.0</td>\n",
       "      <td>65.0</td>\n",
       "      <td>64.0</td>\n",
       "      <td>63.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>42.0</td>\n",
       "      <td>41.0</td>\n",
       "      <td>57.5</td>\n",
       "      <td>65.0</td>\n",
       "      <td>65.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>67 rows × 16 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    MMLU - EM  BoolQ - EM  NarrativeQA - F1  NaturalQuestions (closed) - F1  \\\n",
       "0         4.0         2.0               1.0                             1.0   \n",
       "1         3.0         6.0               2.0                             2.0   \n",
       "2         7.0         4.0              12.5                            10.0   \n",
       "3         5.0         5.0              16.0                            14.0   \n",
       "4        17.0         9.0               3.5                            13.0   \n",
       "..        ...         ...               ...                             ...   \n",
       "62       66.0        63.0              56.0                            61.0   \n",
       "63       52.0        65.0              61.0                            63.0   \n",
       "64       59.0        62.0              60.0                            62.0   \n",
       "65       63.0        64.0              63.0                            67.0   \n",
       "66       59.0        59.0              62.0                            65.0   \n",
       "\n",
       "    NaturalQuestions (open) - F1  QuAC - F1  HellaSwag - EM  OpenbookQA - EM  \\\n",
       "0                           12.0        4.0             NaN              NaN   \n",
       "1                           14.0       16.0             NaN              NaN   \n",
       "2                            4.0        6.0             2.0              2.0   \n",
       "3                            6.0       12.0             NaN              NaN   \n",
       "4                            2.0        9.0             3.5              6.0   \n",
       "..                           ...        ...             ...              ...   \n",
       "62                          58.0       55.0            29.0             29.0   \n",
       "63                          63.0       61.0            30.0             31.0   \n",
       "64                          60.0       60.0            31.0             30.0   \n",
       "65                          66.0       62.0            32.0             32.0   \n",
       "66                          64.0       63.0             NaN              NaN   \n",
       "\n",
       "    TruthfulQA - EM  MS MARCO (regular) - RR@10  MS MARCO (TREC) - NDCG@10  \\\n",
       "0               5.0                         NaN                        NaN   \n",
       "1               6.0                         NaN                        NaN   \n",
       "2               2.0                         3.0                        3.0   \n",
       "3               8.0                         NaN                        NaN   \n",
       "4              24.0                         1.0                        1.0   \n",
       "..              ...                         ...                        ...   \n",
       "62             59.0                        29.0                       26.0   \n",
       "63             40.0                         NaN                       27.0   \n",
       "64             42.5                        30.0                       31.0   \n",
       "65             34.5                        28.0                       28.0   \n",
       "66             50.0                         NaN                        NaN   \n",
       "\n",
       "    CNN/DailyMail - ROUGE-2  XSUM - ROUGE-2  IMDB - EM  CivilComments - EM  \\\n",
       "0                       NaN             NaN        4.5                 7.0   \n",
       "1                       NaN             NaN        2.0                 6.0   \n",
       "2                       7.0             9.0       19.5                 4.0   \n",
       "3                       NaN             NaN        2.0                 9.0   \n",
       "4                       1.5             6.5        6.0                14.5   \n",
       "..                      ...             ...        ...                 ...   \n",
       "62                     36.0            36.0       63.0                49.0   \n",
       "63                     38.0            38.0       64.0                61.0   \n",
       "64                     34.0            40.0       55.0                50.0   \n",
       "65                     23.0            37.0       59.0                60.0   \n",
       "66                     42.0            41.0       57.5                65.0   \n",
       "\n",
       "    RAFT - EM  \n",
       "0         7.0  \n",
       "1        12.0  \n",
       "2         6.0  \n",
       "3        10.5  \n",
       "4        21.0  \n",
       "..        ...  \n",
       "62       61.0  \n",
       "63       56.0  \n",
       "64       62.0  \n",
       "65       63.0  \n",
       "66       65.0  \n",
       "\n",
       "[67 rows x 16 columns]"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Convert all scores to ranks\n",
    "classic_core_ranks_df = classic_core_df[classic_core_voter_columns].rank(ascending=False)\n",
    "classic_core_ranks_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "fe79a3e8-f7fe-43e1-9972-5dc95b93263f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['MMLU - EM',\n",
       " 'BoolQ - EM',\n",
       " 'NarrativeQA - F1',\n",
       " 'NaturalQuestions (closed) - F1',\n",
       " 'NaturalQuestions (open) - F1',\n",
       " 'QuAC - F1',\n",
       " 'HellaSwag - EM',\n",
       " 'OpenbookQA - EM',\n",
       " 'TruthfulQA - EM',\n",
       " 'MS MARCO (regular) - RR@10',\n",
       " 'MS MARCO (TREC) - NDCG@10',\n",
       " 'CNN/DailyMail - ROUGE-2',\n",
       " 'XSUM - ROUGE-2',\n",
       " 'IMDB - EM',\n",
       " 'CivilComments - EM',\n",
       " 'RAFT - EM']"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "classic_core_voter_columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "id": "ba8f8a0f-5b5c-4d8d-9d65-efa0f3579384",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Group size: 1\n",
      "['MMLU - EM' 'BoolQ - EM' 'NaturalQuestions (closed) - F1'\n",
      " 'TruthfulQA - EM' 'IMDB - EM' 'CivilComments - EM' 'RAFT - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1' 'QuAC - F1'\n",
      " 'CNN/DailyMail - ROUGE-2' 'XSUM - ROUGE-2' 'HellaSwag - EM'\n",
      " 'OpenbookQA - EM' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'MS MARCO (regular) - RR@10']\n",
      "Group size: 2\n",
      "['MMLU - EM' 'NaturalQuestions (closed) - F1' 'TruthfulQA - EM'\n",
      " 'IMDB - EM' 'RAFT - EM' 'CivilComments - EM'\n",
      " 'NaturalQuestions (open) - F1' 'QuAC - F1' 'CNN/DailyMail - ROUGE-2'\n",
      " 'XSUM - ROUGE-2' 'HellaSwag - EM' 'OpenbookQA - EM'\n",
      " 'MS MARCO (TREC) - NDCG@10' 'BoolQ - EM' 'NarrativeQA - F1']\n",
      "Group size: 3\n",
      "['NarrativeQA - F1' 'NaturalQuestions (closed) - F1'\n",
      " 'NaturalQuestions (open) - F1' 'RAFT - EM' 'TruthfulQA - EM'\n",
      " 'CivilComments - EM' 'XSUM - ROUGE-2' 'IMDB - EM' 'QuAC - F1'\n",
      " 'MS MARCO (TREC) - NDCG@10' 'CNN/DailyMail - ROUGE-2' 'HellaSwag - EM'\n",
      " 'OpenbookQA - EM']\n",
      "Group size: 4\n",
      "['MMLU - EM' 'NaturalQuestions (closed) - F1' 'TruthfulQA - EM'\n",
      " 'CivilComments - EM' 'RAFT - EM' 'IMDB - EM' 'HellaSwag - EM'\n",
      " 'MS MARCO (TREC) - NDCG@10' 'CNN/DailyMail - ROUGE-2' 'XSUM - ROUGE-2'\n",
      " 'QuAC - F1']\n",
      "Group size: 5\n",
      "['QuAC - F1' 'IMDB - EM' 'RAFT - EM' 'CivilComments - EM' 'HellaSwag - EM'\n",
      " 'OpenbookQA - EM' 'MS MARCO (TREC) - NDCG@10' 'CNN/DailyMail - ROUGE-2'\n",
      " 'XSUM - ROUGE-2' 'TruthfulQA - EM' 'MMLU - EM']\n",
      "Group size: 6\n",
      "['NarrativeQA - F1' 'QuAC - F1' 'TruthfulQA - EM' 'IMDB - EM'\n",
      " 'CivilComments - EM' 'RAFT - EM' 'CNN/DailyMail - ROUGE-2'\n",
      " 'XSUM - ROUGE-2']\n",
      "Group size: 7\n",
      "['NarrativeQA - F1' 'NaturalQuestions (open) - F1' 'QuAC - F1'\n",
      " 'CivilComments - EM' 'RAFT - EM' 'CNN/DailyMail - ROUGE-2']\n",
      "Group size: 8\n",
      "['MMLU - EM' 'BoolQ - EM' 'NarrativeQA - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'QuAC - F1' 'TruthfulQA - EM'\n",
      " 'CivilComments - EM' 'RAFT - EM' 'CNN/DailyMail - ROUGE-2']\n",
      "Group size: 9\n",
      "['NarrativeQA - F1' 'QuAC - F1' 'CivilComments - EM' 'RAFT - EM'\n",
      " 'CNN/DailyMail - ROUGE-2']\n",
      "Group size: 10\n",
      "['QuAC - F1' 'IMDB - EM' 'CivilComments - EM' 'RAFT - EM' 'HellaSwag - EM']\n",
      "Group size: 11\n",
      "['CNN/DailyMail - ROUGE-2' 'XSUM - ROUGE-2']\n",
      "Group size: 12\n",
      "['CNN/DailyMail - ROUGE-2' 'XSUM - ROUGE-2']\n",
      "Group size: 13\n",
      "['HellaSwag - EM']\n",
      "Group size: 14\n",
      "['HellaSwag - EM']\n",
      "Group size: 15\n",
      "['NarrativeQA - F1']\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "final_K_lengths = []\n",
    "group_sizes = range(1, len(classic_core_voter_columns))\n",
    "classic_core_ranks_df = scores_to_ranks(classic_core_df)\n",
    "for g in group_sizes:\n",
    "    print('Group size:', g)\n",
    "    K = greedy_selection_from_ranks(g, classic_core_ranks_df, classic_core_voter_columns, verbose=False) \n",
    "    print(K)\n",
    "    final_K_lengths.append(len(K))\n",
    "    \n",
    "n = len(classic_all_voter_columns)\n",
    "m = len(classic_all_ranks_df)\n",
    "upper_bounds = [((n / g) * math.log(m)) for g in group_sizes]\n",
    "\n",
    "plt.scatter(group_sizes, final_K_lengths, label='Greedy')\n",
    "plt.plot(group_sizes, upper_bounds, label='upper bound')\n",
    "plt.title('Results of greedy algorithm for varying group sizes on HELM core')\n",
    "plt.xlabel('Group size g')\n",
    "plt.ylabel('Final subset length |K|')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "59a981ef-c234-4d69-b73f-d90adf1feff5",
   "metadata": {},
   "source": [
    "## Run Greedy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "0dbf340d-9672-4e77-acb3-6387d472a3cb",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Group size: 1\n",
      "['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'WikiFact - EM'\n",
      " 'Synthetic reasoning (abstra...' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'TruthfulQA - EM' 'LSAT - EM'\n",
      " 'BoolQ - EM' 'LegalSupport - EM' 'IMDB - EM' 'Dyck - EM'\n",
      " 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM' 'bAbI - EM'\n",
      " 'RAFT - EM' 'CivilComments - EM' 'NaturalQuestions (closed) - F1'\n",
      " 'QuAC - F1' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'CNN/DailyMail - ROUGE-2' 'ICE - BPB' 'The Pile - BPB'\n",
      " 'OpenbookQA - EM' 'TwitterAAE - BPB' 'BLiMP - EM' 'HellaSwag - EM'\n",
      " 'MS MARCO (TREC) - NDCG@10' 'MS MARCO (regular) - RR@10']\n",
      "|K| = 33\n",
      "Group size: 2\n",
      "['GSM8K - EM' 'Synthetic reasoning (abstra...' 'Dyck - EM' 'WikiFact - EM'\n",
      " 'LegalSupport - EM' 'RAFT - EM' 'LSAT - EM' 'TruthfulQA - EM'\n",
      " 'NaturalQuestions (open) - F1' 'IMDB - EM' 'QuAC - F1'\n",
      " 'MATH - Equivalent' 'Entity matching - EM' 'bAbI - EM' 'The Pile - BPB'\n",
      " 'OpenbookQA - EM' 'CNN/DailyMail - ROUGE-2' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'MS MARCO (TREC) - NDCG@10' 'BBQ - EM'\n",
      " 'MATH (chain-of-thoughts) - ...' 'TwitterAAE - BPB'\n",
      " 'MS MARCO (regular) - RR@10' 'CivilComments - EM' 'Data imputation - EM'\n",
      " 'XSUM - ROUGE-2' 'ICE - BPB' 'BoolQ - EM' 'BLiMP - EM']\n",
      "|K| = 30\n",
      "Group size: 3\n",
      "['GSM8K - EM' 'WikiFact - EM' 'Synthetic reasoning (abstra...' 'LSAT - EM'\n",
      " 'Dyck - EM' 'TruthfulQA - EM' 'NaturalQuestions (open) - F1' 'IMDB - EM'\n",
      " 'Synthetic reasoning (natura...' 'NaturalQuestions (closed) - F1'\n",
      " 'MS MARCO (regular) - RR@10' 'LegalSupport - EM' 'TwitterAAE - BPB'\n",
      " 'OpenbookQA - EM' 'MATH (chain-of-thoughts) - ...' 'BoolQ - EM'\n",
      " 'CNN/DailyMail - ROUGE-2' 'BLiMP - EM' 'QuAC - F1' 'bAbI - EM' 'BBQ - EM'\n",
      " 'MATH - Equivalent']\n",
      "|K| = 22\n",
      "Group size: 4\n",
      "['WikiFact - EM' 'NaturalQuestions (open) - F1' 'Dyck - EM' 'RAFT - EM'\n",
      " 'IMDB - EM' 'Entity matching - EM' 'TruthfulQA - EM' 'TwitterAAE - BPB'\n",
      " 'XSUM - ROUGE-2' 'GSM8K - EM' 'OpenbookQA - EM' 'MMLU - EM'\n",
      " 'Synthetic reasoning (natura...' 'Synthetic reasoning (abstra...'\n",
      " 'NaturalQuestions (closed) - F1' 'QuAC - F1' 'BLiMP - EM'\n",
      " 'MATH (chain-of-thoughts) - ...' 'MS MARCO (regular) - RR@10']\n",
      "|K| = 19\n",
      "Group size: 5\n",
      "['WikiFact - EM' 'GSM8K - EM' 'Dyck - EM' 'RAFT - EM' 'TruthfulQA - EM'\n",
      " 'TwitterAAE - BPB' 'HellaSwag - EM' 'MATH - Equivalent' 'BoolQ - EM'\n",
      " 'NaturalQuestions (closed) - F1' 'MS MARCO (regular) - RR@10'\n",
      " 'CNN/DailyMail - ROUGE-2' 'MMLU - EM' 'Synthetic reasoning (abstra...']\n",
      "|K| = 14\n",
      "Group size: 6\n",
      "['GSM8K - EM' 'IMDB - EM' 'Synthetic reasoning (abstra...'\n",
      " 'LegalSupport - EM' 'BBQ - EM' 'Dyck - EM' 'BLiMP - EM'\n",
      " 'MATH - Equivalent' 'Synthetic reasoning (natura...' 'TwitterAAE - BPB'\n",
      " 'BoolQ - EM' 'MATH (chain-of-thoughts) - ...']\n",
      "|K| = 12\n",
      "Group size: 7\n",
      "['WikiFact - EM' 'QuAC - F1' 'NaturalQuestions (open) - F1'\n",
      " 'XSUM - ROUGE-2' 'CivilComments - EM' 'ICE - BPB' 'Dyck - EM'\n",
      " 'TruthfulQA - EM' 'MS MARCO (regular) - RR@10' 'bAbI - EM']\n",
      "|K| = 10\n",
      "Group size: 8\n",
      "['MATH (chain-of-thoughts) - ...' 'BoolQ - EM' 'XSUM - ROUGE-2'\n",
      " 'CivilComments - EM' 'TwitterAAE - BPB' 'WikiFact - EM'\n",
      " 'NaturalQuestions (open) - F1' 'Dyck - EM']\n",
      "|K| = 8\n",
      "Group size: 9\n",
      "['GSM8K - EM' 'NarrativeQA - F1' 'CNN/DailyMail - ROUGE-2'\n",
      " 'TruthfulQA - EM' 'BLiMP - EM' 'WikiFact - EM'\n",
      " 'MATH (chain-of-thoughts) - ...' 'Synthetic reasoning (abstra...']\n",
      "|K| = 8\n",
      "Group size: 10\n",
      "['WikiFact - EM' 'MATH (chain-of-thoughts) - ...' 'BBQ - EM'\n",
      " 'NarrativeQA - F1' 'Synthetic reasoning (natura...' 'LSAT - EM'\n",
      " 'Synthetic reasoning (abstra...']\n",
      "|K| = 7\n",
      "Group size: 11\n",
      "['MMLU - EM' 'Synthetic reasoning (abstra...' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'MATH (chain-of-thoughts) - ...' 'Data imputation - EM' 'IMDB - EM']\n",
      "|K| = 6\n",
      "Group size: 12\n",
      "['MATH (chain-of-thoughts) - ...' 'BBQ - EM'\n",
      " 'Synthetic reasoning (natura...' 'LegalSupport - EM' 'IMDB - EM']\n",
      "|K| = 5\n",
      "Group size: 13\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'Dyck - EM'\n",
      " 'Synthetic reasoning (abstra...']\n",
      "|K| = 4\n",
      "Group size: 14\n",
      "['GSM8K - EM' 'XSUM - ROUGE-2' 'Data imputation - EM'\n",
      " 'MATH (chain-of-thoughts) - ...']\n",
      "|K| = 4\n",
      "Group size: 15\n",
      "['GSM8K - EM' 'XSUM - ROUGE-2' 'TruthfulQA - EM']\n",
      "|K| = 3\n",
      "Group size: 16\n",
      "['GSM8K - EM' 'XSUM - ROUGE-2' 'Synthetic reasoning (abstra...']\n",
      "|K| = 3\n",
      "Group size: 17\n",
      "['Synthetic reasoning (abstra...' 'XSUM - ROUGE-2' 'GSM8K - EM']\n",
      "|K| = 3\n",
      "Group size: 18\n",
      "['Synthetic reasoning (abstra...' 'XSUM - ROUGE-2' 'GSM8K - EM']\n",
      "|K| = 3\n",
      "Group size: 19\n",
      "['Synthetic reasoning (abstra...' 'IMDB - EM' 'GSM8K - EM']\n",
      "|K| = 3\n",
      "Group size: 20\n",
      "['WikiFact - EM' 'OpenbookQA - EM']\n",
      "|K| = 2\n",
      "Group size: 21\n",
      "['QuAC - F1' 'IMDB - EM' 'MATH (chain-of-thoughts) - ...']\n",
      "|K| = 3\n",
      "Group size: 22\n",
      "['QuAC - F1' 'BBQ - EM']\n",
      "|K| = 2\n",
      "Group size: 23\n",
      "['CNN/DailyMail - ROUGE-2']\n",
      "|K| = 1\n",
      "Group size: 24\n",
      "['CNN/DailyMail - ROUGE-2']\n",
      "|K| = 1\n",
      "Group size: 25\n",
      "['CNN/DailyMail - ROUGE-2']\n",
      "|K| = 1\n",
      "Group size: 26\n",
      "['OpenbookQA - EM']\n",
      "|K| = 1\n",
      "Group size: 27\n",
      "['OpenbookQA - EM']\n",
      "|K| = 1\n",
      "Group size: 28\n",
      "['OpenbookQA - EM']\n",
      "|K| = 1\n",
      "Group size: 29\n",
      "['WikiFact - EM']\n",
      "|K| = 1\n",
      "Group size: 30\n",
      "['WikiFact - EM']\n",
      "|K| = 1\n",
      "Group size: 31\n",
      "['MATH (chain-of-thoughts) - ...']\n",
      "|K| = 1\n",
      "Group size: 32\n",
      "['GSM8K - EM']\n",
      "|K| = 1\n",
      "Group size: 33\n",
      "['GSM8K - EM']\n",
      "|K| = 1\n"
     ]
    }
   ],
   "source": [
    "outputs_greedy, group_sizes = selection_algorithms.run_greedy_all_gs(classic_all_df, classic_all_voter_columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "3f41790c-9092-4fcc-8bc9-1bd3d13227b9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[33, 30, 22, 19, 14, 12, 10, 8, 8, 7, 6, 5, 4, 4, 3, 3, 3, 3, 3, 2, 3, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]\n"
     ]
    }
   ],
   "source": [
    "print(outputs_greedy)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0067b410-2061-4a79-a8bc-8f5a0cea4015",
   "metadata": {},
   "source": [
    "## Greedy Augmented"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "2d3211d3-d3c2-417f-b781-685b13f15358",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Group size: 1\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'GSM8K - EM'\n",
      " 'MATH (chain-of-thoughts) - ...' 'WikiFact - EM'\n",
      " 'Synthetic reasoning (abstra...' 'Synthetic reasoning (natura...'\n",
      " 'TruthfulQA - EM' 'LSAT - EM' 'BoolQ - EM' 'LegalSupport - EM'\n",
      " 'IMDB - EM' 'Dyck - EM' 'Entity matching - EM' 'Data imputation - EM'\n",
      " 'bAbI - EM' 'RAFT - EM' 'CivilComments - EM' 'QuAC - F1' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'CNN/DailyMail - ROUGE-2' 'ICE - BPB' 'The Pile - BPB'\n",
      " 'TwitterAAE - BPB' 'BLiMP - EM' 'HellaSwag - EM'\n",
      " 'MS MARCO (TREC) - NDCG@10' 'MS MARCO (regular) - RR@10']\n",
      "|K| = 34\n",
      "Group size: 2\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'GSM8K - EM' 'IMDB - EM' 'Dyck - EM'\n",
      " 'WikiFact - EM' 'Synthetic reasoning (natura...'\n",
      " 'Synthetic reasoning (abstra...' 'LegalSupport - EM' 'RAFT - EM'\n",
      " 'Entity matching - EM' 'CNN/DailyMail - ROUGE-2' 'ICE - BPB'\n",
      " 'Data imputation - EM' 'BBQ - EM' 'TwitterAAE - BPB'\n",
      " 'MS MARCO (regular) - RR@10' 'TruthfulQA - EM' 'CivilComments - EM'\n",
      " 'MATH (chain-of-thoughts) - ...' 'BLiMP - EM' 'LSAT - EM'\n",
      " 'HellaSwag - EM' 'BoolQ - EM' 'XSUM - ROUGE-2' 'QuAC - F1']\n",
      "|K| = 31\n",
      "Group size: 3\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'GSM8K - EM' 'IMDB - EM'\n",
      " 'Synthetic reasoning (natura...' 'WikiFact - EM' 'Dyck - EM'\n",
      " 'TruthfulQA - EM' 'Synthetic reasoning (abstra...' 'ICE - BPB'\n",
      " 'MS MARCO (regular) - RR@10' 'LSAT - EM' 'Data imputation - EM'\n",
      " 'BLiMP - EM' 'BoolQ - EM' 'CNN/DailyMail - ROUGE-2' 'CivilComments - EM'\n",
      " 'The Pile - BPB' 'XSUM - ROUGE-2' 'QuAC - F1']\n",
      "|K| = 25\n",
      "Group size: 4\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'WikiFact - EM'\n",
      " 'CNN/DailyMail - ROUGE-2' 'bAbI - EM' 'The Pile - BPB'\n",
      " 'Synthetic reasoning (natura...' 'BoolQ - EM' 'XSUM - ROUGE-2'\n",
      " 'Synthetic reasoning (abstra...' 'RAFT - EM' 'HellaSwag - EM'\n",
      " 'TruthfulQA - EM']\n",
      "|K| = 18\n",
      "Group size: 5\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'WikiFact - EM' 'BBQ - EM' 'RAFT - EM'\n",
      " 'TwitterAAE - BPB' 'Synthetic reasoning (natura...' 'IMDB - EM'\n",
      " 'LegalSupport - EM' 'Dyck - EM']\n",
      "|K| = 15\n",
      "Group size: 6\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'GSM8K - EM' 'BBQ - EM' 'IMDB - EM'\n",
      " 'The Pile - BPB' 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MATH (chain-of-thoughts) - ...']\n",
      "|K| = 14\n",
      "Group size: 7\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'WikiFact - EM' 'BBQ - EM' 'LSAT - EM'\n",
      " 'ICE - BPB' 'MATH (chain-of-thoughts) - ...']\n",
      "|K| = 12\n",
      "Group size: 8\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'MATH (chain-of-thoughts) - ...'\n",
      " 'CNN/DailyMail - ROUGE-2' 'BBQ - EM' 'ICE - BPB']\n",
      "|K| = 11\n",
      "Group size: 9\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'GSM8K - EM' 'XSUM - ROUGE-2' 'BBQ - EM']\n",
      "|K| = 10\n",
      "Group size: 10\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'WikiFact - EM' 'TruthfulQA - EM'\n",
      " 'ICE - BPB']\n",
      "|K| = 10\n",
      "Group size: 11\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'MMLU - EM' 'ICE - BPB']\n",
      "|K| = 9\n",
      "Group size: 12\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1' 'MATH (chain-of-thoughts) - ...'\n",
      " 'ICE - BPB']\n",
      "|K| = 9\n",
      "Group size: 13\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 14\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 15\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 16\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 17\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 18\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 19\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 20\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 21\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 22\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 23\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 24\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 25\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 26\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 27\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 28\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 29\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 30\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 31\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 32\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n",
      "Group size: 33\n",
      "['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "|K| = 7\n"
     ]
    }
   ],
   "source": [
    "outputs_greedy_augmented, group_sizes = selection_algorithms.run_greedy_all_gs(classic_all_df, classic_all_voter_columns, starting_tasks=classic_lite_equiv_columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "4176d73d-9128-4305-aeb8-c2d797344789",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[34, 31, 25, 18, 15, 14, 12, 11, 10, 10, 9, 9, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7]\n"
     ]
    }
   ],
   "source": [
    "print(outputs_greedy_augmented)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "id": "406c7a92-a0eb-46e6-9423-3eb61094705e",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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Y5DJZGrPhRAaZdps3LgR06dPx65du+Ds7Kwqb9q0KZo2bap63rx5czRo0ADff/89Fi1apHVbkydPxsSJE1XPU1JSmPCS4TIxAVq1evGYiIhIQmU22XV0dISpqalGK25iYqJGa29e4eHhGDZsGLZs2YL27dvnW9fExASNGjXKt2XX0tISlpaWBQ+eSJ9ZWQGRkVJHQUREBKAMd2OwsLBAw4YNERERoVYeERGBZs2a6Vxv48aNGDx4MDZs2IAuXbq8cj9CCMTExMDNze21YyYiIiKiwimzLbsAMHHiRAwYMAABAQEIDAzEjz/+iLi4OIwcORJAbveC+/fvY82aNQByE92BAwfiu+++Q9OmTVWtwlZWVlAoFACAGTNmoGnTpqhWrRpSUlKwaNEixMTEYPHixdK8SSIiIqIyrEwnuyEhIUhKSsLMmTMRHx8Pf39/7N+/H56engCA+Ph4tTl3ly9fjqysLHzwwQf44IMPVOWDBg1CWFgYAODx48cYMWIEEhISoFAoUL9+fRw9ehSNGzcu1fdGJJm0NMDLK/fx3buceoyIiCRVpufZ1Vecp48MGufZJaIyitdv/VRm++wSERERkfFjsktERERERovJLhEREREZLSa7RERERGS0mOwSERERkdEq01OPEVEJMDEBAgJePCYiIpIQk10iKl5WVsDp01JHQUREBIDdGIiIiIjIiDHZJSIiIiKjxWSXiIpXenru7YK9vHIfExERSYh9domoeAkB/PXXi8dEREQSYssuERERERktJrtEREREZLSY7BIRERGR0WKyS0RERERGi8kuERERERktzsZARMVLJgP8/F48JiIikhCTXSIqXtbWwOXLUkdBREQEgN0YiIiIiMiIMdklIiIiIqPFZJeIild6OlCrVu7C2wUTEZHE2GeXiIqXEMCVKy8eExERSYgtu0RERERktJjsEhEREZHRYrJLREREREaLyS4RERERGS0mu0RERERktDgbAxEVL5kM8PR88ZiIiEhCTHaJqHhZWwN370odBREREQB2YyAiIiIiI8Zkl4iIiIiMFpNdIipeT58CjRrlLk+fSh0NERGVceyzS0TFKycHOHPmxWMiIiIJsWWXiIiIiIwWk10iIiIiMlpMdomIiIjIaDHZJSIiIiKjxWSXiIiIiIwWZ2MgouLn6Ch1BERERACY7BJRcbOxAR48kDoKIiIi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w6BBg/DRRx/BwcEBzs7OCA0NhYmJic6WaCIigyNtl2EiouLzzz//iDFjxghvb29hbm4ubG1tRePGjcX8+fNFWlqaqh4AsWPHDo31lyxZInx8fIS5ubmoXr26WLNmjdrrV65cEU2bNhVWVlaiXr164uDBg1oHqO3Zs0fUqlVLWFhYiEaNGomYmBidMe/YsUM0adJE2NvbCxsbG9G0aVNx6NAh1esvD1AbNGiQAKCxhIaGquqvX79e1KtXT1hYWIjy5cuLli1bagzce1lKSoro27evsLa2Fq6urmLBggWicePG4tNPP83nSBMRGQ6ZEOycRURUHCIjI9GmTRv8999/KFeunNThFElaWhrc3d3xzTffYNiwYVKHQ0T02tiNgYioDDt//jyuXbuGxo0bIzk5GTNnzgQAdO/eXeLIiIiKB5NdIqIy7uuvv8b169dhYWGBhg0b4tixY3B0dJQ6LCKiYsFuDERERERktDj1GBEREREZLSa7RERERGS0mOwSERERkdFisktERERERovJLhEREREZLSa7RERERGS0mOwSERERkdFisktERERERovJLhEREREZrf8DA4lvWZCQDa4AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Kendall tau distance for borda scores computed from each weak pp subset\n",
    "\n",
    "Ks = []\n",
    "group_sizes = range(1, len(classic_all_voter_columns))\n",
    "classic_all_ranks_df = scores_to_ranks(classic_all_df)\n",
    "for g in group_sizes:\n",
    "    K = greedy_selection_from_ranks(g, classic_all_df, classic_all_voter_columns, verbose=False) \n",
    "    Ks.append(K)\n",
    "\n",
    "kt_distances = []\n",
    "classic_all_borda_scores_df = build_borda_scores_df(classic_all_df, \n",
    "                                             voter_columns_cardinal=classic_all_voter_columns, \n",
    "                                             candidates_column = HELM_CANDIDATES_COLUMN, \n",
    "                                             tiebreak='average')\n",
    "for K in Ks:\n",
    "    subset_borda_scores_df = build_borda_scores_df(classic_all_df, \n",
    "                                             voter_columns_cardinal=K, \n",
    "                                             candidates_column = HELM_CANDIDATES_COLUMN, \n",
    "                                             tiebreak='average')\n",
    "    kt_distance = kendall_tau_distance(subset_borda_scores_df['mean_win_rate_rank'], classic_all_borda_scores_df['mean_win_rate_rank'])\n",
    "    kt_distances.append(kt_distance)\n",
    "    \n",
    "plt.scatter(group_sizes, kt_distances, label='Greedy')\n",
    "plt.axhline(lite_equiv_kendall_tau, label='LITE', color='r')\n",
    "plt.axvline(12, color='r', linestyle='--', label='Min g s.t. LITE satisfies weak PP')\n",
    "plt.title('Results of greedy algorithm for varying group sizes on HELM all (core + targeted)')\n",
    "plt.xlabel('Group size g')\n",
    "plt.ylabel('Kendall tau distance')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "37e4d47f-3bd2-4e54-9dba-5f57ed7045a7",
   "metadata": {},
   "source": [
    "## Min group size s.t. current LITE benchmark satisfies PR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "b778f163-a900-4936-a37a-d05729addafc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.weak_pp_loss_fast(11, classic_all_ranks_df, classic_all_voter_columns, classic_lite_equiv_columns, verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "b3dea22e-aa64-4bb4-b9c2-a8acc7f24785",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.weak_pp_loss_fast(12, classic_all_ranks_df, classic_all_voter_columns, classic_lite_equiv_columns, verbose=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bebee0b3-a263-4cb7-b0c0-86a965a480a3",
   "metadata": {},
   "source": [
    "# IP for PR"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec2bafdd-315c-4b43-a810-9a886b564329",
   "metadata": {},
   "source": [
    "## Run IP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "1841c8b3-58bf-4f35-b9dd-86a70788e2ea",
   "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:22:10 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:10 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:10 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:10 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:10 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:10 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:10 PM: Finished problem compilation (took 5.924e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:10 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:10 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:10 PM: Optimal value: 3.300e+01\n",
      "(CVXPY) Apr 24 11:22:10 PM: Compilation took 5.924e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:10 PM: Solver (including time spent in interface) took 2.642e-02 seconds\n",
      "Optimal value: 33.0\n",
      "Variable var107409: value [1. 1. 1. 1. 1. 1. 0. 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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'ICE - BPB'\n",
      " 'Synthetic reasoning (abstra...' 'The Pile - BPB' 'OpenbookQA - EM'\n",
      " 'MATH - Equivalent' 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BoolQ - EM'\n",
      " 'BBQ - EM' 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1'\n",
      " 'Dyck - EM' 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'bAbI - EM' 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 2\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:11 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:11 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:11 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:11 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:11 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:11 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:11 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:11 PM: Finished problem compilation (took 6.779e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:11 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:11 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:11 PM: Optimal value: 2.100e+01\n",
      "(CVXPY) Apr 24 11:22:11 PM: Compilation took 6.779e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:11 PM: Solver (including time spent in interface) took 7.277e-01 seconds\n",
      "Optimal value: 21.0\n",
      "Variable var107409: value [ 0.  1.  1.  0.  0.  1.  0.  0.  1.  1. -0.  1.  1.  1.  1.  1.  1.  1.\n",
      "  1.  1.  0.  1.  1. -0.  1.  0.  0.  1.  0.  1.  0.  1.  1.  0.]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'The Pile - BPB'\n",
      " 'MATH - Equivalent' 'Synthetic reasoning (natura...'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BoolQ - EM'\n",
      " 'BBQ - EM' 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1'\n",
      " 'Entity matching - EM' 'Data imputation - EM' 'BLiMP - EM' 'bAbI - EM'\n",
      " 'HellaSwag - EM' 'NaturalQuestions (open) - F1' 'CivilComments - EM']\n",
      "Constructing constraint set for group size 3\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:11 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:11 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:11 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:11 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:11 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:11 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:11 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:11 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:11 PM: Finished problem compilation (took 7.203e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:11 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:12 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:12 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 24 11:22:12 PM: Compilation took 7.203e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:12 PM: Solver (including time spent in interface) took 1.004e+00 seconds\n",
      "Optimal value: 14.000000000000002\n",
      "Variable var107409: value [ 0.00000000e+00  1.00000000e+00  1.00000000e+00 -0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.50990331e-14 -0.00000000e+00  1.00000000e+00  1.00000000e+00\n",
      "  1.00000000e+00 -0.00000000e+00 -0.00000000e+00  1.00000000e+00\n",
      "  1.00000000e+00  1.09912079e-14  1.00000000e+00  1.00000000e+00\n",
      "  0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.00000000e+00  0.00000000e+00 -0.00000000e+00  1.00000000e+00\n",
      " -0.00000000e+00  0.00000000e+00  1.00000000e+00  1.00000000e+00\n",
      " -1.92068583e-14  0.00000000e+00]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'IMDB - EM' 'QuAC - F1' 'Entity matching - EM'\n",
      " 'BLiMP - EM' 'bAbI - EM' 'RAFT - EM' 'NaturalQuestions (open) - F1']\n",
      "Constructing constraint set for group size 4\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:13 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:13 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:13 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:13 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:13 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:13 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:13 PM: Finished problem compilation (took 6.849e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:13 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:14 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:14 PM: Optimal value: 1.100e+01\n",
      "(CVXPY) Apr 24 11:22:14 PM: Compilation took 6.849e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:14 PM: Solver (including time spent in interface) took 1.250e+00 seconds\n",
      "Optimal value: 10.999999999999943\n",
      "Variable var107409: value [ 0.00000000e+00  1.46549439e-13 -1.25011113e-13  0.00000000e+00\n",
      "  0.00000000e+00  1.66043649e-14  0.00000000e+00  6.76125822e-14\n",
      "  1.00000000e+00  0.00000000e+00  1.00000000e+00  0.00000000e+00\n",
      "  1.00000000e+00  0.00000000e+00  4.15223411e-14  1.00000000e+00\n",
      "  1.00000000e+00 -1.14274182e-13  2.46469511e-14 -3.07209455e-14\n",
      "  5.89002531e-14  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.00000000e+00  4.66293670e-14 -6.71462885e-14  1.00000000e+00\n",
      "  1.00000000e+00 -3.97274806e-14  1.00000000e+00  1.00000000e+00\n",
      "  0.00000000e+00  1.88515870e-13]\n",
      "Tasks: ['MATH - Equivalent' 'TruthfulQA - EM' 'TwitterAAE - BPB' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'Entity matching - EM' 'BLiMP - EM' 'bAbI - EM'\n",
      " 'NarrativeQA - F1' 'RAFT - EM' 'NaturalQuestions (open) - F1']\n",
      "Constructing constraint set for group size 5\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:14 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:14 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:14 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:14 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:14 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:14 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:14 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:14 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:14 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:14 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:14 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:14 PM: Finished problem compilation (took 8.552e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:14 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:15 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:15 PM: Optimal value: 9.000e+00\n",
      "(CVXPY) Apr 24 11:22:15 PM: Compilation took 8.552e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:15 PM: Solver (including time spent in interface) took 8.888e-01 seconds\n",
      "Optimal value: 9.00000000016035\n",
      "Variable var107409: value [ 0.00000000e+00  1.00000000e+00  1.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  1.00000000e+00\n",
      "  2.21479790e-12  5.25946038e-12 -1.44615389e-12 -1.35591538e-11\n",
      "  1.00000000e+00  0.00000000e+00 -7.10500730e-12  1.00000000e+00\n",
      "  1.00000000e+00 -2.24593677e-11  0.00000000e+00 -6.12563663e-12\n",
      "  0.00000000e+00  1.00000000e+00  0.00000000e+00 -1.22758068e-11\n",
      "  1.32838230e-10  0.00000000e+00  5.02824575e-12  2.42173869e-12\n",
      "  1.00000000e+00 -2.54287988e-10  0.00000000e+00 -4.64772294e-12\n",
      "  1.00000000e+00 -8.20409025e-13]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'OpenbookQA - EM'\n",
      " 'TwitterAAE - BPB' 'BBQ - EM' 'XSUM - ROUGE-2' 'Entity matching - EM'\n",
      " 'NarrativeQA - F1' 'CivilComments - EM']\n",
      "Constructing constraint set for group size 6\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:15 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:15 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:15 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:15 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:15 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:15 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:15 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:15 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:15 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:15 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:15 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:15 PM: Finished problem compilation (took 5.789e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:15 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:16 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:16 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 24 11:22:16 PM: Compilation took 5.789e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:16 PM: Solver (including time spent in interface) took 6.563e-01 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var107409: value [ 0.  0.  0.  0.  0.  0.  0.  1.  0.  0.  1.  0.  1.  0.  1. -0.  0.  0.\n",
      " -0.  0. -0.  1.  0.  0.  0.  1.  0.  1.  0.  0.  1. -0.  0.  0.]\n",
      "Tasks: ['OpenbookQA - EM' 'TruthfulQA - EM' 'TwitterAAE - BPB' 'BoolQ - EM'\n",
      " 'Entity matching - EM' 'CNN/DailyMail - ROUGE-2' 'bAbI - EM' 'RAFT - EM']\n",
      "Constructing constraint set for group size 7\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:16 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:16 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:16 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:16 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:16 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:16 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:16 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:16 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:16 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:16 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:16 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:16 PM: Finished problem compilation (took 7.726e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:16 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:17 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:17 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 24 11:22:17 PM: Compilation took 7.726e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:17 PM: Solver (including time spent in interface) took 7.437e-01 seconds\n",
      "Optimal value: 7.0000000000000036\n",
      "Variable var107409: value [ 0.  0.  0.  0.  0. -0.  0.  0.  1. -0. -0.  0.  0.  0.  0.  1.  0.  0.\n",
      "  1.  0.  0.  1.  1.  1.  0. -0.  0. -0.  0.  1.  0.  0.  0.  0.]\n",
      "Tasks: ['MATH - Equivalent' 'BBQ - EM' 'IMDB - EM' 'Entity matching - EM'\n",
      " 'Data imputation - EM' 'MMLU - EM' 'HellaSwag - EM']\n",
      "Constructing constraint set for group size 8\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:17 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:17 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:17 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:17 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:17 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:17 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:17 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:17 PM: Finished problem compilation (took 6.521e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:17 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:17 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:17 PM: Optimal value: 6.000e+00\n",
      "(CVXPY) Apr 24 11:22:17 PM: Compilation took 6.521e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:17 PM: Solver (including time spent in interface) took 3.267e-01 seconds\n",
      "Optimal value: 5.999999999999768\n",
      "Variable var107409: value [ 0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  1.25559401e-14 -3.91804529e-14  2.02504680e-13\n",
      "  0.00000000e+00  0.00000000e+00  1.00000000e+00 -3.59381241e-14\n",
      "  0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00 -6.59907694e-14  0.00000000e+00\n",
      "  0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      " -8.89921619e-14  0.00000000e+00]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'BoolQ - EM' 'LegalSupport - EM'\n",
      " 'CNN/DailyMail - ROUGE-2' 'NarrativeQA - F1' 'HellaSwag - EM']\n",
      "Constructing constraint set for group size 9\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:17 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:17 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:17 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:17 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:17 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:17 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:17 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:17 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:17 PM: Finished problem compilation (took 7.239e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:17 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:18 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 24 11:22:18 PM: Compilation took 7.239e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:18 PM: Solver (including time spent in interface) took 2.980e-01 seconds\n",
      "Optimal value: 4.999999999999997\n",
      "Variable var107409: value [ 0.00000000e+00  0.00000000e+00 -1.69309011e-14 -1.37667655e-14\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  1.00000000e+00\n",
      " -0.00000000e+00 -2.37407821e-14 -0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00 -9.63061327e-15  0.00000000e+00 -2.84772206e-14\n",
      "  1.00000000e+00  0.00000000e+00 -7.99360578e-15  0.00000000e+00\n",
      " -0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00 -3.62759659e-14 -0.00000000e+00\n",
      "  1.00000000e+00 -0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      " -0.00000000e+00  1.00000000e+00]\n",
      "Tasks: ['OpenbookQA - EM' 'XSUM - ROUGE-2' 'Entity matching - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:18 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:18 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:18 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:18 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:18 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:18 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:18 PM: Finished problem compilation (took 5.587e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:18 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 24 11:22:18 PM: Compilation took 5.587e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:18 PM: Solver (including time spent in interface) took 3.392e-01 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var107409: value [ 0.  1. -0.  0.  0. -0.  0.  1. -0.  0.  0.  0.  0.  0.  0. -0.  1. -0.\n",
      " -0. -0.  0.  0. -0. -0.  0.  0.  0.  1.  0.  0. -0. -0. -0.  0.]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'OpenbookQA - EM' 'XSUM - ROUGE-2'\n",
      " 'bAbI - EM']\n",
      "Constructing constraint set for group size 11\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:18 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:18 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:18 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:18 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:18 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:18 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:18 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:18 PM: Finished problem compilation (took 6.732e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:18 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 24 11:22:18 PM: Compilation took 6.732e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:18 PM: Solver (including time spent in interface) took 2.038e-01 seconds\n",
      "Optimal value: 4.000000000000225\n",
      "Variable var107409: value [ 0.00000000e+00  0.00000000e+00  2.38004061e-14  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.94844141e-13  0.00000000e+00  7.36077865e-14  1.41021218e-13\n",
      "  0.00000000e+00 -2.27335407e-13  0.00000000e+00 -1.15019105e-13\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  2.53994940e-13\n",
      "  0.00000000e+00  1.00000000e+00 -3.31262795e-14 -8.35718870e-14\n",
      "  1.20064969e-13  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.10231420e-13  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  1.00000000e+00]\n",
      "Tasks: ['Entity matching - EM' 'CNN/DailyMail - ROUGE-2' 'HellaSwag - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 12\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:18 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:19 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:19 PM: Finished problem compilation (took 6.723e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:19 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 24 11:22:19 PM: Compilation took 6.723e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:19 PM: Solver (including time spent in interface) took 2.974e-01 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var107409: value [0. 0. 0. 0. 0. 0. 0. 1. 1. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['OpenbookQA - EM' 'MATH - Equivalent' 'Synthetic reasoning (natura...'\n",
      " 'Data imputation - EM']\n",
      "Constructing constraint set for group size 13\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:19 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:19 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:19 PM: Finished problem compilation (took 7.463e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:19 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 24 11:22:19 PM: Compilation took 7.463e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:19 PM: Solver (including time spent in interface) took 2.973e-01 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var107409: value [0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 1. 0. 0. 0. 0. 1. 0. 0.\n",
      " 0. 0. 0. 0. 1. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['BoolQ - EM' 'XSUM - ROUGE-2' 'Entity matching - EM' 'NarrativeQA - F1']\n",
      "Constructing constraint set for group size 14\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:19 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:19 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:19 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:19 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:19 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:19 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:19 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:19 PM: Finished problem compilation (took 6.704e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:19 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:20 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 11:22:20 PM: Compilation took 6.704e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:20 PM: Solver (including time spent in interface) took 1.603e-01 seconds\n",
      "Optimal value: 2.9999999999999516\n",
      "Variable var107409: value [ 0.00000000e+00  4.57411886e-14  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00 -3.40838469e-14\n",
      " -2.35367281e-14 -5.62327962e-14  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  1.00000000e+00 -3.59588902e-15 -2.83106871e-15\n",
      "  0.00000000e+00  1.00000000e+00  0.00000000e+00  4.44089210e-14\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      " -1.13908882e-13  1.00000000e+00]\n",
      "Tasks: ['Entity matching - EM' 'CNN/DailyMail - ROUGE-2'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:20 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:20 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:20 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:20 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:20 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:20 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:20 PM: Finished problem compilation (took 1.089e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:20 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 11:22:20 PM: Compilation took 1.089e-01 seconds\n",
      "(CVXPY) Apr 24 11:22:20 PM: Solver (including time spent in interface) took 1.317e-01 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var107409: value [ 4.88498131e-15  2.63483454e-15  1.61250590e-15  1.24344979e-14\n",
      "  1.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      " -0.00000000e+00  0.00000000e+00  0.00000000e+00  1.00000000e+00\n",
      "  3.10862447e-15  1.61250590e-15  2.00115281e-15  1.07691633e-14\n",
      "  8.45922250e-16  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.02232864e-15  0.00000000e+00  1.39259505e-15  1.00000000e+00\n",
      "  2.76006613e-15  0.00000000e+00  0.00000000e+00  3.81518908e-15\n",
      " -0.00000000e+00  0.00000000e+00  0.00000000e+00  3.39374786e-15\n",
      " -0.00000000e+00  0.00000000e+00]\n",
      "Tasks: ['Synthetic reasoning (abstra...' 'MS MARCO (regular) - RR@10' 'MMLU - EM']\n",
      "Constructing constraint set for group size 16\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:20 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:20 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:20 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:20 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:20 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:20 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:20 PM: Finished problem compilation (took 6.810e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:20 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 11:22:20 PM: Compilation took 6.810e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:20 PM: Solver (including time spent in interface) took 1.244e-01 seconds\n",
      "Optimal value: 2.9999999999999982\n",
      "Variable var107409: value [-0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  1.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  8.43769499e-15  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  1.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  3.77475828e-15  0.00000000e+00\n",
      "  1.00000000e+00  0.00000000e+00  0.00000000e+00  9.54791801e-15\n",
      "  0.00000000e+00  0.00000000e+00 -0.00000000e+00  7.16093851e-15\n",
      "  0.00000000e+00  0.00000000e+00]\n",
      "Tasks: ['Synthetic reasoning (abstra...' 'QuAC - F1' 'BLiMP - EM']\n",
      "Constructing constraint set for group size 17\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:20 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:20 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:20 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:20 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:20 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:20 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:20 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:20 PM: Finished problem compilation (took 6.338e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:20 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:21 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compilation took 6.338e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:21 PM: Solver (including time spent in interface) took 6.839e-02 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var107409: 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. -0.  1.  1.  0. -0.  0.]\n",
      "Tasks: ['BoolQ - EM' 'HellaSwag - EM' 'RAFT - EM']\n",
      "Constructing constraint set for group size 18\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:21 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:21 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:21 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:21 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Finished problem compilation (took 5.511e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:21 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compilation took 5.511e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:21 PM: Solver (including time spent in interface) took 8.938e-02 seconds\n",
      "Optimal value: 3.0000000000008056\n",
      "Variable var107409: value [ 0.00000000e+00 -2.30260255e-13  0.00000000e+00  0.00000000e+00\n",
      " -0.00000000e+00  0.00000000e+00  0.00000000e+00 -4.60520511e-13\n",
      "  1.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  1.15716960e-13  1.15685239e-13\n",
      "  2.30260255e-13  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      " -1.15685239e-13  0.00000000e+00  0.00000000e+00  1.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00]\n",
      "Tasks: ['MATH - Equivalent' 'CNN/DailyMail - ROUGE-2'\n",
      " 'NaturalQuestions (open) - F1']\n",
      "Constructing constraint set for group size 19\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:21 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:21 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:21 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:21 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Finished problem compilation (took 7.767e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:21 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compilation took 7.767e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:21 PM: Solver (including time spent in interface) took 1.610e-01 seconds\n",
      "Optimal value: 1.9999999999999964\n",
      "Variable var107409: value [ 0.00000000e+00  0.00000000e+00 -0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00  0.00000000e+00  2.98647503e-15 -0.00000000e+00\n",
      "  1.00000000e+00 -0.00000000e+00 -0.00000000e+00  0.00000000e+00\n",
      "  0.00000000e+00 -0.00000000e+00  4.44089210e-15  0.00000000e+00\n",
      "  0.00000000e+00 -0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      " -0.00000000e+00  0.00000000e+00  0.00000000e+00 -0.00000000e+00\n",
      "  1.00000000e+00  0.00000000e+00]\n",
      "Tasks: ['XSUM - ROUGE-2' 'CivilComments - EM']\n",
      "Constructing constraint set for group size 20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:21 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:21 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:21 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:21 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Finished problem compilation (took 7.648e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:21 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compilation took 7.648e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:21 PM: Solver (including time spent in interface) took 5.869e-02 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var107409: value [ 0.  0. -0.  0.  0.  0.  0.  0. -0. -0.  0.  0.  0. -0. -0. -0.  1. -0.\n",
      " -0. -0. -0. -0. -0.  0.  0.  0.  0.  0. -0.  0. -0. -0.  1. -0.]\n",
      "Tasks: ['XSUM - ROUGE-2' 'CivilComments - EM']\n",
      "Constructing constraint set for group size 21\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:21 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:21 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:21 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:21 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:21 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:21 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:21 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Finished problem compilation (took 8.270e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:22 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compilation took 8.270e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:22 PM: Solver (including time spent in interface) took 5.895e-02 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var107409: 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.  1. -0. -0. -0.  1.]\n",
      "Tasks: ['HellaSwag - EM' 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 22\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:22 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Finished problem compilation (took 6.869e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:22 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compilation took 6.869e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:22 PM: Solver (including time spent in interface) took 5.741e-02 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var107409: value [ 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.  1. -0.  0. -0. -0.]\n",
      "Tasks: ['Data imputation - EM' 'HellaSwag - EM']\n",
      "Constructing constraint set for group size 23\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:22 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Finished problem compilation (took 7.308e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:22 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compilation took 7.308e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:22 PM: Solver (including time spent in interface) took 3.654e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['CNN/DailyMail - ROUGE-2']\n",
      "Constructing constraint set for group size 24\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:22 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Finished problem compilation (took 7.551e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:22 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compilation took 7.551e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:22 PM: Solver (including time spent in interface) took 3.662e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['CNN/DailyMail - ROUGE-2']\n",
      "Constructing constraint set for group size 25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:22 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Finished problem compilation (took 7.209e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:22 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compilation took 7.209e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:22 PM: Solver (including time spent in interface) took 3.695e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['CNN/DailyMail - ROUGE-2']\n",
      "Constructing constraint set for group size 26\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:22 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:22 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:22 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:22 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:22 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:22 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:22 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Finished problem compilation (took 6.701e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:23 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compilation took 6.701e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:23 PM: Solver (including time spent in interface) took 3.475e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0.]\n",
      "Tasks: ['HellaSwag - EM']\n",
      "Constructing constraint set for group size 27\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:23 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Finished problem compilation (took 7.036e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:23 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compilation took 7.036e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:23 PM: Solver (including time spent in interface) took 3.500e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0.]\n",
      "Tasks: ['HellaSwag - EM']\n",
      "Constructing constraint set for group size 28\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:23 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Finished problem compilation (took 6.438e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:23 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compilation took 6.438e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:23 PM: Solver (including time spent in interface) took 3.315e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0.]\n",
      "Tasks: ['HellaSwag - EM']\n",
      "Constructing constraint set for group size 29\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:23 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Finished problem compilation (took 6.806e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:23 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compilation took 6.806e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:23 PM: Solver (including time spent in interface) took 3.366e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0.]\n",
      "Tasks: ['HellaSwag - EM']\n",
      "Constructing constraint set for group size 30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:23 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Finished problem compilation (took 7.256e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:23 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compilation took 7.256e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:23 PM: Solver (including time spent in interface) took 3.432e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0. 0. 0. 0.]\n",
      "Tasks: ['HellaSwag - EM']\n",
      "Constructing constraint set for group size 31\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:23 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:23 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:23 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:24 PM: Finished problem compilation (took 2.324e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:24 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:24 PM: Compilation took 2.324e-01 seconds\n",
      "(CVXPY) Apr 24 11:22:24 PM: Solver (including time spent in interface) took 4.446e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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.]\n",
      "Tasks: ['NaturalQuestions (open) - F1']\n",
      "Constructing constraint set for group size 32\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:24 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:24 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:24 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:24 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:24 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:24 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:24 PM: Finished problem compilation (took 7.403e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:24 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:24 PM: Compilation took 7.403e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:24 PM: Solver (including time spent in interface) took 2.928e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1. 0.]\n",
      "Tasks: ['CivilComments - EM']\n",
      "Constructing constraint set for group size 33\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 24 11:22:24 PM: Your problem has 34 variables, 4422 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 24 11:22:24 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 24 11:22:24 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 24 11:22:24 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 24 11:22:24 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Compiling problem (target solver=SCIPY).\n",
      "(CVXPY) Apr 24 11:22:24 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> SCIPY\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) Apr 24 11:22:24 PM: Applying reduction SCIPY\n",
      "(CVXPY) Apr 24 11:22:24 PM: Finished problem compilation (took 7.295e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Invoking solver SCIPY  to obtain a solution.\n",
      "Solver terminated with message: Optimization terminated successfully. (HiGHS Status 7: Optimal)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 24 11:22:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 24 11:22:24 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 24 11:22:24 PM: Compilation took 7.295e-02 seconds\n",
      "(CVXPY) Apr 24 11:22:24 PM: Solver (including time spent in interface) took 2.904e-02 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var107409: 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. 1.]\n",
      "Tasks: ['NaturalQuestions (closed) - F1']\n"
     ]
    }
   ],
   "source": [
    "group_sizes = range(1, len(classic_all_voter_columns))\n",
    "classic_all_ranks_df = selection_algorithms.scores_to_ranks(classic_all_df, classic_all_voter_columns)\n",
    "\n",
    "outputs_pr = selection_algorithms.solve_lp(classic_all_ranks_df[classic_all_voter_columns], classic_all_voter_columns, group_sizes=group_sizes, solver='SCIPY')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "2fd1f0ea-7956-42fe-8715-6dfe0a3892da",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[33.0, 21.0, 14.000000000000002, 10.999999999999943, 9.00000000016035, 8.0, 7.0000000000000036, 5.999999999999768, 4.999999999999997, 4.0, 4.000000000000225, 4.0, 4.0, 2.9999999999999516, 3.0, 2.9999999999999982, 3.0, 3.0000000000008056, 1.9999999999999964, 2.0, 2.0, 2.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0]\n"
     ]
    }
   ],
   "source": [
    "print(outputs_pr)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e5e32fca-dd0e-4b22-86cc-6d9afb916589",
   "metadata": {},
   "source": [
    "## IP augmented"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "c367d004-72bc-48f9-8ad0-6ad42a945264",
   "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 03:15:34 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:34 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:34 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:34 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:34 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:34 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:34 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:34 PM: Finished problem compilation (took 6.744e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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 33.000000 after 0.00 sec. (0.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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.00 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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.01 sec. (4.89 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:34 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:34 PM: Optimal value: 3.300e+01\n",
      "(CVXPY) Apr 25 03:15:34 PM: Compilation took 6.744e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:34 PM: Solver (including time spent in interface) took 3.865e-02 seconds\n",
      "Optimal value: 33.0\n",
      "Variable var160706: value [1. 1. 1. 1. 1. 1. 0. 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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'ICE - BPB'\n",
      " 'Synthetic reasoning (abstra...' 'The Pile - BPB' 'OpenbookQA - EM'\n",
      " 'MATH - Equivalent' 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BoolQ - EM'\n",
      " 'BBQ - EM' 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1'\n",
      " 'Dyck - EM' 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'bAbI - EM' 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 2\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:34 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:34 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:34 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:34 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:34 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:34 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:34 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:34 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Finished problem compilation (took 5.915e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4154 rows and 8 columns.\n",
      "MIP Presolve modified 383 coefficients.\n",
      "Reduced MIP has 268 rows, 26 columns, and 2765 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (28.51 ticks)\n",
      "Found incumbent of value 28.000000 after 0.04 sec. (29.57 ticks)\n",
      "Probing time = 0.00 sec. (0.35 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "MIP Presolve eliminated 20 rows and 0 columns.\n",
      "MIP Presolve modified 6 coefficients.\n",
      "Reduced MIP has 248 rows, 26 columns, and 2527 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (2.04 ticks)\n",
      "Probing time = 0.00 sec. (0.32 ticks)\n",
      "Clique table members: 22.\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.71 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           28.0000        7.0000            75.00%\n",
      "*     0+    0                           22.0000        7.0000            68.18%\n",
      "      0     0       20.2024    22       22.0000       20.2024       81    8.17%\n",
      "      0     0       20.6597    23       22.0000      Cuts: 13      100    6.09%\n",
      "      0     0       21.0000    21       22.0000       Cuts: 6      111    4.55%\n",
      "      0     0       21.0000    22       22.0000   ZeroHalf: 5      124    4.55%\n",
      "      0     0        cutoff             22.0000       22.0000      124    0.00%\n",
      "Elapsed time = 0.08 sec. (53.67 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Implied bound cuts applied:  4\n",
      "Zero-half cuts applied:  2\n",
      "Lift and project cuts applied:  1\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.08 sec. (53.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.08 sec. (53.67 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:35 PM: Optimal value: 2.200e+01\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compilation took 5.915e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:35 PM: Solver (including time spent in interface) took 1.077e-01 seconds\n",
      "Optimal value: 22.0\n",
      "Variable var160706: value [ 1.  1.  0.  0.  0.  1. -0.  1.  1.  0.  1.  1.  1.  1.  0.  1.  1.  1.\n",
      "  1.  1.  1.  1.  0.  1.  1.  0.  0.  1.  1.  0.  0.  1.  0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'The Pile - BPB'\n",
      " 'OpenbookQA - EM' 'MATH - Equivalent' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1' 'Dyck - EM'\n",
      " 'Entity matching - EM' 'MMLU - EM' 'BLiMP - EM' 'bAbI - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 3\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:35 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:35 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:35 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:35 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Finished problem compilation (took 6.169e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4295 rows and 8 columns.\n",
      "Reduced MIP has 128 rows, 26 columns, and 1156 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (13.04 ticks)\n",
      "Found incumbent of value 23.000000 after 0.02 sec. (13.92 ticks)\n",
      "Probing time = 0.00 sec. (0.06 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 128 rows, 26 columns, and 1156 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.51 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. (0.74 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           23.0000        7.0000            69.57%\n",
      "*     0+    0                           18.0000        7.0000            61.11%\n",
      "*     0+    0                           17.0000        7.0000            58.82%\n",
      "      0     0       15.2353    18       17.0000       15.2353       55   10.38%\n",
      "      0     0       15.5116    23       17.0000       Cuts: 7       70    8.76%\n",
      "      0     0       16.0000    13       17.0000       Cuts: 5       78    5.88%\n",
      "      0     0       16.0000    16       17.0000   ZeroHalf: 5       83    5.88%\n",
      "*     0+    0                           16.0000       16.0000             0.00%\n",
      "      0     0        cutoff             16.0000       16.0000       83    0.00%\n",
      "Elapsed time = 0.05 sec. (24.08 ticks, tree = 0.01 MB, solutions = 4)\n",
      "\n",
      "Zero-half cuts applied:  5\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.05 sec. (24.09 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.05 sec. (24.09 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:35 PM: Optimal value: 1.600e+01\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compilation took 6.169e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:35 PM: Solver (including time spent in interface) took 7.981e-02 seconds\n",
      "Optimal value: 16.0\n",
      "Variable var160706: value [ 1.  0.  0.  0.  0.  0. -0.  1.  1.  0.  0.  0.  1.  0.  0.  1.  1.  0.\n",
      "  0.  0.  0.  1.  1.  1.  1.  1.  0.  1.  1.  0.  0.  1.  1.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'TwitterAAE - BPB'\n",
      " 'BBQ - EM' 'XSUM - ROUGE-2' 'Entity matching - EM' 'Data imputation - EM'\n",
      " 'MMLU - EM' 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2' 'bAbI - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 4\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:35 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:35 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:35 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:35 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Finished problem compilation (took 5.678e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4353 rows and 8 columns.\n",
      "Reduced MIP has 70 rows, 26 columns, and 620 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (9.47 ticks)\n",
      "Found incumbent of value 18.000000 after 0.02 sec. (10.31 ticks)\n",
      "Probing time = 0.00 sec. (0.03 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 70 rows, 26 columns, and 620 nonzeros.\n",
      "Reduced MIP has 26 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.00 sec. (0.43 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           18.0000        7.0000            61.11%\n",
      "*     0+    0                           16.0000        7.0000            56.25%\n",
      "*     0+    0                           15.0000        7.0000            53.33%\n",
      "*     0+    0                           14.0000        7.0000            50.00%\n",
      "      0     0       12.6637    18       14.0000       12.6637       50    9.54%\n",
      "      0     0       12.9243    16       14.0000       Cuts: 5       59    7.68%\n",
      "      0     0        cutoff             14.0000                     62    0.00%\n",
      "Elapsed time = 0.04 sec. (12.97 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.04 sec. (12.97 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.04 sec. (12.97 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:35 PM: Optimal value: 1.400e+01\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compilation took 5.678e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:35 PM: Solver (including time spent in interface) took 6.487e-02 seconds\n",
      "Optimal value: 14.0\n",
      "Variable var160706: value [ 1.  0.  0.  1.  0.  0. -0.  1.  1.  0.  0.  0.  0.  0.  0.  0.  1.  0.\n",
      "  0.  0.  1.  0.  0.  1.  0.  1.  0.  0.  1.  1.  1.  1.  1.  1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'XSUM - ROUGE-2' 'Dyck - EM' 'MMLU - EM' 'CNN/DailyMail - ROUGE-2'\n",
      " 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 5\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:35 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:35 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:35 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:35 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Finished problem compilation (took 5.540e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4374 rows and 8 columns.\n",
      "Reduced MIP has 49 rows, 26 columns, and 452 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (7.97 ticks)\n",
      "Found incumbent of value 18.000000 after 0.01 sec. (8.74 ticks)\n",
      "Probing time = 0.00 sec. (0.02 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 49 rows, 26 columns, and 452 nonzeros.\n",
      "Reduced MIP has 26 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.23 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.26 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           18.0000        7.0000            61.11%\n",
      "*     0+    0                           14.0000        7.0000            50.00%\n",
      "*     0+    0                           13.0000        7.0000            46.15%\n",
      "*     0+    0                           12.0000        7.0000            41.67%\n",
      "      0     0       11.4452    16       12.0000       11.4452       44    4.62%\n",
      "      0     0        cutoff             12.0000       11.4452       44    4.62%\n",
      "Elapsed time = 0.03 sec. (9.42 ticks, tree = 0.01 MB, solutions = 4)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (9.42 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.03 sec. (9.42 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:35 PM: Optimal value: 1.200e+01\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compilation took 5.540e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:35 PM: Solver (including time spent in interface) took 5.617e-02 seconds\n",
      "Optimal value: 12.0\n",
      "Variable var160706: value [ 1.  0.  0.  0.  0.  0. -0.  1.  1.  0.  1.  0.  1.  0.  0.  1.  1.  0.\n",
      "  0.  0.  0.  1.  0.  1.  0.  0.  0.  0.  1.  0.  0.  1.  0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'TruthfulQA - EM'\n",
      " 'TwitterAAE - BPB' 'BBQ - EM' 'XSUM - ROUGE-2' 'Entity matching - EM'\n",
      " 'MMLU - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 6\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:35 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:35 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:35 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:35 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:35 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:35 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:35 PM: Finished problem compilation (took 5.493e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4394 rows and 10 columns.\n",
      "Reduced MIP has 29 rows, 24 columns, and 240 nonzeros.\n",
      "Reduced MIP has 23 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (7.26 ticks)\n",
      "Found incumbent of value 14.000000 after 0.01 sec. (8.02 ticks)\n",
      "Probing time = 0.00 sec. (0.01 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 29 rows, 24 columns, and 240 nonzeros.\n",
      "Reduced MIP has 23 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.10 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.14 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           14.0000        7.0000            50.00%\n",
      "*     0+    0                           13.0000        7.0000            46.15%\n",
      "      0     0       10.5000     3       13.0000       10.5000       33   19.23%\n",
      "*     0+    0                           11.0000       10.5000             4.55%\n",
      "      0     0        cutoff             11.0000       10.5000       33    4.55%\n",
      "Elapsed time = 0.03 sec. (8.44 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (8.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.03 sec. (8.44 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:35 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:35 PM: Optimal value: 1.100e+01\n",
      "(CVXPY) Apr 25 03:15:35 PM: Compilation took 5.493e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:35 PM: Solver (including time spent in interface) took 5.596e-02 seconds\n",
      "Optimal value: 11.0\n",
      "Variable var160706: value [ 1. -0.  0.  1.  0.  0. -0.  1.  1.  0.  0.  0. -0.  0.  0.  0.  1.  0.\n",
      "  0.  0.  0.  0.  0.  1.  0.  0.  0.  1.  1.  0.  0.  1.  1.  1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'XSUM - ROUGE-2' 'MMLU - EM' 'bAbI - EM' 'NarrativeQA - F1'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 7\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:36 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Finished problem compilation (took 5.951e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4408 rows and 19 columns.\n",
      "Reduced MIP has 15 rows, 15 columns, and 75 nonzeros.\n",
      "Reduced MIP has 15 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (7.56 ticks)\n",
      "Found incumbent of value 12.000000 after 0.01 sec. (8.31 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 15 rows, 14 columns, and 70 nonzeros.\n",
      "Reduced MIP has 14 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.00 sec. (0.04 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           12.0000        7.0000            41.67%\n",
      "*     0+    0                           10.0000        7.0000            30.00%\n",
      "      0     0        9.6667     6       10.0000        9.6667       16    3.33%\n",
      "      0     0        cutoff             10.0000        9.6667       16    3.33%\n",
      "Elapsed time = 0.03 sec. (8.44 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (8.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.03 sec. (8.44 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:36 PM: Optimal value: 1.000e+01\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compilation took 5.951e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:36 PM: Solver (including time spent in interface) took 1.609e-01 seconds\n",
      "Optimal value: 10.0\n",
      "Variable var160706: value [ 1. -0.  0.  1. -0. -0. -0.  1.  1.  0. -0.  0. -0.  0. -0.  1. -0. -0.\n",
      " -0. -0.  0.  0.  0.  1.  0.  0.  0.  1.  1. -0. -0.  1.  0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'OpenbookQA - EM' 'MATH - Equivalent' 'BBQ - EM'\n",
      " 'MMLU - EM' 'bAbI - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 8\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:36 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Finished problem compilation (took 5.907e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4417 rows and 25 columns.\n",
      "Reduced MIP has 6 rows, 9 columns, and 23 nonzeros.\n",
      "Reduced MIP has 9 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (7.57 ticks)\n",
      "Found incumbent of value 11.000000 after 0.01 sec. (8.29 ticks)\n",
      "Probing time = 0.00 sec. (0.00 ticks)\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve eliminated 0 rows and 1 columns.\n",
      "Reduced MIP has 6 rows, 8 columns, and 21 nonzeros.\n",
      "Reduced MIP has 8 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",
      "Reduced MIP has 6 rows, 8 columns, and 21 nonzeros.\n",
      "Reduced MIP has 8 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",
      "Clique table members: 1.\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                           10.0000        7.0000            30.00%\n",
      "      0     0        9.2000     6       10.0000        9.2000        7    8.00%\n",
      "      0     0        cutoff             10.0000        9.2000        7    8.00%\n",
      "Elapsed time = 0.03 sec. (8.38 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (8.38 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.03 sec. (8.38 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:36 PM: Optimal value: 1.000e+01\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compilation took 5.907e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:36 PM: Solver (including time spent in interface) took 5.956e-02 seconds\n",
      "Optimal value: 10.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0.  1. -0.  1. -0. -0.  1. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'MS MARCO (regular) - RR@10' 'LSAT - EM' 'XSUM - ROUGE-2' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 9\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:36 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Finished problem compilation (took 5.750e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (6.45 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (7.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.01 sec. (7.17 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:36 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compilation took 5.750e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:36 PM: Solver (including time spent in interface) took 3.822e-02 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0.  1. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'XSUM - ROUGE-2'\n",
      " 'MMLU - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:36 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Finished problem compilation (took 5.855e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (7.05 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (7.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.01 sec. (7.73 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:36 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compilation took 5.855e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:36 PM: Solver (including time spent in interface) took 3.876e-02 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var160706: value [ 1. -0. -0.  1. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'MMLU - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 11\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:36 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:36 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:36 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:36 PM: Finished problem compilation (took 5.462e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (6.00 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (6.69 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.01 sec. (6.69 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:36 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:36 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 03:15:36 PM: Compilation took 5.462e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:36 PM: Solver (including time spent in interface) took 3.731e-02 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var160706: value [ 1. -0. -0.  1. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'MMLU - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 12\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Finished problem compilation (took 5.792e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.72 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.43 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.01 sec. (5.43 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:37 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compilation took 5.792e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:37 PM: Solver (including time spent in interface) took 1.383e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 13\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Finished problem compilation (took 5.468e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.71 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.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.01 sec. (5.44 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:37 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compilation took 5.468e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:37 PM: Solver (including time spent in interface) took 3.603e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 14\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Finished problem compilation (took 5.788e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.69 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.38 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.01 sec. (5.38 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:37 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compilation took 5.788e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:37 PM: Solver (including time spent in interface) took 3.760e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Finished problem compilation (took 5.029e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.66 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.34 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.01 sec. (5.34 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:37 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compilation took 5.029e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:37 PM: Solver (including time spent in interface) took 3.537e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 16\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Finished problem compilation (took 5.461e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.64 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.33 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.01 sec. (5.33 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:37 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compilation took 5.461e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:37 PM: Solver (including time spent in interface) took 3.610e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 17\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:37 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:37 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:37 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:37 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:37 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:37 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:37 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Finished problem compilation (took 5.260e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.61 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.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.01 sec. (5.29 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:38 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compilation took 5.260e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:38 PM: Solver (including time spent in interface) took 3.644e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 18\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Finished problem compilation (took 5.441e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.59 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.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.01 sec. (5.26 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:38 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compilation took 5.441e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:38 PM: Solver (including time spent in interface) took 1.331e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 19\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Finished problem compilation (took 5.614e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.56 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.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.01 sec. (5.22 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:38 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compilation took 5.614e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:38 PM: Solver (including time spent in interface) took 3.660e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Finished problem compilation (took 5.659e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.52 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.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.01 sec. (5.17 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:38 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compilation took 5.659e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:38 PM: Solver (including time spent in interface) took 3.702e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 21\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Finished problem compilation (took 5.895e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.46 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.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.01 sec. (5.18 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:38 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compilation took 5.895e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:38 PM: Solver (including time spent in interface) took 3.650e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 22\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:38 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:38 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:38 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:38 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:38 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:38 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:38 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Finished problem compilation (took 5.063e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.38 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (5.08 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.01 sec. (5.08 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:39 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compilation took 5.063e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:39 PM: Solver (including time spent in interface) took 3.668e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 23\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Finished problem compilation (took 5.452e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.29 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.97 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.01 sec. (4.97 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:39 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compilation took 5.452e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:39 PM: Solver (including time spent in interface) took 3.732e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 24\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Finished problem compilation (took 5.850e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.26 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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.01 sec. (4.94 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:39 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compilation took 5.850e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:39 PM: Solver (including time spent in interface) took 1.371e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Finished problem compilation (took 4.799e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.23 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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) =    0.01 sec. (4.90 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:39 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compilation took 4.799e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:39 PM: Solver (including time spent in interface) took 3.480e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 26\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Finished problem compilation (took 4.429e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.00 sec. (4.22 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.88 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.01 sec. (4.88 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:39 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compilation took 4.429e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:39 PM: Solver (including time spent in interface) took 2.974e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 27\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:39 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:39 PM: Finished problem compilation (took 4.843e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.20 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.87 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.01 sec. (4.87 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:39 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:39 PM: Compilation took 4.843e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:39 PM: Solver (including time spent in interface) took 3.162e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 28\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Finished problem compilation (took 4.990e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.18 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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.01 sec. (4.86 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:40 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compilation took 4.990e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:40 PM: Solver (including time spent in interface) took 3.572e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 29\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Finished problem compilation (took 4.329e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.16 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.84 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.01 sec. (4.84 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:40 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compilation took 4.329e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:40 PM: Solver (including time spent in interface) took 3.294e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Finished problem compilation (took 5.978e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.14 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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.01 sec. (4.82 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:40 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compilation took 5.978e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:40 PM: Solver (including time spent in interface) took 3.833e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 31\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Finished problem compilation (took 4.615e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.10 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.87 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.01 sec. (4.87 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:40 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compilation took 4.615e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:40 PM: Solver (including time spent in interface) took 3.029e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 32\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Finished problem compilation (took 4.677e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.01 sec. (4.04 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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.01 sec. (4.82 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:40 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compilation took 4.677e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:40 PM: Solver (including time spent in interface) took 3.148e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for group size 33\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem has 34 variables, 4423 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 03:15:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 03:15:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 03:15:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 03:15:40 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 03:15:40 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 03:15:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 03:15:40 PM: Finished problem compilation (took 4.443e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15: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"
     ]
    },
    {
     "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 4423 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.00 sec. (3.98 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.01 sec. (4.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.01 sec. (4.73 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 03:15:40 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 03:15:40 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 03:15:40 PM: Compilation took 4.443e-02 seconds\n",
      "(CVXPY) Apr 25 03:15:40 PM: Solver (including time spent in interface) took 3.174e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var160706: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n"
     ]
    }
   ],
   "source": [
    "group_sizes = range(1, len(classic_all_voter_columns))\n",
    "outputs_pr_augmented = selection_algorithms.solve_lp_pr(classic_all_ranks_df[classic_all_voter_columns], classic_all_voter_columns, group_sizes=group_sizes, starting_tasks=classic_lite_equiv_columns)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "0240d812-7ee3-4023-9a4f-4e0167128c75",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[33.0, 22.0, 16.0, 14.0, 12.0, 11.0, 10.0, 10.0, 8.0, 8.0, 8.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0]\n"
     ]
    }
   ],
   "source": [
    "print(outputs_pr_augmented)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3ccd0ddb-a312-422b-9e6c-31cce721e4d5",
   "metadata": {},
   "source": [
    "## Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "a4f94b40-fe3a-4716-af1a-4478d40cb575",
   "metadata": {},
   "outputs": [
    {
     "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",
    "group_sizes = range(1, len(classic_all_voter_columns))\n",
    "n = len(classic_all_voter_columns)\n",
    "m = len(classic_all_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=12\n",
    "existing_size=7\n",
    "plt.scatter(group_sizes, outputs_greedy, label='Greedy', color='blue')\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(existing_size, 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,n+5))\n",
    "# plt.legend(fontsize=12)\n",
    "plt.savefig('pr_helm.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "48bb52fc-00ec-4f9e-8d08-01ec5288cea5",
   "metadata": {},
   "source": [
    "# IP for PP"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d9ed6538-9e41-453c-8d3a-1d7e0917d042",
   "metadata": {},
   "source": [
    "## Run IP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "8718cc68-d7bc-4be3-b78b-e72b06f449e4",
   "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 25 04:25:53 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:25:53 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:25:53 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:25:53 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:25:53 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25:53 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:25:53 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:25:53 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:25:53 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:25:53 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:25:53 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:25:53 PM: Finished problem compilation (took 2.224e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25: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"
     ]
    },
    {
     "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 8845 rows and 34 columns.\n",
      "MIP Presolve modified 8042 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.07 sec. (64.04 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.07 sec. (68.27 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.07 sec. (68.27 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25:53 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:25:53 PM: Optimal value: 3.400e+01\n",
      "(CVXPY) Apr 25 04:25:53 PM: Compilation took 2.224e-01 seconds\n",
      "(CVXPY) Apr 25 04:25:53 PM: Solver (including time spent in interface) took 1.411e-01 seconds\n",
      "Optimal value: 34.0\n",
      "Variable var187767: 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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'ICE - BPB'\n",
      " 'Synthetic reasoning (abstra...' 'The Pile - BPB'\n",
      " 'HumanEval (Code) - pass@1' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BoolQ - EM'\n",
      " 'BBQ - EM' 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1'\n",
      " 'Dyck - EM' 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'bAbI - EM' 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.05\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:25:53 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:25:53 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:25:53 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:25:53 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:25:53 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25:54 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:25:54 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:25:54 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:25:54 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:25:54 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:25:54 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:25:54 PM: Finished problem compilation (took 2.214e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25: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"
     ]
    },
    {
     "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 6610 rows and 0 columns.\n",
      "MIP Presolve modified 756 coefficients.\n",
      "Reduced MIP has 2235 rows, 34 columns, and 75990 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.07 sec. (56.81 ticks)\n",
      "Found incumbent of value 32.000000 after 0.10 sec. (72.85 ticks)\n",
      "Probing time = 0.00 sec. (1.31 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2235 rows, 34 columns, and 75990 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (24.23 ticks)\n",
      "Probing time = 0.00 sec. (1.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. (39.84 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        1.0000    34       32.0000        1.0000      232   96.87%\n",
      "      0     0        1.0000    32       32.0000      Cuts: 49      261   96.87%\n",
      "      0     0        1.0000    32       32.0000      Cuts: 46      297   96.87%\n",
      "      0     0        2.1656    33       32.0000      Cuts: 33      347   42.57%\n",
      "*     0+    0                           31.0000       18.3784            40.71%\n",
      "Detecting symmetries...\n",
      "      0     2        2.1656    32       31.0000       18.3784      347   40.71%\n",
      "Elapsed time = 0.68 sec. (577.15 ticks, tree = 0.02 MB, solutions = 2)\n",
      "    319   145       25.1852    19       31.0000       18.3784     7449   40.71%\n",
      "   1211   364       27.5676    13       31.0000       25.3731    21345   18.15%\n",
      "\n",
      "Cover cuts applied:  354\n",
      "Flow cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.61 sec. (573.98 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.39 sec. (713.96 ticks)\n",
      "  Sync time (average)   =    0.38 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.00 sec. (1287.94 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25:56 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:25:56 PM: Optimal value: 3.100e+01\n",
      "(CVXPY) Apr 25 04:25:56 PM: Compilation took 2.214e-01 seconds\n",
      "(CVXPY) Apr 25 04:25:56 PM: Solver (including time spent in interface) took 2.231e+00 seconds\n",
      "Optimal value: 31.0\n",
      "Variable var187767: value [1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 0. 1. 1. 1. 1. 1. 1. 1. 1. 1.]\n",
      "Tasks: ['GSM8K - EM' 'WikiFact - EM' 'ICE - BPB' 'Synthetic reasoning (abstra...'\n",
      " 'The Pile - BPB' 'HumanEval (Code) - pass@1' 'OpenbookQA - EM'\n",
      " 'MATH - Equivalent' 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1' 'Dyck - EM'\n",
      " 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10' 'bAbI - EM'\n",
      " 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:25:56 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:25:56 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:25:56 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:25:56 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:25:56 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25:56 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:25:56 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:25:56 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:25:56 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:25:56 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:25:56 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:25:56 PM: Finished problem compilation (took 2.126e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:25:56 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"
     ]
    },
    {
     "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 6726 rows and 0 columns.\n",
      "MIP Presolve modified 16129 coefficients.\n",
      "Reduced MIP has 2119 rows, 34 columns, and 72046 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.14 sec. (327.60 ticks)\n",
      "Found incumbent of value 29.000000 after 0.16 sec. (342.94 ticks)\n",
      "Probing time = 0.00 sec. (1.25 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2119 rows, 34 columns, and 72046 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (22.89 ticks)\n",
      "Probing time = 0.00 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.03 sec. (30.89 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           29.0000        0.0000           100.00%\n",
      "*     0+    0                           25.0000        0.0000           100.00%\n",
      "*     0+    0                           23.0000        0.0000           100.00%\n",
      "      0     0        1.0000    31       23.0000        1.0000      175   95.65%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000    22       23.0000        1.0000      175   95.65%\n",
      "Elapsed time = 0.64 sec. (680.10 ticks, tree = 0.02 MB, solutions = 3)\n",
      "    506   227       11.1423    23       23.0000        7.7273    15491   66.40%\n",
      "*   887+  487                           22.0000        7.8295            64.41%\n",
      "   1460   806        cutoff             22.0000       11.3164    37140   48.56%\n",
      "   2374  1276       12.5926    25       22.0000       12.1429    52934   44.81%\n",
      "   3358  2006       16.3462    14       22.0000       12.5926    80655   42.76%\n",
      "   4223  2519       18.1679    16       22.0000       13.0000    99837   40.91%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 65590 coefficients.\n",
      "Reduced MIP has 2119 rows, 34 columns, and 72046 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (30.43 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 2119 rows, 34 columns, and 72046 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (22.91 ticks)\n",
      "Represolve time = 0.10 sec. (68.41 ticks)\n",
      "   4370     0        2.3370    24       22.0000       Cuts: 4   107074   40.91%\n",
      "   4370     0        2.3370    22       22.0000      Cuts: 62   107106   40.91%\n",
      "   4370     0        2.3467    24       22.0000      Cuts: 15   107160   40.91%\n",
      "   4370     0        2.5882    24       22.0000      Cuts: 30   107187   40.91%\n",
      "   4370     0        2.5882    23       22.0000      Cuts: 23   107226   40.91%\n",
      "   4370     0        2.5882    30       22.0000      Cuts: 27   107286   40.91%\n",
      "   4370     2        2.5882    26       22.0000       13.9665   107286   36.52%\n",
      "   4378     8        8.0000    29       22.0000       13.9665   107777   36.52%\n",
      "   4679    41       18.7165    17       22.0000       13.9665   109501   36.52%\n",
      "   5535   576       18.4186    14       22.0000       13.9665   132256   36.52%\n",
      "   9978  2600    infeasible             22.0000       15.3333   208196   30.30%\n",
      "Elapsed time = 9.83 sec. (5235.53 ticks, tree = 1.07 MB, solutions = 4)\n",
      "  14794  4216       20.0355    11       22.0000       16.5000   284739   25.00%\n",
      "  19454  5191       20.4150     9       22.0000       17.0487   349100   22.51%\n",
      "  23920  5408       21.0000     7       22.0000       17.9310   400822   18.50%\n",
      "  27666  5198       19.0667    17       22.0000       18.5387   447049   15.73%\n",
      "  31363  5099        cutoff             22.0000       18.7426   482141   14.81%\n",
      "  35010  4943       19.0000    10       22.0000       19.0000   524767   13.64%\n",
      "  38396  3617        cutoff             22.0000       19.3731   562822   11.94%\n",
      "  41812  1967    infeasible             22.0000       20.5566   589047    6.56%\n",
      "  45033   742    infeasible             22.0000       21.0000   610999    4.55%\n",
      "  46871   320       21.0000    10       22.0000       21.0000   620482    4.55%\n",
      "Elapsed time = 42.88 sec. (15568.36 ticks, tree = 0.39 MB, solutions = 4)\n",
      "\n",
      "Cover cuts applied:  2014\n",
      "Flow cuts applied:  1\n",
      "Mixed integer rounding cuts applied:  44\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.58 sec. (677.63 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =   42.37 sec. (14900.08 ticks)\n",
      "  Sync time (average)   =    4.92 sec.\n",
      "  Wait time (average)   =    0.08 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =   42.94 sec. (15577.71 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:26:39 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:26:39 PM: Optimal value: 2.200e+01\n",
      "(CVXPY) Apr 25 04:26:39 PM: Compilation took 2.126e-01 seconds\n",
      "(CVXPY) Apr 25 04:26:39 PM: Solver (including time spent in interface) took 4.301e+01 seconds\n",
      "Optimal value: 22.0\n",
      "Variable var187767: value [ 1. -0.  1.  1.  1.  1.  1. -0.  1.  1. -0.  1. -0. -0. -0.  1. -0.  1.\n",
      "  1. -0.  1. -0.  1.  1. -0.  1.  1.  1.  1.  1.  1. -0.  1. -0.]\n",
      "Tasks: ['GSM8K - EM' 'WikiFact - EM' 'ICE - BPB' 'Synthetic reasoning (abstra...'\n",
      " 'The Pile - BPB' 'HumanEval (Code) - pass@1' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'MS MARCO (regular) - RR@10' 'BBQ - EM'\n",
      " 'LegalSupport - EM' 'IMDB - EM' 'Dyck - EM' 'Data imputation - EM'\n",
      " 'MMLU - EM' 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'bAbI - EM' 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'CivilComments - EM']\n",
      "Constructing constraint set for epsilon 0.15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:26:39 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:26:39 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:26:39 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:26:39 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:26:39 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:26:39 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:26:39 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:26:39 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:26:39 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:26:39 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:26:40 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:26:40 PM: Finished problem compilation (took 2.741e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:26: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"
     ]
    },
    {
     "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 6870 rows and 0 columns.\n",
      "MIP Presolve modified 13541 coefficients.\n",
      "Reduced MIP has 1975 rows, 34 columns, and 67150 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.14 sec. (317.89 ticks)\n",
      "Found incumbent of value 24.000000 after 0.16 sec. (332.41 ticks)\n",
      "Probing time = 0.00 sec. (1.16 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1975 rows, 34 columns, and 67150 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (21.35 ticks)\n",
      "Probing time = 0.00 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.03 sec. (21.30 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                           20.0000        0.0000           100.00%\n",
      "*     0+    0                           19.0000        0.0000           100.00%\n",
      "*     0+    0                           16.0000        0.0000           100.00%\n",
      "      0     0        1.0000    20       16.0000        1.0000      114   93.75%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000    17       16.0000        1.0000      114   93.75%\n",
      "Elapsed time = 0.60 sec. (649.48 ticks, tree = 0.02 MB, solutions = 4)\n",
      "    820   584       11.2397    12       16.0000        5.5738    15597   65.16%\n",
      "   1600   872        cutoff             16.0000        6.7841    22487   57.60%\n",
      "   2475  1307       12.5926    10       16.0000        8.0000    34711   50.00%\n",
      "   3923  2133    infeasible             16.0000        8.3951    56227   47.53%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 61950 coefficients.\n",
      "Reduced MIP has 1975 rows, 34 columns, and 67150 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (28.54 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 1975 rows, 34 columns, and 67150 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (22.19 ticks)\n",
      "Represolve time = 0.11 sec. (64.55 ticks)\n",
      "   4519     0        1.1413    21       16.0000       Cuts: 6    73207   47.15%\n",
      "   4519     0        1.5387    26       16.0000      Cuts: 33    73269   47.15%\n",
      "   4519     0        1.5642    26       16.0000      Fract: 2    73471   47.15%\n",
      "   4519     0        2.8333    18       16.0000      Cuts: 46    73525   47.15%\n",
      "   4519     0        2.8333    18       16.0000      Cuts: 38    73561   47.15%\n",
      "   4519     2        2.8333    18       16.0000        8.4553    73561   47.15%\n",
      "   4542    17        6.3333    18       16.0000        8.4553    74068   47.15%\n",
      "   5309   394    infeasible             16.0000        8.4553    85980   47.15%\n",
      "   6400   953        8.6667    16       16.0000        8.6667   102778   45.83%\n",
      "   7653  1572       11.3333    13       16.0000        9.0000   121275   43.75%\n",
      "*  9400  2416      integral     0       15.0000        9.7143   143277   35.24%\n",
      "  12821  3699       12.5447    14       15.0000       10.0000   191823   33.33%\n",
      "Elapsed time = 9.63 sec. (4576.55 ticks, tree = 1.66 MB, solutions = 5)\n",
      "  18016  5874       13.2222    13       15.0000       10.4000   260222   30.67%\n",
      "  23016  7615       13.0000     9       15.0000       11.0000   318564   26.67%\n",
      "  27340  8825       13.6000     7       15.0000       11.1379   371430   25.75%\n",
      "  31826  9907       13.0000    12       15.0000       11.3176   420038   24.55%\n",
      "  36243 10965       14.0000    10       15.0000       11.4286   472367   23.81%\n",
      "  39616 11332    infeasible             15.0000       11.9579   510413   20.28%\n",
      "  42890 11736       12.1429    10       15.0000       12.0000   542136   20.00%\n",
      "  45981 12207       12.0000    16       15.0000       12.0000   576825   20.00%\n",
      "  48200 12584    infeasible             15.0000       12.0000   604616   20.00%\n",
      "  50958 12833    infeasible             15.0000       12.0000   630522   20.00%\n",
      "Elapsed time = 41.06 sec. (14115.01 ticks, tree = 7.29 MB, solutions = 5)\n",
      "  53951 13094       12.1429    10       15.0000       12.1429   665035   19.05%\n",
      "  57007 13068        cutoff             15.0000       12.1892   693561   18.74%\n",
      "  59758 12874       13.0000    10       15.0000       12.5000   721486   16.67%\n",
      "  62338 12745        cutoff             15.0000       12.6667   751428   15.56%\n",
      "  64601 12535    infeasible             15.0000       12.9497   768006   13.67%\n",
      "  66791 12315        cutoff             15.0000       13.0000   788564   13.33%\n",
      "  68886 12142        cutoff             15.0000       13.0000   814307   13.33%\n",
      "  70975 11928       13.0000    11       15.0000       13.0000   831021   13.33%\n",
      "  72962 11774        cutoff             15.0000       13.0000   853886   13.33%\n",
      "  74874 11688       13.0000    11       15.0000       13.0000   873967   13.33%\n",
      "Elapsed time = 78.96 sec. (23654.86 ticks, tree = 7.47 MB, solutions = 5)\n",
      "  76824 11623       13.0000    11       15.0000       13.0000   885413   13.33%\n",
      "  78719 11588        cutoff             15.0000       13.0000   913159   13.33%\n",
      "  80568 11521    infeasible             15.0000       13.0000   923689   13.33%\n",
      "  82304 11539       13.0000     8       15.0000       13.0000   949192   13.33%\n",
      "  84048 11458       13.0000    12       15.0000       13.0000   959978   13.33%\n",
      "  85743 11303       13.0000    12       15.0000       13.0000   985343   13.33%\n",
      "  87384 11190       14.0000    11       15.0000       13.0000  1001348   13.33%\n",
      "  89023 11165       13.5385    10       15.0000       13.0000  1016840   13.33%\n",
      "  90647 11175       13.0000    12       15.0000       13.0000  1036738   13.33%\n",
      "  92203 11101       13.0000    11       15.0000       13.0000  1056976   13.33%\n",
      "Elapsed time = 123.28 sec. (33198.08 ticks, tree = 7.78 MB, solutions = 5)\n",
      "  93817 11062       13.0334    14       15.0000       13.0000  1077747   13.33%\n",
      "  95402 11127        cutoff             15.0000       13.0000  1092974   13.33%\n",
      "  97048 11184       13.7143    10       15.0000       13.0000  1106796   13.33%\n",
      "  98578 11180       14.0000     5       15.0000       13.0000  1128247   13.33%\n",
      " 100206 10907       13.2222    10       15.0000       13.0000  1148030   13.33%\n",
      " 101992 10728       14.0000    12       15.0000       13.0000  1158986   13.33%\n",
      " 103779 10188        cutoff             15.0000       13.0000  1180203   13.33%\n",
      " 105483  9640        cutoff             15.0000       13.2766  1189270   11.49%\n",
      " 107231  9032    infeasible             15.0000       13.4150  1200293   10.57%\n",
      " 109093  8363        cutoff             15.0000       13.5000  1222650   10.00%\n",
      "Elapsed time = 172.90 sec. (42740.55 ticks, tree = 6.52 MB, solutions = 5)\n",
      " 110715  7725       14.0000    10       15.0000       13.6927  1241617    8.72%\n",
      " 112127  7465       14.0000     7       15.0000       13.8388  1244537    7.74%\n",
      " 113555  6941        cutoff             15.0000       13.9643  1257457    6.90%\n",
      " 114918  6711        cutoff             15.0000       14.0000  1263237    6.67%\n",
      " 116286  6259       14.0000     6       15.0000       14.0000  1273029    6.67%\n",
      " 117673  6011        cutoff             15.0000       14.0000  1280420    6.67%\n",
      " 119045  5387        cutoff             15.0000       14.0000  1295711    6.67%\n",
      " 120372  5203       14.0000     8       15.0000       14.0000  1301328    6.67%\n",
      " 122218  4622        cutoff             15.0000       14.0000  1314967    6.67%\n",
      " 124165  3850       14.0000    12       15.0000       14.0000  1337675    6.67%\n",
      "Elapsed time = 224.13 sec. (52280.83 ticks, tree = 2.94 MB, solutions = 5)\n",
      " 126123  3240        cutoff             15.0000       14.0000  1357821    6.67%\n",
      " 128129  3055       14.0000     9       15.0000       14.0000  1363359    6.67%\n",
      " 130094  2246        cutoff             15.0000       14.0000  1388498    6.67%\n",
      " 132053  2016        cutoff             15.0000       14.0000  1396457    6.67%\n",
      " 134032  1308       14.0000     7       15.0000       14.0000  1419963    6.67%\n",
      " 135915  1223        cutoff             15.0000       14.0000  1424267    6.67%\n",
      " 137875   673       14.0000    10       15.0000       14.0000  1450137    6.67%\n",
      " 139786   131       14.0000     7       15.0000       14.0000  1473981    6.67%\n",
      "\n",
      "Cover cuts applied:  9830\n",
      "Flow cuts applied:  4\n",
      "Mixed integer rounding cuts applied:  141\n",
      "Gomory fractional cuts applied:  3\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.67 sec. (648.07 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =  265.71 sec. (60036.03 ticks)\n",
      "  Sync time (average)   =   20.80 sec.\n",
      "  Wait time (average)   =    0.14 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =  266.38 sec. (60684.09 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:06 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:06 PM: Optimal value: 1.500e+01\n",
      "(CVXPY) Apr 25 04:31:06 PM: Compilation took 2.741e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:06 PM: Solver (including time spent in interface) took 2.665e+02 seconds\n",
      "Optimal value: 15.0\n",
      "Variable var187767: value [-0.  1.  1.  1.  1.  1. -0.  1. -0. -0.  1.  1. -0.  1. -0. -0.  1. -0.\n",
      " -0.  1. -0. -0.  1.  1. -0. -0. -0.  1. -0. -0. -0.  1. -0.  0.]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'ICE - BPB'\n",
      " 'Synthetic reasoning (abstra...' 'The Pile - BPB' 'OpenbookQA - EM'\n",
      " 'TruthfulQA - EM' 'MS MARCO (regular) - RR@10' 'LSAT - EM'\n",
      " 'XSUM - ROUGE-2' 'QuAC - F1' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'bAbI - EM' 'NaturalQuestions (open) - F1']\n",
      "Constructing constraint set for epsilon 0.20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:06 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:06 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:06 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:06 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:06 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:06 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:06 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:06 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:06 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:06 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:06 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:06 PM: Finished problem compilation (took 3.917e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:06 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"
     ]
    },
    {
     "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 6930 rows and 0 columns.\n",
      "MIP Presolve modified 11449 coefficients.\n",
      "Reduced MIP has 1915 rows, 34 columns, and 65110 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.12 sec. (191.01 ticks)\n",
      "Found incumbent of value 22.000000 after 0.14 sec. (205.59 ticks)\n",
      "Probing time = 0.00 sec. (1.13 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1915 rows, 34 columns, and 65110 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (20.71 ticks)\n",
      "Probing time = 0.01 sec. (1.13 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. (13.03 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           22.0000        0.0000           100.00%\n",
      "*     0+    0                           15.0000        0.0000           100.00%\n",
      "*     0+    0                           14.0000        0.0000           100.00%\n",
      "*     0+    0                           13.0000        0.0000           100.00%\n",
      "      0     0        1.0000    12       13.0000        1.0000       48   92.31%\n",
      "*     0+    0                           12.0000        1.0000            91.67%\n",
      "      0     0        2.4638    23       12.0000      Cuts: 63      212   79.47%\n",
      "      0     0        2.4638    18       12.0000      Cuts: 84      234   79.47%\n",
      "      0     0        2.4638    17       12.0000      Cuts: 30      247   79.47%\n",
      "*     0+    0                           11.0000        2.4638            77.60%\n",
      "      0     0        2.4638    17       11.0000     Covers: 1      249   77.27%\n",
      "Detecting symmetries...\n",
      "      0     2        2.4638    16       11.0000        4.3590      249   60.37%\n",
      "Elapsed time = 0.86 sec. (799.80 ticks, tree = 0.02 MB, solutions = 6)\n",
      "    970   554        6.0000    23       11.0000        5.7627    14903   47.61%\n",
      "   1600   622        9.6226     9       11.0000        6.2963    16916   42.76%\n",
      "   2681  1213        9.0234    11       11.0000        6.4327    35921   41.52%\n",
      "   4594  1772        cutoff             11.0000        7.2761    56942   33.85%\n",
      "   6471  2134        9.8347     9       11.0000        7.9688    78408   27.56%\n",
      "\n",
      "Performing restart 1\n",
      "\n",
      "Repeating presolve.\n",
      "Tried aggregator 1 time.\n",
      "MIP Presolve modified 59255 coefficients.\n",
      "Reduced MIP has 1915 rows, 34 columns, and 65110 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (27.50 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Reduced MIP has 1915 rows, 34 columns, and 65110 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (21.41 ticks)\n",
      "Represolve time = 0.12 sec. (63.08 ticks)\n",
      "   6772     0        2.5000    15       11.0000      Cuts: 33    84987   25.88%\n",
      "   6772     0        3.0000    13       11.0000       Cuts: 9    85005   25.88%\n",
      "   6772     0        3.0000    14       11.0000      Cuts: 41    85028   25.88%\n",
      "   6772     0        3.0000    16       11.0000      Cuts: 21    85081   25.88%\n",
      "   6772     0        3.0000    19       11.0000       Cuts: 8    85136   25.88%\n",
      "   6772     2        3.0000    18       11.0000        8.1528    85136   25.88%\n",
      "   6789    19        8.0000    14       11.0000        8.1528    85857   25.88%\n",
      "   7967   364        cutoff             11.0000        8.1528    99259   25.88%\n",
      "   9316   283        cutoff             11.0000        9.0000   116217   18.18%\n",
      "\n",
      "Cover cuts applied:  344\n",
      "Mixed integer rounding cuts applied:  7\n",
      "Gomory fractional cuts applied:  5\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.80 sec. (797.76 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    8.05 sec. (4046.49 ticks)\n",
      "  Sync time (average)   =    1.55 sec.\n",
      "  Wait time (average)   =    0.05 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    8.85 sec. (4844.25 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:16 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:16 PM: Optimal value: 1.100e+01\n",
      "(CVXPY) Apr 25 04:31:16 PM: Compilation took 3.917e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:16 PM: Solver (including time spent in interface) took 9.054e+00 seconds\n",
      "Optimal value: 11.0\n",
      "Variable var187767: value [-0. -0.  1. -0. -0.  1. -0. -0.  1. -0. -0.  1. -0. -0.  1. -0. -0.  1.\n",
      " -0. -0. -0. -0.  1.  1.  1.  1. -0. -0. -0. -0. -0. -0.  1. -0.]\n",
      "Tasks: ['WikiFact - EM' 'The Pile - BPB' 'MATH - Equivalent'\n",
      " 'MS MARCO (regular) - RR@10' 'BoolQ - EM' 'LegalSupport - EM'\n",
      " 'Data imputation - EM' 'MMLU - EM' 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2'\n",
      " 'CivilComments - EM']\n",
      "Constructing constraint set for epsilon 0.25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:16 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:16 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:16 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:16 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:16 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:16 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:16 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:16 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:16 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:16 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:16 PM: Finished problem compilation (took 3.675e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 7055 rows and 0 columns.\n",
      "MIP Presolve modified 22045 coefficients.\n",
      "Reduced MIP has 1790 rows, 34 columns, and 60860 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.16 sec. (365.19 ticks)\n",
      "Found incumbent of value 19.000000 after 0.18 sec. (377.49 ticks)\n",
      "Probing time = 0.00 sec. (1.05 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1790 rows, 34 columns, and 60860 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (19.35 ticks)\n",
      "Probing time = 0.00 sec. (1.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.03 sec. (11.67 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           19.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     9       10.0000        1.0000       46   90.00%\n",
      "      0     0        1.8378    12       10.0000      Cuts: 53       89   81.62%\n",
      "      0     0        1.8378    13       10.0000      Cuts: 35      102   81.62%\n",
      "      0     0        1.8378    11       10.0000      Cuts: 13      118   81.62%\n",
      "*     0+    0                            9.0000        1.8378            79.58%\n",
      "Detecting symmetries...\n",
      "      0     2        1.8378    11        9.0000        3.4000      118   62.22%\n",
      "Elapsed time = 0.66 sec. (665.80 ticks, tree = 0.02 MB, solutions = 4)\n",
      "*   398+  268                            8.0000        3.4000            57.50%\n",
      "   1594   759        6.0177    10        8.0000        4.3871    17336   45.16%\n",
      "   1926   674        6.5806    10        8.0000        4.3871    14498   45.16%\n",
      "   3650  1178        cutoff              8.0000        5.4400    32269   32.00%\n",
      "   5412   904        6.5714    11        8.0000        6.1818    52907   22.73%\n",
      "\n",
      "Cover cuts applied:  591\n",
      "Mixed integer rounding cuts applied:  4\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.61 sec. (664.14 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    3.37 sec. (1334.08 ticks)\n",
      "  Sync time (average)   =    0.83 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    3.98 sec. (1998.22 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:20 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:20 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 04:31:20 PM: Compilation took 3.675e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:20 PM: Solver (including time spent in interface) took 4.063e+00 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var187767: value [0. 1. 0. 0. 0. 1. 0. 0. 0. 0. 0. 1. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 1.\n",
      " 0. 1. 0. 0. 0. 0. 0. 0. 1. 0.]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'The Pile - BPB'\n",
      " 'MS MARCO (regular) - RR@10' 'BoolQ - EM' 'Data imputation - EM'\n",
      " 'MMLU - EM' 'CNN/DailyMail - ROUGE-2' 'CivilComments - EM']\n",
      "Constructing constraint set for epsilon 0.30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:20 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:20 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:20 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:20 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:20 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:20 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:20 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:20 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:20 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:20 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:20 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:20 PM: Finished problem compilation (took 3.349e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 7180 rows and 0 columns.\n",
      "MIP Presolve modified 27788 coefficients.\n",
      "Reduced MIP has 1665 rows, 34 columns, and 56610 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.23 sec. (499.58 ticks)\n",
      "Found incumbent of value 16.000000 after 0.25 sec. (512.99 ticks)\n",
      "Probing time = 0.01 sec. (0.98 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1665 rows, 34 columns, and 56610 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (17.96 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.02 sec. (9.59 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                            8.0000        0.0000           100.00%\n",
      "      0     0        1.0000     8        8.0000        1.0000       23   87.50%\n",
      "      0     0        1.6038    10        8.0000      Cuts: 35       71   79.95%\n",
      "      0     0        1.6038    11        8.0000      Cuts: 33       98   79.95%\n",
      "*     0+    0                            7.0000        1.6038            77.09%\n",
      "      0     0        1.6038    12        7.0000      Cuts: 24      117   55.10%\n",
      "Detecting symmetries...\n",
      "      0     2        1.6038    10        7.0000        3.1429      117   55.10%\n",
      "Elapsed time = 0.70 sec. (859.12 ticks, tree = 0.02 MB, solutions = 4)\n",
      "   1662   698        5.0572    11        7.0000        4.0000    14186   42.86%\n",
      "   3928   767    infeasible              7.0000        5.1515    30615   26.41%\n",
      "\n",
      "Cover cuts applied:  504\n",
      "Mixed integer rounding cuts applied:  3\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.66 sec. (857.82 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.39 sec. (598.75 ticks)\n",
      "  Sync time (average)   =    0.54 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    2.05 sec. (1456.57 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:23 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:23 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:31:23 PM: Compilation took 3.349e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:23 PM: Solver (including time spent in interface) took 2.114e+00 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var187767: value [-0.  1. -0. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0. -0. -0.  1.  1. -0.  1. -0. -0. -0.  1.  1.]\n",
      "Tasks: ['MATH (chain-of-thoughts) - ...' 'The Pile - BPB'\n",
      " 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10' 'NarrativeQA - F1'\n",
      " 'CivilComments - EM' 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.35\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:23 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:23 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:23 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:23 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:23 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:23 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:23 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:23 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:23 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:23 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:23 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:23 PM: Finished problem compilation (took 3.841e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 7259 rows and 0 columns.\n",
      "MIP Presolve modified 30961 coefficients.\n",
      "Reduced MIP has 1586 rows, 34 columns, and 53924 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.21 sec. (459.28 ticks)\n",
      "Found incumbent of value 13.000000 after 0.24 sec. (471.27 ticks)\n",
      "Probing time = 0.00 sec. (0.93 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1586 rows, 34 columns, and 53924 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (17.12 ticks)\n",
      "Probing time = 0.00 sec. (0.93 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. (8.68 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                            6.0000        0.0000           100.00%\n",
      "      0     0        1.0000     7        6.0000        1.0000       16   83.33%\n",
      "      0     0        1.3127    12        6.0000     Cuts: 102       54   78.12%\n",
      "      0     0        1.3127    11        6.0000      Cuts: 83       83   78.12%\n",
      "      0     0        1.3127    11        6.0000      Cuts: 45       98   78.12%\n",
      "*     0+    0                            5.0000        1.3127            73.75%\n",
      "Detecting symmetries...\n",
      "      0     2        1.3127    11        5.0000        2.0000       98   60.00%\n",
      "Elapsed time = 0.74 sec. (677.16 ticks, tree = 0.02 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  51\n",
      "Mixed integer rounding cuts applied:  4\n",
      "Gomory fractional cuts applied:  3\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.69 sec. (675.85 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.36 sec. (73.62 ticks)\n",
      "  Sync time (average)   =    0.17 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.05 sec. (749.46 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:24 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:24 PM: Optimal value: 5.000e+00\n",
      "(CVXPY) Apr 25 04:31:24 PM: Compilation took 3.841e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:24 PM: Solver (including time spent in interface) took 1.254e+00 seconds\n",
      "Optimal value: 5.0\n",
      "Variable var187767: value [-0. -0. -0. -0.  1.  1. -0. -0.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.]\n",
      "Tasks: ['Synthetic reasoning (abstra...' 'The Pile - BPB' 'MATH - Equivalent'\n",
      " 'MMLU - EM' 'HellaSwag - EM']\n",
      "Constructing constraint set for epsilon 0.40\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:24 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:24 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:24 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:24 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:24 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:24 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:24 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:24 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:24 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:24 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:25 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:25 PM: Finished problem compilation (took 3.972e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 7398 rows and 0 columns.\n",
      "MIP Presolve modified 40253 coefficients.\n",
      "Reduced MIP has 1447 rows, 34 columns, and 49198 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.22 sec. (534.28 ticks)\n",
      "Found incumbent of value 11.000000 after 0.23 sec. (546.26 ticks)\n",
      "Probing time = 0.00 sec. (0.85 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1447 rows, 34 columns, and 49198 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (15.54 ticks)\n",
      "Probing time = 0.01 sec. (0.85 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. (7.76 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                            6.0000        0.0000           100.00%\n",
      "*     0+    0                            5.0000        0.0000           100.00%\n",
      "      0     0        1.0000     6        5.0000        1.0000       16   80.00%\n",
      "      0     0        1.2319    12        5.0000     Cuts: 104       46   75.36%\n",
      "      0     0        1.2319    11        5.0000      Cuts: 30       61   75.36%\n",
      "      0     0        1.5000     6        5.0000      Cuts: 10       75   70.00%\n",
      "      0     0        1.5303    13        5.0000      Cuts: 63      115   69.39%\n",
      "      0     0        1.5441    19        5.0000      Cuts: 19      136   69.12%\n",
      "Detecting symmetries...\n",
      "      0     0        1.5462    22        5.0000       Cuts: 8      144   69.08%\n",
      "      0     0        2.0000    16        5.0000       Cuts: 7      155   60.00%\n",
      "      0     0        2.0000    15        5.0000      Cuts: 12      161   60.00%\n",
      "*     0+    0                            4.0000        2.0000            50.00%\n",
      "      0     0        cutoff              4.0000        4.0000      161    0.00%\n",
      "Elapsed time = 0.97 sec. (1263.46 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.98 sec. (1263.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.98 sec. (1263.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:26 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:26 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 04:31:26 PM: Compilation took 3.972e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:26 PM: Solver (including time spent in interface) took 1.048e+00 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var187767: value [1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 1. 1. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['GSM8K - EM' 'TruthfulQA - EM' 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2']\n",
      "Constructing constraint set for epsilon 0.45\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:26 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:26 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:26 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:26 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:26 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:26 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:26 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:26 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:26 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:26 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:26 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:26 PM: Finished problem compilation (took 3.017e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 7588 rows and 0 columns.\n",
      "MIP Presolve modified 49474 coefficients.\n",
      "Reduced MIP has 1257 rows, 34 columns, and 42738 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.26 sec. (665.28 ticks)\n",
      "Found incumbent of value 9.000000 after 0.28 sec. (675.71 ticks)\n",
      "Probing time = 0.01 sec. (0.74 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1257 rows, 34 columns, and 42738 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (13.47 ticks)\n",
      "Probing time = 0.00 sec. (0.74 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. (6.70 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                            5.0000        0.0000           100.00%\n",
      "*     0+    0                            4.0000        0.0000           100.00%\n",
      "      0     0        1.0000     6        4.0000        1.0000       15   75.00%\n",
      "      0     0        1.0000     7        4.0000     Cuts: 121       35   75.00%\n",
      "      0     0        1.0000     7        4.0000      Cuts: 61       50   75.00%\n",
      "Detecting symmetries...\n",
      "      0     2        1.0000     7        4.0000        1.0000       50   75.00%\n",
      "Elapsed time = 0.58 sec. (806.03 ticks, tree = 0.02 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  60\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.54 sec. (805.03 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.31 sec. (93.54 ticks)\n",
      "  Sync time (average)   =    0.17 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.85 sec. (898.58 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:27 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:27 PM: Optimal value: 4.000e+00\n",
      "(CVXPY) Apr 25 04:31:27 PM: Compilation took 3.017e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:27 PM: Solver (including time spent in interface) took 9.227e-01 seconds\n",
      "Optimal value: 4.0\n",
      "Variable var187767: value [1. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'MS MARCO (regular) - RR@10' 'MMLU - EM']\n",
      "Constructing constraint set for epsilon 0.50\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:27 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:27 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:27 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:27 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:27 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:27 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:27 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:27 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:27 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:27 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:27 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:27 PM: Finished problem compilation (took 3.768e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:27 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"
     ]
    },
    {
     "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 7757 rows and 0 columns.\n",
      "MIP Presolve modified 48145 coefficients.\n",
      "Reduced MIP has 1088 rows, 34 columns, and 36992 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.14 sec. (301.84 ticks)\n",
      "Found incumbent of value 7.000000 after 0.15 sec. (310.81 ticks)\n",
      "Probing time = 0.00 sec. (0.63 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1088 rows, 34 columns, and 36992 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (11.59 ticks)\n",
      "Probing time = 0.00 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.02 sec. (6.20 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     8        4.0000        1.0000       17   75.00%\n",
      "      0     0        1.0000     7        4.0000      Cuts: 84       40   75.00%\n",
      "      0     0        1.2143     7        4.0000      Cuts: 58       55   69.64%\n",
      "*     0+    0                            3.0000        1.2143            59.52%\n",
      "      0     0        1.3333     7        3.0000      Cuts: 82       61   55.56%\n",
      "      0     0        1.3333     7        3.0000    MIRcuts: 1       62   55.56%\n",
      "Detecting symmetries...\n",
      "      0     0        cutoff              3.0000        3.0000       62    0.00%\n",
      "Elapsed time = 0.37 sec. (443.03 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  9\n",
      "Mixed integer rounding cuts applied:  1\n",
      "Gomory fractional cuts applied:  2\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.38 sec. (443.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.38 sec. (443.15 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:28 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:28 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 04:31:28 PM: Compilation took 3.768e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:28 PM: Solver (including time spent in interface) took 4.522e-01 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var187767: value [-0. -0. -0.  1.  1. -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.  1.]\n",
      "Tasks: ['ICE - BPB' 'Synthetic reasoning (abstra...'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.55\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:28 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:28 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:28 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:28 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:28 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:28 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:28 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:28 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:28 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:28 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:28 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:28 PM: Finished problem compilation (took 3.128e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 7844 rows and 0 columns.\n",
      "MIP Presolve modified 45868 coefficients.\n",
      "Reduced MIP has 1001 rows, 34 columns, and 34034 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.10 sec. (156.37 ticks)\n",
      "Found incumbent of value 6.000000 after 0.11 sec. (165.56 ticks)\n",
      "Probing time = 0.00 sec. (0.58 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1001 rows, 34 columns, and 34034 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (10.77 ticks)\n",
      "Probing time = 0.00 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.02 sec. (5.26 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     6        3.0000        1.0000       16   66.67%\n",
      "      0     0        1.0213    11        3.0000      Cuts: 73       35   65.96%\n",
      "      0     0        1.3333     4        3.0000      Cuts: 41       43   55.56%\n",
      "Detecting symmetries...\n",
      "      0     2        1.3333     4        3.0000        1.4286       43   52.38%\n",
      "Elapsed time = 0.30 sec. (259.24 ticks, tree = 0.02 MB, solutions = 2)\n",
      "\n",
      "Cover cuts applied:  2\n",
      "Mixed integer rounding cuts applied:  1\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.27 sec. (258.56 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    0.10 sec. (18.19 ticks)\n",
      "  Sync time (average)   =    0.02 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    0.37 sec. (276.75 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:29 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:29 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 04:31:29 PM: Compilation took 3.128e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:29 PM: Solver (including time spent in interface) took 4.404e-01 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var187767: value [0. 0. 1. 0. 1. 1. 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.]\n",
      "Tasks: ['WikiFact - EM' 'Synthetic reasoning (abstra...' 'The Pile - BPB']\n",
      "Constructing constraint set for epsilon 0.60\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:29 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:29 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:29 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:29 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:29 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:29 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:29 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:29 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:29 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:29 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:29 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:29 PM: Finished problem compilation (took 3.221e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8034 rows and 0 columns.\n",
      "MIP Presolve modified 56949 coefficients.\n",
      "Reduced MIP has 811 rows, 34 columns, and 27574 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.12 sec. (236.17 ticks)\n",
      "Found incumbent of value 6.000000 after 0.13 sec. (244.82 ticks)\n",
      "Probing time = 0.01 sec. (0.47 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 811 rows, 34 columns, and 27574 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (9.85 ticks)\n",
      "Probing time = 0.01 sec. (0.47 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. (3.85 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       12   66.67%\n",
      "      0     0        1.0000     4        3.0000      Cuts: 47       22   66.67%\n",
      "      0     0        1.0357     9        3.0000      Cuts: 11       37   65.48%\n",
      "      0     0        1.0533     8        3.0000      Cuts: 32       42   64.89%\n",
      "      0     0        1.0599     7        3.0000      Cuts: 23       48   64.67%\n",
      "      0     0        1.2000     6        3.0000      Cuts: 39       50   60.00%\n",
      "Detecting symmetries...\n",
      "      0     0        1.5000     5        3.0000   ZeroHalf: 1       54   50.00%\n",
      "      0     0        1.5000     5        3.0000       Cuts: 4       57   50.00%\n",
      "      0     0        2.0000     5        3.0000      Cuts: 31       59   33.33%\n",
      "      0     0        2.0000     5        3.0000       Cuts: 2       63   33.33%\n",
      "      0     0        cutoff              3.0000        3.0000       63    0.00%\n",
      "Elapsed time = 0.33 sec. (372.57 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Zero-half cuts applied:  3\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.34 sec. (372.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.34 sec. (372.65 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:30 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:30 PM: Optimal value: 3.000e+00\n",
      "(CVXPY) Apr 25 04:31:30 PM: Compilation took 3.221e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:30 PM: Solver (including time spent in interface) took 4.066e-01 seconds\n",
      "Optimal value: 3.0\n",
      "Variable var187767: value [0. 0. 1. 0. 1. 1. 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.]\n",
      "Tasks: ['WikiFact - EM' 'Synthetic reasoning (abstra...' 'The Pile - BPB']\n",
      "Constructing constraint set for epsilon 0.65\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:30 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:30 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:30 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:30 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:30 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:30 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:30 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:30 PM: Finished problem compilation (took 3.446e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8173 rows and 0 columns.\n",
      "MIP Presolve modified 56594 coefficients.\n",
      "Reduced MIP has 672 rows, 34 columns, and 22848 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.12 sec. (187.55 ticks)\n",
      "Found incumbent of value 5.000000 after 0.13 sec. (195.07 ticks)\n",
      "Probing time = 0.00 sec. (0.39 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 672 rows, 34 columns, and 22848 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (8.22 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.00 sec. (3.23 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.0000     5        2.0000        1.0000       12   50.00%\n",
      "      0     0        cutoff              2.0000                     67    0.00%\n",
      "Elapsed time = 0.20 sec. (225.77 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.20 sec. (225.84 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. (225.84 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:30 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:30 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 04:31:30 PM: Compilation took 3.446e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:30 PM: Solver (including time spent in interface) took 4.119e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var187767: 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",
      " 1. 0. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['QuAC - F1' 'BLiMP - EM']\n",
      "Constructing constraint set for epsilon 0.70\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:30 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:30 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:30 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:30 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:30 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:30 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:30 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:30 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:31 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:31 PM: Finished problem compilation (took 4.401e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8252 rows and 0 columns.\n",
      "MIP Presolve modified 66547 coefficients.\n",
      "Reduced MIP has 593 rows, 34 columns, and 20162 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.07 sec. (32.70 ticks)\n",
      "Found incumbent of value 4.000000 after 0.08 sec. (39.86 ticks)\n",
      "Probing time = 0.00 sec. (0.34 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 593 rows, 34 columns, and 20162 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (7.31 ticks)\n",
      "Probing time = 0.00 sec. (0.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.01 sec. (2.85 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                            3.0000        0.0000           100.00%\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     5        2.0000        1.0000       12   50.00%\n",
      "      0     0        cutoff              2.0000                     63    0.00%\n",
      "Elapsed time = 0.16 sec. (66.75 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (66.81 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. (66.81 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:31 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:31 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 04:31:31 PM: Compilation took 4.401e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:31 PM: Solver (including time spent in interface) took 2.235e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var187767: 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",
      " 1. 0. 0. 0. 0. 0. 0. 0. 0. 0.]\n",
      "Tasks: ['QuAC - F1' 'BLiMP - EM']\n",
      "Constructing constraint set for epsilon 0.75\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:31 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:31 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:31 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:31 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:31 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:31 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:31 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:31 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:31 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:31 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:32 PM: Finished problem compilation (took 3.995e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8377 rows and 0 columns.\n",
      "MIP Presolve modified 59025 coefficients.\n",
      "Reduced MIP has 468 rows, 34 columns, and 15912 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (30.63 ticks)\n",
      "Found incumbent of value 4.000000 after 0.06 sec. (37.24 ticks)\n",
      "Probing time = 0.00 sec. (0.27 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 468 rows, 34 columns, and 15912 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (5.57 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.00 sec. (1.97 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        6   50.00%\n",
      "      0     0        cutoff              2.0000                     68    0.00%\n",
      "Elapsed time = 0.12 sec. (58.51 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.12 sec. (58.51 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. (58.51 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:32 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:32 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 04:31:32 PM: Compilation took 3.995e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:32 PM: Solver (including time spent in interface) took 2.016e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var187767: 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.]\n",
      "Tasks: ['WikiFact - EM' 'ICE - BPB']\n",
      "Constructing constraint set for epsilon 0.80\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:32 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:32 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:32 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:32 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:32 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:32 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:32 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:32 PM: Finished problem compilation (took 3.957e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8502 rows and 0 columns.\n",
      "MIP Presolve modified 51093 coefficients.\n",
      "Reduced MIP has 343 rows, 34 columns, and 11662 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (28.58 ticks)\n",
      "Found incumbent of value 2.000000 after 0.07 sec. (34.65 ticks)\n",
      "Probing time = 0.00 sec. (0.19 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 343 rows, 34 columns, and 11662 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (4.24 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.34 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     2        2.0000        1.0000        3   50.00%\n",
      "      0     0        cutoff              2.0000                     73    0.00%\n",
      "Elapsed time = 0.10 sec. (50.60 ticks, tree = 0.01 MB, solutions = 1)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.11 sec. (50.60 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. (50.60 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:32 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:32 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 04:31:32 PM: Compilation took 3.957e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:32 PM: Solver (including time spent in interface) took 1.703e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var187767: value [ 1.  1. -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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...']\n",
      "Constructing constraint set for epsilon 0.85\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:32 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:32 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:32 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:32 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:32 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:32 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:32 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:32 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:33 PM: Finished problem compilation (took 3.000e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8562 rows and 0 columns.\n",
      "MIP Presolve modified 46765 coefficients.\n",
      "Reduced MIP has 283 rows, 34 columns, and 9622 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (27.55 ticks)\n",
      "Found incumbent of value 2.000000 after 0.04 sec. (33.41 ticks)\n",
      "Probing time = 0.00 sec. (0.43 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 283 rows, 34 columns, and 9622 nonzeros.\n",
      "Reduced MIP has 34 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (3.54 ticks)\n",
      "Probing time = 0.00 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.00 sec. (1.17 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     2        2.0000        1.0000        3   50.00%\n",
      "      0     0        cutoff              2.0000                     54    0.00%\n",
      "Elapsed time = 0.10 sec. (47.26 ticks, tree = 0.01 MB, solutions = 1)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.10 sec. (47.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.10 sec. (47.29 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:33 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:33 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 04:31:33 PM: Compilation took 3.000e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:33 PM: Solver (including time spent in interface) took 1.613e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var187767: value [ 1.  1. -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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...']\n",
      "Constructing constraint set for epsilon 0.90\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:33 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:33 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:33 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:33 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:33 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:33 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:33 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:33 PM: Finished problem compilation (took 2.405e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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"
     ]
    },
    {
     "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 8724 rows and 3 columns.\n",
      "MIP Presolve modified 36593 coefficients.\n",
      "Reduced MIP has 121 rows, 31 columns, and 3751 nonzeros.\n",
      "Reduced MIP has 31 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (28.19 ticks)\n",
      "Found incumbent of value 2.000000 after 0.04 sec. (33.28 ticks)\n",
      "Probing time = 0.00 sec. (0.15 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 121 rows, 31 columns, and 3751 nonzeros.\n",
      "Reduced MIP has 31 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (1.53 ticks)\n",
      "Probing time = 0.00 sec. (0.15 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.34 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                            2.0000        0.0000           100.00%\n",
      "      0     0        1.0000     2        2.0000        1.0000        2   50.00%\n",
      "      0     0        cutoff              2.0000                     58    0.00%\n",
      "Elapsed time = 0.10 sec. (38.49 ticks, tree = 0.01 MB, solutions = 1)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.11 sec. (38.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.11 sec. (38.49 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:33 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:33 PM: Optimal value: 2.000e+00\n",
      "(CVXPY) Apr 25 04:31:33 PM: Compilation took 2.405e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:33 PM: Solver (including time spent in interface) took 1.734e-01 seconds\n",
      "Optimal value: 2.0\n",
      "Variable var187767: value [ 1.  1. -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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...']\n",
      "Constructing constraint set for epsilon 0.95\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:31:33 PM: Your problem has 34 variables, 8845 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:31:33 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:31:33 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:31:33 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:31:33 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:33 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:31:33 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:31:33 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:31:34 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:31:34 PM: Finished problem compilation (took 5.192e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31: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 1.000000 after 0.00 sec. (0.21 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 8845 rows and 34 columns.\n",
      "MIP Presolve modified 16694 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.05 sec. (20.89 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.05 sec. (21.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.05 sec. (21.13 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:31:34 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:31:34 PM: Optimal value: 1.000e+00\n",
      "(CVXPY) Apr 25 04:31:34 PM: Compilation took 5.192e-01 seconds\n",
      "(CVXPY) Apr 25 04:31:34 PM: Solver (including time spent in interface) took 1.180e-01 seconds\n",
      "Optimal value: 1.0\n",
      "Variable var187767: 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.]\n",
      "Tasks: ['GSM8K - EM']\n"
     ]
    }
   ],
   "source": [
    "group_sizes = range(1, len(classic_all_voter_columns))\n",
    "classic_all_ranks_df = selection_algorithms.scores_to_ranks(classic_all_df, classic_all_voter_columns)\n",
    "\n",
    "outputs_pp = selection_algorithms.solve_lp_pp(classic_all_ranks_df[classic_all_voter_columns], classic_all_voter_columns, epsilons=np.arange(0, 1, 0.05))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "1d8c8242-90f0-4b42-be33-76c204157387",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[34.0, 31.0, 22.0, 15.0, 11.0, 8.0, 7.0, 5.0, 4.0, 4.0, 3.0, 3.0, 3.0, 2.0, 2.0, 2.0, 2.0, 2.0, 2.0, 1.0]\n"
     ]
    }
   ],
   "source": [
    "print(outputs_pp)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "381fded4-d67e-4c4b-b5c2-08a640668449",
   "metadata": {},
   "source": [
    "## IP Augmented"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "c437895f-8eb9-4a2c-ab4f-09b23959d48d",
   "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 25 04:33:04 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:04 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:04 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:04 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:04 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:04 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:04 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:04 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:04 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:04 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:04 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:04 PM: Finished problem compilation (took 3.309e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.03 sec. (18.71 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.04 sec. (22.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.04 sec. (22.94 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:04 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:04 PM: Optimal value: 3.400e+01\n",
      "(CVXPY) Apr 25 04:33:04 PM: Compilation took 3.309e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:04 PM: Solver (including time spent in interface) took 1.135e-01 seconds\n",
      "Optimal value: 34.0\n",
      "Variable var230968: 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.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'WikiFact - EM' 'ICE - BPB'\n",
      " 'Synthetic reasoning (abstra...' 'The Pile - BPB'\n",
      " 'HumanEval (Code) - pass@1' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BoolQ - EM'\n",
      " 'BBQ - EM' 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1'\n",
      " 'Dyck - EM' 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'BLiMP - EM' 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'bAbI - EM' 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.05\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:05 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:05 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:05 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:05 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:05 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:05 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:05 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:05 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:05 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:05 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:05 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:05 PM: Finished problem compilation (took 3.739e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 6693 rows and 7 columns.\n",
      "MIP Presolve modified 10249 coefficients.\n",
      "Reduced MIP has 2153 rows, 27 columns, and 57382 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.27 sec. (504.57 ticks)\n",
      "Found incumbent of value 33.000000 after 0.29 sec. (517.57 ticks)\n",
      "Probing time = 0.00 sec. (2.43 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "MIP Presolve eliminated 1 rows and 0 columns.\n",
      "MIP Presolve modified 149 coefficients.\n",
      "Reduced MIP has 2152 rows, 27 columns, and 57342 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.06 sec. (42.54 ticks)\n",
      "Probing time = 0.01 sec. (2.43 ticks)\n",
      "Clique table members: 27.\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.29 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           33.0000        7.0000            78.79%\n",
      "*     0+    0                           31.0000        7.0000            77.42%\n",
      "      0     0       22.3034    26       31.0000       22.3034      136   28.05%\n",
      "      0     0       23.3349    25       31.0000      Cuts: 24      164   16.10%\n",
      "      0     0       24.1339    25       31.0000      Cuts: 13      194   16.10%\n",
      "      0     0       24.1457    25       31.0000       Cuts: 4      199   16.10%\n",
      "      0     0        cutoff             31.0000       31.0000      199    0.00%\n",
      "Elapsed time = 0.81 sec. (920.72 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "GUB cover cuts applied:  1\n",
      "Cover cuts applied:  1\n",
      "Mixed integer rounding cuts applied:  5\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.82 sec. (920.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.82 sec. (920.89 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:06 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:06 PM: Optimal value: 3.100e+01\n",
      "(CVXPY) Apr 25 04:33:06 PM: Compilation took 3.739e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:06 PM: Solver (including time spent in interface) took 8.881e-01 seconds\n",
      "Optimal value: 31.0\n",
      "Variable var230968: value [1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 0. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n",
      " 0. 1. 1. 1. 1. 1. 1. 1. 1. 1.]\n",
      "Tasks: ['GSM8K - EM' 'WikiFact - EM' 'ICE - BPB' 'Synthetic reasoning (abstra...'\n",
      " 'The Pile - BPB' 'HumanEval (Code) - pass@1' 'OpenbookQA - EM'\n",
      " 'MATH - Equivalent' 'Synthetic reasoning (natura...' 'TruthfulQA - EM'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'BBQ - EM'\n",
      " 'XSUM - ROUGE-2' 'LegalSupport - EM' 'IMDB - EM' 'QuAC - F1' 'Dyck - EM'\n",
      " 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM'\n",
      " 'CNN/DailyMail - ROUGE-2' 'MS MARCO (TREC) - NDCG@10' 'bAbI - EM'\n",
      " 'NarrativeQA - F1' 'HellaSwag - EM' 'RAFT - EM'\n",
      " 'NaturalQuestions (open) - F1' 'CivilComments - EM'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.10\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:06 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:06 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:06 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:06 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:06 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:06 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:06 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:06 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:06 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:06 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:06 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:06 PM: Finished problem compilation (took 3.251e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:06 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"
     ]
    },
    {
     "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 6807 rows and 7 columns.\n",
      "MIP Presolve modified 16668 coefficients.\n",
      "Reduced MIP has 2039 rows, 27 columns, and 54156 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.17 sec. (372.94 ticks)\n",
      "Found incumbent of value 28.000000 after 0.19 sec. (385.79 ticks)\n",
      "Probing time = 0.00 sec. (0.93 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 2039 rows, 27 columns, and 54156 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (16.82 ticks)\n",
      "Probing time = 0.00 sec. (0.93 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. (19.67 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           28.0000        7.0000            75.00%\n",
      "*     0+    0                           25.0000        7.0000            72.00%\n",
      "      0     0       15.8667    23       25.0000       15.8667      115   36.53%\n",
      "*     0+    0                           24.0000       15.8667            33.89%\n",
      "      0     0       16.9645    19       24.0000      Cuts: 16      132   29.31%\n",
      "      0     0       17.2688    14       24.0000      Cuts: 13      151   28.05%\n",
      "      0     0       17.5484    14       24.0000      Cuts: 11      158   26.88%\n",
      "      0     0       18.0000    14       24.0000       Cuts: 5      164   25.00%\n",
      "Detecting symmetries...\n",
      "      0     2       18.0000    14       24.0000       18.0000      164   25.00%\n",
      "Elapsed time = 0.59 sec. (657.38 ticks, tree = 0.02 MB, solutions = 3)\n",
      "*   586+  224                           23.0000       19.0000            17.39%\n",
      "   1215   266        cutoff             23.0000       20.3521    10382   11.51%\n",
      "\n",
      "Cover cuts applied:  535\n",
      "Flow cuts applied:  1\n",
      "Mixed integer rounding cuts applied:  5\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.55 sec. (655.42 ticks)\n",
      "Parallel b&c, 16 threads:\n",
      "  Real time             =    1.04 sec. (430.57 ticks)\n",
      "  Sync time (average)   =    0.43 sec.\n",
      "  Wait time (average)   =    0.00 sec.\n",
      "                          ------------\n",
      "Total (root+branch&cut) =    1.59 sec. (1085.99 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:08 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:08 PM: Optimal value: 2.300e+01\n",
      "(CVXPY) Apr 25 04:33:08 PM: Compilation took 3.251e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:08 PM: Solver (including time spent in interface) took 1.666e+00 seconds\n",
      "Optimal value: 23.0\n",
      "Variable var230968: value [1. 1. 0. 1. 1. 0. 1. 1. 1. 1. 0. 0. 0. 1. 0. 1. 1. 0. 1. 1. 0. 1. 1. 1.\n",
      " 1. 0. 1. 1. 1. 1. 0. 1. 0. 1.]\n",
      "Tasks: ['GSM8K - EM' 'MATH (chain-of-thoughts) - ...' 'ICE - BPB'\n",
      " 'Synthetic reasoning (abstra...' 'HumanEval (Code) - pass@1'\n",
      " 'OpenbookQA - EM' 'MATH - Equivalent' 'Synthetic reasoning (natura...'\n",
      " 'LSAT - EM' 'BBQ - EM' 'XSUM - ROUGE-2' 'IMDB - EM' 'QuAC - F1'\n",
      " 'Entity matching - EM' 'Data imputation - EM' 'MMLU - EM' 'BLiMP - EM'\n",
      " 'MS MARCO (TREC) - NDCG@10' 'bAbI - EM' 'NarrativeQA - F1'\n",
      " 'HellaSwag - EM' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.15\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:08 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:08 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:08 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:08 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:08 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:08 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:08 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:08 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:08 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:08 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:08 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:08 PM: Finished problem compilation (took 3.380e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 6966 rows and 7 columns.\n",
      "MIP Presolve modified 22650 coefficients.\n",
      "Reduced MIP has 1880 rows, 27 columns, and 50172 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.14 sec. (303.41 ticks)\n",
      "Found incumbent of value 24.000000 after 0.16 sec. (315.53 ticks)\n",
      "Probing time = 0.01 sec. (0.85 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1880 rows, 27 columns, and 50172 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.03 sec. (15.56 ticks)\n",
      "Probing time = 0.00 sec. (0.85 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. (11.95 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           24.0000        7.0000            70.83%\n",
      "*     0+    0                           20.0000        7.0000            65.00%\n",
      "*     0+    0                           17.0000        7.0000            58.82%\n",
      "      0     0       12.9771    15       17.0000       12.9771       58   23.66%\n",
      "      0     0       13.2857    16       17.0000       Cuts: 8       73   18.78%\n",
      "      0     0       14.0000    15       17.0000      Cuts: 15       86   17.65%\n",
      "      0     0       14.0000    13       17.0000       Cuts: 5       91   17.65%\n",
      "      0     0       14.0000    10       17.0000    MIRcuts: 1       92   13.42%\n",
      "      0     0        cutoff             17.0000       17.0000       92    0.00%\n",
      "Elapsed time = 0.65 sec. (1049.09 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  1\n",
      "Flow cuts applied:  1\n",
      "Mixed integer rounding cuts applied:  3\n",
      "Gomory fractional cuts applied:  1\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.66 sec. (1049.23 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. (1049.23 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:09 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:09 PM: Optimal value: 1.700e+01\n",
      "(CVXPY) Apr 25 04:33:09 PM: Compilation took 3.380e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:09 PM: Solver (including time spent in interface) took 7.268e-01 seconds\n",
      "Optimal value: 17.0\n",
      "Variable var230968: value [1. 0. 0. 1. 1. 1. 0. 1. 1. 1. 0. 1. 0. 1. 0. 0. 0. 1. 0. 0. 1. 0. 0. 1.\n",
      " 0. 0. 1. 1. 1. 0. 0. 1. 0. 1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'Synthetic reasoning (abstra...'\n",
      " 'The Pile - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'MS MARCO (regular) - RR@10' 'LSAT - EM'\n",
      " 'LegalSupport - EM' 'Dyck - EM' 'MMLU - EM' 'MS MARCO (TREC) - NDCG@10'\n",
      " 'bAbI - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.20\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:09 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:09 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:09 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:09 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:09 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:09 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:09 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:09 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:09 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:09 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:09 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:09 PM: Finished problem compilation (took 2.967e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 7205 rows and 7 columns.\n",
      "MIP Presolve modified 33164 coefficients.\n",
      "Reduced MIP has 1641 rows, 27 columns, and 43620 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.17 sec. (400.81 ticks)\n",
      "Found incumbent of value 21.000000 after 0.18 sec. (411.93 ticks)\n",
      "Probing time = 0.01 sec. (0.73 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1641 rows, 27 columns, and 43620 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (13.51 ticks)\n",
      "Probing time = 0.00 sec. (0.73 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. (9.30 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           21.0000        7.0000            66.67%\n",
      "*     0+    0                           14.0000        7.0000            50.00%\n",
      "      0     0       11.4865    11       14.0000       11.4865       47   17.95%\n",
      "*     0+    0                           13.0000       11.4865            11.64%\n",
      "      0     0        cutoff             13.0000       13.0000       57    0.00%\n",
      "Elapsed time = 0.33 sec. (509.27 ticks, tree = 0.01 MB, solutions = 3)\n",
      "\n",
      "Cover cuts applied:  4\n",
      "Mixed integer rounding cuts applied:  2\n",
      "Gomory fractional cuts applied:  4\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.34 sec. (509.40 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. (509.40 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:10 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:10 PM: Optimal value: 1.300e+01\n",
      "(CVXPY) Apr 25 04:33:10 PM: Compilation took 2.967e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:10 PM: Solver (including time spent in interface) took 4.116e-01 seconds\n",
      "Optimal value: 13.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1.  1. -0. -0.  1.  1. -0.  1. -0. -0.\n",
      " -0. -0. -0.  0. -0.  1. -0. -0.  1.  1.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'TwitterAAE - BPB' 'LSAT - EM'\n",
      " 'BBQ - EM' 'MMLU - EM' 'MS MARCO (TREC) - NDCG@10' 'bAbI - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.25\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:10 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:10 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:10 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:10 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:10 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:10 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:10 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:10 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:10 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:10 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:10 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:10 PM: Finished problem compilation (took 3.525e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 7528 rows and 7 columns.\n",
      "MIP Presolve modified 40319 coefficients.\n",
      "Reduced MIP has 1318 rows, 27 columns, and 35478 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.14 sec. (345.05 ticks)\n",
      "Found incumbent of value 18.000000 after 0.15 sec. (354.11 ticks)\n",
      "Probing time = 0.01 sec. (0.58 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 1318 rows, 27 columns, and 35478 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.02 sec. (10.97 ticks)\n",
      "Probing time = 0.00 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.02 sec. (5.84 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           18.0000        7.0000            61.11%\n",
      "*     0+    0                           11.0000        7.0000            36.36%\n",
      "      0     0       10.3030     5       11.0000       10.3030       13    6.34%\n",
      "      0     0        cutoff             11.0000       10.3030       13    6.34%\n",
      "Elapsed time = 0.23 sec. (382.70 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.23 sec. (382.81 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. (382.81 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:11 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:11 PM: Optimal value: 1.100e+01\n",
      "(CVXPY) Apr 25 04:33:11 PM: Compilation took 3.525e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:11 PM: Solver (including time spent in interface) took 2.994e-01 seconds\n",
      "Optimal value: 11.0\n",
      "Variable var230968: value [1. 0. 0. 1. 0. 1. 0. 1. 1. 0. 0. 1. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      " 0. 0. 0. 0. 1. 0. 0. 1. 0. 1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'The Pile - BPB' 'OpenbookQA - EM'\n",
      " 'MATH - Equivalent' 'MS MARCO (regular) - RR@10' 'LSAT - EM' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.30\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:11 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:11 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:11 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:11 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:11 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:11 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:11 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:11 PM: Finished problem compilation (took 2.866e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 7921 rows and 7 columns.\n",
      "MIP Presolve modified 53928 coefficients.\n",
      "Reduced MIP has 925 rows, 27 columns, and 24943 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.09 sec. (108.41 ticks)\n",
      "Found incumbent of value 15.000000 after 0.10 sec. (116.54 ticks)\n",
      "Probing time = 0.01 sec. (0.38 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 925 rows, 27 columns, and 24943 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (8.98 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.00 sec. (3.49 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           15.0000        7.0000            53.33%\n",
      "*     0+    0                           10.0000        7.0000            30.00%\n",
      "      0     0        9.3407     3       10.0000        9.3407        9    6.59%\n",
      "      0     0        cutoff             10.0000        9.3407        9    6.59%\n",
      "Elapsed time = 0.16 sec. (138.02 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.16 sec. (138.10 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. (138.10 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:11 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:11 PM: Optimal value: 1.000e+01\n",
      "(CVXPY) Apr 25 04:33:11 PM: Compilation took 2.866e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:11 PM: Solver (including time spent in interface) took 2.250e-01 seconds\n",
      "Optimal value: 10.0\n",
      "Variable var230968: value [1. 0. 0. 0. 0. 0. 0. 1. 1. 0. 0. 1. 1. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      " 0. 0. 0. 0. 1. 0. 0. 1. 0. 1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'MS MARCO (regular) - RR@10' 'TwitterAAE - BPB' 'LSAT - EM' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.35\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:11 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:11 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:11 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:11 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:11 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:11 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:11 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:11 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:12 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:12 PM: Finished problem compilation (took 3.537e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8345 rows and 7 columns.\n",
      "MIP Presolve modified 25356 coefficients.\n",
      "Reduced MIP has 501 rows, 27 columns, and 13512 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.05 sec. (45.21 ticks)\n",
      "Found incumbent of value 13.000000 after 0.06 sec. (51.66 ticks)\n",
      "Probing time = 0.00 sec. (0.20 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 501 rows, 27 columns, and 13512 nonzeros.\n",
      "Reduced MIP has 27 binaries, 0 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (4.87 ticks)\n",
      "Probing time = 0.00 sec. (0.20 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.84 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           13.0000        7.0000            46.15%\n",
      "*     0+    0                            9.0000        7.0000            22.22%\n",
      "      0     0        8.5427     4        9.0000        8.5427        6    5.08%\n",
      "      0     0        cutoff              9.0000        8.5427        6    5.08%\n",
      "Elapsed time = 0.10 sec. (63.09 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.11 sec. (63.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.11 sec. (63.13 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:12 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:12 PM: Optimal value: 9.000e+00\n",
      "(CVXPY) Apr 25 04:33:12 PM: Compilation took 3.537e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:12 PM: Solver (including time spent in interface) took 3.187e-01 seconds\n",
      "Optimal value: 9.0\n",
      "Variable var230968: value [1. 0. 0. 0. 0. 0. 0. 1. 1. 1. 0. 1. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 1.\n",
      " 0. 0. 0. 0. 1. 0. 0. 1. 0. 1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'Synthetic reasoning (natura...' 'MS MARCO (regular) - RR@10' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.40\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:12 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:12 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:12 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:12 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:12 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:12 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:12 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:12 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:12 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:12 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:12 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:12 PM: Finished problem compilation (took 3.190e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8616 rows and 8 columns.\n",
      "MIP Presolve modified 17881 coefficients.\n",
      "Reduced MIP has 230 rows, 26 columns, and 5980 nonzeros.\n",
      "Reduced MIP has 25 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (30.26 ticks)\n",
      "Found incumbent of value 11.000000 after 0.05 sec. (35.38 ticks)\n",
      "Probing time = 0.00 sec. (0.28 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 230 rows, 26 columns, and 5980 nonzeros.\n",
      "Reduced MIP has 25 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.01 sec. (2.24 ticks)\n",
      "Probing time = 0.00 sec. (0.28 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.62 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           11.0000        7.0000            36.36%\n",
      "*     0+    0                            8.0000        7.0000            12.50%\n",
      "      0     0        7.8704     2        8.0000        7.8704        2    1.62%\n",
      "      0     0        cutoff              8.0000        7.8704        2    1.62%\n",
      "Elapsed time = 0.07 sec. (43.00 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.07 sec. (43.02 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.07 sec. (43.02 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:12 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:12 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 04:33:12 PM: Compilation took 3.190e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:12 PM: Solver (including time spent in interface) took 1.355e-01 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var230968: value [ 1.  0.  0.  1.  0.  0.  0.  1.  1.  0.  0.  0.  0.  0.  0.  0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  1. -0.  0.  0.  0.  1.  0.  0.  1.  0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'ICE - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'MMLU - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.45\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:13 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:13 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:13 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:13 PM: Finished problem compilation (took 4.073e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8784 rows and 15 columns.\n",
      "MIP Presolve modified 9730 coefficients.\n",
      "Reduced MIP has 62 rows, 19 columns, and 1178 nonzeros.\n",
      "Reduced MIP has 18 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.04 sec. (26.50 ticks)\n",
      "Found incumbent of value 10.000000 after 0.05 sec. (31.24 ticks)\n",
      "Probing time = 0.00 sec. (0.05 ticks)\n",
      "Tried aggregator 1 time.\n",
      "Detecting symmetries...\n",
      "Reduced MIP has 62 rows, 19 columns, and 1178 nonzeros.\n",
      "Reduced MIP has 18 binaries, 1 generals, 0 SOSs, and 0 indicators.\n",
      "Presolve time = 0.00 sec. (0.53 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. (0.14 ticks)\n",
      "\n",
      "        Nodes                                         Cuts/\n",
      "   Node  Left     Objective  IInf  Best Integer    Best Bound    ItCnt     Gap\n",
      "\n",
      "*     0+    0                           10.0000        7.0000            30.00%\n",
      "*     0+    0                            8.0000        7.0000            12.50%\n",
      "      0     0        7.2961     2        8.0000        7.2961        2    8.80%\n",
      "      0     0        cutoff              8.0000        7.2961        2    8.80%\n",
      "Elapsed time = 0.06 sec. (32.45 ticks, tree = 0.01 MB, solutions = 2)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.06 sec. (32.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.06 sec. (32.45 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:13 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:13 PM: Optimal value: 8.000e+00\n",
      "(CVXPY) Apr 25 04:33:13 PM: Compilation took 4.073e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:13 PM: Solver (including time spent in interface) took 1.381e-01 seconds\n",
      "Optimal value: 8.0\n",
      "Variable var230968: value [ 1.  0.  0. -0.  0.  1.  0.  1.  1.  0.  0. -0.  0.  0.  0. -0.  0.  0.\n",
      "  0.  0.  0.  0.  0.  1. -0. -0. -0.  0.  1. -0.  0.  1.  0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'The Pile - BPB' 'OpenbookQA - EM' 'MATH - Equivalent'\n",
      " 'MMLU - EM' 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.50\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:13 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:13 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:13 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:13 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:13 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:13 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:13 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:13 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:13 PM: Finished problem compilation (took 2.636e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 25708 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.03 sec. (21.01 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (25.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.03 sec. (25.61 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:14 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:14 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:14 PM: Compilation took 2.636e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:14 PM: Solver (including time spent in interface) took 1.016e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.55\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:14 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:14 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:14 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:14 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:14 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:14 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:14 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:14 PM: Finished problem compilation (took 5.582e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 35924 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.03 sec. (19.47 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.04 sec. (24.12 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.04 sec. (24.12 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:14 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:14 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:14 PM: Compilation took 5.582e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:14 PM: Solver (including time spent in interface) took 1.035e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.60\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:14 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:14 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:14 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:14 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:14 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:14 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:14 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:14 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:15 PM: Finished problem compilation (took 3.491e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:15 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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 36263 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.04 sec. (21.05 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.05 sec. (25.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.05 sec. (25.70 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:15 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:15 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:15 PM: Compilation took 3.491e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:15 PM: Solver (including time spent in interface) took 1.162e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.65\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:15 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:15 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:15 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:15 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:15 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:15 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:15 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:15 PM: Finished problem compilation (took 3.140e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:15 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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 36598 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.04 sec. (20.69 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.05 sec. (25.34 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.05 sec. (25.34 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:15 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:15 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:15 PM: Compilation took 3.140e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:15 PM: Solver (including time spent in interface) took 2.434e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.70\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:15 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:15 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:15 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:15 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:15 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:15 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:15 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:15 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:16 PM: Finished problem compilation (took 3.173e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 64522 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.02 sec. (20.60 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.04 sec. (25.25 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.04 sec. (25.25 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:16 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:16 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:16 PM: Compilation took 3.173e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:16 PM: Solver (including time spent in interface) took 1.051e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.75\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:16 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:16 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:16 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:16 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:16 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:16 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:16 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:16 PM: Finished problem compilation (took 3.805e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 57149 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.02 sec. (20.45 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (25.10 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.03 sec. (25.10 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:16 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:16 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:16 PM: Compilation took 3.805e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:16 PM: Solver (including time spent in interface) took 9.953e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.80\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:16 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:16 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:16 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:16 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:16 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:16 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:16 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:16 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:17 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:17 PM: Finished problem compilation (took 3.105e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 49505 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.03 sec. (20.31 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.05 sec. (24.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.05 sec. (24.96 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:17 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:17 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:17 PM: Compilation took 3.105e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:17 PM: Solver (including time spent in interface) took 2.249e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.85\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:17 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:17 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:17 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:17 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:17 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:17 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:17 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:17 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:17 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:17 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:17 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:17 PM: Finished problem compilation (took 3.772e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33: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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 45501 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.04 sec. (20.24 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.05 sec. (24.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.05 sec. (24.89 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:18 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:18 PM: Compilation took 3.772e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:18 PM: Solver (including time spent in interface) took 1.060e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.90\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:18 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:18 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:18 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:18 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:18 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:18 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:18 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:18 PM: Finished problem compilation (took 3.544e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:18 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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 34462 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.02 sec. (20.06 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (24.71 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.03 sec. (24.71 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:18 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:18 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:18 PM: Compilation took 3.544e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:18 PM: Solver (including time spent in interface) took 9.777e-02 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n",
      "Constructing constraint set for epsilon 0.95\n",
      "Solving\n",
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.6.5                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 25 04:33:18 PM: Your problem has 34 variables, 8846 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 25 04:33:18 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 25 04:33:18 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 25 04:33:18 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 25 04:33:18 PM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:18 PM: Compiling problem (target solver=CPLEX).\n",
      "(CVXPY) Apr 25 04:33:18 PM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> CPLEX\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 25 04:33:18 PM: Applying reduction CPLEX\n",
      "(CVXPY) Apr 25 04:33:18 PM: Finished problem compilation (took 3.335e-01 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:18 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"
     ]
    },
    {
     "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 8846 rows and 34 columns.\n",
      "MIP Presolve modified 16203 coefficients.\n",
      "All rows and columns eliminated.\n",
      "Presolve time = 0.02 sec. (19.78 ticks)\n",
      "\n",
      "Root node processing (before b&c):\n",
      "  Real time             =    0.03 sec. (22.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.03 sec. (22.54 ticks)\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 25 04:33:19 PM: Problem status: optimal\n",
      "(CVXPY) Apr 25 04:33:19 PM: Optimal value: 7.000e+00\n",
      "(CVXPY) Apr 25 04:33:19 PM: Compilation took 3.335e-01 seconds\n",
      "(CVXPY) Apr 25 04:33:19 PM: Solver (including time spent in interface) took 2.330e-01 seconds\n",
      "Optimal value: 7.0\n",
      "Variable var230968: value [ 1. -0. -0. -0. -0. -0. -0.  1.  1. -0. -0. -0. -0. -0. -0. -0. -0. -0.\n",
      " -0. -0. -0. -0. -0.  1. -0. -0. -0. -0.  1. -0. -0.  1. -0.  1.]\n",
      "Tasks: ['GSM8K - EM' 'OpenbookQA - EM' 'MATH - Equivalent' 'MMLU - EM'\n",
      " 'NarrativeQA - F1' 'NaturalQuestions (open) - F1'\n",
      " 'NaturalQuestions (closed) - F1']\n"
     ]
    }
   ],
   "source": [
    "group_sizes = range(1, len(classic_all_voter_columns))\n",
    "classic_all_ranks_df = selection_algorithms.scores_to_ranks(classic_all_df, classic_all_voter_columns)\n",
    "outputs_pp_augmented = selection_algorithms.solve_lp_pp(classic_all_ranks_df[classic_all_voter_columns], \n",
    "                                              classic_all_voter_columns, epsilons=np.arange(0, 1, 0.05), \n",
    "                                              starting_tasks=classic_lite_equiv_columns)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "cbcefb2e-dd38-4a7d-82e0-364b34f29baa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[34.0, 31.0, 23.0, 17.0, 13.0, 11.0, 10.0, 9.0, 8.0, 8.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0, 7.0]\n"
     ]
    }
   ],
   "source": [
    "print(outputs_pp_augmented)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "860eed2b-54a6-49fb-b01f-6291b5bb2134",
   "metadata": {},
   "source": [
    "## Min epsilon s.t. Lite doesn't satisfy PP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "908e657d-d498-4ea9-846b-1bccd0f6bd94",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 116,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.strong_pp_loss_fast(0.5, classic_all_ranks_df, classic_all_voter_columns, classic_lite_equiv_columns, verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "id": "d7ff418a-78a6-4d22-9629-3b7ef6b50c3b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 120,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selection_algorithms.strong_pp_loss_fast(0.45, classic_all_ranks_df, classic_all_voter_columns, classic_lite_equiv_columns, verbose=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "611fc256-6428-46b3-8707-fda9ca41cad5",
   "metadata": {},
   "source": [
    "## Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "6782d1f2-e0a4-4902-bd0e-c2c6c2702238",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/s_/ycjsvp3d07b2h09m_hw3bkyr0000gn/T/ipykernel_29940/3677522892.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_29940/3677522892.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": "iVBORw0KGgoAAAANSUhEUgAAAdIAAAF5CAYAAAAru6sbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAXlhJREFUeJzt3XlcVOX+B/DPzLAIIghiCso6KosQq+bC5pK7maTeyp9lm0ulaWk3LBeom+VSXruleU1LzaTclbSruQEm4gIo4oqKICKCMOzLzPP7Y+TECALDmZkzM3zfr9d5NfOcZ57z5YR855zzLCLGGAMhhBBCWkUsdACEEEKIIaNESgghhPBAiZQQQgjhgRIpIYQQwgMlUkIIIYQHSqSEEEIID5RICSGEEB4okRJCCCE8mAgdgL5RKBS4e/cuOnToAJFIJHQ4hBBCBMAYQ0lJCRwdHSEWN33NSYn0MXfv3oWTk5PQYRBCCNEDd+7cQffu3ZusQ4n0MR06dACgPHnW1tYCR0MIP6NHj4aZmRk+//xzeHl5CR0OIQZDJpPBycmJywlNoUT6mLrbudbW1pRIicE7ceKEdh5RlJcDffooXycnA5aWmj8GIXqgJf9+KJESYsS09pyfMeDSpb9fE9KGUa9dQtqA6upqVFdXCx0GIUaJEikhRu7NN99Ex44dceDAAaFDIcQoUSIlxMiZmJigoqICSUlJQodCiFES0cLeqmQyGWxsbFBcXEydjYhRuHbtGmpra+Hp6am5Z6ZlZYCVlfJ1aSnQvr1m2iVET6iTC6izESFGrmfPnkKHQIhRo0RKCFGfSAS4uPz9mpA2jBIpIW3A2bNn8csvv8DT0xNvvvkm/wYtLYFbt/i3Q4gRoM5GhLQB586dw8qVK7FlyxahQyHE6NAVKSFtwODBgzFt2jQMGTJE6FAIMTrUa/cx1GuXkBaoqADCwpSvT5wALCyEjYcQDaNeu4QQ7VIogDNn/n5NSBtGz0gJaUOys7Nx7NgxocMgxKjQFSkhbURaWhr8/PxgbW2NgoICmJjQP39CNIGuSAlpI3r37g17e3v07t0b9+7dEzocQowGfSUlpI2QSCS4ceMGdaIjRMPoipSQNoSSKCGaR1ekhLRBNTU1KCkpgZ2dXesbsbfXXECEGDCDuiL9/vvvIRKJsGTJEqFDIcRgbdmyBQ4ODvjnP//Z+kbatwfy85UbrfxC2jiDSaQPHz7Exx9//MT9GRkZGDVqFDw9PdGrVy+8+OKLyMnJ0WGEhBgGR0dHFBQUICEhATQfCyH8GUwiXbhwIUJCQhrdl5WVhdDQUPj4+CAjIwOXLl2CSCRCeHg4ZDKZjiMlRL+FhYXhzz//xIULFzS3PikhbZhBJNK0tDTs2LHjibd0Fy9eDLlcjpiYGIhEIpiYmGDlypW4efMmVq1apdNYCdF3JiYmGDx4ML9xpBUVQESEcquo0FRohBgkg0iks2fPRkxMDDp27Nhgn1wux44dOzBw4EC0a9eOK3d0dISnpydiY2N1GCkhbYRCARw/rtxoikDSxul9Io2NjYVMJsMbb7zR6P7MzEyUlJRAKpU22CeVSnH58mVUVVVpO0xCDM4PP/yAZ555BgcOHBA6FEIMml4n0vLycnz44Yf45ptvIBY3Hmp+fj6AxsfHWVtbQ6FQoLCw8InHqKqqgkwmU9kIaQvOnz+P06dP010bQnjS63GkS5cuRUhICAYOHKjVY0RHR2utfUL01RtvvIHevXsjMjJS6FAIMWh6m0hv3ryJNWvWIDU1tcl69o8GhTd2JSmTySAWi5scdB4VFYX3339f5TNOTk6tjJoQwxEQEICAgAChwyDE4OltIj18+DDat2+P0aNHc2XV1dUAgLVr12L37t3w8PDA1q1b0aFDB2RmZjZoIzMzE56enjA3N3/icczNzZvcTwghhDRFb5+RvvXWW7h9+zZSUlK47ffffwcAzJgxAykpKYiNjYVEIkFkZCQSExNVOhXl5uYiIyMDkyZNEupHIETvyeVy7Nu3D2+++ab6nfIsLZUbIW2c3iZSdURHR0MsFmPRokVgjKG2thbz5s2Dm5sb5s6dK3R4hOgtkUiEGTNm4IcffsChQ4da/sH27YGyMuVGUwSSNs4gEmlRURH8/f0xatQoAMpbu/7+/ti0aRMAwMXFBSdOnEBaWhq8vLzg7e2N2tpaHDt2jFa7IKQJYrEYb7/9Nt57771Gh5ARQponYjTZpgqZTAYbGxsUFxdTEiaEkDZKnVxgEFekhBA9U1kJjB6t3CorhY6GEEHpba9dQohuXb16FZcuXcLzzz/ffGW5HHjU+Q9yuVbjIkTfUSIlhOD8+fMIDAyElZUV7t+/DwsLC6FDIsRg0K1dQgj8/f0hlUoREhLCTbtJCGkZuiIlhEAkEuHSpUswMzMTOhRCDA5dkRJCAICSKCGtRImUEKKirKwMOTk5QodBiMGgREoI4WzZsgVPPfUUPvjgA6FDIcRg0DNSQgjHw8MD5eXlSE9Ph0KheOI6wGjfHqC5XAgBQFekhJB6goODcfbsWaSlpT05iRJCVNAVKSGEIxKJEBgYKHQYhBgU+spJCGkUYwwKhaLxnZWVwMSJyo2mCCRtHCVSQkgD3377Lby8vLB9+/bGK8jlwPbtyo2mCCRtHCVSQkgDd+7cwZUrV56cSAkhHHpGSghp4LXXXoOvry/Gjh0rdCiE6D1KpISQBjw8PODh4SF0GIQYBLq1SwghhPBAiZQQ0ii5XI6ff/4ZL7zwAkpKSoQOhxC9RYmUENIosViM6Oho7Ny5E/v37xc6HEL0Fj0jJYQ0SiQS4b333kNeXh769u2rutPSEigt/fs1IW0YJVJCyBO98847je8QiZTz7RJC6NYuIYQQwodaV6QxMTEaOeiiRYs00g4hRPsYYzh79iwuXLiA1157TVlYVQVMn658/f33gLm5cAESIjARYy1fC8nNzY3/AUUiZGZmtqhuVlYW1q5di0OHDkEul6OyshKmpqZ44403MGvWLIhEIgDAkiVLsGHDBtjZ2al83tbWFkePHlUrPplMBhsbGxQXF8Pa2lqtzxJijC5duoTevXvDzMwM9+/fh42NDVBWBlhZKSuUltJtXmJ01MkFal2R3rx5k1dg6jpy5AhWr16NQ4cOoX///gCAnTt3YsKECSgpKcHHH3/M1Y2JicHUqVN1Gh8hbYGXlxeCg4Ph7u6O4uJiZSIlhHDUfkb6n//8RxtxNKpr166YP38+l0QBIDIyEr6+vtixY4fO4iCkLROJRDh9+jRiY2Ph7OwsdDiE6B21e+3OmTMHbm5uGD16tDbiUTFixAiMGDGiQXlJSQl69uyp9eMTQpTqHqMQQhpS+4p0xIgReOmll5CSktJs3ZKSErzwwgutieuJ7S1YsABlZWX44osvVPYdPHgQQ4cOhZ+fH3x9fTF79mzk5uY222ZVVRVkMpnKRghpXGFhIa5duyZ0GIToFbUTaWxsLKRSKcaOHYucnJwn1ktPT0efPn2wZ88eXgHW8fb2hq2tLfbu3YudO3ciICCA22dpaQmRSIStW7ciNTUVe/fuRVJSEoKCgpCdnd1ku0uXLoWNjQ23OTk5aSReQozNli1b0KVLF8ydO1foUAjRL6wVsrOzWbdu3Zifnx8rKSlpsH/Lli3MysqK2drasj179rTmEI2qqqpiP/zwAzMzM2PLli1rsu7FixcZADZ9+vQm61VWVrLi4mJuu3PnDgPAiouLNRY3Icbg0qVLDADr06cPqy0uZgxQbqWlQodGiMYVFxe3OBeoNfylvtTUVISGhmLgwIGIi4uDWCxGbW0t3nvvPaxduxb+/v7Yvn27RobMPO6tt97Cxo0bceXKFUil0ifWs7GxgbOzMy5cuNDitls7/IUxpnyOpJAD+fFARS5g4QB0DgXEkr/3E2LAMjMz4e7urkyhDx4oC+3tlTMdEWJE1MkFrZ7ZyM/PD9u2bcPhw4fx9ttvIzs7GyEhIVizZg3efPNNnDx5kncSraiogFwub1Du7+8PuVyOc+fOAQDu3bvX6OfFYjEUCgWvGFqCMYZjM2cid/cyYK8r8Ocg4OTLyv/udUXu7mU4NnMmWvmdhRC94e7urnwhEgGdOys3SqKkjVM7kW7duhXp6emQy+UYNWoUVq9ejXXr1sHT0xMXL17ETz/9hO+//x7mGpjpZOTIkfj1118blN+6dQsAYG9vDwBwcHDA3bt3VercuHEDRUVF6NOnD+84miMSieA5wh0Jn25A7sWHKvtyLxYh4dMN8BzhTlekxGgoFArU1NQIHQYhekHtRPp///d/ePrpp2FlZYXAwECcPn0aTk5OMDExQVxcHKZMmaLRAJcuXcolTgA4fvw41qxZg759+yIsLIwrj4qKQkVFBQCguLgYM2fOhI2NDRYsWKDReBqlkMMB3yBkfDYSdnVHbqZylpfczPZI2NUNIeNz4ID/KG/7EmLgvvrqK/RwcsL14cOBd95RThdISBum9jjSgwcPIjU1FWlpaUhNTcXWrVu5b6aDBw9G165d8fTTT6tsvr6+rQru888/x8aNGzF69GhIJBKUlZXBzMwMs2bNQlRUFCQSCQDlVXJsbCyCg4MhEolQXFyMgQMHIikpCb169WrVsdWSHw+UZ8PBHVwylfoV4UZqR4SMz4aDexlQXqqs1yVC+/EQokUVFRXIu3sXXnfvAkePAsuW0Vy7pE1rdWejOjU1Nbh06RKXWNPS0pCWlob79+8rDyASNfqcU1+1qrPRrV+Uz0QfOXe4Cy4ndYLnMwUIHJr3d70BWwHXlzQcMSG6defOHVw4dQqjJk1SFtBcu8QIaW2u3caYmprCz88Pfn5+Krd18/LykJKSolaPWYNl4cC9zM1sjxupHeH5TAFupHaEg3up8or0sXqEGConJyc4PbZABCFtGe8rUmPTqitShVzZO/di0aNnosrbucpnpN2Vz0h9bIHnbgJiiXZ/AEJ0od7qL6ykBKK6lWAIMRJauyKl9UifQCxBLmYhYdcGZdJ8dAXq4F6GkPE5yuTq8zocKIkSI3TixAmEjxoldBiECEav1yMVQmuuSOvGkXqOcIcDvgHK601LaOmEXLyLywczEbFmDQ2BIcah3hXpP0aPRuz+/QIHRIhmqZML6NbuY2hmI0JaoF4iLbh9G51oeTViZHTa2YgocUlSLGl0iAslUWJULCyAmzcBAJ26dxc4GEKERYmUEKI+sRhwdVUporsupK1q9Vy7hBACKJdMfOmll7BkyRKhQyFEEHRFSghRX3U18PHHAIBrffpg27ZtsLW1RVRUFNq1aydwcIToFiVSQoj6amqAFSsAAGOLizF37ly88sorlERJm0SJlBDCi0QiwVdffSV0GIQIhp6REkIIITxQIiWEaERRURGio6MxevRoWsSetCkaSaSZmZl46623IJVK4e7uDgCIjo5GXFycJponhBiAmpoafPHFF/j999+RmJgodDiE6AzvZ6SpqakICwsDYwxSqRQPHz4EAPj5+eHdd98FYwxjxozhHSghRL917twZn332Gbp3745+/foJHQ4hOsN7isCRI0fCx8cHMTExsLCwQEBAAM6fPw8AuHLlCqZNm4bjx49rJFhdaO0UgZpE0w0SvVdvikBaj5QYI51OEXj16lUcOHCAe1//D7yHhwfKy8v5HqJNaXoC/O7IxSyaAJ8Iz8ICuHjx79eEtGG8n5E2d0Gbl5fH9xBtikgkgucIdyR8ugG5Fx+q7Mu9WISETzfAc4Q7JVEiLLEY6N1buYlV/4wwxhAbG4uQkBDcu3dPoAAJ0R3eiVQqleKjjz5CTU1Ng30xMTHw9vbme4i2RSGHA75ByPhsJOzqjtxM5S0z5SLh3ZTrneI/ytu+hOipVatWITExEd9++63QoRCidbyfkSYlJSEiIgJWVlYIDg5GcnIywsPDkZqaitzcXMTHxyMwMFBT8Wqd4M9I844Bfw4CUJc8u0PqV4QbqR0RMj6bWzQcQ442usoMITpRXQ18/rny9YIFgJmZyu4DBw7g9OnTePvtt9G5c2cBAiSEH52vR3r69GnMnz8fiYmJUCgUEIvFCA0NxfLlyxEcHMy3eZ0SPJHe+gU4+TL39tzhLric1AmezxQgcGi92+QDtgKuL+k+PkIA6mxEjJ46uUAj40j79u2L48ePo6SkBNnZ2SgpKcGuXbvw1FNPISsrq9XtZmVlYcGCBejTpw8CAwPh7e0NPz8/rF69usGz2YyMDIwaNQqenp7o1asXXnzxReTk5PD90XTPwoF7mZvZHjdSO8LzmQLcSO3I3eZ9vB4hhBDh8E6knTt3xrZt2wAAFhYWcHR0hIWFBbZt24ZXX30Vnp6erW77yJEjWL16NVavXo1z587h0qVLWLx4MebMmYPP624rQZlwQ0ND4ePjg4yMDFy6dAkikQjh4eGQyWR8f0Td6hyq7J2baYWEXd0RMj4bgUPz6j0ztQIsnZT1CNFzaWlpmDJlCnbt2iV0KIRoDe9EWlBQgMmTJ+P1119XGeoyY8YMHD16FF26dGl12127dsX8+fPRv39/riwyMhK+vr7YsWMHV7Z48WLI5XLExMRAJBLBxMQEK1euxM2bN7Fq1apWH18QYglyMevvjkWPnok6uJchZHwOEnZ1Qy7eBcQSgQMlpHnbt2/Hli1b8OWXXwodCiFawzuRPv3001i6dCl+/vlnBAUFISUlRWU/n2EaI0aMwOLFixuUl5SUcB0Y5HI5duzYgYEDB6os4eTo6AhPT0/Exsa2+vhCYIzh8sFMhCx8HQ4+HVX2OfjYImTh67h8MJPmMiUG4Z133sHkyZOp9y4xarwnZBCLxfjwww8xaNAgvPTSS+jfvz+WLl2KOXPmaCA8VSUlJVi6dCnKysrwxRdfAFDO81tSUgKpVNqgvlQqRVxcHKqqqmBubq7xeLRBJBL9PdmC4oMGMxs5iCXoOo5mNiKGoUuXLtiyZYvQYRCiVRpbj7RPnz5ISUnB22+/jffffx+HDh3Cjz/+qKnm4e3tjatXr8LT0xM7d+5EQEAAACA/Px8AGu1VZW1tDYVCgcLCQjg4NN45p6qqClVVVdx7fXimyiVJsaTRIS6URAkhRH9odBk1KysrbNq0CZs3b0ZiYiL8/PxQWFiokbYvXbqE8vJyvP/++xg8eDCWL1+ukXaXLl0KGxsbbnNyctJIu4QYtXbtgNOnlVu9RypPUlhYiH/961/45JNPdBAcIbrFO5Feu3YNgwcPVplvd/LkyTh37hycnZ1RUlLC9xAcMzMzvP7663jllVcQFRWFGzduwN7eHkDjV5IymQxisRh2dnZPbDMqKgrFxcXcdufOHY3FS4jRkkiAPn2Um6T5jm/p6en45JNPsGLFCty/f18HARKiO7xv7V58NHF1XUKr4+7ujsTERJXeteqqqKiAmZkZJI/9Q/X394dcLse5c+cQGRmJDh06IDMzs8HnMzMz4enp2eTzUXNzc4N5fkqIoQoJCcFrr72GIUOGwNbWVuhwCNEo3lekLi4ucHFxQftGZjaRSCSYNGlSq9seOXIkfv311wblt27dAqBM3hKJBJGRkUhMTFR51pmbm4uMjAxexyeEPEF1NbB8uXKrrm62ukgkwoYNGzB58mSYmprqIEBCdEejz0gbM2zYMF6fX7p0KZc4AeD48eNYs2YN+vbti7CwMABAdHQ0xGIxFi1aBMYYamtrMW/ePLi5uWHu3Lm8jk8IaURNDfDhh8qtkQUrCGlLWnVrd9++fbCxsUFYWBhiYmKarFt367c1Pv/8c2zcuBGjR4+GRCJBWVkZzMzMMGvWLERFRXG3fF1cXHDixAl88MEH8PLygkKhQEBAAI4dOybY4tyEkIbkcjl27dqF3377DVu3bm3w2IYQQ9SqSevt7Ozg6uqKc+fOQSxu+qJWJBJBLjecJb8En7SeEEPQyknrS0tL4ezsjIcPH2Lnzp0YP368FoMkpPXUyQWtuiI9dOgQLC0tAQB+fn44f/78E+vWjfckhBArKytERUWhpKQEAwYMEDocQjSiVYk0KCiIe93YFH71NbefENK2zJ8/X+gQCNEo3sNfRowYgaysLFhbW6Njx44AgI0bNyI1NRXPPvssnn/+eb6HIIQQQvQW7167X375JTw9PbFx40YAwKpVq/DGG29g06ZNGD9+PLZu3co7SEKI8blw4QKmTp2Ka9euCR0KIbzwTqRxcXE4cuQI5s6dC8YYVq5ciTFjxuDBgwdISEgwvGXMCCHNa9cOOHpUubVgisDGREVF4aeffsLXX3+t4eAI0S3et3blcjn69esHADh9+jRycnLwyy+/QCwWo2/fvqihMWaEGB+JBIiI4NXE/PnzYWlpiddee00zMREiEN6JtP7omdjYWDg7OyMkJIQro5VKCCGNCQ8PR3h4uNBhEMIb70Tq4uKCzz77DFKpFOvXr1eZSSg+Pp4GXBNijGpqgHXrlK+nTQNo2j/ShvF+Rrps2TJs2rQJkydPRo8ePTBv3jwAwJw5czB06FA899xzvIMkhOiZ6mrg3XeVWwvm2m1KRUUFoqOjER0draHgCNGtVs1s1JiCggJ06tSJe5+fn4/y8nJ06dIF7VrZGUEINLMRIS3QypmNGnPgwAGMGjUKpqamuHbtGlxcXDQUJCGtp/WZjRpTP4kCQOfOnTXVNCHEiI0YMQJvvvkmnn32WTg7OwsdDiFq01giJYSQ1hCJRPjvf/8rdBiEtJrWl1EjhBB11NTUoLKyUugwCGkxSqSEEL0RHx8PPz8/fP7550KHQkiLUSIlhOiN+/fvIyMjAz/++CNdlRKDwTuRymSyRsuvXbuGLVu20MxGhBgjc3Ng/37lZm6usWYjIyPxzTffIDU11aB6+5O2jffwl8DAQJw7d65B+blz5zBr1iw4OTlh27ZtfA6hUzT8hRBCiDq5gPcV6ZPycGBgIBITE5GRkcH3EISQNur06dN0i5fovVYNf8nKysKtW7cAAGVlZYiPj2+QUBljyM7OfuKtX0KIAaupAX7+Wfl68mStTBEYFRWFL774AjExMVi4cKHG2ydEU1qVSDdu3Ijo6GhuQvqIRlaBYIxBLBZj0aJFvAIkhOih6mqgbtWWiRO1kkj9/f0BAHl5eRpvmxBNatUz0tu3b+PWrVtgjOGtt97C+vXrG9QxNTWFq6srHB0dNRKortAzUkJaQINTBD4JYwwXL16Er6+vxtsmpDlanyLQxcWFmw9z+vTptBQSIUTjRCIRJVFiEHh3Nqpb7YUQQrTl4cOHWLx4MaqqqoQOhZAGNDLXbmZmJpYuXYojR46AMYbMzExER0cjODgYo0eP5tXuunXrEBcXB8YYamtr4ebmhgULFiA0NJSrt2TJEmzYsAF2dnYqn7e1tcXRo0dbfXxCiPAYY4iIiEBaWhratWuHqKgooUMiRAXvRJqamoqwsDAwxiCVSvHw4UMAgJ+fH959910wxjBmzJhWtf3222/j/v37+OOPP+Do6IiamhrMnj0b4eHh2LVrF8aNG8fVjYmJwdSpU/n+OIQQPSMSiTB//nwsXboU/fr1EzocQhrgfWv3o48+wrRp05CXl4fz58/D1tYWAPD888/j4MGDWL58Oa/2Fy5cyHVYMjU1xVdffQWJRIKVK1fyDZ0QYiAmT56MlJQUDBo0SOhQCGmA9xXp1atXceDAAe593ZAYAPDw8EB5eXmr2963bx9MTFRDtLCwgJ2dHXflSwgRgLk58Ouvf7/WMpFIBFMtDLEhRBO0NrNRHT5jwExNTVUSMwAUFhYiPz8fgwcPVik/ePAghg4dCj8/P/j6+mL27NnIzc1t9hhVVVWQyWQqGyGkGSYmyvGjEycqX+sIYwzbtm3D0KFDUV1drbPjEtIU3olUKpXio48+anRy+piYGHh7e/M9hIq1a9fC3t5epcOBpaUlRCIRtm7ditTUVOzduxdJSUkICgpCdnZ2k+0tXboUNjY23Obk5KTReAkhmlNSUoLZs2fjzz//pMXAid7gPWl9UlISIiIiYGVlheDgYCQnJyM8PBypqanIzc1FfHw8AgMDNRLsuXPnMGTIEOzcubPZZyXp6enw8fHB9OnTsXbt2ifWq6qqUulSL5PJ4OTkRBMyENKU2lpg1y7l6/HjdXpVumXLFmRmZuLDDz+kFWKI1qgzIQPvRAooJ5aeP38+EhMToVAoIBaLERoaiuXLlyM4OJhv8wCAjIwMDB8+HN99912LewHb2NjA2dkZFy5caPFxaGYjQlpABzMbESIkrc9s9Li+ffvi+PHjqKiowMOHD2FrawsLCwtNNA0ASElJwfPPP48ffvgBzz77bIP99+7dQ9euXRuUi8ViKBQKjcVBCNE/dX9zCBEK72eklZWVyMrKQlFRESwsLODo6Iht27Zhzpw5iIuL4x1gUlISxo0bh82bN6sk0fpXug4ODrh7967K527cuIGioiL06dOHdwyEEP2Tk5ODMWPGICwsrNE+GoToCu9E+uWXX8LT0xMbN24EAKxatQpvvPEGNm3ahPHjx2Pr1q2tbvvEiRN49tlnMW7cONy+fRtbtmzhtrNnz6rUjYqKQkVFBQCguLgYM2fOhI2NDRYsWND6H44QorcsLCxw6tQpXLlyBUlJSUKHQ9ow3s9I+/bti9WrV6Nfv35gjMHZ2RkBAQHYvXs3zpw5g3fffRenT59uVduBgYE4f/78E/fXhf7LL78gNjYW165dg0gkQnFxMQYOHIjo6Gh4eHiodUx6RkpIC+jJM9IDBw7A3d1d7X/nhDRHp52NgoKCuKvDpKQk9O/fHydOnEBISAgAICAgoMlkqG8okRLSAnqSSAnRFnVygUYnZIiNjYWzszOXRAE0mFCBEEK0ITs7GxcvXhQ6DNIG8e616+Ligs8++wxSqRTr16/H3LlzuX3x8fGQSCR8D0FaiTHW5BeZ5vYT8kRmZsCjfhEwMxM2FihnNnvhhRfQs2dPnDlzpsHUooRoE+8r0mXLlmHTpk2YPHkyevTowa1POmfOHAwdOhTPPfcc7yCJ+hhjODZzJnITExvdn5uYiGMzZzY7xSMhjTI1BaZOVW56MAducHAwzM3NYWVlhYKCAqHDIW2MRiZkAICCggJ06tSJe5+fn4/y8nJ06dLFoGYfMaZnpLmJiUiYNw8hK1bAYeDAZssJMWTXrl1Djx496C4L0Qidz2xkTIwpkQINkyYlUaIRtbXAH38oXw8frtMpAluKHl0QPnSeSBUKBTZt2oSTJ08iJycH3bp1w8CBAzFlyhSIxbzvHuuUsSVS4O9kKo2MxI2dOymJEv70uNcuYwwrVqzAX3/9he3btxvc3yCiH3SaSO/cuYPhw4fj8uXLDfZ5eXnhjz/+QPfu3fkcQqeMMZECwLnly3H5xx/hOXUqAufPFzocYuj0OJFeu3YNvr6+qKqqwp49e6ifBmkVnQ5/effdd2FhYYE9e/YgNzcXVVVVuHv3Lnbt2oV27dph1qxZfA9BeMpNTMSNnTvhOXUqbuzc+cQOSIQYg549e+K7777D2rVrMXbsWKHDIW0A7ytSOzs73Lx5EzY2Ng32PXz4ED179sSDBw/4HEKnjO2KNDcxEQkffICQT16Fg09H5F4sQsJnPyFk5Uq6vUtaT4+vSAnRBJ1ekbq7uzeaRAHA1tYWzs7OfA9BWik3MREJ789GyAv34CB7Gzj5MhxkbyPkhXtIeH82XZmSNqG6uhqrV69GbW2t0KEQI8U7kfbp0+eJc+mePn0a3t7efA9BWoExhsv/XY6QsVfh0O22yj6HblkIGXsVl/+7nMaREqPGGMOYMWPw3nvv4ZNPPhE6HGKk1O6zvmnTJpX3fn5+eOmllzB06FD4+vrC2toaxcXFuHDhAvbu3YuPPvpIY8GSlhMxBSLGnYWoorSRvQwO7mXo2vscREwBiGj2KWKcRCIR3nrrLZw5c0Zl6lJCNEntZ6TqdiUXiUSQy+VqfUZIRvOMNO8Y8Oeg5usNOQp0idB2NMTY1NQA69YpX0+bphezGzWlsLAQdnZ2QodBDIg6uUDtK1IvLy/8/vvvLarLGMPo0aPVPQTRhIpczdYjpD5TU+Cdd4SOosXqJ1GZTAYzMzODmnGN6De1E+lrr70GFxcXteoTAVg4aLYeIUYgNTUVEyZMwODBg/H9998LHQ4xEmon0rpJ6Vtqzpw56h6CaELnUMCyO1CeA6Cxu/ci5f7OobqOjBgDuRyIj1e+Dg0FDGSVp7y8PNy4cQPV1dUN5gcnpLW0PndW3759tX0I0hixBAj696M3j883+uh90CplPULUVVkJDBqk3CorhY6mxYYNG4atW7fi3LlzlESJxvCeafr1119vcn9WVhbfQ5DWcooEQrcDZ98DyrP/LrfsrkyiTpGChUaIUF588UWhQyBGhnci/fnnn+Ho6KhSVlJSgsLCQlhbW1NPOaE5RQLdxgH58cqORRYOytu5dCVKCA4fPowdO3bgu+++o5ViSKvxTqTe3t44f/58g/L79+/jyy+/xJgxY/gegvAlltAQF0Iek5ubizFjxqCqqgr9+/fHK6+8InRIxEDxnms3MzMT7u7uT9w/dOhQHD58mM8hdMpoxpESok1GMtfu6tWrceHCBaxevRoWFhZCh0P0iFbHkT6uqSQKALdu3Wp125mZmVi3bh3i4uLAGENtbS3c3NywYMEChIaq9jbNyMjABx98gMzMTCgUCgQGBmLlypXo1q1bq49PCDFus2bNolu6hDfeifTEiRMNyhhjKCwsxPbt29GxY8dWt/3222/j/v37+OOPP+Do6IiamhrMnj0b4eHh2LVrF8aNGwdA2aEpNDQUr7/+OuLi4iCXyzFlyhSEh4fj3LlzdGVJCGnU40n0jz/+wNChQyExkOE8RE8wnkQiEROLxSqbSCRiIpGIubq6slOnTrW67eHDh7OdO3eqlJWXlzMTExMWGhrKlU2dOpV17NiRVVRUcGU5OTlMLBaz6OhotY5ZXFzMALDi4uJWx02I0auqYmzZMuVWVSV0NBoxZ84cBoAtWbJE6FCIHlAnF/C+IpVKpVi/fr1KmUQiQZcuXSCVStWem7e+ffv2wcRENUQLCwvY2dnh4cOHAAC5XI4dO3YgLCxMZcovR0dHeHp6IjY2FosWLWp1DISQRpiZAfPnCx2FRgUGBkIkEvH6m0XaJt6J9LXXXkN4eLgmYmnAtJGJsAsLC5Gfn8+NBcvMzERJSQmkUmmDulKpFHFxcaiqqoK5ublWYiSEGIcpU6YgMDAQvXv3FjoUYmB4f/WaO3cusrKyUFRUxJVt3LgRc+bMQVxcHN/mG1i7di3s7e0RFRUFAMjPzweARp+DWltbQ6FQoLCw8IntVVVVQSaTqWyEkGbI5UBysnIzoNWdmlM/iVZWVqLSgGZtIsLhnUiXLVsGT09PbNy4EQCwatUqvPHGG9i0aRPGjx+PrVu38g6yzrlz57B8+XLExsaia9euGmlz6dKlsLGx4TYnJyeNtEuIUausBPr2VW5GmGzKysowduxYTJw4EdXV1UKHQ/Qc70QaFxeHI0eOYO7cuWCMYeXKlRgzZgwePHiAhIQErFq1SgNhKoe3PP/889i8eTMGDfp7nU17e3sAaPRKUiaTQSwWNzm7UlRUFIqLi7ntzp07GomXEGK40tPTkZCQgKNHjyIjI0PocIie4/2MVC6Xo1+/fgCA06dPIycnB7/88gvEYjH69u2Lmpoa3kGmpKTg+eefxw8//IBnn31WZZ9UKkWHDh2QmZnZ4HOZmZnw9PRs8vmoubk5PT8lhKjo27cv9uzZAysrK/j5+QkdDtFzvK9IWb2JkWJjY+Hs7IyQkBCujO9g56SkJIwbNw6bN29WSaLBwcEAlD2EIyMjkZiYiKqqKm5/bm4uMjIyMGnSJF7HJ4S0TcOGDcOAAQO494WFhVAoFAJGRPQV70Tq4uKCzz77DL/88gvWr1+PV199ldsXHx/Pa2DziRMn8Oyzz2LcuHG4ffs2tmzZwm1nz57l6kVHR0MsFmPRokXcDEjz5s2Dm5sb5s6dy+vnI4SQO3fuoF+/fpg1a5bKxQMhAPhPyHD16lXWs2dPJhKJWEBAAJPJZIwxxt577z1mZmbGYmJiWt12QEAAg3JV6ka3+tLT09mIESOYh4cH69mzJ5s0aRK7c+eO2sekCRkIaYHSUsYA5VZaKnQ0Wvfbb78xkUjEXFxc2P3794UOh+iAOrmA96T1dR5fbT4/Px/l5eXo0qWLykQJ+o4mrSekBYxk0np1bNu2DQMGDICzs7PQoRAd0Omk9XUeX22+c+fOmmqaEKJvTE2BxYv/ft0GPL4g+L179zQ2DI8YNpoLixCiPjMzYMkS5WZmJnQ0OvfXX3/B09MTK1euFDoUogcokRJCiJpOnDiB4uJi7N27F7W1tUKHQwSmsVu7hJA2RKEA6iYq8PIC2thE7//85z/RpUsXTJw4scHCGqTtod8AQoj6KioAHx/l6zbS2ehxU6dOVXmfnZ2N7t27CxMMEZTWv0bevHlT24cghBBBbdq0CVKpFNu3bxc6FCIArSfSF154QduHIIQQQcXHx6O6uhpHjhwROhQiALVv7Q4ePFit+tevX1f3EIQQYlDWrl2L0NBQ/N///Z/QoRABqJ1Ik5OTuXlu66Snp6OqqgpSqRQ2NjYoKipCZmYmFAoF+vTpo7FgCSFEH0kkErzyyivce8YYbt68CXd3dwGjIrqidiLt0aMHjh49yr3funUrUlJSEB0dDQsLC668oqICCxcupF8kI8EYa3IBgub2E9JWMMYwf/58rF27Fv/73/9UJr4nxkntZ6S7d+9Wef/dd99h2bJlKkkUACwsLLBixQr8+OOPfOIjeoAxhmMzZyI3MbHR/bmJiTg2cyZN5k0IgJqaGqSlpaGsrAxpaWlCh0N0QO1E6uLiovK+uYWw7927p+4hiJ4RiUTwnDIFCfPmNUimuYmJSJg3D55TptAVaVtiagrMm6fc2sgUgS1lZmaG3bt3Y/fu3ZgxY4bQ4RAd4N1rt3379li6dGmDqxGFQoHPP/+cJn43Eg4DByJkxQqVZFqXRENWrIDDwIECR0h0yswMWL5cubXBKQKbY2lpiXHjxnHvS0pKqEevEeO9+sv27dvxj3/8A127dkVAQABsbW1RWFiI8+fP4/79+/jtt98wfvx4TcWrdbT6S9Pqkqc0MhI3du6kJEpIM+RyOSIjI7F//36sWbMG06ZNEzok0gI6Xf1lwoQJOHLkCBYuXIhDhw6hpqYGpqam6NevH7Zt24awsDC+hyB6xGHgQEgjI3H5xx/hOXUqJdG2SqEAsrKUr52d29wUgepQKBR46qmnYGpqCj8/P6HDIVqgsfVIAeUvzIMHD2Bvbw+xgf7DoivSptEVKQHQJtcj5YMxhitXrsDT01OljPoV6C91coFGs51YLMZTTz1lsEmUNK3+M9HA+fMbPDMlhDROJBKpJNHs7GyEhYUho27if2LQNJLxMjMz8dZbb0EqlXLjRqOjoxEXF6eJ5okeaKxjUWMdkAghzZs9ezYSEhIwffp0GjZmBHg/I01NTUVYWBgYY5BKpXj48CEAwM/PD++++y4YYxgzZgzvQIlwGGO4vHlzo7dx65Lp5c2b0XXAALpVRUgLfP/99xCJRPjqq6/o34wR4P2MdOTIkfDx8UFMTAwsLCwQEBCA8+fPAwCuXLmCadOm4fjx4xoJVhfoGWnjaGYjooKekWpccnIy/P39YUrjcvWCTp+RXr16FcuXL+dmNqr/x9TDwwPl5eV8D0H0QHNJkpIoIa139uxZhIeHY/jw4ZDJZEKHQ9TEO5E2d0Gbl5fH9xCEEGLU8vPzIZFI0K5dO7Snq3uDwzuRSqVSfPTRR6ipqWmwLyYmBt7e3nwPgaKiIkyePBkikQi3bt3i3R4hhCcTE+Dtt5WbCe+uFm3eiBEjcOrUKfzyyy+QSCRCh0PUxPtfwGeffYaIiAj88MMPCA4ORlZWFl544QWkpqYiNzcX8fHxvNr/3//+hxkzZsDS0vKJdZYsWYINGzbAzs5OpdzW1lZlpRqiAQo5kB8PVOQCFg5A51BATP/w2xxzc+Dbb4WOwqj07t1b5f2yZctgaWmJd999V6CISEvxTqTPPPMMjh8/jvnz5+PQoUNQKBTYs2cPQkNDsW3bNgQGBvJq/9NPP8WOHTuwZ88epKenP7FeTEwMpk6dyutYpBl3dgJn3wPKs/8us+wOBP0bcIoULi5CjMyZM2fwz3/+EwDw9NNP0wxxek4j92T69u2L48ePo6KiAg8fPoStrW2DZdVa6+jRozAxMcGePXs00h5ppTs7gfgJAB57Jl6eoywP3U7JtC1hDHjwQPna3h6gzmYaFRQUhC+//BI5OTmURA0A70Qqk8m4rsEWFhZcAr127RqSkpLwj3/8g1d3bhN6/iI8hVx5Jfp4EgUelYmAs3OAbuPoNm9bUV4OPPWU8jUNf9E4kUiEDz/8UKUzZ1VVFXJycrhJb4j+4N3ZKCIiotHykpISrFmzBlOmTOF7iBY5ePAghg4dCj8/P/j6+mL27NnIzc1t9nNVVVWQyWQqG3lMfrzq7dwGGFB+R1mPEKIxdcPKGGOYMWMGgoKCsH//foGjIo/T2vCXwMBAJCYm6mQuSUtLS4hEImzduhWpqanYu3cvkpKSEBQUhOzsphIAsHTpUtjY2HCbk5OT1uM1OBXNfyFRqx4hRC1lZWW4cuUKiouLYWNjI3Q45DGtum+alZXFDUMpKytDfHx8g4TKGEN2drZOrvA+/PBDlfdubm7YsGEDfHx88Nlnn2Ht2rVP/GxUVBTef/997r1MJqNk+jgLB83WI4SoxcrKCsePH8eRI0cQGhrKlRcWFjYYrUB0r1WJdOPGjYiOjuZuOzR2e5cxBrFYjEWLFvEKsLV69+4Na2trJDYzmbq5uTnMzc11FJWB6hyq7J1bnoPGn5OKlPs7hzayjxCiCaamphg+fDj3vqCgAD4+Phg7diy++uorWNVN2Uh0rlWJdOrUqYiIiABjDG+99RbWr1/foI6pqSlcXV3h6OjIO8jm3Lt3D127dm1QLhaLoVAotH58oyeWKIe4xE8AIIJqMn3UWzNoFXU0IkSHDh48iLy8PCQkJNAkDgJrVSJ1cXGBi4sLAGD69OkIDw/XaFDqcnBwQE5OjkrSvnHjBoqKijBu3DgBIzMiTpHKIS6NjiNdRUNfCNGxyZMno3v37ujQoYPKcMPq6mqYmZkJGFnbw7uz0dSpU7F37178/vvvKuWxsbG4f/8+3+ZbLCoqChUVFQCA4uJizJw5EzY2NliwYIHOYjB6TpHAc7eAIUeBAVuV/33uJiXRtsjEBHj1VeVGQ9QEEx4erjLpTWxsLPz9/XHmzBkBo2p7eCfS//znP5g4cSI2b96sUn7s2DEEBgbi0qVLvNqPiYmBv78/12Fo1KhR8Pf3R0pKCldn69atKC4uRnBwMHx8fODj4wM7OzskJSWhV69evI5PHiOWAF0iANeXlP+l27ltk7k58OOPyo36GOgFhUKBTz/9FBkZGdi7d6/Q4bQpvNcjDQ4OxooVKxrtcBQXF4fvvvsOcXFxfA6hU7QeKSHEUBUUFGDlypVYsmQJd3uX1gpuHZ2uR6pQKJ44KcPo0aNbNCkCIcTAMKZc3LusTPma6IVOnTrh888/V0miEydOxMqVKyGXywWOznjxTqQPHz5scn9hYSHfQxAj0twNEJ43SIiulJcDVlbKrbxc6GjIExw8eBA7duzAggULcOPGDaHDMVq8E6mXlxcWL17c4NuOXC7HokWL4OXlxfcQxEgwxnBs5kzkPmFsb25iIo7NnEnJlBANGTFiBNavX48VK1ZQfxEt4v2M9OzZswgLC4O1tTUCAgJgZ2eHwsJCnD9/HjKZDAkJCQgICNBUvFpHz0i1KzcxEQnz5iFkxQo4DBzYbDnRU2VlyqtRgCatNzC3b9/GBx98gFWrVqF79+5Ch6O31MoFTAOSk5NZeHg4k0gkTCQSMYlEwiIiIlhycrImmtep4uJiBoAVFxcLHYrRupuQwH7t14/dTUho9D0xAKWljCmfjipfE4MxcuRIBoBFRkYKHYpeUycX8L4irU8b65HqGl2R6kbdFag0MhI3du6kK1FDQ1ekBisjIwMzZszA2rVruUdvNTU1kEgkEIt5P+0zGjrttVufhYUFHB0dDTaJEt1xGDgQ0shIXP7xR0gjIymJEqIjXl5eOH78uEr/leXLl2PAgAE4ffq0gJEZLo0k0szMTLz11luQSqXcorPR0dEGNX6U6FZuYiJu7NwJz6lTcWPnzid2QCKEaFd1dTX+85//ICkpCdeuXRM6HIPEe26v1NRUhIWFgTEGqVTKDYfx8/PDu+++C8YYxowZwztQYjwe71jkMGAAdTQyNBIJMGHC36+JwTIzM8O5c+ewfv16vPTSS1z5lStX4OjoiA4dOggYnWHg/Yx05MiR8PHxQUxMDCwsLBAQEIDz588DUP6PmDZtGo4fP66RYHWBnpFqF/XaJUT/1dbWIiAgAPn5+di1axf69+8vdEg6p04u4H1FevXqVRw4cIB7X38qKg8PD5TTYG3yCGMMlzdvbjRZOgwciJAVK3B582Z0HTCApjQjREDZ2dmorKxEdXU1PDw8hA5H7/FOpM1d0Obl5fE9BDESIpEIEWvWPDFJOgwcSEmUED3g6uqK9PR0pKenw87Ojiv/9ttvMWzYMPTs2VPA6PQP785GUqkUH330EWpqahrsi4mJgbe3N99DECPSXJKkJGogysoAkUi5lZUJHQ3RAjMzM5XJdM6dO4dZs2bBx8cH2dnZTXyy7eF9RfrZZ58hIiICP/zwA4KDg5GVlYUXXngBqampyM3NRXx8vCbiJIQQIqAOHTpg5MiR6NixI82I9BjeV6TPPPMMjh8/Dm9vbxw6dAiFhYXYs2cPnJyccPz4cZVFZwkhhBimnj17Ii4uDhs2bODKiouLER4ejq1bt0KhUAgYnbA0srR93759cfz4caOY2YjoiEIO5McDFbmAhQPQOVTtRcJZM+ssNrefEKI+83oLua9YsQInTpxAUVGRytCZtkbrMxtNnTpVk4cgxuDOTmCvK/DnIODky8r/7nVVlrcQo5VkCBHcvHnz8NlnnyEmJob70iqXy7F27VqUlJQIHJ3uqD2OdNOmTWodYNGiRbh165ZanxESjSPVsjs7gfgJAB7/tXt05Ri6HXCKbFFTNCZVQDTXLnmC7du3Y+LEiXB3d8e1a9cMdv5erY4jVfcKk26tEY5CDpx9Dw2TKB6ViYCzc4Bu41p0m7du7Gn9pElJlBBhtWvXDr169cKLL76okkQLCwtVhtIYE7UTqZeXF37//fcW1WWMYfTo0WoHRYxUfjxQ3lS3eQaU31HW6xLRoibrJ1NaSUaHJBJg1Ki/XxPyyJgxYzBy5EhUV1dzZRcvXkRQUBBeffVVrF271mCvUp9E7UT62muvwcXFRa36fBUVFeGdd97B1q1bcfPmTbi6uvJukwigIlez9R6pv5KM59SplER1oV07gBalIE8gkUhU+srs3r0b1dXVePjwodElUaAVnY3mzZun1fqP+9///ofAwECkpqY2WS8jIwOjRo2Cp6cnd1shJyeH17GJhlk4aLbeI7SSDCH67ZNPPkFCQgJiYmK4sqKiIkyYMAEJCQkCRqYZer+M2qeffoodO3ZgQt1KE43IyspCaGgofHx8kJGRgUuXLkEkEiE8PBwymYx3DERDOocClt3BdSxqQARYOinrtVD9Z6KB8+dzt3nVSabN9bejnr+E8Ddw4ECVNVC/++477NixAzNmzDD4f2O8E2lqaioCAgIQGxsLa2trblBu3TJq+/fv59X+0aNHVaapaszixYshl8u5LtgmJiZYuXIlbt68iVWrVvE6PtEgsQQI+vejN48n00fvg1a1eDxpYx2L6j8zbUkypWE0rVRWpuyp2749TRFIWmXSpEmYNm0aFi5cyHVKra2txbp161BUVCRscOpiPI0YMYLNmzePlZeXM8YY8/f35/ZdvnyZhYWF8T0EY4yxxYsXMwDs5s2bKuW1tbWsQ4cObPTo0Q0+4+3tzby9vdU6TnFxMQPAiouL+YRLmpK1g7Fd3Rn7GX9vu5yU5S2kUCjYkenT2d2EhEb3301IYEemT2cKhaLZtu4mJLBf+/Vr0NaTygljrLSUMUC5lZYKHQ0xErt27WIAmKurK5PL5YLGok4uMPhl1DIzM1FSUgKpVNpgn1QqRVxcHKqqqlRm4yACc4pUDnHhMbORJleSoWE0hOgHExMT+Pj4YPTo0Sqdkn777TcMGzYMNjY2Akb3ZAa/jFp+fj4ANDpgtu5Wc2FhIRwcGu/AUlVVhaqqKu49PVPVEbGkxUNcnkSTK8nQMBpChDdmzBiMHj1aZehMeno6Jk2aBGtra+Tk5MCqbiIQPdLml1FbunQpbGxsuM3JyUnokIhA6g+jkUZGUhIlRAAikUjlDuKDBw/g7e2NwYMHqyTRo0eP6s2Fj8Evo2Zvbw+g8StJmUwGsVjc5GwaUVFReP/991U+Q8m0bXp8GI3DgAGUTAkRWHh4OC5evKgyd29RURF3+zctLY0bLSIUg19GTSqVokOHDsjMzGywLzMzE56enk0+HzU3N4e1tbXKRtoeTQyjAWgoDSHaIBKJVP423759G87OznB1dYWbmxtXnpqaKshk+RoZR1q3jFpJSQmys7NRUlKCo0ePIjg4WBPNN0kikSAyMhKJiYkqzzpzc3ORkZGBSZMmaT0GYtg0MYwGaGNDacRiIDxcuRnhTDVEv/n5+SEjIwOHDx/m+kIoFAqMHz8ejo6OOHnypE7j0coyamVlZSoPi7UtOjoaYrEYixYtAmMMtbW1mDdvHtzc3DB37lydxUEMD2MMlzdvbrRjUV0yvbx5c4uSn0gkgueUKY0m37pk7TllinEs5GBhARw7ptxo7WEiAJFIhK5du3Lvc3JyYGpqColEAn9/f90G05rxNefOnWMLFy5kCxcuVBljc/ToUebs7MzEYjFr164dmzNnTovG8TUlOjqa+fn5sS5dujAAzMvLi/n5+bHz58+r1EtPT2cjRoxgHh4erGfPnmzSpEnszp07ah+PxpG2Pc39jqr7O/z4+FMaj0qIbigUCnbt2jWNtKVOLlB7PVIAmDt3Lv773//izTffxL/+9S+0b98eMpkMUqkUpaWlmDJlCsRiMX7++Wd88cUXeOeddzT+BUBbaD1Sogl1V6A0lIYQw6TV9UgB4K+//sLu3bsxdOhQrmzr1q0oKCjAt99+i5kzZwIAxo8fj0WLFhlUIiVEE4x+RZqyMqBuFaZbt2hhb9KmteoZaWVlpUoSBZSroltaWqos/D18+HBuwgRC2pI2sSLNgwfKjZA2rlVXpI+vJ1dSUoL4+HgMHz5cZQ06AHo7pRMxIgo5r+kGNe3xXsAOAwaoPd0gY6zJTknN7ddWW4SQhlp1RVpbW4va2lru/fbt21FbW4uxY8c2WpcQrbmzE9jrCvw5CDj5svK/e12V5QLQtxVpNNkWIaRxrUqkvXv3xscff4ySkhJcuHABMTExaNeuHf7xj3+o1Pvtt9/QsWNHTcRJSEN3dgLxE4DybNXy8hxluY6TKdPQUBpNDqNpU0NyCBFKa7oFp6amMgsLCyYWi5lYLGYikYh9+eWX3P6kpCT2j3/8g5mamrJFixa15hCCoeEvBkJe23ApNpVNpFyaTV6r07A0OZRGk8NoND4kh5ZRI0ZO68NfAODChQv46aefIJfLMXToUIwePZrbd/bsWW5B75dffhk9e/bURM7XCRr+YiDyjilv4zZnyFHeq8wISZPDaDQ6JKesDKibQLy0lHrtEqOj9eEvAODr64sVK1Y0ui8oKAhBQUGtbZqQ5lXkaraentLkMBqNDskRi4G6KUBpikDSxtG/AGKYLBpfX7bV9fSUJofRaHRIjoUFkJys3GiKQNLG8V5GjRBBdA4FLLsrOxahsacTIuX+zqEtb9MIh9Fooy1CiCq6IiWGSSwBgv796M3jPU4fvQ9a1fJEaITDaLTRFiGkIUqkxHA5RQKh2wHLbqrllt2V5U6RLWvHSIfRaLotFeXlyikCXV2Vrwlpw1rda9dYcT217t6lXruGQiEH8hOByntAu65A54EtvxJVyIE4L6D87pPrWHYDRl/S6W1epu8zG5WVAV26KF/n5VGvXWJ0ZDIZbBwdtdtr1+g5OgodAdEbOQB0O9Vlc2lNnbSnybYaVZdQCWmj6NYuIYQQwgNdkT7J3bsA3do1fnkngGOjmq8X8TvQJUz78RgKurVLjJ1M1uI7k5RIn6R9e/rj0Ba4DgPsWjCMxnWYoENh9Br9WyHGSC5vcVW6tUvaNk0PoyGEtDmUSAnR1DCatkQkAry9lRutHEPaOLq1SwigTJbdxunVzEZ6zdISSE8XOgpC9AIlUkLqiCUGvVIMIUQYdGtXz8lkMpw8eVLoMAghhDwBXZHqsaqqKqxduxYVFRWwt7dHr169hA6JEKXycqBPH+Xr5GTlrV5C2iijSaS3bt2Cj48PevTo0WDfN998g9BQNVYB0RPm5uYICAhAVlYWTVdoaPRsJRmNYwy4dOnv14S0YUaTSAEgODgYx44dEzoMjRo0aBAkEon6c6ES4dzZCZx9T3USfMvuymE21AOYEKNDz0j1nImJCSVRQ6JnK8kQQrSPEqmBUCgUSE5Oxo4dO9Rf8orohkKuvBJtdIakR2Vn5yjrEUKMhlEl0ry8PLzyyit45pln0LNnTzz33HM4fPhwk5+pqqqCTCZT2fRRcXEx/vjjD1y8eBE3btwQOhzSmPz4hleiKhhQfkdZjxBiNIwmkUokEigUCrz11ltISkrChQsX4O/vj2HDhmH9+vVP/NzSpUthY2PDbU5OTjqMuuVsbW0xaNAgjBw5Eu7u7kKHQxpTkavZeoQQg2D0C3v37dsXV69eRV5eHszNzRvsr6qqQlVVFfdeJpPBycmpRYu5EqIi7xjw56Dm6w05avgTP5SXK6cHBJS9d2n4CzEyMpkMNjY2tLA3APTr1w/Jycm4ePEigoKCGuw3NzdvNMHqO8YYKisrYWFhIXQopE7nUGXv3OZWkumsxlAsTQ6j0WRblpbArVut+ywhRsZoEmlxcTHMzMwaJBaJRPmHQqFQCBGWVjx48AB79+6FRCLBK6+8Qr169UXdSjLxE6BcOaZ+Mm3FSjKaHEZDQ3II0RqjeUb63nvv4euvv25QfubMGVhaWqJ3794CRKUdEokEubm5yMnJQUFBgdDhkPo0tZKMJofR0JAcQrTKaK5IAWDNmjWYMGECN5XemjVrkJCQgC+++AKWRvQMx9bWFpGRkejWrRs9x9VHfFeSaXYYjUg5jKbbuObb1GRb9VVUAGFhytcnTgD0iIG0YUaTSD/44AN07NgREyZMgEgkQlFRERwcHLBlyxZMnjxZ6PA0zsvLS+gQSFP4rCSjzjCa5o6hybbqUyiAM2f+fk1IG2Y0idTX1xerVq0SOgxB5OfnQyQSwd7eXuhQiCZochgNDckhROuM5hlpW3XhwgWsXbsW+/btoxmPjIWFg+bqabItQkijKJEaOGdnZ0gkElhYWKC6ulrocIgm1A2jwZN6Y4sAS6eWDaPRZFv11Z/mMO9E66c9VMiV429v/aL8L5/pEzXZFiFqMJpbu22VjY0NZs6cCVtbW6FDIZqiyWE0mh6SAyh7+SbO+vv9sVGAXSuG0tDwHmIk6IrUCFASNUKaGkaj6ba4oTR3VcvVHUpDw3uIETH6KQLVpc60UPqmpqYGiYmJ8PDwgIMDPfMyCvo0s5FCDux1VSasSgBzHpWvAtAO4GZueu5m0+3Wb6dRLWxH020RUg9NEdhG/fnnn0hKSsL169fxxhtv0IxHxoDPMBpNt1V/KE07AGsfr9DCoTSGMLyHEDXQrV0jMnDgQNjb26N///5Ch0KMkaaG0tDwHmJk6IrUiHTo0AFvv/02XYkS7dDUUBoa3kOMDCVSI1M/iTLGKKkSzam/uk01A5Y9Kv8QgBnQ4tVtNLlKTltZcYdi0muUSI3UzZs3ceDAATz33HPo3r270OEQY1B/KI0CQMajcgWg1lAafR7eo49DcigmvUfPSI1Uamoq8vPzcfz4caFDIcaEG0rjqFqu7lAafRzeo49DciimlrclIBr+8hhDHv5SX2lpKRITExEeHo527doJHQ4xNiUywNpG+frG74DrMMO+PaiPQ3IoJkGHLqmTC+iK1EhZWVlh+PDhlESJdtT/w9YlrPV/6OqG5Li+pPwvnz+YfNpSZxiNrtqimFrelsAokbYRhYWFQodAiP7SxyE5FJN69QREidTIMcawZ88efPPNN8jKyhI6HEL0kz4OyaGY1KsnIEqkRk4kEkEsVv5vvn37tsDREKNiaancjIE+rrhDMam/MpFAKwBRIm0DhgwZgtdffx2hoX//Qh47dgzXr1+HXE5LTZFWaN8eKCtTbu3bCx0Nf3XDaAA0/MPeyiE5fNuimNQfurTXFfhzEHDyZeV/97rqpOcvJdI2wNLSEk5OTtz7wsJCHD9+HL/88gtqamq4curATdo0fRySQzG1rB2Bh9HQ8JfHGMvwl6YUFhbi5MmTqK6uRmTk37+o27dvR1lZGQYPHqySeAlpU/RlSA7F1PLPamEYDa3+QppkZ2eHMWPGqJTJ5XJcu3YN1dXVkEj+/mUrKipCaWkpunXrRtMNkr9VVgIvvKB8vWMHYEzDrPRpxR1Nt6PJtvQlJj1YAYgSKQEASCQSzJgxA9evX1dZy/TcuXOIj4+Hv78/xo0bJ2CERK/I5cDvv//9mhCh6MEwGqN5RlpZWYmPPvoIHh4eePrppxEcHIy9e/cKHZZBsbW1RZ8+fRpMfG9ubg5XV1eurLKyEuvXr8eePXtUPp+fn4+CggLU1tbqKmRCSFunB8NojOaKdMqUKbh48SISExNhb2+Pffv2Yfz48di9e3eD25ik5YYMGYKIiAiVjkjXrl1DTk5Og4R54MAB3Lx5E88//zz8/PwAKJ/HxsfHo3PnzhgwYABXt7q6GqampnS7mBDCjzZWAFKTUVyRHj9+HNu3b8eSJUtgb28PABg7diyGDh2K9957j3qj8iSRSGBi8vd3LmdnZ7z44osYPHiwSj0TExOYmZmpPJgvKChASkoKLly4oFJ327Zt+Ne//oWMjAyu7P79+/j1119x+PBhlbpXrlxBSkoKioqKuLLa2loUFRWhoqJCEz8iIcRQaXoYTSsYxRXpr7/+CkB59VTfkCFD8Mcff+DMmTPo06ePEKEZJRsbG9jY2DQof/nllwGoDqOxs7PDoEGDGsz5W1JSArlcrlJeXFyMjIwMlWe0AHDy5ElkZWVh4sSJ6NixIwDg7t272LhxI2xtbTF79myu7o4dO5CVlYURI0bAy8sLAPDgwQPs378f1tbWKr2Uk5OTkZeXh6effhrOzs4AgPLycpw/fx7m5uYIDg7m6t6+fRvFxcVwdHTkvqzV1NTg9u3bMDExUbn1XVxcjMrKSlhZWaH9ozGWCoUCJSUlEIlEKl80ampqoFAoVL6s1J0/ulonpIXqhtE0uhzbKq0vx2YUiTQlJQXW1tbcH7g6UqkUgHJJMUqkulM/AXTq1AlhYWEN6kyfPh0lJSWwsrLiyjp37oyRI0c2SLrdu3dvcKUrl8thYmICc3NzlbqlpaWQyWQqE01UVFTg9u3bsLW1Val7/fp1XL16FY6OjlwiLSkpweHDh9G+fXuVRHrmzBlcvHgRI0aM4H7PSktL8fPPP8PMzAxRUVFc3WPHjiElJQWDBw/mJsEoLy/HqlWrAACLFy/m6h46dAjJyckIDQ3lrvCrq6vxxRdfAAAWLFgAU1NTAMDRo0dx6tQp9O3bl/vSyBjDypUrIRKJ8Pbbb8PCwgIAkJSUhFOnTsHX11flzsH3338PuVyOKVOmoEOHDgCAtLQ0nDp1Cj179sSgQYO4ulu2bOGGSNV9gbly5QpOnToFt6eeQv3/q7t27UJZWRlGjhyJTp06AVCuiXvq1Ck4ODggIiKCq/v777+jtLQUgwYNQufOnQEA2dnZOHXqFOzt7VXqHjlyBEVFRRg4cCC6dOkCAMjLy8Nff/2Fjh07qtRNSEhAYWEh+vTpw30ZKygowF9//QUrKyuVuqdPn0Z+fj78/f3RrZtyDGNxcTFOnjwJCwsLlbrnz59HXl4eevfuzQ0LKy0txcmTJ2Fqaqpyzi5cuIB79+6hV69ecHFxAaDsU5CQkACxWKzy/+Ly5cvIycmBu7s73NzcACi/WMXHKydpHzRoEPdv6fr167hz5w5cXFzg7u4OQPlvoK5uSEgI90Xs5s2byMrKQrdu3dCjRw/ueCdOnAAA9OvXD2ZmZgCAO3fu4NatW+jSpQt69erF1T158iTkcjmCg4O536m7d+8iMzMTnTt3hoeHh8q5rKmpgb+/P/fFMS8vD9evX4ednR33hRYAzp49i6qqKvj6+nK/fw8ePMDVq1dhY2OD3r17c3VTU1NRXl4Ob29v7ot7YWEhrly5gg4dOsDHx4ere/HiRZSWOsIj9Dxsay/qfIFwo0ik+fn5jY7zqSvLz89/4merqqpQVVXFvS8uLgagHENEtEsikaCiooK7PSsWi+Hp6QlA9fw/88wz3Ou68k6dOmHWrFlgjKnUDQ8PR79+/WBjY8OVm5qaYsSIETAxMVGp6+bmBmtra1hZWXHlVVVV6NGjB8zNzVXqtm/fHg4ODpBIJFx5aWkpbGxsYGpqqlK3trYWEokENTU1XHlJSQlqamogEolU6paVlaGyshLl5eVceWVlJSorK7lj1A1HKi4uhkwm4zZAeaVbUFDAnZu6CTYePHiAe/fuwcHBQeV4WVlZUCgUKCoq4q588/LycPPmTbRv316l7o0bN1BZWYmHDx9y00zevXsXly9fhriyElxNmQwZGRkoKSlB3759ucSfk5ODtLQ0lJaWIjAwkGs3PT0dhYWF8Pb25r4I3b17F2fPnoWTk5NK3bS0NOTl5cHNzU3lD3pSUhK6du2qUjc1NRXZ2dlwcHDg/qDn5uYiMTERnTp1alA3MzMTtra23B/0e/fu4cSJE7C2tlapm5KSgqtXr6Jdu3bcH/QHDx7g6NGjsLCwQFBQkEq76enpEIlE3Be34uJi/PnnnzAxMVH5cpaamoqUlBSEhYVxXz7Ky8tx6NAhAEBQUBCXSNPS0pCcnIx+/fqp3BH5448/AAA+Pj5ccrx48SJOnjyJ4OBgPPXUU9zxDhw4AADo0aMH9wU2PT0dx48fh5+fH7p27crVPXjwIGpqauDs7Mz9HJcvX8ahQ4fg7e2tctfof//7H8rKytC1a1fui9GVK1dw4MAB9OjRg/uiAgCHDx9GUVERbG1tufJr165h3759cHV1VRm/fvjwYTx48ADt27fn7vjcvHkTe/fuRbdu3bgvv4DyS+bdu3cxceJESHoEAhaPdpSWobXq/i206NEgMwI9e/Zk3bt3b1B+6NAhBoB9/vnnT/zs4sWLGZRPqGmjjTbaaKNNZbtz506zOcgorkjt7e2Rnp7eoLzuG0Xdt6TGREVF4f333+feKxQKFBYWolOnTq1+RiWTyeDk5IQ7d+4Y7exImkDnqWXoPLUcnauWofPUPMYYSkpK4Ojo2Gxdo0ik/v7++Ouvv1BQUMDdIgGAzMxMAOCGYjTG3Ny8wXO2uudBfFlbW9MvaQvQeWoZOk8tR+eqZeg8Na2xTpWNMYrhL5MmTQIA/Pnnnyrlf/75J9zd3VWeSxBCCCGaZBSJNCIiAhMmTMCSJUvw4MEDAEBcXBwOHTqEVatW0TACQgghWmMUt3YBYPPmzViyZAkGDhwIc3NzmJqaYufOnRg7dqzOYzE3N8fixYsb3DImqug8tQydp5ajc9UydJ40i5ZRI4QQQngwilu7hBBCiFAokRJCCCE8UCIlhBBCeKBESoiBi4qKgkgkwo8//ih0KIS0SZRI1cBn8fCioiLMmDEDvXr1Qu/evREaGoqTJ09qOWJhtPY8paWl4Z133oG3tzd8fX3h5eWFCRMmIC0tTQdR654mFqO/fv06vvrqKy1FqD/4nquff/4ZISEhCAoKglQqhb+/P/797383/0EDw+c8HTt2DEOHDuX+/QUFBWHDhg1ajthItH6G27ZnwoQJzNPTk+Xn5zPGGNu7dy+TSCRs3759TX6utraW9evXj4WFhbGysjLGGGPffPMNa9euHTtz5ozW49a11p4nDw8PNnz4cPbw4UPGGGOlpaXsueeeY+bm5uz06dPaDlvnWnue6hs9ejQbN24cA8A2btyopUiFx+dcffzxx8zf35/dvn2bMab89zh9+nQ2ZMgQrcYshNaep+TkZGZmZsbmzZvH5HI5Y4yx3bt3M5FIxL777jutx23oKJG20LFjxxgAtm3bNpXy4cOHM3d3d6ZQKJ742R9//JEBYKdOnVIp9/DwYIMGDdJKvELhc548PDzYuXPnVMquXr3KALApU6ZoJV6h8DlPdeLi4piXlxe3OIOxJlI+5yo5OZmJRKIGX1jv37/PTpw4oZV4hcLnPH344YcMACsoKFAp9/X1Zf3799dKvMaEbu22UFOLh2dmZuLMmTNNfrZDhw7o27dvg88eO3YM9+/f13zAAuFzntLS0hAQEKBS1r17dwDAw4cPNRypsPicJ0C5ZumcOXPw73//m1uH0ljxOVfr1q1D165dVZY6A5QLWdStFWss+JynuqX6amtrVcprampU1vYljaNE2kItWTy8qc+6ubk1mKpQKpWCMWZUzwD5nKe69RTru3LlCgCoLIhsDPicJwD4+uuv4e3tjWeffVZrMeoLPucqISEBbm5u2LFjB8LCwuDp6Ym+ffti9erVLVtn0oDwOU8zZ85Et27d8NFHH6GyshKMMaxbtw5Xr17FnDlztBm2UTDur7IaxGfx8Pz8fG5Ve3U/a2j4nKfGfPfdd+jVqxemT5+ukfj0BZ/zlJubixUrViApKUlr8ekTPucqKysLWVlZWL58OXbt2oWuXbti//79mDBhAq5cuYJvv/1Wa3HrGp/z5OTkhGPHjmHq1Kno2LEjOnToAEtLS+zbtw+jRo3SWszGgq5Iid6Ki4vDzp07sWPHDlhaWgodjt748MMPMW3atEa/nBFVlZWVKCsrw4oVK+Dg4ACRSISxY8fixRdfxJo1a3D79m2hQ9QLf/31F5555hn4+/ujsLAQ9+/fx7p16/Dqq6/SsKoWoETaQvb29txC4fW1ZPFwPp81NJr6WU+cOIHp06fjwIED8PHx0WiM+qC15+nkyZM4duwYFixYoNX49Amf36kOHToAUK5ZXF9AQAAYY0hOTtZcoALjc57mzJkDiUSCr7/+GpaWlhCJRBg+fDgmT56MadOm4datW9oK2yhQIm0hf39/yGQyFBQUqJS3ZPFwf39/3Lp1q8EzmczMTIhEIjz99NOaD1ggfM5TnUOHDuGVV17B/v370adPH63EKbTWnqeDBw/C1NQUAwcOhL+/P/z9/fHmm28CABYtWgR/f3/MnTtXu8HrGJ/fKW9vbwCAQqFQKa/rXPN4uSHjc57S0tLg5uYGU1NTlXIPDw/U1NQ02/mtzRO0z7ABOXr0KAPAYmNjVcpHjBih0rW8traW5eXlqdTZuHEjA8CSkpJUyr28vFhERIR2A9cxPueJMeW4Nzc3N3bp0iWu7O7du2zs2LHaDVzH+J6nxtoy1uEvfM7Vl19+yQCw+Ph4lfJp06YxkUjEMjMztRu8DvE5Ty4uLszBwYEbQ1qnbljMkSNHtBu8gaNEqoYJEyYwLy8vbrDz/v37mUQiYXv37uXqTJs2jYnFYpaYmMiV1U3IEBERwU3I8N133xn1hAytOU+xsbHMzMyMLV68mG3evJnbvv76a+bi4qLrH0PrWnueHmfsiZSx1p+r0tJS1rNnTxYWFsZkMhljjLGkpCTWvn17NnPmTN3+EDrQ2vP073//mwFgS5Ys4RLu2bNnWceOHVlQUBCrra3V7Q9iYCiRqqGiooL985//ZL169WK+vr4sMDCQ7dmzR6XOwoULmZ2dHbtw4YJK+cOHD9m0adNYz549mbe3NwsJCWEJCQm6DF9nWnuebG1tGYBGN2NMpHx+nxhjLD09nfn5+TGpVMoAMCcnJ+bn58cOHTqkqx9BZ/icq7t377JXXnmFde/enXl4eDBvb2/29ddfN7j6MgZ8ztOOHTtYaGgo8/DwYD4+Pqx3797s448/5mYaI09GC3sTQgghPFBnI0IIIYQHSqSEEEIID5RICSGEEB4okRJCCCE8UCIlhBBCeKBESgghhPBAiZQQQgjhgRIpIYQQwgMlUkIMwPLly+Ht7Q2RSETLWhGiZ2hhb0I0zNXVFZaWljAzMwMAlJaW4saNG3BycoKdnR0AoLq6GuXl5S1enmr+/PmYOHEi3NzctBU2IaSVKJESogW///47XF1dAQDHjh3DoEGDEBMTg6lTpwIAbt26hYiICMHiI4RoDt3aJUTDwsPDYWFh0WQdCwsLhIeH6ygi41VSUoJPPvkEvXr1goWFBezs7NC/f3/89ddfQodG2hBKpIRo2E8//YQuXbo0WadLly746aefuPdnz57FyJEj4eLiAnd3d4SFheHIkSMtOl5SUhKGDh0KNzc3uLm5YcSIEUhJSeH2x8bGwt/fHyKRCIsWLcKSJUswYMAA2NjYoGPHjgCAlJQUvPzyy/Dz80NAQAD8/PwQHR2NqqqqJ7bzySef4JlnnkG3bt0wZcoUlJSUqMRV/2fy9/dHUFAQFi9ejPz8fLXifxLGGIYNG4bVq1dj/Pjx+Pbbb/Hxxx/D1dUVHTp0aNG5I0QjBF59hhCj19x6ocnJyczCwoJ99NFH3FqQ//nPf5hEImH79+/n6t28ebNBO0lJSczc3JzNmzePK/vggw9Yhw4d2LVr11SOA4A5Ojqyffv2McYYy8zMZLa2towxxpYuXcpefPFFVlVVxRhjrKCggPXv35/NmTOnQbx4tGRb3WLZWVlZzNrami1cuLDBz/Txxx9zP9ORI0eYqakp27VrV6vif9yZM2cYALZjx44m6xGibZRICdGy5hJpeHg469y5M6uurlYp9/X1Ze7u7tz7xhJpWFgYs7OzYxUVFVxZWVkZs7KyYq+//rpKewDYsGHDVMquX7/OGGMsNze3wbqTa9asYZaWllwirN/OmDFjVMpGjhzJBgwYoPIzPfXUUw1+pkmTJnGJXN34H3f9+nUmFovZm2++ya5fv87y8/MbHI8QXaBbu4QIqLy8HPHx8QgMDISpqanKvv79+yMzMxNXr1594mcTEhIQHByMdu3aceWWlpaQSqWN3hr28fFReS+VSgEAHTt2xLp16zBgwAD4+vrC398fn3/+OcrLy3Hv3r0G7Xh6eqq8t7e35+rV/UwBAQENfqbY2FiMGTOm1fE/Hvu6deuwefNm9OjRA507d8b169eb/Awh2kC9dgkR0MOHD6FQKLhhMfV16tQJAJCfn49evXo98bPJycnw9/dX2VdYWAiRSNTgM096dvjmm2/iwIEDOHz4MAICAgAAP/74I1577TWV56R12rdvr/JeLBZDLpc3+zPxjb++b7/9FlFRUfjwww/Rp08fWFhYNHqeCNE2SqSECMjW1hZisRiFhYUN9hUUFAAAOnfu3ORnw8PDsWvXrlbHUFFRgW3btmHGjBlcEuWjqZ+psXqtiT87Oxtz587FmjVr8MYbb/AJlxDe6NYuIQKytLREaGgozp8/j5qaGpV9p06dgru7+xOvsuo+m5qaCoVCobJv9+7dWLJkSYtiqK2thVwuh1is+ucgNze35T9II3E19jPNmDEDv/zyC+/4U1NTUVNTw92aJkRIlEgJEdjy5cshk8kQHR0NxhgAYO3atUhPT8fq1aub/Wxubi5iYmK4z165cgVz5sxBYGBgi47foUMHREREIDY2FpmZmQCAO3fuYO3atRr5merExcVh7969GDRoEO/4PT09YWpqiilTpuDTTz/Fhg0b8OWXX2L06NFITU1tddyEtIrAnZ0IMWovvPACk0ql3JCRIUOGNFrvzJkzbPjw4czZ2Zm5urqykJAQdvjwYW7/smXLmJeXF9fOlClTuH3Jycls2LBhrFu3biwwMJCFhISw3bt3c/sPHjzI/Pz8GADWpUsX5ufnx86fP69y/Lt377JJkyaxrl27smeeeYY999xzbM6cOQwA8/LyYj/99FODdl5++WXGGGNDhgxhtra2zNTUlPn5+bH09HSVn8nJyYn5+fmxESNGsLS0tAY/e3PxP8nevXtZv379mKWlJTM3N2dSqZRNnjxZpQcwIbogYuzR10BCCCGEqI1u7RJCCCE8UCIlhBBCeKBESgghhPBAiZQQQgjhgRIpIYQQwgMlUkIIIYQHSqSEEEIID5RICSGEEB4okRJCCCE8UCIlhBBCeKBESgghhPBAiZQQQgjhgRIpIYQQwsP/A8PK4T6M6TYQAAAAAElFTkSuQmCC",
      "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(classic_all_voter_columns)\n",
    "m = len(classic_all_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.5\n",
    "epsilim_index = np.where(abs(epsilons-epslim) < 0.001)[0][0]\n",
    "existing_size=7\n",
    "plt.scatter(epsilons, outputs_pp, label='IP', color='orange')\n",
    "plt.scatter(epsilons[:epsilim_index], outputs_pp_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_helm.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
