convert.py 18.1 KB
Newer Older
S
SunAhong1993 已提交
1
# Copyright (c) 2020  PaddlePaddle Authors. All Rights Reserved.
J
jiangjiajun 已提交
2 3 4 5 6 7 8 9 10 11 12 13
#
# Licensed under the Apache License, Version 2.0 (the "License"
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
S
SunAhong1993 已提交
14

15
from six import text_type as _text_type
S
SunAhong1993 已提交
16
from x2paddle import program
W
wjj19950828 已提交
17
from x2paddle.utils import ConverterCheck
18
import argparse
J
jiangjiajun 已提交
19
import sys
W
WJJ1995 已提交
20
import logging
W
wjj19950828 已提交
21
import time
22

J
jiangjiajun 已提交
23

24 25
def arg_parser():
    parser = argparse.ArgumentParser()
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
    parser.add_argument(
        "--model",
        "-m",
        type=_text_type,
        default=None,
        help="define model file path for tensorflow or onnx")
    parser.add_argument(
        "--prototxt",
        "-p",
        type=_text_type,
        default=None,
        help="prototxt file of caffe model")
    parser.add_argument(
        "--weight",
        "-w",
        type=_text_type,
        default=None,
        help="weight file of caffe model")
    parser.add_argument(
        "--save_dir",
        "-s",
        type=_text_type,
        default=None,
        help="path to save translated model")
J
upgrade  
jiangjiajun 已提交
50 51 52
    parser.add_argument(
        "--framework",
        "-f",
53 54 55 56
        type=_text_type,
        default=None,
        help="define which deeplearning framework(tensorflow/caffe/onnx/paddle2onnx)"
    )
S
SunAhong1993 已提交
57 58 59 60 61
    parser.add_argument(
        "--caffe_proto",
        "-c",
        type=_text_type,
        default=None,
J
upgrade  
jiangjiajun 已提交
62 63
        help="optional: the .py file compiled by caffe proto file of caffe model"
    )
64 65 66 67 68 69 70 71 72 73 74 75
    parser.add_argument(
        "--version",
        "-v",
        action="store_true",
        default=False,
        help="get version of x2paddle")
    parser.add_argument(
        "--define_input_shape",
        "-d",
        action="store_true",
        default=False,
        help="define input shape for tf model")
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
    parser.add_argument(
        "--convert_torch_project",
        "-tp",
        action='store_true',
        help="Convert the PyTorch Project.")
    parser.add_argument(
        "--project_dir",
        "-pd",
        type=_text_type,
        default=None,
        help="define project folder path for pytorch")
    parser.add_argument(
        "--pretrain_model",
        "-pm",
        type=_text_type,
        default=None,
        help="pretrain model file of pytorch model")
93 94 95 96 97
    parser.add_argument(
        "--enable_code_optim",
        "-co",
        default=True,
        help="Turn on code optimization")
W
wjj19950828 已提交
98 99 100 101
    parser.add_argument(
        "--disable_feedback",
        "-df",
        default=False,
W
wjj19950828 已提交
102
        help="Tune off feedback of model conversion.")
W
WJJ1995 已提交
103 104 105 106 107 108 109 110 111 112 113 114 115 116
    parser.add_argument(
        "--to_lite", "-tl", default=False, help="convert to Paddle-Lite format")
    parser.add_argument(
        "--lite_valid_places",
        "-vp",
        type=_text_type,
        default="arm",
        help="Specify the executable backend of the model")
    parser.add_argument(
        "--lite_model_type",
        "-mt",
        type=_text_type,
        default="naive_buffer",
        help="The type of lite model")
117

118
    return parser
J
jiangjiajun 已提交
119

C
Channingss 已提交
120

W
WJJ1995 已提交
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
def convert2lite(save_dir,
                 lite_valid_places="arm",
                 lite_model_type="naive_buffer"):
    """Convert to Paddle-Lite format."""

    from paddlelite.lite import Opt
    opt = Opt()
    opt.set_model_dir(save_dir + "/inference_model")
    opt.set_valid_places(lite_valid_places)
    opt.set_model_type(lite_model_type)
    opt.set_optimize_out(save_dir + "/opt")
    opt.run()


