Skip to content

[AAAI'23 Paper] A machine learning defense for auditors of black box automated decision-making systems.

Notifications You must be signed in to change notification settings

tutut834834/unfooling

 
 

Repository files navigation

Unfooling Perturbation-Based Post Hoc Explainers

Code for our paper, "Unfooling Perturbation-Based Post Hoc Explainers." Here, we provide a solution to the scaffolding-based adversarial attack on perturbation-based explainers. We propose a novel conditional anomaly detection algorithm to detect and defend against the attack.

Abstract:

Monumental advancements in artificial intelligence (AI) have lured the interest of doctors, lenders, judges, and other professionals. While these high-stakes decision-makers are optimistic about the technology, those familiar with AI systems are wary about the lack of transparency of its decision-making processes. Perturbation-based post hoc explainers offer a model agnostic means of interpreting these systems while only requiring query-level access. However, recent work demonstrates that these explainers can be fooled adversarially. This discovery has adverse implications for auditors, regulators, and other sentinels. With this in mind, several natural questions arise - how can we audit these black box systems? And how can we ascertain that the auditee is complying with the audit in good faith? In this work, we rigorously formalize this problem and devise a defense against adversarial attacks on perturbation-based explainers. We propose algorithms for the detection (CAD-Detect) and defense (CAD-Defend) of these attacks, which are aided by our novel conditional anomaly detection approach, KNN-CAD. We demonstrate that our approach successfully detects whether a black box system adversarially conceals its decision-making process and mitigates the adversarial attack on real-world data for the prevalent explainers, LIME and SHAP.

Note: We adapt the "fooling" portion of the code from Fooling-LIME-SHAP in this repository.

Installation

All required packages are listed in requirements.txt. This can be installed in a virtual environment using tools, such as virtualenv or conda.

Example of installation via pip:

pip install -r requirements.txt

Run Instructions

The approach can be run via the Jupyter Notebook run.ipynb. Jupyter Notebook is listed as a requirement and should be installed already. If you're in a virtual environment, ensure that you have generated a kernel for the environment. If you don't know what this mean, read this.

jupyter notebook run.ipynb

How to Cite This Work

(link) Zachariah Carmichael and Walter J. Scheirer. "Unfooling Perturbation-Based Post Hoc Explainers." Proceedings of the AAAI Conference on Artificial Intelligence, 2023.

BibTeX:

@inproceedings{CarmichaelUnfooling2023,
  title     = {Unfooling Perturbation-Based Post Hoc Explainers},
  author    = {Carmichael, Zachariah and Scheirer, Walter J.},
  year      = 2023,
  booktitle = {Proceedings of the {AAAI} Conference on Artificial Intelligence},
  publisher = {{AAAI} Press},
}

About

[AAAI'23 Paper] A machine learning defense for auditors of black box automated decision-making systems.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 90.8%
  • Jupyter Notebook 9.2%