{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"provenance":[],"collapsed_sections":[]},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"code","execution_count":null,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"gRmi4PwuY1Ju","executionInfo":{"status":"ok","timestamp":1664157867400,"user_tz":420,"elapsed":70509,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"517d8b4b-ec6a-4d83-d2a6-83b9edfd144c"},"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/gdrive\n"]}],"source":["import numpy as np\n","import pandas as pd\n","from google.colab import drive\n","drive.mount('/content/gdrive')\n","# drive_path = '/content/drive/My Drive/thesis/proposal/UP-AR-recourse/'\n","drive_path = '/content/gdrive/My Drive/UP-AR-recourse/'\n","\n","# !pip install torchattacks\n","# !python -m pip install –-upgrade pip\n","# !pip install pre-commit==1.20.0\n","# !pip install pytest==6.1.2\n","# !pip install sphinx==4.0.2\n","# !pip install sphinx-rtd-theme==0.5.2\n","# !pip install sphinx_autodoc_typehints==1.12.0\n","# !pip install numpydoc==1.1.0\n","# !pip install causalgraphicalmodels\n","# !pip install keras==2.1.5\n","# !pip install recourse\n","# !pip install lime\n","# !pip install dice_ml\n","# !pip install tensorflow==1.14.0\n","# !pip uninstall h5py\n","# !pip install h5py==2.10.0\n"]},{"cell_type":"markdown","source":["# 1 - Adult"],"metadata":{"id":"kuOY6ziEtr4U"}},{"cell_type":"markdown","source":["### Nonlinear"],"metadata":{"id":"P2kxeriMo4J2"}},{"cell_type":"code","source":["import numpy as np\n","import pandas as pd\n","\n","results_files = [drive_path + 'results/adult/results_ActionableRecourse_adult_nonlinear.csv',\n","                 drive_path + 'results/adult/results_UserPreferred_adult_nonlinear.csv',\n","                 drive_path + 'results/adult/results_CCHVAE_adult_nonlinear.csv',\n","                 drive_path + 'results/adult/results_Clue_adult_nonlinear.csv',\n","                 drive_path + 'results/adult/results_GrowingSpheres_adult_nonlinear.csv',\n","                 drive_path + 'results/adult/results_Face_adult_nonlinear.csv',\n","                 drive_path + 'results/adult/results_Wachter_adult_nonlinear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/adult/results_ActionableRecourse_adult_nonlinear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_adult')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    total_points = df.shape[0]/np.mean(df['Success_Rate'])\n","    total_non_violated = sum(df['Cstr_Vio']==0)\n","    adjusted_success_rate = total_non_violated/total_points\n","    print(file.split('results_')[1].split('_adult')[0])\n","    print(total_points)\n","    print(total_non_violated)\n","    print(adjusted_success_rate)\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_adult')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Nonlinear Results:')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":787},"id":"htOsPm97Y8iI","executionInfo":{"status":"ok","timestamp":1663786570790,"user_tz":420,"elapsed":930,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"c8f5ee65-9c92-4882-ec62-93847b524bed"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["ActionableRecourse\n","1000.0\n","418\n","0.418\n","UserPreferred\n","1000.0000000000001\n","821\n","0.821\n","CCHVAE\n","1000.0\n","0\n","0.0\n","Clue\n","1000.0\n","0\n","0.0\n","GrowingSpheres\n","1000.0\n","844\n","0.844\n","Face\n","1000.0\n","1\n","0.001\n","Wachter\n","999.9999999999999\n","156\n","0.15600000000000003\n","Nonlinear Results:\n"]},{"output_type":"execute_result","data":{"text/plain":["                   Success_Rate Time_taken  Cstr_Vio Redundancy Proximity  \\\n","ActionableRecourse        0.418   9.198168       0.0        0.0  2.097332   \n","UserPreferred             0.821   0.756995       0.0   0.781973  1.772716   \n","CCHVAE                    0.844   0.774432  4.469194   5.830569  3.953509   \n","Clue                      0.844   1.489702  3.582938   7.819905  3.139856   \n","GrowingSpheres            0.844   0.028871       0.0   2.864929  1.302668   \n","Face                        1.0   6.782723     4.575      7.549  4.105562   \n","Wachter                   0.554   0.040769  1.436823   3.055957   0.73957   \n","\n","                    Sparsity  \n","ActionableRecourse  2.535885  \n","UserPreferred       2.784409  \n","CCHVAE              9.406398  \n","Clue                8.305687  \n","GrowingSpheres      5.092417  \n","Face                   7.914  \n","Wachter             4.902527  "],"text/html":["\n","  <div id=\"df-62d3262c-8532-44b9-8b87-8795affbfe6a\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>ActionableRecourse</th>\n","      <td>0.418</td>\n","      <td>9.198168</td>\n","      <td>0.0</td>\n","      <td>0.0</td>\n","      <td>2.097332</td>\n","      <td>2.535885</td>\n","    </tr>\n","    <tr>\n","      <th>UserPreferred</th>\n","      <td>0.821</td>\n","      <td>0.756995</td>\n","      <td>0.0</td>\n","      <td>0.781973</td>\n","      <td>1.772716</td>\n","      <td>2.784409</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE</th>\n","      <td>0.844</td>\n","      <td>0.774432</td>\n","      <td>4.469194</td>\n","      <td>5.830569</td>\n","      <td>3.953509</td>\n","      <td>9.406398</td>\n","    </tr>\n","    <tr>\n","      <th>Clue</th>\n","      <td>0.844</td>\n","      <td>1.489702</td>\n","      <td>3.582938</td>\n","      <td>7.819905</td>\n","      <td>3.139856</td>\n","      <td>8.305687</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres</th>\n","      <td>0.844</td>\n","      <td>0.028871</td>\n","      <td>0.0</td>\n","      <td>2.864929</td>\n","      <td>1.302668</td>\n","      <td>5.092417</td>\n","    </tr>\n","    <tr>\n","      <th>Face</th>\n","      <td>1.0</td>\n","      <td>6.782723</td>\n","      <td>4.575</td>\n","      <td>7.549</td>\n","      <td>4.105562</td>\n","      <td>7.914</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter</th>\n","      <td>0.554</td>\n","      <td>0.040769</td>\n","      <td>1.436823</td>\n","      <td>3.055957</td>\n","      <td>0.73957</td>\n","      <td>4.902527</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-62d3262c-8532-44b9-8b87-8795affbfe6a')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-62d3262c-8532-44b9-8b87-8795affbfe6a button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-62d3262c-8532-44b9-8b87-8795affbfe6a');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":8}]},{"cell_type":"markdown","source":["### Linear"],"metadata":{"id":"u3Ga4VDroxse"}},{"cell_type":"code","source":["import numpy as np\n","import pandas as pd\n","\n","results_files = [drive_path + 'results/adult/results_GrowingSpheres_adult_linear.csv',\n","                 drive_path + 'results/adult/results_Wachter_adult_linear.csv',\n","                 drive_path + 'results/adult/results_ActionableRecourse_adult_linear.csv',\n","                 #drive_path + 'results/adult/results_UserPreferred_adult_linear.csv',\n","                 drive_path + 'results/adult/results_CCHVAE_adult_linear.csv',\n","                 #drive_path + 'results/adult/results_Clue_adult_linear.csv',\n","                 drive_path + 'results/adult/results_Face_adult_linear.csv',\n","                 drive_path + 'results/adult/results_UserPreferred_adult_linear.csv',\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/adult/results_ActionableRecourse_adult_linear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_adult')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_adult')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","total_summary_df[desired_cols]"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":238},"id":"5bZLZqbmkv3f","executionInfo":{"status":"ok","timestamp":1663627506091,"user_tz":420,"elapsed":346,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"51618bb0-6207-4a42-81fc-64b5ac209bc9"},"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["                   Success_Rate Time_taken  Cstr_Vio Redundancy Proximity  \\\n","GrowingSpheres            0.839    0.04254       0.0   1.762813  2.050946   \n","Wachter                     1.0   0.098075     1.678       0.87  1.446714   \n","ActionableRecourse        0.759   7.793444       0.0   0.030303  2.125164   \n","CCHVAE                    0.839   1.084509  4.222884   6.845054  3.957042   \n","Face                        1.0   8.375337     4.528      5.905  4.281271   \n","UserPreferred             0.818   0.673386       0.0   0.551345  1.788162   \n","\n","                    Sparsity  \n","GrowingSpheres      5.854589  \n","Wachter                5.802  \n","ActionableRecourse  2.309618  \n","CCHVAE              9.462455  \n","Face                   7.807  \n","UserPreferred       2.876528  "],"text/html":["\n","  <div id=\"df-3c7da953-5d75-4590-84ee-e98fab25e128\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>GrowingSpheres</th>\n","      <td>0.839</td>\n","      <td>0.04254</td>\n","      <td>0.0</td>\n","      <td>1.762813</td>\n","      <td>2.050946</td>\n","      <td>5.854589</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter</th>\n","      <td>1.0</td>\n","      <td>0.098075</td>\n","      <td>1.678</td>\n","      <td>0.87</td>\n","      <td>1.446714</td>\n","      <td>5.802</td>\n","    </tr>\n","    <tr>\n","      <th>ActionableRecourse</th>\n","      <td>0.759</td>\n","      <td>7.793444</td>\n","      <td>0.0</td>\n","      <td>0.030303</td>\n","      <td>2.125164</td>\n","      <td>2.309618</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE</th>\n","      <td>0.839</td>\n","      <td>1.084509</td>\n","      <td>4.222884</td>\n","      <td>6.845054</td>\n","      <td>3.957042</td>\n","      <td>9.462455</td>\n","    </tr>\n","    <tr>\n","      <th>Face</th>\n","      <td>1.0</td>\n","      <td>8.375337</td>\n","      <td>4.528</td>\n","      <td>5.905</td>\n","      <td>4.281271</td>\n","      <td>7.807</td>\n","    </tr>\n","    <tr>\n","      <th>UserPreferred</th>\n","      <td>0.818</td>\n","      <td>0.673386</td>\n","      <td>0.0</td>\n","      <td>0.551345</td>\n","      <td>1.788162</td>\n","      <td>2.876528</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-3c7da953-5d75-4590-84ee-e98fab25e128')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-3c7da953-5d75-4590-84ee-e98fab25e128 button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-3c7da953-5d75-4590-84ee-e98fab25e128');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":6}]},{"cell_type":"markdown","source":["# 2- Heloc\n"],"metadata":{"id":"k4H5qYbHtug-"}},{"cell_type":"markdown","source":["### Nonlinear"],"metadata":{"id":"TXuIbsxlozaZ"}},{"cell_type":"code","source":["%cd drive_path + 'CARLA-new_eval/'\n","\n","import numpy as np\n","import pandas as pd\n","\n","results_files = [#drive_path + 'results/heloc/results_ActionableRecourse_heloc_nonlinear.csv',\n","                 drive_path + 'results/heloc/results_UserPreferred_heloc_nonlinear.csv',\n","                 drive_path + 'results/heloc/results_CCHVAE_heloc_nonlinear.csv',\n","                 drive_path + 'results/heloc/results_Clue_heloc_nonlinear.csv',\n","                 drive_path + 'results/heloc/results_GrowingSpheres_heloc_nonlinear.csv',\n","                 drive_path + 'results/heloc/results_Face_heloc_nonlinear.csv',\n","                 drive_path + 'results/heloc/results_Wachter_heloc_nonlinear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/heloc/results_UserPreferred_heloc_nonlinear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_heloc')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_heloc')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Nonlinear Results (Heloc):')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":273},"id":"fGoMxh9qY8lE","executionInfo":{"status":"ok","timestamp":1660369824272,"user_tz":420,"elapsed":688,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"012050c5-d5da-452e-c35e-df714702b195"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["/content/gdrive/.shortcut-targets-by-id/1HG3Y-0h1cVshzcZzZ87DncQjsPaVpbJe/jayanth-recourse/CARLA-new_eval\n","Nonlinear Results (Heloc):\n"]},{"output_type":"execute_result","data":{"text/plain":["               Success_Rate Time_taken Cstr_Vio Redundancy   Proximity  \\\n","UserPreferred         0.282   0.463697      0.0   1.248227   59.424793   \n","CCHVAE                  1.0   0.667134     16.0        9.8    7.172777   \n","Clue                    1.0   1.634717     16.0       19.8   10.162535   \n","GrowingSpheres          1.0   0.280792      0.0      0.392   33.191641   \n","Face                    1.0   0.724254     12.9       13.4    3.767942   \n","Wachter               0.276   2.428692     16.0   2.478261  169.699941   \n","\n","                 Sparsity  \n","UserPreferred    5.716312  \n","CCHVAE               21.8  \n","Clue                 21.8  \n","GrowingSpheres      5.608  \n","Face                 18.4  \n","Wachter         21.731884  "],"text/html":["\n","  <div id=\"df-3734b31b-9c51-4aaf-b299-7550ae0c0afb\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>UserPreferred</th>\n","      <td>0.282</td>\n","      <td>0.463697</td>\n","      <td>0.0</td>\n","      <td>1.248227</td>\n","      <td>59.424793</td>\n","      <td>5.716312</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE</th>\n","      <td>1.0</td>\n","      <td>0.667134</td>\n","      <td>16.0</td>\n","      <td>9.8</td>\n","      <td>7.172777</td>\n","      <td>21.8</td>\n","    </tr>\n","    <tr>\n","      <th>Clue</th>\n","      <td>1.0</td>\n","      <td>1.634717</td>\n","      <td>16.0</td>\n","      <td>19.8</td>\n","      <td>10.162535</td>\n","      <td>21.8</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres</th>\n","      <td>1.0</td>\n","      <td>0.280792</td>\n","      <td>0.0</td>\n","      <td>0.392</td>\n","      <td>33.191641</td>\n","      <td>5.608</td>\n","    </tr>\n","    <tr>\n","      <th>Face</th>\n","      <td>1.0</td>\n","      <td>0.724254</td>\n","      <td>12.9</td>\n","      <td>13.4</td>\n","      <td>3.767942</td>\n","      <td>18.4</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter</th>\n","      <td>0.276</td>\n","      <td>2.428692</td>\n","      <td>16.0</td>\n","      <td>2.478261</td>\n","      <td>169.699941</td>\n","      <td>21.731884</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-3734b31b-9c51-4aaf-b299-7550ae0c0afb')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-3734b31b-9c51-4aaf-b299-7550ae0c0afb button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-3734b31b-9c51-4aaf-b299-7550ae0c0afb');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":11}]},{"cell_type":"markdown","source":["### Linear"],"metadata":{"id":"jiNPuJPOpO7s"}},{"cell_type":"code","source":["%cd drive_path + 'CARLA-new_eval/'\n","\n","import numpy as np\n","import pandas as pd\n","\n","results_files = [#drive_path + 'results/heloc/results_ActionableRecourse_heloc_linear.csv',\n","                 drive_path + 'results/heloc/results_UserPreferred_heloc_linear.csv',\n","                #  drive_path + 'results/heloc/results_CCHVAE_heloc_linear.csv',\n","                 drive_path + 'results/heloc/results_Clue_heloc_linear.csv',\n","                 drive_path + 'results/heloc/results_GrowingSpheres_heloc_linear.csv',\n","                 drive_path + 'results/heloc/results_Face_heloc_linear.csv',\n","                 drive_path + 'results/heloc/results_Wachter_heloc_linear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/heloc/results_UserPreferred_heloc_linear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_heloc')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_heloc')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Nonlinear Results (Heloc):')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":242},"id":"0dSe3FvhMJfM","executionInfo":{"status":"ok","timestamp":1660427595756,"user_tz":420,"elapsed":1632,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"eeb78c3e-d97f-4d90-a77e-3f76021ca5c4"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["/content/gdrive/.shortcut-targets-by-id/1HG3Y-0h1cVshzcZzZ87DncQjsPaVpbJe/jayanth-recourse/CARLA-new_eval\n","Nonlinear Results (Heloc):\n"]},{"output_type":"execute_result","data":{"text/plain":["               Success_Rate Time_taken Cstr_Vio Redundancy Proximity  \\\n","UserPreferred           1.0   0.049458      0.0      0.364    1.3178   \n","Clue                  0.266    1.67008     16.0   20.37594  6.908758   \n","GrowingSpheres        0.604   0.031093      0.0   1.274834    1.7387   \n","Face                    1.0   0.819713   12.912     15.184  3.275965   \n","Wachter                 1.0   0.043089    9.664     10.006  1.187016   \n","\n","                 Sparsity  \n","UserPreferred       2.626  \n","Clue            21.699248  \n","GrowingSpheres   5.768212  \n","Face               17.998  \n","Wachter            13.292  "],"text/html":["\n","  <div id=\"df-3ef15efe-23c6-4e01-92a1-e1da163863e5\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>UserPreferred</th>\n","      <td>1.0</td>\n","      <td>0.049458</td>\n","      <td>0.0</td>\n","      <td>0.364</td>\n","      <td>1.3178</td>\n","      <td>2.626</td>\n","    </tr>\n","    <tr>\n","      <th>Clue</th>\n","      <td>0.266</td>\n","      <td>1.67008</td>\n","      <td>16.0</td>\n","      <td>20.37594</td>\n","      <td>6.908758</td>\n","      <td>21.699248</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres</th>\n","      <td>0.604</td>\n","      <td>0.031093</td>\n","      <td>0.0</td>\n","      <td>1.274834</td>\n","      <td>1.7387</td>\n","      <td>5.768212</td>\n","    </tr>\n","    <tr>\n","      <th>Face</th>\n","      <td>1.0</td>\n","      <td>0.819713</td>\n","      <td>12.912</td>\n","      <td>15.184</td>\n","      <td>3.275965</td>\n","      <td>17.998</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter</th>\n","      <td>1.0</td>\n","      <td>0.043089</td>\n","      <td>9.664</td>\n","      <td>10.006</td>\n","      <td>1.187016</td>\n","      <td>13.292</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-3ef15efe-23c6-4e01-92a1-e1da163863e5')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-3ef15efe-23c6-4e01-92a1-e1da163863e5 button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-3ef15efe-23c6-4e01-92a1-e1da163863e5');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":8}]},{"cell_type":"markdown","source":["# 3 - Give Me Some Credit\n"],"metadata":{"id":"KCjvcadKxTz4"}},{"cell_type":"markdown","source":["### Nonlinear"],"metadata":{"id":"TnlXplqBolCE"}},{"cell_type":"code","source":["import numpy as np\n","import pandas as pd\n","\n","results_files = [drive_path + 'results/credit/results_ActionableRecourse_give_me_some_credit_nonlinear.csv',\n","                 drive_path + 'results/credit/results_UserPreferred_give_me_some_credit_nonlinear.csv',\n","                 drive_path + 'results/credit/results_CCHVAE_give_me_some_credit_nonlinear.csv',\n","                 drive_path + 'results/credit/results_Clue_give_me_some_credit_nonlinear.csv',\n","                 drive_path + 'results/credit/results_GrowingSpheres_give_me_some_credit_nonlinear.csv',\n","                 drive_path + 'results/credit/results_Face_give_me_some_credit_nonlinear.csv',\n","                 drive_path + 'results/credit/results_Wachter_give_me_some_credit_nonlinear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/credit/results_UserPreferred_give_me_some_credit_nonlinear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_heloc')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_heloc')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Nonlinear Results (Credit):')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":287},"id":"9ssrKE6axVhI","executionInfo":{"status":"ok","timestamp":1664157875294,"user_tz":420,"elapsed":3678,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"684d97c1-ba67-47d2-9cf6-90b72edead25"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Nonlinear Results (Credit):\n"]},{"output_type":"execute_result","data":{"text/plain":["                                                   Success_Rate Time_taken  \\\n","ActionableRecourse_give_me_some_credit_nonlinea...        0.025   0.447726   \n","UserPreferred_give_me_some_credit_nonlinear.csv        0.942205   0.076955   \n","CCHVAE_give_me_some_credit_nonlinear.csv                    1.0   1.047135   \n","Clue_give_me_some_credit_nonlinear.csv                    0.744   1.154762   \n","GrowingSpheres_give_me_some_credit_nonlinear.csv          0.746   0.023755   \n","Face_give_me_some_credit_nonlinear.csv                      1.0   8.053234   \n","Wachter_give_me_some_credit_nonlinear.csv                   1.0   0.028522   \n","\n","                                                   Cstr_Vio Redundancy  \\\n","ActionableRecourse_give_me_some_credit_nonlinea...      0.0        0.0   \n","UserPreferred_give_me_some_credit_nonlinear.csv         0.0   1.301985   \n","CCHVAE_give_me_some_credit_nonlinear.csv                2.0      9.988   \n","Clue_give_me_some_credit_nonlinear.csv                  2.0   9.427419   \n","GrowingSpheres_give_me_some_credit_nonlinear.csv        0.0   6.954424   \n","Face_give_me_some_credit_nonlinear.csv                1.572       6.65   \n","Wachter_give_me_some_credit_nonlinear.csv             1.492      6.842   \n","\n","                                                   Proximity  Sparsity  \n","ActionableRecourse_give_me_some_credit_nonlinea...  0.165793      1.72  \n","UserPreferred_give_me_some_credit_nonlinear.csv     0.491436  3.222258  \n","CCHVAE_give_me_some_credit_nonlinear.csv            1.149194    10.058  \n","Clue_give_me_some_credit_nonlinear.csv              2.112163      11.0  \n","GrowingSpheres_give_me_some_credit_nonlinear.csv     1.01358  8.892761  \n","Face_give_me_some_credit_nonlinear.csv               1.19878      6.69  \n","Wachter_give_me_some_credit_nonlinear.csv            1.07909      8.46  "],"text/html":["\n","  <div id=\"df-8296c60a-ed85-4d5d-a3d6-152d29b63879\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>ActionableRecourse_give_me_some_credit_nonlinear.csv</th>\n","      <td>0.025</td>\n","      <td>0.447726</td>\n","      <td>0.0</td>\n","      <td>0.0</td>\n","      <td>0.165793</td>\n","      <td>1.72</td>\n","    </tr>\n","    <tr>\n","      <th>UserPreferred_give_me_some_credit_nonlinear.csv</th>\n","      <td>0.942205</td>\n","      <td>0.076955</td>\n","      <td>0.0</td>\n","      <td>1.301985</td>\n","      <td>0.491436</td>\n","      <td>3.222258</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE_give_me_some_credit_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>1.047135</td>\n","      <td>2.0</td>\n","      <td>9.988</td>\n","      <td>1.149194</td>\n","      <td>10.058</td>\n","    </tr>\n","    <tr>\n","      <th>Clue_give_me_some_credit_nonlinear.csv</th>\n","      <td>0.744</td>\n","      <td>1.154762</td>\n","      <td>2.0</td>\n","      <td>9.427419</td>\n","      <td>2.112163</td>\n","      <td>11.0</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres_give_me_some_credit_nonlinear.csv</th>\n","      <td>0.746</td>\n","      <td>0.023755</td>\n","      <td>0.0</td>\n","      <td>6.954424</td>\n","      <td>1.01358</td>\n","      <td>8.892761</td>\n","    </tr>\n","    <tr>\n","      <th>Face_give_me_some_credit_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>8.053234</td>\n","      <td>1.572</td>\n","      <td>6.65</td>\n","      <td>1.19878</td>\n","      <td>6.69</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter_give_me_some_credit_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>0.028522</td>\n","      <td>1.492</td>\n","      <td>6.842</td>\n","      <td>1.07909</td>\n","      <td>8.46</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-8296c60a-ed85-4d5d-a3d6-152d29b63879')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-8296c60a-ed85-4d5d-a3d6-152d29b63879 button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-8296c60a-ed85-4d5d-a3d6-152d29b63879');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":2}]},{"cell_type":"markdown","source":["### Linear"],"metadata":{"id":"yImJfQkPpI7E"}},{"cell_type":"code","source":["import numpy as np\n","import pandas as pd\n","\n","results_files = [drive_path + 'results/credit/results_ActionableRecourse_give_me_some_credit_linear.csv',\n","                 drive_path + 'results/credit/results_UserPreferred_give_me_some_credit_linear.csv',\n","                 drive_path + 'results/credit/results_CCHVAE_give_me_some_credit_linear.csv',\n","                 drive_path + 'results/credit/results_Clue_give_me_some_credit_linear.csv',\n","                 drive_path + 'results/credit/results_GrowingSpheres_give_me_some_credit_linear.csv',\n","                 drive_path + 'results/credit/results_Face_give_me_some_credit_linear.csv',\n","                 drive_path + 'results/credit/results_Wachter_give_me_some_credit_linear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/credit/results_UserPreferred_give_me_some_credit_linear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_heloc')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_heloc')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Linear Results (Credit):')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":287},"id":"5iLe3ijOG3LX","executionInfo":{"status":"ok","timestamp":1664157878796,"user_tz":420,"elapsed":2610,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"bf4ce349-5767-4517-ebdc-b47ac2c7983d"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Linear Results (Credit):\n"]},{"output_type":"execute_result","data":{"text/plain":["                                                  Success_Rate Time_taken  \\\n","ActionableRecourse_give_me_some_credit_linear.csv     0.169231   0.727366   \n","UserPreferred_give_me_some_credit_linear.csv               1.0    0.12952   \n","CCHVAE_give_me_some_credit_linear.csv                      1.0   1.371132   \n","Clue_give_me_some_credit_linear.csv                      0.618   0.981064   \n","GrowingSpheres_give_me_some_credit_linear.csv            0.618   0.028211   \n","Face_give_me_some_credit_linear.csv                        1.0  11.915268   \n","Wachter_give_me_some_credit_linear.csv                     1.0   0.030072   \n","\n","                                                  Cstr_Vio Redundancy  \\\n","ActionableRecourse_give_me_some_credit_linear.csv      0.0        0.0   \n","UserPreferred_give_me_some_credit_linear.csv           0.0   1.470538   \n","CCHVAE_give_me_some_credit_linear.csv                  2.0       8.64   \n","Clue_give_me_some_credit_linear.csv                    2.0   7.925566   \n","GrowingSpheres_give_me_some_credit_linear.csv          0.0   4.080906   \n","Face_give_me_some_credit_linear.csv                  1.648      7.468   \n","Wachter_give_me_some_credit_linear.csv               1.236      3.506   \n","\n","                                                  Proximity  Sparsity  \n","ActionableRecourse_give_me_some_credit_linear.csv  0.932942  1.909091  \n","UserPreferred_give_me_some_credit_linear.csv       0.681942  3.927148  \n","CCHVAE_give_me_some_credit_linear.csv              2.051528      11.0  \n","Clue_give_me_some_credit_linear.csv                2.103443      11.0  \n","GrowingSpheres_give_me_some_credit_linear.csv      1.394841  8.993528  \n","Face_give_me_some_credit_linear.csv                2.304352     8.446  \n","Wachter_give_me_some_credit_linear.csv             1.420763      7.18  "],"text/html":["\n","  <div id=\"df-176d5451-87d4-430e-a62c-892a68dbf8ab\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>ActionableRecourse_give_me_some_credit_linear.csv</th>\n","      <td>0.169231</td>\n","      <td>0.727366</td>\n","      <td>0.0</td>\n","      <td>0.0</td>\n","      <td>0.932942</td>\n","      <td>1.909091</td>\n","    </tr>\n","    <tr>\n","      <th>UserPreferred_give_me_some_credit_linear.csv</th>\n","      <td>1.0</td>\n","      <td>0.12952</td>\n","      <td>0.0</td>\n","      <td>1.470538</td>\n","      <td>0.681942</td>\n","      <td>3.927148</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE_give_me_some_credit_linear.csv</th>\n","      <td>1.0</td>\n","      <td>1.371132</td>\n","      <td>2.0</td>\n","      <td>8.64</td>\n","      <td>2.051528</td>\n","      <td>11.0</td>\n","    </tr>\n","    <tr>\n","      <th>Clue_give_me_some_credit_linear.csv</th>\n","      <td>0.618</td>\n","      <td>0.981064</td>\n","      <td>2.0</td>\n","      <td>7.925566</td>\n","      <td>2.103443</td>\n","      <td>11.0</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres_give_me_some_credit_linear.csv</th>\n","      <td>0.618</td>\n","      <td>0.028211</td>\n","      <td>0.0</td>\n","      <td>4.080906</td>\n","      <td>1.394841</td>\n","      <td>8.993528</td>\n","    </tr>\n","    <tr>\n","      <th>Face_give_me_some_credit_linear.csv</th>\n","      <td>1.0</td>\n","      <td>11.915268</td>\n","      <td>1.648</td>\n","      <td>7.468</td>\n","      <td>2.304352</td>\n","      <td>8.446</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter_give_me_some_credit_linear.csv</th>\n","      <td>1.0</td>\n","      <td>0.030072</td>\n","      <td>1.236</td>\n","      <td>3.506</td>\n","      <td>1.420763</td>\n","      <td>7.18</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-176d5451-87d4-430e-a62c-892a68dbf8ab')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-176d5451-87d4-430e-a62c-892a68dbf8ab button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-176d5451-87d4-430e-a62c-892a68dbf8ab');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":3}]},{"cell_type":"markdown","source":["# 4 - Compas"],"metadata":{"id":"3ninVlX1k2o3"}},{"cell_type":"markdown","source":["### Nonlinear"],"metadata":{"id":"1GW_0L7RovmY"}},{"cell_type":"code","source":["%cd drive_path + 'CARLA-new_eval/'\n","\n","import numpy as np\n","import pandas as pd\n","\n","results_files = [drive_path + 'results/compas/results_ActionableRecourse_compas_nonlinear.csv',\n","                 drive_path + 'results/compas/results_UserPreferred_compas_nonlinear.csv',\n","                 drive_path + 'results/compas/results_CCHVAE_compas_nonlinear.csv',\n","                 drive_path + 'results/compas/results_Clue_compas_nonlinear.csv',\n","                 drive_path + 'results/compas/results_GrowingSpheres_compas_nonlinear.csv',\n","                 drive_path + 'results/compas/results_Face_compas_nonlinear.csv',\n","                 drive_path + 'results/compas/results_Wachter_compas_nonlinear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/compas/results_UserPreferred_compas_nonlinear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_heloc')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_heloc')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Nonlinear Results (compas):')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":305},"id":"LuBHW07wxVkI","executionInfo":{"status":"ok","timestamp":1664162118810,"user_tz":420,"elapsed":2104,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"1631fa90-5fc3-4c7d-8d55-b66731b786a4"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["/content/gdrive/.shortcut-targets-by-id/1HG3Y-0h1cVshzcZzZ87DncQjsPaVpbJe/jayanth-recourse/CARLA-new_eval\n","Nonlinear Results (compas):\n"]},{"output_type":"execute_result","data":{"text/plain":["                                        Success_Rate Time_taken  Cstr_Vio  \\\n","ActionableRecourse_compas_nonlinear.csv     0.648045    0.19941       0.0   \n","UserPreferred_compas_nonlinear.csv          0.923775   0.035114       0.0   \n","CCHVAE_compas_nonlinear.csv                      1.0   5.087444  2.268156   \n","Clue_compas_nonlinear.csv                        1.0   1.439444  1.231844   \n","GrowingSpheres_compas_nonlinear.csv              1.0   0.028793       0.0   \n","Face_compas_nonlinear.csv                        1.0   0.365641  2.385047   \n","Wachter_compas_nonlinear.csv                     1.0   0.051388       1.0   \n","\n","                                        Redundancy Proximity  Sparsity  \n","ActionableRecourse_compas_nonlinear.csv        0.0  0.779188  0.903017  \n","UserPreferred_compas_nonlinear.csv        0.599214  0.633233  1.823183  \n","CCHVAE_compas_nonlinear.csv               4.308659  1.699539  4.913408  \n","Clue_compas_nonlinear.csv                 3.914804  1.477283  4.642458  \n","GrowingSpheres_compas_nonlinear.csv       1.092179  0.473718  3.354749  \n","Face_compas_nonlinear.csv                 3.962617   2.34867  4.715888  \n","Wachter_compas_nonlinear.csv              1.613128  0.558033  4.353352  "],"text/html":["\n","  <div id=\"df-4fdfe7ab-3ff2-4d9f-9cbe-f63a97fdc1b1\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>ActionableRecourse_compas_nonlinear.csv</th>\n","      <td>0.648045</td>\n","      <td>0.19941</td>\n","      <td>0.0</td>\n","      <td>0.0</td>\n","      <td>0.779188</td>\n","      <td>0.903017</td>\n","    </tr>\n","    <tr>\n","      <th>UserPreferred_compas_nonlinear.csv</th>\n","      <td>0.923775</td>\n","      <td>0.035114</td>\n","      <td>0.0</td>\n","      <td>0.599214</td>\n","      <td>0.633233</td>\n","      <td>1.823183</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE_compas_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>5.087444</td>\n","      <td>2.268156</td>\n","      <td>4.308659</td>\n","      <td>1.699539</td>\n","      <td>4.913408</td>\n","    </tr>\n","    <tr>\n","      <th>Clue_compas_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>1.439444</td>\n","      <td>1.231844</td>\n","      <td>3.914804</td>\n","      <td>1.477283</td>\n","      <td>4.642458</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres_compas_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>0.028793</td>\n","      <td>0.0</td>\n","      <td>1.092179</td>\n","      <td>0.473718</td>\n","      <td>3.354749</td>\n","    </tr>\n","    <tr>\n","      <th>Face_compas_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>0.365641</td>\n","      <td>2.385047</td>\n","      <td>3.962617</td>\n","      <td>2.34867</td>\n","      <td>4.715888</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter_compas_nonlinear.csv</th>\n","      <td>1.0</td>\n","      <td>0.051388</td>\n","      <td>1.0</td>\n","      <td>1.613128</td>\n","      <td>0.558033</td>\n","      <td>4.353352</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-4fdfe7ab-3ff2-4d9f-9cbe-f63a97fdc1b1')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-4fdfe7ab-3ff2-4d9f-9cbe-f63a97fdc1b1 button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-4fdfe7ab-3ff2-4d9f-9cbe-f63a97fdc1b1');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":4}]},{"cell_type":"markdown","source":["### Linear"],"metadata":{"id":"nclaWrpipG0e"}},{"cell_type":"code","source":["%cd drive_path + 'CARLA-new_eval/'\n","\n","\n","import numpy as np\n","import pandas as pd\n","\n","results_files = [drive_path + 'results/compas/results_ActionableRecourse_compas_linear.csv',\n","                 drive_path + 'results/compas/results_UserPreferred_compas_linear.csv',\n","                 drive_path + 'results/compas/results_CCHVAE_compas_linear.csv',\n","                 drive_path + 'results/compas/results_Clue_compas_linear.csv',\n","                 drive_path + 'results/compas/results_GrowingSpheres_compas_linear.csv',\n","                 drive_path + 'results/compas/results_Face_compas_linear.csv',\n","                 drive_path + 'results/compas/results_Wachter_compas_linear.csv'\n","                ]\n","\n","df = pd.read_csv(drive_path + 'results/compas/results_UserPreferred_compas_linear.csv').drop('Unnamed: 0', axis=1)\n","summary = df.describe()\n","\n","new_cols = []\n","for col in summary.columns:\n","    new_cols.append('{}'.format(col))\n","    #new_cols.append('{}_std'.format(col))\n","recourse_types = [i.split('results_')[1].split('_heloc')[0] for i in results_files]\n","total_summary_df = pd.DataFrame(columns = new_cols, index = recourse_types)\n","for file in results_files:\n","    df = pd.read_csv(file).drop('Unnamed: 0', axis=1)\n","    summary = df.describe()\n","    for col in summary:\n","        total_summary_df.loc[file.split('results_')[1].split('_heloc')[0]][col] = summary.loc['mean'][col]\n","        #total_summary_df.loc[file.split('_run_')[0]][col+'_std'] = summary.loc['std'][col]\n","desired_cols = ['Success_Rate',\n","                'Time_taken',\n","                'Cstr_Vio',\n","                'Redundancy',\n","                'Proximity',\n","                'Sparsity'\n","                ]\n","print('Linear Results (compas):')\n","total_summary_df[desired_cols]\n","                 \n","                 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":305},"id":"jWqDlBeaxVnB","executionInfo":{"status":"ok","timestamp":1663570238771,"user_tz":420,"elapsed":2239,"user":{"displayName":"Ian Hardy","userId":"01608928063074550753"}},"outputId":"7dfd93c8-c014-43f6-c753-a74e555f27dd"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["/content/gdrive/.shortcut-targets-by-id/1HG3Y-0h1cVshzcZzZ87DncQjsPaVpbJe/jayanth-recourse/CARLA-new_eval\n","Linear Results (compas):\n"]},{"output_type":"execute_result","data":{"text/plain":["                                     Success_Rate Time_taken  Cstr_Vio  \\\n","ActionableRecourse_compas_linear.csv     0.516917   0.247402       0.0   \n","UserPreferred_compas_linear.csv          0.996212   0.045877       0.0   \n","CCHVAE_compas_linear.csv                      1.0   0.050488  1.620301   \n","Clue_compas_linear.csv                      0.037   1.113647  2.081081   \n","GrowingSpheres_compas_linear.csv              1.0   0.037855       0.0   \n","Face_compas_linear.csv                        1.0   0.401964  2.473684   \n","Wachter_compas_linear.csv                     1.0   0.036913       1.0   \n","\n","                                     Redundancy Proximity  Sparsity  \n","ActionableRecourse_compas_linear.csv        0.0  1.442862  1.570909  \n","UserPreferred_compas_linear.csv        0.809886  0.816945  2.735741  \n","CCHVAE_compas_linear.csv               2.684211  1.738195  4.917293  \n","Clue_compas_linear.csv                 5.243243  2.899829  5.540541  \n","GrowingSpheres_compas_linear.csv       0.342657  1.128636  3.979021  \n","Face_compas_linear.csv                 4.385338  2.465532  4.808271  \n","Wachter_compas_linear.csv              0.853147  1.063662  4.832168  "],"text/html":["\n","  <div id=\"df-1f395201-28c1-429c-a39d-20dc35bba44f\">\n","    <div class=\"colab-df-container\">\n","      <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>Success_Rate</th>\n","      <th>Time_taken</th>\n","      <th>Cstr_Vio</th>\n","      <th>Redundancy</th>\n","      <th>Proximity</th>\n","      <th>Sparsity</th>\n","    </tr>\n","  </thead>\n","  <tbody>\n","    <tr>\n","      <th>ActionableRecourse_compas_linear.csv</th>\n","      <td>0.516917</td>\n","      <td>0.247402</td>\n","      <td>0.0</td>\n","      <td>0.0</td>\n","      <td>1.442862</td>\n","      <td>1.570909</td>\n","    </tr>\n","    <tr>\n","      <th>UserPreferred_compas_linear.csv</th>\n","      <td>0.996212</td>\n","      <td>0.045877</td>\n","      <td>0.0</td>\n","      <td>0.809886</td>\n","      <td>0.816945</td>\n","      <td>2.735741</td>\n","    </tr>\n","    <tr>\n","      <th>CCHVAE_compas_linear.csv</th>\n","      <td>1.0</td>\n","      <td>0.050488</td>\n","      <td>1.620301</td>\n","      <td>2.684211</td>\n","      <td>1.738195</td>\n","      <td>4.917293</td>\n","    </tr>\n","    <tr>\n","      <th>Clue_compas_linear.csv</th>\n","      <td>0.037</td>\n","      <td>1.113647</td>\n","      <td>2.081081</td>\n","      <td>5.243243</td>\n","      <td>2.899829</td>\n","      <td>5.540541</td>\n","    </tr>\n","    <tr>\n","      <th>GrowingSpheres_compas_linear.csv</th>\n","      <td>1.0</td>\n","      <td>0.037855</td>\n","      <td>0.0</td>\n","      <td>0.342657</td>\n","      <td>1.128636</td>\n","      <td>3.979021</td>\n","    </tr>\n","    <tr>\n","      <th>Face_compas_linear.csv</th>\n","      <td>1.0</td>\n","      <td>0.401964</td>\n","      <td>2.473684</td>\n","      <td>4.385338</td>\n","      <td>2.465532</td>\n","      <td>4.808271</td>\n","    </tr>\n","    <tr>\n","      <th>Wachter_compas_linear.csv</th>\n","      <td>1.0</td>\n","      <td>0.036913</td>\n","      <td>1.0</td>\n","      <td>0.853147</td>\n","      <td>1.063662</td>\n","      <td>4.832168</td>\n","    </tr>\n","  </tbody>\n","</table>\n","</div>\n","      <button class=\"colab-df-convert\" onclick=\"convertToInteractive('df-1f395201-28c1-429c-a39d-20dc35bba44f')\"\n","              title=\"Convert this dataframe to an interactive table.\"\n","              style=\"display:none;\">\n","        \n","  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\"viewBox=\"0 0 24 24\"\n","       width=\"24px\">\n","    <path d=\"M0 0h24v24H0V0z\" fill=\"none\"/>\n","    <path d=\"M18.56 5.44l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94zm-11 1L8.5 8.5l.94-2.06 2.06-.94-2.06-.94L8.5 2.5l-.94 2.06-2.06.94zm10 10l.94 2.06.94-2.06 2.06-.94-2.06-.94-.94-2.06-.94 2.06-2.06.94z\"/><path d=\"M17.41 7.96l-1.37-1.37c-.4-.4-.92-.59-1.43-.59-.52 0-1.04.2-1.43.59L10.3 9.45l-7.72 7.72c-.78.78-.78 2.05 0 2.83L4 21.41c.39.39.9.59 1.41.59.51 0 1.02-.2 1.41-.59l7.78-7.78 2.81-2.81c.8-.78.8-2.07 0-2.86zM5.41 20L4 18.59l7.72-7.72 1.47 1.35L5.41 20z\"/>\n","  </svg>\n","      </button>\n","      \n","  <style>\n","    .colab-df-container {\n","      display:flex;\n","      flex-wrap:wrap;\n","      gap: 12px;\n","    }\n","\n","    .colab-df-convert {\n","      background-color: #E8F0FE;\n","      border: none;\n","      border-radius: 50%;\n","      cursor: pointer;\n","      display: none;\n","      fill: #1967D2;\n","      height: 32px;\n","      padding: 0 0 0 0;\n","      width: 32px;\n","    }\n","\n","    .colab-df-convert:hover {\n","      background-color: #E2EBFA;\n","      box-shadow: 0px 1px 2px rgba(60, 64, 67, 0.3), 0px 1px 3px 1px rgba(60, 64, 67, 0.15);\n","      fill: #174EA6;\n","    }\n","\n","    [theme=dark] .colab-df-convert {\n","      background-color: #3B4455;\n","      fill: #D2E3FC;\n","    }\n","\n","    [theme=dark] .colab-df-convert:hover {\n","      background-color: #434B5C;\n","      box-shadow: 0px 1px 3px 1px rgba(0, 0, 0, 0.15);\n","      filter: drop-shadow(0px 1px 2px rgba(0, 0, 0, 0.3));\n","      fill: #FFFFFF;\n","    }\n","  </style>\n","\n","      <script>\n","        const buttonEl =\n","          document.querySelector('#df-1f395201-28c1-429c-a39d-20dc35bba44f button.colab-df-convert');\n","        buttonEl.style.display =\n","          google.colab.kernel.accessAllowed ? 'block' : 'none';\n","\n","        async function convertToInteractive(key) {\n","          const element = document.querySelector('#df-1f395201-28c1-429c-a39d-20dc35bba44f');\n","          const dataTable =\n","            await google.colab.kernel.invokeFunction('convertToInteractive',\n","                                                     [key], {});\n","          if (!dataTable) return;\n","\n","          const docLinkHtml = 'Like what you see? Visit the ' +\n","            '<a target=\"_blank\" href=https://colab.research.google.com/notebooks/data_table.ipynb>data table notebook</a>'\n","            + ' to learn more about interactive tables.';\n","          element.innerHTML = '';\n","          dataTable['output_type'] = 'display_data';\n","          await google.colab.output.renderOutput(dataTable, element);\n","          const docLink = document.createElement('div');\n","          docLink.innerHTML = docLinkHtml;\n","          element.appendChild(docLink);\n","        }\n","      </script>\n","    </div>\n","  </div>\n","  "]},"metadata":{},"execution_count":3}]},{"cell_type":"code","source":[],"metadata":{"id":"caJj7OnjxVqQ"},"execution_count":null,"outputs":[]}]}