def tf2paddle(model_path,
              save_dir,
              define_input_shape=False,
              convert_to_lite=False,
              lite_valid_places="arm",
W
wjj19950828 已提交
140 141
              lite_model_type="naive_buffer",
              disable_feedback=False):
W
wjj19950828 已提交
142 143
    # for convert_id
    time_info = int(time.time())
W
wjj19950828 已提交
144
    if not disable_feedback:
W
wjj19950828 已提交
145 146 147
        ConverterCheck(
            task="TensorFlow", time_info=time_info,
            convert_state="Start").start()
J
jiangjiajun 已提交
148 149
    # check tensorflow installation and version
    try:
150 151
        import os
        os.environ["TF_CPP_MIN_LOG_LEVEL"] = '3'
J
jiangjiajun 已提交
152 153 154
        import tensorflow as tf
        version = tf.__version__
        if version >= '2.0.0' or version < '1.0.0':
W
WJJ1995 已提交
155
            logging.info(
W
WJJ1995 已提交
156
                "[ERROR] 1.0.0<=TensorFlow<2.0.0 is required, and v1.14.0 is recommended"
J
jiangjiajun 已提交
157 158 159
            )
            return
    except:
W
WJJ1995 已提交
160
        logging.info(
W
WJJ1995 已提交
161
            "[ERROR] TensorFlow is not installed, use \"pip install TensorFlow\"."
J
jiangjiajun@baidu.com 已提交
162
        )
J
jiangjiajun 已提交
163
        return
164

J
jiangjiajun 已提交
165
    from x2paddle.decoder.tf_decoder import TFDecoder
S
SunAhong1993 已提交
166
    from x2paddle.op_mapper.tf2paddle.tf_op_mapper import TFOpMapper
167

W
WJJ1995 已提交
168
    logging.info("Now translating model from TensorFlow to Paddle.")
169
    model = TFDecoder(model_path, define_input_shape=define_input_shape)
S
SunAhong1993 已提交
170
    mapper = TFOpMapper(model)
S
SunAhong1993 已提交
171
    mapper.paddle_graph.build()
W
WJJ1995 已提交
172
    logging.info("Model optimizing ...")
S
SunAhong1993 已提交
173 174 175
    from x2paddle.optimizer.optimizer import GraphOptimizer
    graph_opt = GraphOptimizer(source_frame="tf")
    graph_opt.optimize(mapper.paddle_graph)
W
WJJ1995 已提交
176
    logging.info("Model optimized!")
S
SunAhong1993 已提交
177
    mapper.paddle_graph.gen_model(save_dir)
W
WJJ1995 已提交
178
    logging.info("Successfully exported Paddle static graph model!")
W
wjj19950828 已提交
179
    if not disable_feedback:
W
wjj19950828 已提交
180 181 182
        ConverterCheck(
            task="TensorFlow", time_info=time_info,
            convert_state="Success").start()
W
WJJ1995 已提交
183
    if convert_to_lite:
W
WJJ1995 已提交
184
        logging.info("Now translating model from Paddle to Paddle Lite ...")
W
wjj19950828 已提交
185
        if not disable_feedback:
W
wjj19950828 已提交
186 187 188
            ConverterCheck(
                task="TensorFlow", time_info=time_info,
                lite_state="Start").start()
W
WJJ1995 已提交
189
        convert2lite(save_dir, lite_valid_places, lite_model_type)
W
WJJ1995 已提交
190
        logging.info("Successfully exported Paddle Lite support model!")
W
wjj19950828 已提交
191
        if not disable_feedback:
W
wjj19950828 已提交
192 193 194
            ConverterCheck(
                task="TensorFlow", time_info=time_info,
                lite_state="Success").start()
195 196 197 198 199 200 201 202
    # for convert survey
    logging.info("================================================")
    logging.info("")
    logging.info(
        "Model Convertd! Fill this survey to help X2Paddle better, https://iwenjuan.baidu.com/?code=npyd51 "
    )
    logging.info("")
    logging.info("================================================")
203 204


W
WJJ1995 已提交
205 206 207 208 209 210
def caffe2paddle(proto_file,
                 weight_file,
                 save_dir,
                 caffe_proto,
                 convert_to_lite=False,
                 lite_valid_places="arm",
W
wjj19950828 已提交
211 212
                 lite_model_type="naive_buffer",
                 disable_feedback=False):
