Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a bias detector based on optimal transport #434

Merged
merged 26 commits into from
Jul 23, 2023

Conversation

jmarecek
Copy link
Contributor

There is an increasing interest in estimating bias in terms of Wasserstein-2 distances (or related distances between measures, often computable using optimal-transport algorithms), cf.
http://proceedings.mlr.press/v97/gordaliza19a.html (ICML 2019)
https://academic.oup.com/imaiai/article-abstract/8/4/817/5586771 (Information and Inference, 2019)
https://openreview.net/forum?id=-welFirjMss (NeurIPS 2022)
Following some discussions with Rahul Nair ([email protected]), we would like to contribute a new detector, with the same signature as the original mdss detector of @Adebayo-Oshingbesan:
https://github.com/Trusted-AI/AIF360/blob/master/aif360/detectors/mdss_detector.py

Could we ask @hoffmansc for a code review, please?

Closes #433

@hoffmansc
Copy link
Collaborator

Hi, @jmarecek. Thanks for your work!

I have a couple requests:

  • Can you include an ot_bias_scan function in aif360/sklearn/detectors/ as well? The functionality should be the same but the signature is a bit different. This is just for consistency. See aif360/sklearn/detectors/detectors.py for an example.
  • Can you import your function in the __init__.py files for aif360/detectors/ and aif360/sklearn/detectors/? Again, for consistency. This will allow us to import the function directly from the subpackage instead of the source file.
  • I think you'll need to add ot to the dependency list. You can do this by adding an entry to the extras dict in setup.py (you can name it 'OptimalTransport') as well as requirements.txt.
  • We also need a unit test file for this PR. Please see the tests section of the contribution guide for more information.
  • For the demo notebook, could you add some text explaining what the ot_matrix means, how it should be used, etc.? Also, can you make it clear what the difference between this and MDSS bias scan is in the text? The description just seems copy-pasted from the other notebook.
  • Finally, this isn't a big deal but we use Google-style docstrings for this project. I believe the formatting you used causes some minor issues when built with Sphinx.

At a high level, though, there seems to be a lot of repeated code here. Is there a way we can reuse the MDSS bias scan code for this? For example, how does this differ from adding another "scoring function"? That seems much cleaner to me and would cut down considerably on the checklist above.

@Illia-Kryvoviaz Illia-Kryvoviaz force-pushed the master branch 2 times, most recently from 8397ee4 to 7271964 Compare March 24, 2023 13:30
@jmarecek
Copy link
Contributor Author

jmarecek commented Apr 15, 2023

Hi @hoffmansc,

I hope all is well. Illia has pushed the unit tests, doc strings, etc. It would be great to revisit this.

I don't see how the MDSS scan could be extended to work with OT (or many other types of bias).

Illia and I would be happy to jump on a call, should this be faster?

Thanks!
Jakub

@rahulnair23
Copy link

Hi @jmarecek @Illia-Kryvoviaz - I've reviewed this as well and happy to have a call to discuss some details here. In addition to the points raised above by @hoffmansc (FYI - point 1 is still open, and points 2 and 3 have only been partially completed), please also consider:

  • The output of the bias detector here appears to only return the cost of the transport. This in itself lacks context. Could you include additional context, for example, similar to the output of MDSS scan?
  • The demo notebook here contains the references to the MDSS paper. Is there a reference paper for use of optimal transport for bias detection you can cite here?
  • The demo notebook on the COMPASS dataset ends with the cost of the transport which isn't illustrative as a bias scan. Are the additional steps you can include to show use?

Thank you.

@Illia-Kryvoviaz Illia-Kryvoviaz force-pushed the master branch 12 times, most recently from c6c90fd to fef1bc9 Compare June 7, 2023 14:38
Signed-off-by: Illia-Kryvoviaz <[email protected]>
Signed-off-by: Illia-Kryvoviaz <[email protected]>
Signed-off-by: Illia-Kryvoviaz <[email protected]>
Signed-off-by: Illia-Kryvoviaz <[email protected]>
@Illia-Kryvoviaz
Copy link

Hello @hoffmansc!
We updated the code based on your feedback. Could you please check out the changes and the argument ordering question?

As for detector vs metric, we argue that this should be an independent detector, rather than a metric, because it is too time-consuming to be a metric or run the subgroup analysis similar to MDSS.

@hoffmansc
Copy link
Collaborator

