This document describes how to contribute this project.
Before starting your contribution, please check README to understand what this project is and setup your development environment.
Steps to add a new sample program.
If you found an algorithm which you want to implement, let's create an issue to propose it on GitHub. We will check it and give a comment as soon as possible.
If we agreed with your proposal, let's go to Step 2.
It if OK to just create an issue to propose. Someone might see your proposal and implement in the future. In this case, please a paper or ducumentation about the algorithm to understand it.
When you implement a sample program of an algorithm, please keep the following items in mind.
- Use only Python. Using other language is not acceptable.
- Acceptable version of Python is 3.x.
- Implement an animation by using matplotlib to show how the algorithm works.
- Use only libraries and tools written in Requirements section of README.
- Implement as simple as possible. The main purpose to help a user to understand the algorithm. It is not for practical usage.
If you added a new sample program, please add a unit test code for it under test directory. When you implement the test code, please refer to the existing code. Additionally, each unit tests should be able to run without animation because test process stops and an exception occurs. After you completed to implement the test code, confirm the test passes by executing the script, run_test_suites.sh/bat.
If your sample program and test were ready, let's create a pull request and submit it. When you create the PR, please write a description about the following items.
- The overview of your PR.
- How did you confirm that your program works well.
After you submitted your PR, each unit tests is executed automatically by GitHub Actions. If an error occured and unit tests failed, please investigate the reason and fix it. After all tests passed and any problems were not found by code review, I will allow you to merge your PR into main branch.
Reporting and fixing a defect are also welcome.
When you report an issue, please provide the following information.
- A clear and concise description about the defect.
- A clear and consice description about your expectation.
- Screenshots to help explaining the defect.
- OS version.
- Python version.
- Each libraries version.
Additionally, you can see existing reported issues and fix the defect. And then, please don't forget to add a unit test code to check the defect was fixed. After you completed fixing, let's submit a PR following the rule of Step 4.
Adding a documentation about existing programs is also welcome.
There have not been any rules about documentation yet. If you had any suggestion of how to write documentations, please submit a PR and I will review it.
Supporting this project financially is also a great contribution!!.
If you or your company could support this project, please consider Sponsor @ShisatoYano on GitHub Sponsors.