W
wjj19950828 已提交
213 214
    # for convert_id
    time_info = int(time.time())
W
wjj19950828 已提交
215
    if not disable_feedback:
W
wjj19950828 已提交
216 217
        ConverterCheck(
            task="Caffe", time_info=time_info, convert_state="Start").start()
J
jiangjiajun 已提交
218
    from x2paddle.decoder.caffe_decoder import CaffeDecoder
S
SunAhong1993 已提交
219
    from x2paddle.op_mapper.caffe2paddle.caffe_op_mapper import CaffeOpMapper
S
SunAhong1993 已提交
220
    import google.protobuf as gpb
S
SunAhong1993 已提交
221 222 223
    ver_part = gpb.__version__.split('.')
    version_satisfy = False
    if (int(ver_part[0]) == 3 and int(ver_part[1]) >= 6) \
W
WJJ1995 已提交
224
            or (int(ver_part[0]) > 3):
S
SunAhong1993 已提交
225
        version_satisfy = True
J
jiangjiajun@baidu.com 已提交
226
    assert version_satisfy, '[ERROR] google.protobuf >= 3.6.0 is required'
W
WJJ1995 已提交
227
    logging.info("Now translating model from caffe to paddle.")
W
WJJ1995 已提交
228
    model = CaffeDecoder(proto_file, weight_file, caffe_proto)
J
jiangjiajun 已提交
229
    mapper = CaffeOpMapper(model)
S
SunAhong1993 已提交
230
    mapper.paddle_graph.build()
W
WJJ1995 已提交
231
    logging.info("Model optimizing ...")
S
SunAhong1993 已提交
232
    from x2paddle.optimizer.optimizer import GraphOptimizer
S
SunAhong1993 已提交
233
    graph_opt = GraphOptimizer(source_frame="caffe")
S
SunAhong1993 已提交
234
    graph_opt.optimize(mapper.paddle_graph)
W
WJJ1995 已提交
235
    logging.info("Model optimized!")
S
SunAhong1993 已提交
236
    mapper.paddle_graph.gen_model(save_dir)
W
WJJ1995 已提交
237
    logging.info("Successfully exported Paddle static graph model!")
W
wjj19950828 已提交
238
    if not disable_feedback:
W
wjj19950828 已提交
239 240
        ConverterCheck(
            task="Caffe", time_info=time_info, convert_state="Success").start()
W
WJJ1995 已提交
241
    if convert_to_lite:
W
WJJ1995 已提交
242
        logging.info("Now translating model from Paddle to Paddle Lite ...")
W
wjj19950828 已提交
243
        if not disable_feedback:
W
wjj19950828 已提交
244 245
            ConverterCheck(
                task="Caffe", time_info=time_info, lite_state="Start").start()
W
WJJ1995 已提交
246
        convert2lite(save_dir, lite_valid_places, lite_model_type)
W
WJJ1995 已提交
247
        logging.info("Successfully exported Paddle Lite support model!")
W
wjj19950828 已提交
248
        if not disable_feedback:
W
wjj19950828 已提交
249 250
            ConverterCheck(
                task="Caffe", time_info=time_info, lite_state="Success").start()
251 252 253 254 255 256 257 258
    # for convert survey
    logging.info("================================================")
    logging.info("")
    logging.info(
        "Model Convertd! Fill this survey to help X2Paddle better, https://iwenjuan.baidu.com/?code=npyd51 "
    )
    logging.info("")
    logging.info("================================================")
259 260


W
WJJ1995 已提交
261 262 263 264
def onnx2paddle(model_path,
                save_dir,
                convert_to_lite=False,
                lite_valid_places="arm",
W
wjj19950828 已提交
265 266
                lite_model_type="naive_buffer",
                disable_feedback=False):
W
wjj19950828 已提交
267 268
    # for convert_id
    time_info = int(time.time())
W
wjj19950828 已提交
269
    if not disable_feedback:
W
wjj19950828 已提交
270 271
        ConverterCheck(
            task="ONNX", time_info=time_info, convert_state="Start").start()
C
update  
channingss 已提交
272 273 274 275
    # check onnx installation and version
    try:
        import onnx
        version = onnx.version.version
