{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e4051792",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from robustness_plot import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d70d19b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "============================================================\n",
      "OUTLIER CORRUPTION EXPERIMENT\n",
      "============================================================\n",
      "Device: cpu\n",
      "Dimension: 5\n",
      "Number of samples: 500\n",
      "Contamination levels: [0.01, 0.05, 0.1]\n",
      "Magnitude distance t: 0.001\n",
      "============================================================\n",
      "\n",
      "\n",
      "============================================================\n",
      "Processing epsilon = 0.01\n",
      "============================================================\n",
      "Number of outliers: 5\n",
      "Computing distances for each outlier radius...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing radii (ε=0.01): 100%|██████████| 29/29 [00:22<00:00,  1.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "============================================================\n",
      "Processing epsilon = 0.05\n",
      "============================================================\n",
      "Number of outliers: 25\n",
      "Computing distances for each outlier radius...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing radii (ε=0.05): 100%|██████████| 29/29 [00:07<00:00,  3.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "============================================================\n",
      "Processing epsilon = 0.1\n",
      "============================================================\n",
      "Number of outliers: 50\n",
      "Computing distances for each outlier radius...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing radii (ε=0.1): 100%|██████████| 29/29 [00:08<00:00,  3.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "All experiments completed!\n",
      "============================================================\n",
      "OUTLIER CORRUPTION EXPERIMENT\n",
      "============================================================\n",
      "Device: cpu\n",
      "Dimension: 5\n",
      "Number of samples: 500\n",
      "Contamination levels: [0.01, 0.05, 0.1]\n",
      "Magnitude distance t: 0.001\n",
      "============================================================\n",
      "\n",
      "\n",
      "============================================================\n",
      "Processing epsilon = 0.01\n",
      "============================================================\n",
      "Number of outliers: 5\n",
      "Computing distances for each outlier radius...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing radii (ε=0.01): 100%|██████████| 29/29 [00:09<00:00,  3.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "============================================================\n",
      "Processing epsilon = 0.05\n",
      "============================================================\n",
      "Number of outliers: 25\n",
      "Computing distances for each outlier radius...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing radii (ε=0.05): 100%|██████████| 29/29 [00:10<00:00,  2.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "============================================================\n",
      "Processing epsilon = 0.1\n",
      "============================================================\n",
      "Number of outliers: 50\n",
      "Computing distances for each outlier radius...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing radii (ε=0.1): 100%|██████████| 29/29 [00:08<00:00,  3.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "All experiments completed!\n",
      "Saved: outlier_plots/outlier_eps0.01_D5_n500_t0.001.pgf\n",
      "Saved: outlier_plots/outlier_eps0.01_D5_n500_t0.001.png\n",
      "Saved: outlier_plots/outlier_eps0.05_D5_n500_t0.001.pgf\n",
      "Saved: outlier_plots/outlier_eps0.05_D5_n500_t0.001.png\n",
      "Saved: outlier_plots/outlier_eps0.1_D5_n500_t0.001.pgf\n",
      "Saved: outlier_plots/outlier_eps0.1_D5_n500_t0.001.png\n",
      "Saved: outlier_plots/outlier_combined_D5_n500_t0.001.pgf\n",
      "Saved: outlier_plots/outlier_combined_D5_n500_t0.001.png\n",
      "\n",
      "============================================================\n",
      "SUMMARY STATISTICS\n",
      "============================================================\n",
      "\n",
      "============================================================\n",
      "Epsilon = 0.01\n",
      "============================================================\n",
      "\n",
      "Wasserstein Distance:\n",
      "  Min distance: 0.025624 (R=2)\n",
      "  Max distance: 9.992471 (R=1000)\n",
      "  Growth rate: 389.97x\n",
      "\n",
      "Magnitude Distance:\n",
      "  Min distance: 0.000003 (R=2)\n",
      "  Max distance: 1.399708 (R=950)\n",
      "  Growth rate: 417043.94x\n",
      "\n",
      "Relative sensitivity:\n",
      "  Magnitude/Wasserstein growth ratio: 1069.43\n",
      "\n",
      "============================================================\n",
      "Epsilon = 0.05\n",
      "============================================================\n",
      "\n",
      "Wasserstein Distance:\n",
      "  Min distance: 0.076850 (R=2)\n",
      "  Max distance: 49.919208 (R=1000)\n",
      "  Growth rate: 649.57x\n",
      "\n",
      "Magnitude Distance:\n",
      "  Min distance: 0.000036 (R=2)\n",
      "  Max distance: 2.508670 (R=1000)\n",
      "  Growth rate: 69986.00x\n",
      "\n",
      "Relative sensitivity:\n",
      "  Magnitude/Wasserstein growth ratio: 107.74\n",
      "\n",
      "============================================================\n",
      "Epsilon = 0.1\n",
      "============================================================\n",
      "\n",
      "Wasserstein Distance:\n",
      "  Min distance: 0.131387 (R=2)\n",
      "  Max distance: 99.829046 (R=1000)\n",
      "  Growth rate: 759.81x\n",
      "\n",
      "Magnitude Distance:\n",
      "  Min distance: 0.000066 (R=2)\n",
      "  Max distance: 2.743354 (R=1000)\n",
      "  Growth rate: 41828.24x\n",
      "\n",
      "Relative sensitivity:\n",
      "  Magnitude/Wasserstein growth ratio: 55.05\n",
      "\n",
      "============================================================\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Experiment parameters\n",
    "D = 5           # Dimension\n",
    "n = 500         # Number of samples\n",
    "epsilon_values = [0.01, 0.05, 0.1]  # Contamination level\n",
    "t = 0.001         # Scaling parameter for magnitude distance\n",
    "\n",
    "# Device selection (use 'cuda' for GPU, 'cpu' for CPU)\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "# Run experiment\n",
    "radii, wasserstein_distances, magnitude_distances = run_outlier_experiment(\n",
    "    D=D, \n",
    "    n=n, \n",
    "    epsilon_values=epsilon_values, \n",
    "    t=t, \n",
    "    device=device, \n",
    "    seed=42\n",
    ")\n",
    "\n",
    "\n",
    "# Run experiments\n",
    "results = run_outlier_experiment(D=D,\n",
    "    n=n,\n",
    "    epsilon_values=epsilon_values,\n",
    "    t=t, \n",
    "    device=device,\n",
    "    seed=42\n",
    "    )\n",
    "\n",
    "# Plot results\n",
    "plot_results(results, D=D, n=n, t=t, save_dir='outlier_plots')\n",
    "\n",
    "# Print statistics\n",
    "print_summary_statistics(results)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env_mag",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
