Skip to content

Commit d6a7648

Browse files
committed
Merge branch 'develop' of github.com:baidu/Paddle into feature/c_api
2 parents 91927cc + 946693b commit d6a7648

File tree

8 files changed

+109
-19
lines changed

8 files changed

+109
-19
lines changed

Dockerfile

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ ARG WITH_DOC
1313
ARG WITH_STYLE_CHECK
1414

1515
ENV WOBOQ OFF
16-
ENV WITH_GPU=${WITH_AVX:-OFF}
16+
ENV WITH_GPU=${WITH_GPU:-OFF}
1717
ENV WITH_AVX=${WITH_AVX:-ON}
1818
ENV WITH_DOC=${WITH_DOC:-OFF}
1919
ENV WITH_STYLE_CHECK=${WITH_STYLE_CHECK:-OFF}

cmake/system.cmake

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,11 @@ ELSE(WIN32)
2828
STRING(REGEX MATCH "[0-9]+.[0-9]+" VERSION "${MACOSX_VERSION}")
2929
SET(MACOS_VERSION ${VERSION})
3030
SET(HOST_SYSTEM "macosx")
31+
IF(NOT DEFINED ENV{MACOSX_DEPLOYMENT_TARGET})
32+
# Set cache variable - end user may change this during ccmake or cmake-gui configure.
33+
SET(CMAKE_OSX_DEPLOYMENT_TARGET ${MACOS_VERSION} CACHE STRING
34+
"Minimum OS X version to target for deployment (at runtime); newer APIs weak linked. Set to empty string for default value.")
35+
ENDIF()
3136
ELSE(APPLE)
3237

3338
IF(EXISTS "/etc/issue")

doc/design/releasing_process.md