W
WJJ1995 已提交
276 277 278
        v0, v1, v2 = version.split('.')
        version_sum = int(v0) * 100 + int(v1) * 10 + int(v2)
        if version_sum < 160:
W
WJJ1995 已提交
279
            logging.info("[ERROR] onnx>=1.6.0 is required")
C
update  
channingss 已提交
280 281
            return
    except:
W
WJJ1995 已提交
282 283
        logging.info(
            "[ERROR] onnx is not installed, use \"pip install onnx==1.6.0\".")
C
update  
channingss 已提交
284
        return
W
WJJ1995 已提交
285
    logging.info("Now translating model from onnx to paddle.")
C
update  
channingss 已提交
286 287

    from x2paddle.decoder.onnx_decoder import ONNXDecoder
S
SunAhong1993 已提交
288
    from x2paddle.op_mapper.onnx2paddle.onnx_op_mapper import ONNXOpMapper
R
root 已提交
289
    model = ONNXDecoder(model_path)
C
Channingss 已提交
290
    mapper = ONNXOpMapper(model)
S
SunAhong1993 已提交
291
    mapper.paddle_graph.build()
W
wjj19950828 已提交
292 293 294 295 296
    logging.info("Model optimizing ...")
    from x2paddle.optimizer.optimizer import GraphOptimizer
    graph_opt = GraphOptimizer(source_frame="onnx")
    graph_opt.optimize(mapper.paddle_graph)
    logging.info("Model optimized.")
S
SunAhong1993 已提交
297
    mapper.paddle_graph.gen_model(save_dir)
W
WJJ1995 已提交
298
    logging.info("Successfully exported Paddle static graph model!")
W
wjj19950828 已提交
299
    if not disable_feedback:
W
wjj19950828 已提交
300 301
        ConverterCheck(
            task="ONNX", time_info=time_info, convert_state="Success").start()
W
WJJ1995 已提交
302
    if convert_to_lite:
W
WJJ1995 已提交
303
        logging.info("Now translating model from Paddle to Paddle Lite ...")
W
wjj19950828 已提交
304
        if not disable_feedback:
W
wjj19950828 已提交
305 306
            ConverterCheck(
                task="ONNX", time_info=time_info, lite_state="Start").start()
W
WJJ1995 已提交
307
        convert2lite(save_dir, lite_valid_places, lite_model_type)
W
WJJ1995 已提交
308
        logging.info("Successfully exported Paddle Lite support model!")
W
wjj19950828 已提交
309
        if not disable_feedback:
W
wjj19950828 已提交
310 311
            ConverterCheck(
                task="ONNX", time_info=time_info, lite_state="Success").start()
312 313 314 315 316 317 318 319
    # for convert survey
    logging.info("================================================")
    logging.info("")
    logging.info(
        "Model Convertd! Fill this survey to help X2Paddle better, https://iwenjuan.baidu.com/?code=npyd51 "
    )
    logging.info("")
    logging.info("================================================")
C
Channingss 已提交
320 321


W
WJJ1995 已提交
322 323 324 325
def pytorch2paddle(module,
                   save_dir,
                   jit_type="trace",
                   input_examples=None,
326
                   enable_code_optim=True,
W
WJJ1995 已提交
327 328
                   convert_to_lite=False,
                   lite_valid_places="arm",
W
wjj19950828 已提交
329 330
                   lite_model_type="naive_buffer",
                   disable_feedback=False):
W
wjj19950828 已提交
331 332
    # for convert_id
    time_info = int(time.time())
W
wjj19950828 已提交
333
    if not disable_feedback:
W
wjj19950828 已提交
334 335
        ConverterCheck(
            task="PyTorch", time_info=time_info, convert_state="Start").start()
S
SunAhong1993 已提交
336 337 338 339
    # check pytorch installation and version
    try:
        import torch
        version = torch.__version__
W
WJJ1995 已提交
340 341 342 343 344 345 346
        v0, v1, v2 = version.split('.')
        # Avoid the situation where the version is equal to 1.7.0+cu101
        if '+' in v2:
            v2 = v2.split('+')[0]
        version_sum = int(v0) * 100 + int(v1) * 10 + int(v2)
        if version_sum < 150:
            logging.info(
W
WJJ1995 已提交
347
                "[ERROR] PyTorch>=1.5.0 is required, 1.6.0 is the most recommended"
W
WJJ1995 已提交
348
            )
