{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0f8980f-7564-4fb4-9ce0-4fb832c29fa6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8165644-5ccc-4bcb-8dda-8ad5cd35f9dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "random_seed = 42\n",
    "n_samples = 5\n",
    "n_resamples = 5"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70f66c37-ee71-4d3b-aa5a-19e88b486bbc",
   "metadata": {},
   "source": [
    "## Stacking Constraints of Different Types"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75b3eab9-a26f-4457-a8e9-91530bbe460b",
   "metadata": {},
   "outputs": [],
   "source": [
    "option1_path = f'experiment_data/adult_constraint_ablation/evaluation_results/collected_data_option1_{n_samples}_{n_resamples}_{random_seed}.npy'\n",
    "option1_baseline_path = f'experiment_data/adult_constraint_ablation/evaluation_results/collected_data_option1_{n_samples}_{n_resamples}_{random_seed}_baseline.npy'\n",
    "\n",
    "availability = []\n",
    "if os.path.isfile(option1_path):\n",
    "    availability.append(True)\n",
    "else:\n",
    "    availability.append(False)\n",
    "    print(f'Please run: run_adult_ablation.py --option 1 --n_samples {n_samples} --n_resamples {n_resamples} --random_seed {random_seed}')\n",
    "\n",
    "if os.path.isfile(option1_baseline_path):\n",
    "    availability.append(True)\n",
    "else:\n",
    "    availability.append(False)\n",
    "    print(f'Please run: run_adult_ablation.py --option 1 --n_samples {n_samples} --n_resamples {n_resamples} --random_seed {random_seed} --baseline_mode')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f4a7c250-38c2-461a-abf1-fbf17c13115e",
   "metadata": {},
   "outputs": [],
   "source": [
    "if all(availability):\n",
    "    collected_data = np.load(option1_path)\n",
    "    baseline_data = np.load(option1_baseline_path)\n",
    "    \n",
    "    mean_baseline = np.mean(baseline_data[0, :, :, :, 0], axis=(0, 1))\n",
    "    std_baseline = np.std(baseline_data[0, :, :, :, 0], axis=(0, 1))\n",
    "    print(f'Accuracy: ${100*mean_baseline[3]:.1f} \\pm {100*std_baseline[3]:.2f}$    DP Sex: ${mean_baseline[6]:.2f} \\pm {std_baseline[6]:.3f}$    Mean Age 30: ${mean_baseline[7]:.1f} \\pm {std_baseline[7]:.2f}$    Male-Female Age Diff.: ${mean_baseline[8]:.1f} \\pm {std_baseline[8]:.2f}$    I3: ${100*mean_baseline[9]:.1f} \\pm {100*std_baseline[9]:.2f}$    I2: ${100*mean_baseline[10]:.1f} \\pm {100*std_baseline[10]:.2f}$')\n",
    "    for comb in collected_data:\n",
    "        mean_comb = np.mean(comb[:, :, :, 0], axis=(0, 1))\n",
    "        std_comb = np.std(comb[:, :, :, 0], axis=(0, 1))\n",
    "        print(f'Accuracy: ${100*mean_comb[3]:.1f} \\pm {100*std_comb[3]:.2f}$    DP Sex: ${mean_comb[6]:.2f} \\pm {std_comb[6]:.3f}$    Mean Age 30: ${mean_comb[7]:.1f} \\pm {std_comb[7]:.2f}$    Male-Female Age Diff.: ${mean_comb[8]:.1f} \\pm {std_comb[8]:.2f}$    I3: ${100*mean_comb[9]:.1f} \\pm {100*std_comb[9]:.2f}$    I2: ${100*mean_comb[10]:.1f} \\pm {100*std_comb[10]:.2f}$')\n",
    "else:\n",
    "    print('Data could not be loaded, please see above which scripts were not ran')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b007e83e-9afd-46d3-9941-0dc6a87da36c",
   "metadata": {},
   "source": [
    "## Stacking Logical Constraints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e9a6a39-89cb-4304-a58a-eadb2c2f727b",
   "metadata": {},
   "outputs": [],
   "source": [
    "option2_path = f'experiment_data/adult_constraint_ablation/evaluation_results/collected_data_option2_{n_samples}_{n_resamples}_{random_seed}.npy'\n",
    "option2_baseline_path = f'experiment_data/adult_constraint_ablation/evaluation_results/collected_data_option2_{n_samples}_{n_resamples}_{random_seed}_baseline.npy'\n",
    "\n",
    "availability = []\n",
    "if os.path.isfile(option2_path):\n",
    "    availability.append(True)\n",
    "else:\n",
    "    availability.append(False)\n",
    "    print(f'Please run: run_adult_ablation.py --option 2 --n_samples {n_samples} --n_resamples {n_resamples} --random_seed {random_seed}')\n",
    "\n",
    "if os.path.isfile(option2_baseline_path):\n",
    "    availability.append(True)\n",
    "else:\n",
    "    availability.append(False)\n",
    "    print(f'Please run: run_adult_ablation.py --option 2 --n_samples {n_samples} --n_resamples {n_resamples} --random_seed {random_seed} --baseline_mode')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40a800f8-e628-4de9-ae97-170c0e65a493",
   "metadata": {},
   "outputs": [],
   "source": [
    "if all(availability):\n",
    "    collected_data = np.load(option2_path)\n",
    "    baseline_data = np.load(option2_baseline_path)\n",
    "    mean_baseline = np.mean(baseline_data[0, :, :, :, 0], axis=(0, 1))\n",
    "    std_baseline = np.std(baseline_data[0, :, :, :, 0], axis=(0, 1))\n",
    "    print(f'Accuracy: ${100*mean_baseline[3]:.1f} \\pm {100*std_baseline[3]:.1f}$    I1: {100*mean_baseline[6]:.1f}%    I2: {100*mean_baseline[7]:.1f}%    I3: {100*mean_baseline[8]:.1f}%    LC1: {100*mean_baseline[9]:.1f}%    LC2: {100*mean_baseline[10]:.1f}%')\n",
    "    for comb in collected_data:\n",
    "        mean_comb = np.mean(comb[:, :, :, 0], axis=(0, 1))\n",
    "        acc = mean_comb[3]\n",
    "        std_acc = np.std(comb[:, :, :, 0], axis=(0, 1))[3]\n",
    "        print(f'Accuracy: ${100*acc:.1f} \\pm {100*std_acc:.1f}$    I1: {100*mean_comb[6]:.1f}%    I2: {100*mean_comb[7]:.1f}%    I3: {100*mean_comb[8]:.1f}%    LC1: {100*mean_comb[9]:.1f}%    LC2: {100*mean_comb[10]:.1f}%')\n",
    "else:\n",
    "    print('Data could not be loaded, please see above which scripts were not ran')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "642a4822-3789-4ac4-a02f-1a01be9fc401",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