Lines changed: 58 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,58 @@
1+
# Paddle发行规范
2+
3+
Paddle使用git-flow branching model做分支管理,使用[Semantic Versioning](http://semver.org/)标准表示Paddle版本号。
4+
5+
Paddle每次发新的版本,遵循以下流程:
6+
7+
1.`develop`分支派生出新的分支,分支名为`release/版本号`。例如,`release/0.10.0`
8+
2. 将新分支的版本打上tag,tag为`版本号rc.Patch号`。第一个tag为`0.10.0rc1`,第二个为`0.10.0rc2`,依次类推。
9+
3. 对这个版本的提交,做如下几个操作:
10+
* 编译这个版本的Docker发行镜像,发布到dockerhub。如果失败,修复Docker编译镜像问题,Patch号加一,返回第二步
11+
* 编译这个版本的Ubuntu Deb包。如果失败,修复Ubuntu Deb包编译问题,Patch号加一,返回第二步。
12+
* 使用Regression Test List作为检查列表,测试Docker镜像/ubuntu安装包的功能正确性
13+
* 如果失败,记录下所有失败的例子,在这个`release/版本号`分支中,修复所有bug后,Patch号加一,返回第二步
14+
4. 第三步完成后,将`release/版本号`分支合入master分支,并删除`release/版本号`分支。将master分支的合入commit打上tag,tag为`版本号`。同时再将`master`分支合入`develop`分支。最后删除`release/版本号`分支。
15+
5. 编译master分支的Docker发行镜像,发布到dockerhub。编译ubuntu的deb包,发布到github release页面
16+
6. 协同完成Release Note的书写
17+
18+
19+
需要注意的是:
20+
21+
* `release/版本号`分支一旦建立,一般不允许再从`develop`分支合入`release/版本号`。这样保证`release/版本号`分支功能的封闭,方便测试人员测试Paddle的行为。
22+
*`release/版本号`分支存在的时候,如果有bugfix的行为,需要将bugfix的分支同时merge到`master`, `develop``release/版本号`这三个分支。
23+
24+
# Paddle 分支规范
25+
26+
Paddle开发过程使用[git-flow](http://nvie.com/posts/a-successful-git-branching-model/)分支规范,并适应github的特性做了一些区别。
27+
28+
* Paddle的主版本库遵循[git-flow](http://nvie.com/posts/a-successful-git-branching-model/)分支规范。其中:
29+
* `master`分支为稳定(stable branch)版本分支。每一个`master`分支的版本都是经过单元测试和回归测试的版本。
30+
* `develop`分支为开发(develop branch)版本分支。每一个`develop`分支的版本都经过单元测试,但并没有经过回归测试。
31+
* `release/版本号`分支为每一次Release时建立的临时分支。在这个阶段的代码正在经历回归测试。
32+
33+
* 其他用户的fork版本库并不需要严格遵守[git-flow](http://nvie.com/posts/a-successful-git-branching-model/)分支规范,但所有fork的版本库的所有分支都相当于特性分支。
34+
* 建议,开发者fork的版本库使用`develop`分支同步主版本库的`develop`分支
35+
* 建议,开发者fork的版本库中,再基于`develop`版本fork出自己的功能分支。
36+
* 当功能分支开发完毕后,向Paddle的主版本库提交`Pull Reuqest`,进而进行代码评审。
37+
* 在评审过程中,开发者修改自己的代码,可以继续在自己的功能分支提交代码。
38+
39+
* BugFix分支也是在开发者自己的fork版本库维护,与功能分支不同的是,BugFix分支需要分别给主版本库的`master``develop`与可能有的`release/版本号`分支,同时提起`Pull Request`
40+
41+
# Paddle回归测试列表
42+
43+
本列表说明Paddle发版之前需要测试的功能点。
44+
45+
## Paddle Book中所有章节
46+
47+
Paddle每次发版本首先要保证Paddle Book中所有章节功能的正确性。功能的正确性包括验证Paddle目前的`paddle_trainer`训练和纯使用`Python`训练模型正确性。
48+
49+
| | 新手入门章节 | 识别数字 | 图像分类 | 词向量 | 情感分析 | 语意角色标注 | 机器翻译 | 个性化推荐 |
50+
| --- | --- | --- | --- | --- | --- | --- | --- | --- |
51+
| API.V2 + Docker + GPU | | | | | | | | |
52+
| API.V2 + Docker + CPU | | | | | | | | |
53+
| `paddle_trainer` + Docker + GPU | | | | | | | | |
54+
| `paddle_trainer` + Docker + CPU | | | | | | | | |
55+
| API.V2 + Ubuntu + GPU | | | | | | | | |
56+
| API.V2 + Ubuntu + CPU | | | | | | | | |
57+
| `paddle_trainer` + Ubuntu + GPU | | | | | | | | |
58+
| `paddle_trainer` + Ubuntu + CPU | | | | | | | | |

paddle/function/ContextProjectionOpTest.cpp

Lines changed: 15 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -28,11 +28,12 @@ void testMatrixProjectionForward(int context_start,
2828
std::max(0, (int)(context_start + context_length - 1));
2929
if (pad == 0) is_padding = false;
3030

31-
FunctionCompare test("ContextProjectionForward",
32-
FuncConfig()
33-
.set("context_length", context_length)
34-
.set("context_start", context_start)
35-
.set("begin_pad", std::max(0, -context_start)));
31+
FunctionCompare test(
32+
"ContextProjectionForward",
33+
FuncConfig()
34+
.set("context_length", context_length)
35+
.set("context_start", context_start)
36+
.set("begin_pad", (size_t)std::max(0, -context_start)));
3637

3738
// prepare input arguments
3839
test.addSequence(SequenceIdArg(TensorShape{batch_size}));
@@ -51,21 +52,22 @@ void testMatrixProjectionForward(int context_start,
5152
}
5253

5354
void testMatrixProjectionBackward(int context_start,
54-
int context_length,
55+
size_t context_length,
5556
bool is_padding,
5657
size_t batch_size,
5758
size_t input_dim) {
5859
size_t pad = std::max(0, -context_start) +
5960
std::max(0, (int)(context_start + context_length - 1));
6061
if (pad == 0) is_padding = false;
6162

62-
FunctionCompare test("ContextProjectionBackward",
63-
FuncConfig()
64-
.set("context_length", context_length)
65-
.set("context_start", context_start)
66-
.set("begin_pad", std::max(0, -context_start))
67-
.set("is_padding", is_padding)
68-
.set("total_pad", pad));
63+
FunctionCompare test(
64+
"ContextProjectionBackward",
65+
FuncConfig()
66+
.set("context_length", context_length)
67+
.set("context_start", context_start)
68+
.set("begin_pad", (size_t)std::max(0, -context_start))
69+
.set("is_padding", is_padding)
70+
.set("total_pad", pad));
6971

7072
// prepare input arguments
7173
test.addSequence(SequenceIdArg(TensorShape{batch_size}));

paddle/gserver/layers/TransLayer.cpp

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -56,7 +56,14 @@ void TransLayer::backward(const UpdateCallback& callback) {
5656
return;
5757
}
5858
MatrixPtr preGrad = getInputGrad(0);
59-
outputGrad->transpose(preGrad, false);
59+
if (preGrad) {
60+
MatrixPtr transGrad = Matrix::create(preGrad->getHeight(),
61+
preGrad->getWidth(),
62+
/* trans= */ false,
63+
preGrad->useGpu());
64+
outputGrad->transpose(transGrad, false);
65+
preGrad->add(*transGrad);
66+
}
6067
}
6168

6269
} // namespace paddle

paddle/gserver/tests/test_LayerGrad.cpp

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1689,6 +1689,22 @@ TEST(Layer, smooth_l1) {
16891689
}
16901690
}
16911691

1692+
TEST(Layer, TransLayer) {
1693+
TestConfig config;
1694+
const int height = 128;
1695+
const int width = 1028;
1696+
config.layerConfig.set_type("trans");
1697+
config.layerConfig.set_size(width);
1698+
1699+
config.inputDefs.push_back(
1700+
{INPUT_DATA, "layer_0", /* dim= */ height * width, /* paraSize= */ 0});
1701+
config.layerConfig.add_inputs();
1702+
1703+
for (auto useGpu : {false, true}) {
1704+
testLayerGrad(config, "trans", height, /* trans= */ false, useGpu);
1705+
}
1706+
}
1707+
16921708
int main(int argc, char** argv) {
16931709
testing::InitGoogleTest(&argc, argv);
16941710
initMain(argc, argv);

paddle/math/tests/test_matrixCompare.cpp

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -235,8 +235,10 @@ TEST(Matrix, unary) {
235235
testMatrixTranspose(height, width);
236236
testMatrixRotate(height, width);
237237
}
238-
// inverse
238+
// inverse
239+
#ifdef PADDLE_USE_LAPACK
239240
testMatrixInverse(height);
241+
#endif
240242
}
241243
}
242244

paddle/scripts/docker/build.sh

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -75,9 +75,8 @@ fi
7575

7676
paddle version
7777

78-
# generate production docker image Dockerfile
79-
if [ ${USE_MIRROR} ]; then
80-
MIRROR_UPDATE="sed 's@http:\/\/archive.ubuntu.com\/ubuntu\/@mirror:\/\/mirrors.ubuntu.com\/mirrors.txt@' -i /etc/apt/sources.list && \\"
78+
if [[ -n ${APT_MIRROR} ]]; then
79+
MIRROR_UPDATE="sed -i '${APT_MIRROR}' /etc/apt/sources.list && \\"
8180
else
8281
MIRROR_UPDATE="\\"
8382
fi
@@ -99,6 +98,7 @@ ADD build/*.deb /usr/local/opt/paddle/deb/
9998
# run paddle version to install python packages first
10099
RUN dpkg -i /usr/local/opt/paddle/deb/*.deb && \
101100
rm -f /usr/local/opt/paddle/deb/*.deb && \
101+
pip install /usr/opt/paddle/share/wheels/*.whl && \
102102
paddle version
103103
${CPU_DOCKER_PYTHON_HOME_ENV}
104104
${DOCKERFILE_CUDNN_DSO}

0 commit comments

Comments
 (0)