Thanks for your updates. I'm not sure I understand your point about detector vs. metric. It's fine if the metric is slow. The question is which classification better fits the algorithm and I think if it doesn't identify a subgroup like MDSS it shouldn't be called a detector. Metrics are simply anything which takes in data (predictions, ground truth, features, groups, etc.) and returns a numerical score (either per-group or "reduced" by taking the difference between groups, for example). Am I misinterpreting your algorithm?

@jmarecek
Copy link
Contributor Author

Like I mentioned above, there are a variety of scoring functions within the "Optimal transport perspective", incl.
https://en.wikipedia.org/wiki/Wasserstein_metric Wp for integers p,
https://pythonot.github.io/auto_examples/gromov/plot_gromov.html for various integers and metrics on the underlying spaces,
fused Gromov-Wasserstein variants, etc. So I don't really think it is a single scoring function.

@hoffmansc
Copy link
Collaborator

I understand there can be multiple distance/scoring functions. I'm not saying there needs to be any changes to the function just that it would be better suited under aif360.metrics instead of aif360.detectors. Even though it has options with respect to scoring function, the output is still a numerical value not a subgroup.

@krvarshney
Copy link
Contributor

Sam, your logic for it to be under metrics makes sense to me.

@jmarecek
Copy link
Contributor Author

Hi Kush -- so what about this: we contribute the OT-based metrics to aif360.metrics, and we add some "SimpleDetector" to detectors, which would not try to run the subgroup scan. That way, the current functionality of the code would be easy to access. Would that work? Jakub

Signed-off-by: Illia-Kryvoviaz <[email protected]>
@rahulnair23
Copy link

Thanks for the call and discussion today @hoffmansc @jmarecek . As concluded, from an end-user point of view the OT-based measures are better suited under aif360.metrics (as opposed to aif360.detectors).

@hoffmansc
Copy link
Collaborator

Actually, to be clear, it's only strictly necessary to put it under aif360.sklearn.metrics. This is the most straightforward thing to implement. It is optional to put it under aif360.metrics (i.e., the class-based Metric interface). The scikit-learn style functions are preferred going forward and the Metric class is only supported for backwards compatibility.

@Illia-Kryvoviaz
Copy link

Hello @hoffmansc!
We've put the ot_bias_scan under the aif360.sklearn.metrics. Additionally, we've renamed the ot_detector to ot_metric and moved the code from the aif360.detectors folder to the aif360.metrics folder - it would seem more logical to have it there now. Could you please review the changes? Thank you!

Copy link
Collaborator

@hoffmansc hoffmansc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good for now, thanks. I made one suggestion -- renaming the function to ot_distance. If this is acceptable, I can merge it.

Down the line, I would like this to integrate with aif360.sklearn.metrics.intersection()/difference() instead of how it handles prot_attr currently but I can make a separate PR with those changes and ask for your review.

aif360/metrics/ot_metric.py Outdated Show resolved Hide resolved
aif360/sklearn/detectors/detectors.py Outdated Show resolved Hide resolved
aif360/sklearn/metrics/metrics.py Outdated Show resolved Hide resolved
aif360/sklearn/metrics/metrics.py Outdated Show resolved Hide resolved
aif360/sklearn/metrics/metrics.py Outdated Show resolved Hide resolved
aif360/sklearn/metrics/metrics.py Outdated Show resolved Hide resolved
aif360/sklearn/metrics/metrics.py Outdated Show resolved Hide resolved
aif360/sklearn/metrics/metrics.py Outdated Show resolved Hide resolved
@Illia-Kryvoviaz
Copy link

Hello @hoffmansc!
All changes were implemented as you suggested.

@hoffmansc
Copy link
Collaborator

@Illia-Kryvoviaz It looks like one of the tests is failing. This line should be pos_label=fav

ot_distance(p, q, favorable_value=fav)

Signed-off-by: Illia-Kryvoviaz <[email protected]>
@Illia-Kryvoviaz
Copy link

Yes, you are right @hoffmansc. Now it looks right.

@hoffmansc hoffmansc merged commit 502ff47 into Trusted-AI:master Jul 23, 2023
andrewklayk pushed a commit to andrewklayk/AIF360 that referenced this pull request Sep 8, 2023
divyagaddipati pushed a commit to divyagaddipati/AIF360 that referenced this pull request Sep 22, 2023
meghana009 pushed a commit to meghana009/AIF360 that referenced this pull request Sep 22, 2023
Signed-off-by: Venkata Meghana Achanta <[email protected]>
Signed-off-by: meghana009 <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add a bias detector based on optimal transport
5 participants