开发 Development¶
TensorLayer始于一个帝国理工的研究项目,目前由数位 GitHub 的贡献者负责维护和进行改进。
作为一个为研究员和工程师开发的开源项目,我们诚挚地欢迎您为对项目提供帮助。 每个微小的支持都会帮助我们并且会被记录下来。
理念¶
TensorLayer的想法源于组合TensorFlow的灵活性和正确的 building blocks的可用性来训练神经网络的需求。 它依照下列设计目标所开发:
简洁:易于使用,易于扩展与修改以便于研究和工程中使用。
快速:在GPU的支持下运行速度与纯TensorFlow脚本速度一致。简洁但不牺牲性能。
兼容:一个网络被抽象到正则化,成本和每一层的输出,易于与其他TensorFlow的库协作。
透明:在抽象后面不隐藏TensorFlow,尽量依赖TensorFlow的功能并且遵循TensorFlow的约定。
如何参与我们¶
如果您在深度学习和强化学习方面发布了一种新的算法, 欢迎您分享您的算法给TensorLayer
说明它是怎么工作的,如果可以话请给出学术论文的链接。
尽可能地缩减其范围,以以致于便于实现
报告BUG¶
请您在 GitHub 上报告BUG。 如果您打算报告BUG,请包含以下内容:
您的TensorLayer和TensorFlow版本号
重现BUG的步骤,最好能减少到数个python 命令
您获得的结果和您期望的结果。
如果您不确定遇到的行为是否是BUG, 或者你不确定错误是否与TensorLayer或TensorFlow有关, 请您先在 our mailing list 查看下。
修复BUG¶
通过GitHub的问题栏(issues)来查看BUG报告。 任何被标记为BUG的项对所有想要修复它的人来说都是开放的。 如果您发现了TensorLayer的一个你可以自己修复的BUG, 您可以用任何方法来实现修复并且无需立即报告这个BUG。
如何参与我们¶
在GitHub上编辑¶
正如刚刚文档中修复BUG所说的简单方法, 点击文档右上角的*Edit on GitHub*链接或者API引用列表中的对象的*[source]*链接来打开GitHub中的源文件, 然后在你的浏览器中点击*Edit this file*链接并发送拉请求(Pull Request). 你只需要一个免费的GitHub账户就可以做到了。
对于任何较大幅度的修改,请遵循以下步骤来更新TensorLayer开发。
文档¶
文档由 Sphinx 生成。 如果要本地编辑它,运行下列命令: .. code:: bash
cd docs make html
如果您想要重新生成整个文档,运行下列命令:
cd docs
make clean
make html
然后,打开 docs/_build/index.html
来查看会出现在 readthedocs 文档。
如果您更改了很多内容,并且似乎出现了许多误导性的错误信息或警告,运行``make clean html``来让Sphinx重新生成所有文件。
编写英文文档文字时,请尽可能地按照现有文档的文字习惯, 来保证整个库文字的一致性。所使用的语法及约定的相关信息,请参考以下文档:
测试¶
TensorLayer有100%的代码覆盖率,这过去被证明是十分有用的的, 但也带来了一些责任:
每当您更改任何代码的时候,您应该运行测试脚本来测试它是否能优化现有属性。
您修改的每个BUG说明一个缺少的测试案例,
所以每个修复BUG的方案应该配置一个您没修复前的测试案例。
发送拉请求¶
当您对您添加的内容感到满意并且测试通过,文档规范,简明,不存在任何注释错误。 您可以将您的更改提交到一个新的分支(branch),并且将这个分支与您的副本(fork)合并, 然后通过GitHub的网站发送一个拉请求(pull request)
所有的这些步骤在GitHub上有相当不错的说明: https://guides.github.com/introduction/flow/
当您提交拉请求时,请附带一个更改内容的说明,以帮助我们能更好的检阅它。 如果它是一个正在开放的问题(issue),比如:issue#123,请在您的描述中添加 Fixes#123,*Resolves#123*或者*Closes#123*,这样当您的拉请求被接纳之后 GitHub会关闭那个问题。