S
SunAhong1993 已提交
349
            return
W
WJJ1995 已提交
350
        if version_sum > 160:
W
WJJ1995 已提交
351
            logging.info("[WARNING] PyTorch==1.6.0 is recommended")
S
SunAhong1993 已提交
352
    except:
W
WJJ1995 已提交
353
        logging.info(
W
WJJ1995 已提交
354
            "[ERROR] PyTorch is not installed, use \"pip install torch==1.6.0 torchvision\"."
S
SunAhong1993 已提交
355 356
        )
        return
W
WJJ1995 已提交
357
    logging.info("Now translating model from PyTorch to Paddle.")
358

S
SunAhong1993 已提交
359
    from x2paddle.decoder.pytorch_decoder import ScriptDecoder, TraceDecoder
S
SunAhong1993 已提交
360
    from x2paddle.op_mapper.pytorch2paddle.pytorch_op_mapper import PyTorchOpMapper
S
SunAhong1993 已提交
361

S
SunAhong1993 已提交
362
    if jit_type == "trace":
S
SunAhong1993 已提交
363
        model = TraceDecoder(module, input_examples)
S
SunAhong1993 已提交
364
    else:
S
SunAhong1993 已提交
365
        model = ScriptDecoder(module, input_examples)
S
SunAhong1993 已提交
366 367
    mapper = PyTorchOpMapper(model)
    mapper.paddle_graph.build()
W
WJJ1995 已提交
368
    logging.info("Model optimizing ...")
S
SunAhong1993 已提交
369
    from x2paddle.optimizer.optimizer import GraphOptimizer
S
SunAhong1993 已提交
370
    graph_opt = GraphOptimizer(source_frame="pytorch", jit_type=jit_type)
S
SunAhong1993 已提交
371
    graph_opt.optimize(mapper.paddle_graph)
W
WJJ1995 已提交
372
    logging.info("Model optimized!")
373 374
    mapper.paddle_graph.gen_model(
        save_dir, jit_type=jit_type, enable_code_optim=enable_code_optim)
W
WJJ1995 已提交
375
    logging.info("Successfully exported Paddle static graph model!")
W
wjj19950828 已提交
376
    if not disable_feedback:
W
wjj19950828 已提交
377 378 379
        ConverterCheck(
            task="PyTorch", time_info=time_info,
            convert_state="Success").start()
W
WJJ1995 已提交
380
    if convert_to_lite:
W
WJJ1995 已提交
381
        logging.info("Now translating model from Paddle to Paddle Lite ...")
W
wjj19950828 已提交
382
        if not disable_feedback:
W
wjj19950828 已提交
383 384
            ConverterCheck(
                task="PyTorch", time_info=time_info, lite_state="Start").start()
W
WJJ1995 已提交
385
        convert2lite(save_dir, lite_valid_places, lite_model_type)
W
WJJ1995 已提交
386
        logging.info("Successfully exported Paddle Lite support model!")
W
wjj19950828 已提交
387
        if not disable_feedback:
W
wjj19950828 已提交
388 389 390
            ConverterCheck(
                task="PyTorch", time_info=time_info,
                lite_state="Success").start()
391 392 393 394 395 396 397 398
    # for convert survey
    logging.info("================================================")
    logging.info("")
    logging.info(
        "Model Convertd! Fill this survey to help X2Paddle better, https://iwenjuan.baidu.com/?code=npyd51 "
    )
    logging.info("")
    logging.info("================================================")
S
SunAhong1993 已提交
399 400


401
def main():
W
WJJ1995 已提交
402
    logging.basicConfig(level=logging.INFO)
J
jiangjiajun 已提交
403
    if len(sys.argv) < 2:
W
WJJ1995 已提交
404 405 406 407
        logging.info("Use \"x2paddle -h\" to print the help information")
        logging.info(
            "For more information, please follow our github repo below:)")
        logging.info("\nGithub: https://github.com/PaddlePaddle/X2Paddle.git\n")
J
jiangjiajun 已提交
408 409
        return

410 411 412
    parser = arg_parser()
    args = parser.parse_args()

