Yiqun Liu
Yiqun Liu
您好,similarity_net当前只提供了simnet_bow-pairwise的预训练模型。
### Profile结果 ``` -------------------------> Profiling Report CPU 5009 210.123 210.076980 (0.999782) 0.045869 (0.000218) 0.036519 0.996315 0.0419491 0.00221879 thread0::GpuMemcpyAsync:CPU->GPU 20036 204.476 173.512282 (0.848571) 30.963505 (0.151429) 0.007 1.77937 0.0102054 0.00215916 thread0::GpuMemcpySync:GPU->CPU 5009...
### TImeline分析 - 总体来说,GPU利用的比较满。 data:image/s3,"s3://crabby-images/69208/69208dc2c1c2718534328a214f4da21efc5df65a" alt="image" - 开始时GPU存在不少空闲 data:image/s3,"s3://crabby-images/b6541/b6541330df7338268c5c0fae34e304f526b8da3b" alt="image" - stack op里面有cuMalloc和cuFree操作,并且有2次cuda stream的同步操作 data:image/s3,"s3://crabby-images/784b1/784b12e282cd1ff99a51cfc0741f9cbf0effa479" alt="image" - 很多的reshape和transpose操作 - softmax是否使用cudnn?
### 优化方案 - [ ] 多个lookup_table操作的融合,@Xreki due to 2019年8月30日 - 有一个输入是[00000,11111]这样的id(只有0,1两个取值),有的实现里把这部分换成matmul data:image/s3,"s3://crabby-images/6a52c/6a52c1cee25acc77a68ebdd3933e326ef0bd662c" alt="image" - [ ] 确定模型中的reshape操作是否必须的,是否可以移除。很多reshape的输入输出shape看起来是一样的。@Xreki —— 见https://github.com/PaddlePaddle/benchmark/issues/165#issuecomment-521229670 - **不能直接移除** data:image/s3,"s3://crabby-images/6e960/6e960d4bed26c668090f3a5437f6699ba5de8447" alt="image" - [x] 预测时,dropout可转变成scale,@Xreki due to 2019年8月22日 —— 见https://github.com/PaddlePaddle/Paddle/pull/19297 -...
### Intel相关的一些工作 - 移除attention模块中的reshape和transpose op,https://github.com/PaddlePaddle/Paddle/pull/16342 - 扩展matmul,以支持multi-head,https://github.com/PaddlePaddle/Paddle/pull/18570
#### 确定模型中的reshape操作是否必须的,是否可以移除。很多reshape的输入输出shape看起来是一样的。@Xreki data:image/s3,"s3://crabby-images/6e960/6e960d4bed26c668090f3a5437f6699ba5de8447" alt="image" ```text I0814 10:13:53.083331 11085 operator.cc:170] CPUPlace Op(reshape2), inputs:{Shape[], ShapeTensor[], X[fc_0.tmp_1:float[1, 128, 768]({})]}, outputs:{Out[fc_0.tmp_1:float[1, 128, 768]({})], XShape[reshape2_0.tmp_0:[-1]({{}})]}. I0814 10:13:53.083364 11085 operator.cc:993] expected_kernel_key:data_type[float]:data_layout[ANY_LAYOUT]:place[CPUPlace]:library_type[PLAIN] I0814 10:13:53.083400 11085 tensor_util.cu:28] TensorCopy 1,...
### 优化效果汇总 - 单位:ms/sample | 版本 | P40时间 (Total) |时间 (去掉第一次run)| 测试时间 | PR |版本描述 | 加速效果 | |---|---|---|---|---|---|---| | 0 | 8.36 | | 2019-08-14 | - | baseline...
在版本1的基础上,在预测了使用了`fuse_elewise_add_act_pass`,可以融合`elementwise_add`+`relu`的计算,并成功匹配到14个子图,但总体性能下降。 ```text + /paddle/build_paddle/build_docker_manylinux_cuda90/paddle/fluid/inference/tests/api/samples/ernie_tester --logtostderr --model_dir=/data/ernie/model --data=/data/ernie/seq128_data/test_ds --repeat=1 --warmup_steps=1 --use_gpu=true --use_analysis=true --print_outputs=false --profile=false [==========] Running 1 test from 1 test case. [----------] Global test environment set-up. [----------] 1 test from...
`stack`与`concat`的功能类似。尝试: #### 方法一:用`concat`代替`stack`,运行出现错误,发现`stack`和`concat`输出的维度不一样,不可行 - `stack`输出的维度 ``` I0820 09:17:21.934635 17390 operator.cc:168] CUDAPlace(0) Op(stack), inputs:{X[scale_0.tmp_0:float[1, 128, 128]({}), scale_0.tmp_0:float[1, 128, 128]({}), scale_0.tmp_0:float[1, 128, 128]({}), scale_0.tmp_0:float[1, 128, 128]({}), scale_0.tmp_0:float[1, 128, 128]({}), scale_0.tmp_0:float[1, 128, 128]({}),...
**实现fc的GPU kernel** :https://github.com/PaddlePaddle/Paddle/pull/19687 **FC的融合**:https://github.com/PaddlePaddle/Paddle/pull/19733 - fc=mul+elementwise_add+relu,主要是将fc中的elementwise_add和relu计算融合起来。 - 测试结果,加速效果:2.1% ```text --- Running IR pass [fc_fuse_pass] --- detected 12 subgraphs WARNING: Logging before InitGoogleLogging() is written to STDERR I0909 06:52:40.161475 7826 fc_fuse_pass.cc:122]...