Contribute and Extend RAI
How to contribute and extend RAI (User Guide)
Here’s the short summary
If you are a first-time contributor,
Go to ResponsibleAI and click the “fork” button to create your own copy of the project from master.
Clone the project to your local computer.
Develop your contribution.
Push your changes back to your fork on GitHub.
Adding Metric Group
What are its requirements
To add a New metrics, we need to create 3 files inside Metrics folder.
__init__.py file.
json file.
Python file.
In
__init__.py
file we have to import the python file that we have created inside the folder.
Example:
__init__.py file example
How to expand RAI using Metric group
Inside
json file
, we need to define parametrs as name, display_name, compatibility, dependency_list, tags, complexity_class, metrics.- parameter:
name:
- parameter:
display_name:
- parameter:
compatibility:
- parameter:
dependency_list:
- parameter:
tags:
- parameter:
complexity_class:
- parameter:
metrics:
Example:
json_metric file example
Create subclass of class and implement the method
We can create subclass of class and implement the methods.
In
python file
, we need to create a class for respective metric_group and we need to define methods for update and compute inside the class.
Example:
metric_python_file example
Adding Certificates
What are is requirements
To add a New Certificates , we need to create a json file inside a standard folder.
How to expand RAI using Certificates
For certificates there are two key value pairs , first one meta and second one conditions.
Inside meta we need to give diplay name, description, tags and level.
Inside condition we need to give operator and terms.
Create a certificate and implement
Inside certificate folder, go to standard folder and their make a
json file
and fill all given parameters.- parameter:
meta:
- parameter:
condition:
Example:
sample certficate
Adding Analysis
What are is requirements
To add a New Analysis, we need to create 3 files inside Analysis folder.
__init__.py file.
json file.
Python file.
In
__init__.py
file - we have to import the py file that we have created inside the folder.
Example:
__init__.py file example
How to expand RAI using Analysis
Inside
json file
, we need to give parametrs name, display_name, compatibility, src, dependency_list, tags, complexity_class.- parameter:
name:
- parameter:
display_name:
- parameter:
compatibility:
- parameter:
src:
- parameter:
dependency_list:
- parameter:
tags:
- parameter:
complexity_class:
Example:
Analysis_json_file example
Create subclass of class and implement the method
We can create subclass of class and implement the methods.
In
python file
, we need to create a class for respective Analysis and we need to define methods for initialize ,compute, to_string, to_html inside the class.
Example:
Analysispyfile.png example
Contribution of users to expand its features
Contributing to RAI
Thank you for taking time to start contributing! We want to make contributing to this project as easy and transparent as possible, whether it’s:
Reporting a bug
Discussing the current state of the code
Submitting a fix
Proposing new features
Becoming a maintainer
We Develop with Github
We use github to host code, to track issues and feature requests, as well as accept pull requests.
Pull requests are the best way to propose changes to the codebase. We actively welcome your pull requests:
Fork the repo and create your branch from master.
If you’ve added code that should be tested, add tests.
If you’ve changed APIs, update the documentation.
Ensure the test suite passes.
Make sure your code lints.
Issue that pull request!
Any contributions you make will be under the Apache License, Version 2
In short, when you submit code changes, your submissions are understood to be under the same Apache License that covers the project.
Feel free to contact the maintainers if that’s a concern.
Report bugs using Github’s Issues
We use GitHub issues to track public bugs. Report a bug by opening a new issue
Write bug reports with detail, background, and sample code.
Please consider to include the following in a bug report:
A quick summary and/or background
Steps to reproduce - Be specific! - Give sample code if you can.
What you expected would happen
What actually happened
Notes (possibly including why you think this might be happening, or stuff you tried that didn’t work)
License
By contributing, you agree that your contributions will be licensed under its Apache License, Version 2.
References
This document was adapted from here.