J
jiangjiajun 已提交
413
    if args.version:
J
jiangjiajun 已提交
414
        import x2paddle
W
WJJ1995 已提交
415 416
        logging.info("x2paddle-{} with python>=3.5, paddlepaddle>=1.6.0\n".
                     format(x2paddle.__version__))
J
jiangjiajun 已提交
417 418
        return

419 420
    if not args.convert_torch_project:
        assert args.framework is not None, "--framework is not defined(support tensorflow/caffe/onnx)"
S
SunAhong1993 已提交
421 422
    assert args.save_dir is not None, "--save_dir is not defined"

M
mamingjie-China 已提交
423
    try:
S
add lrn  
SunAhong1993 已提交
424 425
        import platform
        v0, v1, v2 = platform.python_version().split('.')
426
        if not (int(v0) >= 3 and int(v1) >= 5):
W
WJJ1995 已提交
427
            logging.info("[ERROR] python>=3.5 is required")
S
add lrn  
SunAhong1993 已提交
428
            return
M
mamingjie-China 已提交
429 430
        import paddle
        v0, v1, v2 = paddle.__version__.split('.')
W
WJJ1995 已提交
431
        logging.info("paddle.__version__ = {}".format(paddle.__version__))
432
        if v0 == '0' and v1 == '0' and v2 == '0':
W
WJJ1995 已提交
433 434
            logging.info(
                "[WARNING] You are use develop version of paddlepaddle")
S
SunAhong1993 已提交
435
        elif int(v0) != 2 or int(v1) < 0:
W
WJJ1995 已提交
436
            logging.info("[ERROR] paddlepaddle>=2.0.0 is required")
M
mamingjie-China 已提交
437 438
            return
    except:
W
WJJ1995 已提交
439
        logging.info(
J
jiangjiajun@baidu.com 已提交
440 441
            "[ERROR] paddlepaddle not installed, use \"pip install paddlepaddle\""
        )
442

443 444 445 446 447 448 449 450 451 452
    if args.convert_torch_project:
        assert args.project_dir is not None, "--project_dir should be defined while translating pytorch project"
        from x2paddle.project_convertor.pytorch.convert import main as convert_torch
        convert_torch(args)
    else:
        if args.framework == "tensorflow":
            assert args.model is not None, "--model should be defined while translating tensorflow model"
            define_input_shape = False
            if args.define_input_shape:
                define_input_shape = True
W
WJJ1995 已提交
453 454 455 456 457 458
            tf2paddle(
                args.model,
                args.save_dir,
                define_input_shape,
                convert_to_lite=args.to_lite,
                lite_valid_places=args.lite_valid_places,
W
wjj19950828 已提交
459 460
                lite_model_type=args.lite_model_type,
                disable_feedback=args.disable_feedback)
461

462 463
        elif args.framework == "caffe":
            assert args.prototxt is not None and args.weight is not None, "--prototxt and --weight should be defined while translating caffe model"
W
WJJ1995 已提交
464 465 466 467 468 469 470
            caffe2paddle(
                args.prototxt,
                args.weight,
                args.save_dir,
                args.caffe_proto,
                convert_to_lite=args.to_lite,
                lite_valid_places=args.lite_valid_places,
W
wjj19950828 已提交
471 472
                lite_model_type=args.lite_model_type,
                disable_feedback=args.disable_feedback)
473 474
        elif args.framework == "onnx":
            assert args.model is not None, "--model should be defined while translating onnx model"
W
WJJ1995 已提交
475 476 477 478 479
            onnx2paddle(
                args.model,
                args.save_dir,
                convert_to_lite=args.to_lite,
                lite_valid_places=args.lite_valid_places,
W
wjj19950828 已提交
480 481
                lite_model_type=args.lite_model_type,
                disable_feedback=args.disable_feedback)
482
        elif args.framework == "paddle2onnx":
W
WJJ1995 已提交
483
            logging.info(
484 485
                "Paddle to ONNX tool has been migrated to the new github: https://github.com/PaddlePaddle/paddle2onnx"
            )
486

487 488 489
        else:
            raise Exception(
                "--framework only support tensorflow/caffe/onnx now")
490 491 492


if __name__ == "__main__":
S
SunAhong1993 已提交
493
    main()