-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Jay Wang <jay@zijie.wang>
- Loading branch information
Showing
2 changed files
with
169 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,169 @@ | ||
# GAM Changer | ||
<h1> | ||
<a href="https://interpret.ml/gam-changer/"><img src='https://i.imgur.com/njlqCrQ.png' width='100%'></a> | ||
</h1> | ||
|
||
A Python package to run GAM Changer in your computation notebooks. | ||
Interactive visualization tool to help domain experts and data scientists easily and responsibly edit Generalized Additive Models (GAMs). | ||
|
||
<!-- [data:image/s3,"s3://crabby-images/fbe1d/fbe1d2f89215b7589b3f89aa2112c2614f97d3b5" alt="Binder"](https://mybinder.org/v2/gh/interpretml/gam-changer/master?urlpath=lab/tree/examples/gam_changer_adult.ipynb) --> | ||
|
||
[data:image/s3,"s3://crabby-images/b88d6/b88d61513829d5be58264883804f4c2d24ac9328" alt="build"](https://github.com/interpretml/gam-changer/actions) | ||
[data:image/s3,"s3://crabby-images/ee123/ee1239239ddcddba38771328de2b77ea08f2702b" alt="pypi"](https://pypi.org/project/gamchanger/) | ||
[data:image/s3,"s3://crabby-images/01aa0/01aa0dcc161775f7e0f6dad5399db20bc77850fe" alt="Lite"](https://interpret.ml/gam-changer/notebook/retro/notebooks/?path=gam_changer_adult.ipynb) | ||
[data:image/s3,"s3://crabby-images/12837/12837dfc67df87429e6379df3d28713b452198e1" alt="license"](https://github.com/interpretml/gam-changer/blob/master/LICENSE) | ||
[data:image/s3,"s3://crabby-images/d7ffd/d7ffda18820df8c98def47940c2cce8ae8485124" alt="DOI:10.1145/3534678.3539074"](https://doi.org/10.1145/3534678.3539074) | ||
[data:image/s3,"s3://crabby-images/fdcc6/fdcc60625514a323d6ac755c3487cf128ebab4c4" alt="arxiv badge"](https://arxiv.org/abs/2206.15465) | ||
|
||
<!-- <a href="https://youtu.be/D6whtfInqTc" target="_blank"><img src="https://i.imgur.com/J3C0aov.png" style="max-width:100%;"></a> --> | ||
|
||
<table> | ||
<tr> | ||
<td colspan="2"><img src='https://i.imgur.com/eKzKJfl.png'></td> | ||
</tr> | ||
<tr></tr> | ||
<tr> | ||
<td><a href="https://youtu.be/D6whtfInqTc">📺 Video</a></td> | ||
<td><a href="https://dl.acm.org/doi/10.1145/3534678.3539074">📖 "Interpretability, Then What? Editing Machine Learning Models to Reflect Human Knowledge and Values"</a></td> | ||
</tr> | ||
</table> | ||
|
||
<!-- For more information, check out our manuscript: | ||
[**GAM Changer: Editing Generalized Additive Models with Interactive Visualization**](https://arxiv.org/abs/2112.03245). | ||
Zijie J. Wang, Alex Kale, Harsha Nori, Peter Stella, Mark Nunnally, Duen Horng Chau, Mihaela Vorvoreanu, Jennifer Wortman Vaughan, Rich Caruana. | ||
*arXiv:2112.03245, 2021.* --> | ||
|
||
## GAM Changer Features | ||
|
||
<img align="center" width="600px" src="https://user-images.githubusercontent.com/15007159/184291928-c675b83e-be82-4206-bd30-47dc93008fec.gif"> | ||
|
||
--- | ||
|
||
## Get Started | ||
|
||
For a live demo, visit: http://interpret.ml/gam-changer/ | ||
|
||
### How to Edit My Own GAMs? | ||
|
||
You can use this demo to edit your own GAMs: choose the `my model` tab and upload the `model.json` (model weights) and `sample.json` (sample data to evaluate the model). | ||
|
||
If you use [EBM](https://github.com/interpretml/interpret), you can generate these two files easily with the GAM Changer python package. | ||
|
||
```shell | ||
# First install the GAM Changer python package | ||
pip install gamchanger | ||
``` | ||
|
||
```python | ||
import gamchanger as gc | ||
from json import dump | ||
|
||
# Extract model weights | ||
model_data = gc.get_model_data(ebm) | ||
|
||
# Generate sample data | ||
sample_data = gc.get_sample_data(ebm, x_test, y_test) | ||
|
||
# Save to `model.json` and `sample.json` | ||
dump(model_data, open('./model.json', 'w')) | ||
dump(sample_data, open('./sample.json', 'w')) | ||
``` | ||
|
||
### Computational Notebook Widget | ||
|
||
You can use GAM Changer directly in your computational notebooks (e.g., Jupyter Notebook, VSCode Notebook, Google Colab). | ||
|
||
Check out three live notebook demos below. | ||
|
||
|Jupyter Lite|Binder|Google Colab| | ||
|:---:|:---:|:---:| | ||
|[data:image/s3,"s3://crabby-images/01aa0/01aa0dcc161775f7e0f6dad5399db20bc77850fe" alt="Lite"](https://interpret.ml/gam-changer/notebook/retro/notebooks/?path=gam_changer_adult.ipynb)|[data:image/s3,"s3://crabby-images/fbe1d/fbe1d2f89215b7589b3f89aa2112c2614f97d3b5" alt="Binder"](https://mybinder.org/v2/gh/interpretml/gam-changer/master?urlpath=lab/tree/examples/gam_changer_adult.ipynb)|[data:image/s3,"s3://crabby-images/e7985/e79852128a5f83c92496b9d734ca52d01e009a39" alt="Open In Colab"](https://colab.research.google.com/drive/1OgAVZKqs2VwmY13QuOjCxlOEyexsYjtm?usp=sharing)| | ||
|
||
Use the following snippet to load GAM Changer in your favorite notebooks: | ||
|
||
```python | ||
# Install the GAM Changer python package | ||
!pip install gamchanger | ||
|
||
import gamchanger as gc | ||
|
||
# Load GAM Changer with the model and sample data | ||
gc.visualize(ebm, x_feed, y_feed) | ||
``` | ||
|
||
### Load Edited Models | ||
|
||
After finishing editing a model, you can save the new model along with all the editing history to a `*.gamchanger` file by clicking the save button. You can load the new model in Python: | ||
|
||
```python | ||
from json import load | ||
import gamchanger as gc | ||
|
||
# Load the `*.gamchanger` file | ||
gc_dict = load(open('./edit-8-27-2021.gamchanger', 'r')) | ||
|
||
# This will return a deep copy of your original EBM where edits are applied | ||
new_ebm = gc.get_edited_model(ebm, gc_dict) | ||
``` | ||
|
||
## Development | ||
|
||
Clone or download this repository: | ||
|
||
```bash | ||
git clone git@github.com:interpretml/gam-changer.git | ||
|
||
# use degit if you don't want to download commit histories | ||
degit interpretml/gam-changer.git | ||
``` | ||
|
||
Install the dependencies: | ||
|
||
```bash | ||
npm install | ||
``` | ||
|
||
Then run GAM Changer: | ||
|
||
```bash | ||
npm run dev | ||
``` | ||
|
||
Navigate to [localhost:5000](https://localhost:5005). You should see GAM Changer running in your browser :) | ||
|
||
## Credits | ||
|
||
GAM Changer is created by <a href="https://zijie.wang">Jay Wang</a>, | ||
<a href="http://students.washington.edu/kalea/">Alex Kale</a>, | ||
<a href="https://www.linkedin.com/in/harshanori/">Harsha Nori</a>, | ||
<a href="https://nyulangone.org/doctors/1548522964/peter-a-stella">Peter Stella</a>, | ||
<a href="https://nyulangone.org/doctors/1144385360/mark-e-nunnally">Mark Nunnally</a>, | ||
<a href="https://www.cc.gatech.edu/~dchau/">Polo Chau</a>, | ||
<a href="https://www.microsoft.com/en-us/research/people/mivorvor/">Mickey Vorvoreanu</a>, | ||
<a href="http://www.jennwv.com">Jenn Wortman Vaughan</a>, | ||
and <a href="https://www.microsoft.com/en-us/research/people/rcaruana/">Rich Caruana</a>, | ||
which was the result of a research collaboration between | ||
Microsoft Research, NYU Langone Health, Georgia Tech and University of Washington. | ||
Jay Wang and Alex Kale were summer interns at Microsoft Research. | ||
|
||
We thank Steven Drucker, Adam Fourney, Saleema Amershi, Dean Carignan, Rob DeLine, Haekyu Park, and the InterpretML team for their support and constructive feedback. | ||
|
||
## Citation | ||
|
||
```bibTeX | ||
@inproceedings{wangInterpretabilityThenWhat2022, | ||
title = {Interpretability, {{Then What}}? {{Editing Machine Learning Models}} to {{Reflect Human Knowledge}} and {{Values}}}, | ||
shorttitle = {Interpretability, {{Then What}}?}, | ||
booktitle = {Proceedings of the 28th {{ACM SIGKDD International Conference}} on {{Knowledge Discovery}} \& {{Data Mining}}}, | ||
author = {Wang, Zijie J. and Kale, Alex and Nori, Harsha and Stella, Peter and Nunnally, Mark E. and Chau, Duen Horng and Vorvoreanu, Mihaela and Vaughan, Jennifer Wortman and Caruana, Rich}, | ||
year = {2022}, | ||
url = {https://interpret.ml/gam-changer}, | ||
} | ||
``` | ||
|
||
## License | ||
|
||
The software is available under the [MIT License](./LICENSE). | ||
|
||
## Contact | ||
|
||
If you have any questions, feel free to [open an issue](https://github.com/interpretml/gam-changer/issues/new) or contact [Jay Wang](https://zijie.wang). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters