зеркало из https://github.com/microsoft/caffe.git
121 строка
6.5 KiB
Markdown
121 строка
6.5 KiB
Markdown
---
|
|
title: Developing and Contributing
|
|
---
|
|
# Development and Contributing
|
|
|
|
Caffe is developed with active participation of the community.<br>
|
|
The [BVLC](http://bvlc.eecs.berkeley.edu/) brewers welcome all contributions!
|
|
|
|
The exact details of contributions are recorded by versioning and cited in our [acknowledgements](http://caffe.berkeleyvision.org/#acknowledgements).
|
|
This method is impartial and always up-to-date.
|
|
|
|
## License
|
|
|
|
Caffe is licensed under the terms in [LICENSE](https://github.com/BVLC/caffe/blob/master/LICENSE). By contributing to the project, you agree to the license and copyright terms therein and release your contribution under these terms.
|
|
|
|
## Copyright
|
|
|
|
Caffe uses a shared copyright model: each contributor holds copyright over their contributions to Caffe. The project versioning records all such contribution and copyright details.
|
|
|
|
If a contributor wants to further mark their specific copyright on a particular contribution, they should indicate their copyright solely in the commit message of the change when it is committed. Do not include copyright notices in files for this purpose.
|
|
|
|
### Documentation
|
|
|
|
This website, written with [Jekyll](http://jekyllrb.com/), acts as the official Caffe documentation -- simply run `scripts/build_docs.sh` and view the website at `http://0.0.0.0:4000`.
|
|
|
|
We prefer tutorials and examples to be documented close to where they live, in `readme.md` files.
|
|
The `build_docs.sh` script gathers all `examples/**/readme.md` and `examples/*.ipynb` files, and makes a table of contents.
|
|
To be included in the docs, the readme files must be annotated with [YAML front-matter](http://jekyllrb.com/docs/frontmatter/), including the flag `include_in_docs: true`.
|
|
Similarly for IPython notebooks: simply include `"include_in_docs": true` in the `"metadata"` JSON field.
|
|
|
|
Other docs, such as installation guides, are written in the `docs` directory and manually linked to from the `index.md` page.
|
|
|
|
We strive to provide lots of usage examples, and to document all code in docstrings.
|
|
We absolutely appreciate any contribution to this effort!
|
|
|
|
### Versioning
|
|
|
|
The `master` branch receives all new development including community contributions.
|
|
We try to keep it in a reliable state, but it is the bleeding edge, and things do get broken every now and then.
|
|
BVLC maintainers will periodically make releases by marking stable checkpoints as tags and maintenance branches. [Past releases](https://github.com/BVLC/caffe/releases) are catalogued online.
|
|
|
|
#### Issues & Pull Request Protocol
|
|
|
|
Post [Issues](https://github.com/BVLC/caffe/issues) to propose features, report [bugs], and discuss framework code.
|
|
Large-scale development work is guided by [milestones], which are sets of Issues selected for bundling as releases.
|
|
|
|
Please note that since the core developers are largely researchers, we may work on a feature in isolation for some time before releasing it to the community, so as to claim honest academic contribution.
|
|
We do release things as soon as a reasonable technical report may be written, and we still aim to inform the community of ongoing development through Github Issues.
|
|
|
|
**When you are ready to develop a feature or fixing a bug, follow this protocol**:
|
|
|
|
- Develop in [feature branches] with descriptive names. Branch off of the latest `master`.
|
|
- Bring your work up-to-date by [rebasing] onto the latest `master` when done.
|
|
(Groom your changes by [interactive rebase], if you'd like.)
|
|
- [Pull request] your contribution to `BVLC/caffe`'s `master` branch for discussion and review.
|
|
- Make PRs *as soon as development begins*, to let discussion guide development.
|
|
- A PR is only ready for merge review when it is a fast-forward merge, and all code is documented, linted, and tested -- that means your PR must include tests!
|
|
- When the PR satisfies the above properties, use comments to request maintainer review.
|
|
|
|
The following is a poetic presentation of the protocol in code form.
|
|
|
|
#### [Shelhamer's](https://github.com/shelhamer) “life of a branch in four acts”
|
|
|
|
Make the `feature` branch off of the latest `bvlc/master`
|
|
|
|
git checkout master
|
|
git pull upstream master
|
|
git checkout -b feature
|
|
# do your work, make commits
|
|
|
|
Prepare to merge by rebasing your branch on the latest `bvlc/master`
|
|
|
|
# make sure master is fresh
|
|
git checkout master
|
|
git pull upstream master
|
|
# rebase your branch on the tip of master
|
|
git checkout feature
|
|
git rebase master
|
|
|
|
Push your branch to pull request it into `BVLC/caffe:master`
|
|
|
|
git push origin feature
|
|
# ...make pull request to master...
|
|
|
|
Now make a pull request! You can do this from the command line (`git pull-request -b master`) if you install [hub](https://github.com/github/hub). Hub has many other magical uses.
|
|
|
|
The pull request of `feature` into `master` will be a clean merge. Applause.
|
|
|
|
[bugs]: https://github.com/BVLC/caffe/issues?labels=bug&page=1&state=open
|
|
[milestones]: https://github.com/BVLC/caffe/issues?milestone=1
|
|
[Pull request]: https://help.github.com/articles/using-pull-requests
|
|
[interactive rebase]: https://help.github.com/articles/interactive-rebase
|
|
[rebasing]: http://git-scm.com/book/en/Git-Branching-Rebasing
|
|
[feature branches]: https://www.atlassian.com/git/workflows#!workflow-feature-branch
|
|
|
|
**Historical note**: Caffe once relied on a two branch `master` and `dev` workflow.
|
|
PRs from this time are still open but these will be merged into `master` or closed.
|
|
|
|
### Testing
|
|
|
|
Run `make runtest` to check the project tests. New code requires new tests. Pull requests that fail tests will not be accepted.
|
|
|
|
The `gtest` framework we use provides many additional options, which you can access by running the test binaries directly. One of the more useful options is `--gtest_filter`, which allows you to filter tests by name:
|
|
|
|
# run all tests with CPU in the name
|
|
build/test/test_all.testbin --gtest_filter='*CPU*'
|
|
|
|
# run all tests without GPU in the name (note the leading minus sign)
|
|
build/test/test_all.testbin --gtest_filter=-'*GPU*'
|
|
|
|
To get a list of all options `googletest` provides, simply pass the `--help` flag:
|
|
|
|
build/test/test_all.testbin --help
|
|
|
|
### Style
|
|
|
|
- **Run `make lint` to check C++ code.**
|
|
- Wrap lines at 80 chars.
|
|
- Follow [Google C++ style](http://google-styleguide.googlecode.com/svn/trunk/cppguide.xml) and [Google python style](http://google-styleguide.googlecode.com/svn/trunk/pyguide.html) + [PEP 8](http://legacy.python.org/dev/peps/pep-0008/).
|
|
- Remember that “a foolish consistency is the hobgoblin of little minds,” so use your best judgement to write the clearest code for your particular case.
|