README.md 4.0 KB
Newer Older
J
Jason 已提交
1
# X2Paddle
J
Jason 已提交
2
[![License](https://img.shields.io/badge/license-Apache%202-blue.svg)](LICENSE)
J
Jason 已提交
3
[![Version](https://img.shields.io/github/release/PaddlePaddle/X2Paddle.svg)](https://github.com/PaddlePaddle/X2Paddle/releases)  
J
Jason 已提交
4 5 6
X2Paddle支持将其余深度学习框架训练得到的模型,转换至PaddlePaddle模型。  
X2Paddle is a toolkit for converting trained model to PaddlePaddle from other deep learning frameworks.

J
Jason 已提交
7
## 转换模型库
J
Jason 已提交
8
X2Paddle在多个主流的CV模型上,测试过TensorFlow/Caffe/ONNX模型的转换,可以在[X2Paddle-Model-Zoo](x2paddle_model_zoo.md)查看我们的模型测试列表。如果你在新的模型上进行了测试转换,也欢迎继续补充该列表;如若无法转换,可通过ISSUE反馈给我们,我们会尽快跟进。
J
Jason 已提交
9

J
Jason 已提交
10 11
## 环境依赖

M
mamingjie-China 已提交
12
python == 2.7 | python >= 3.5  
J
Jason 已提交
13
paddlepaddle >= 1.5.0  
J
Jason 已提交
14

J
Jason 已提交
15 16
**按需安装以下依赖**  
tensorflow : tensorflow == 1.14.0  
J
Jason 已提交
17
caffe : 无  
C
channingss 已提交
18
onnx : onnx == 1.5.0  onnxruntime == 0.4.0
J
Jason 已提交
19

J
Jason 已提交
20
## 安装
J
Jason 已提交
21 22
### 安装方式一(推荐)
使用最新的代码版本,可使用如下方式进行安装  
J
Jason 已提交
23
```
J
Jason 已提交
24
pip install git+https://github.com/PaddlePaddle/X2Paddle.git@develop
J
Jason 已提交
25
```
J
Jason 已提交
26

J
Jason 已提交
27
### 安装方式二
J
Jason 已提交
28
我们会定期更新pip源上的x2paddle版本
J
Jason 已提交
29
```
J
Jason 已提交
30
pip install x2paddle
J
Jason 已提交
31
```
J
Jason 已提交
32

J
Jason 已提交
33 34 35 36 37 38 39
### 安装方式三
```
git clone https://github.com/PaddlePaddle/X2Paddle.git
cd X2Paddle
git checkout develop
python setup.py install
```
J
Jason 已提交
40 41 42 43 44 45 46 47

## 使用方法
### TensorFlow
```
x2paddle --framework=tensorflow --model=tf_model.pb --save_dir=pd_model
```
### Caffe
```
S
SunAhong1993 已提交
48
x2paddle --framework=caffe --prototxt=deploy.proto --weight=deploy.caffemodel --save_dir=pd_model
J
Jason 已提交
49
```
J
Jason 已提交
50
### ONNX
C
channingss 已提交
51 52 53
```
x2paddle --framework=onnx --model=onnx_model.onnx --save_dir=pd_model
```
J
Jason 已提交
54 55 56
### 参数选项
| 参数 | |
|----------|--------------|
J
Jason 已提交
57
|--framework | 源模型类型 (tensorflow、caffe、onnx) |
S
SunAhong1993 已提交
58
|--prototxt | 当framework为caffe时,该参数指定caffe模型的proto文件路径 |
J
Jason 已提交
59 60
|--weight | 当framework为caffe时,该参数指定caffe模型的参数文件路径 |
|--save_dir | 指定转换后的模型保存目录路径 |
J
Jason 已提交
61
|--model | 当framework为tensorflow/onnx时,该参数指定tensorflow的pb模型文件或onnx模型路径 |
J
Jason 已提交
62 63 64
|--caffe_proto | **[可选]** 由caffe.proto编译成caffe_pb2.py文件的存放路径,当存在自定义Layer时使用,默认为None |
|--without_data_format_optimization | **[可选]** For TensorFlow, 当指定该参数时,关闭NHWC->NCHW的优化,见[文档Q2](FAQ.md) |
|--define_input_shape | **[可选]** For TensorFlow, 当指定该参数时,强制用户输入每个Placeholder的shape,见[文档Q2](FAQ.md) |
J
Jason 已提交
65

J
Jason 已提交
66

J
Jason 已提交
67 68 69 70 71
## 使用转换后的模型
转换后的模型包括`model_with_code``inference_model`两个目录。  
`model_with_code`中保存了模型参数,和转换后的python模型代码  
`inference_model`中保存了序列化的模型结构和参数,可直接使用paddle的接口进行加载,见[load_inference_model](https://www.paddlepaddle.org.cn/documentation/docs/zh/1.5/api_guides/low_level/inference.html#api-guide-inference)

J
Jason 已提交
72 73 74 75 76
## 小工具
X2Paddle提供了工具解决如下问题,详见[tools/README.md](tools/README.md)
1. 检测模型是否在PaddleLite中支持  
2. 合并模型参数文件

J
Jason 已提交
77
## 相关文档
J
Jason 已提交
78
1. [X2Paddle使用过程中常见问题](FAQ.md)  
J
Jason 已提交
79
2. [如何导出TensorFlow的pb模型](export_tf_model.md)
J
Jason 已提交
80 81
3. [X2Paddle测试模型库](x2paddle_model_zoo.md)  
4. [PyTorch模型导出为ONNX模型](pytorch_to_onnx.md)
J
Jason 已提交
82
5. [X2Paddle内置的Caffe自定义层](caffe_custom_layer.md)
J
jiangjiajun 已提交
83

J
Jason 已提交
84 85 86 87 88 89 90 91 92
## 更新历史
2019.08.05  
1. 统一tensorflow/caffe/onnx模型转换代码和对外接口
2. 解决上一版caffe2fluid无法转换多分支模型的问题
3. 解决Windows上保存模型无法加载的问题
4. 新增optimizer,优化代码结构,合并conv、batch_norm的bias和激活函数  

**如果你需要之前版本的tensorflow2fluid/caffe2fluid/onnx2fluid,可以继续访问release-0.3分支,获取之前版本的代码使用。**

J
Jason 已提交
93

J
jiangjiajun 已提交
94 95 96 97
## Acknowledgements

X2Paddle refers to the following projects:
- [MMdnn](https://github.com/microsoft/MMdnn)