Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Бенчмаркинг PaddlePaddle] Реализация пайплайна для PaddlePaddle #508

Merged
Merged
Show file tree
Hide file tree
Changes from 41 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
8f8ca1e
init
IgorKonovalovAleks Mar 3, 2024
d39ce82
style fix, input fix
IgorKonovalovAleks Mar 10, 2024
5853169
style fix
IgorKonovalovAleks Mar 10, 2024
56d0529
gpu device support
IgorKonovalovAleks Mar 19, 2024
3ccef36
style 1
IgorKonovalovAleks Mar 20, 2024
a216280
parser arguments + output handling fix
IgorKonovalovAleks Mar 25, 2024
fcedaec
parameters parser
IgorKonovalovAleks Apr 20, 2024
571a573
init
IgorKonovalovAleks Mar 3, 2024
e4f28c8
style fix, input fix
IgorKonovalovAleks Mar 10, 2024
8e3bbaf
style fix
IgorKonovalovAleks Mar 10, 2024
8eae024
gpu device support
IgorKonovalovAleks Mar 19, 2024
d30fbdc
style 1
IgorKonovalovAleks Mar 20, 2024
472f920
parser arguments + output handling fix
IgorKonovalovAleks Mar 25, 2024
62177bc
parameters parser
IgorKonovalovAleks Apr 20, 2024
770b1df
config + model download
IgorKonovalovAleks Apr 21, 2024
12a50a3
Merge remote-tracking branch 'origin/paddlepaddle_inference' into pad…
IgorKonovalovAleks Apr 21, 2024
a59847c
config fix
IgorKonovalovAleks Apr 21, 2024
1358078
config fix 1
IgorKonovalovAleks Apr 21, 2024
1658a07
framework wrapper
IgorKonovalovAleks Apr 21, 2024
c1de22c
command line fix
IgorKonovalovAleks Apr 21, 2024
2eb6594
command line fix 1
IgorKonovalovAleks Apr 21, 2024
9f18ee2
command line fix 2
IgorKonovalovAleks Apr 21, 2024
40b2ef4
command line fix 3
IgorKonovalovAleks Apr 23, 2024
b1ec5ab
command line fix 4
IgorKonovalovAleks Apr 28, 2024
9529fb4
requirements update
IgorKonovalovAleks Apr 28, 2024
6f47a12
args
IgorKonovalovAleks Apr 28, 2024
a8603be
command line fix 5
IgorKonovalovAleks Apr 29, 2024
54dbec5
model path and input shape requirement
IgorKonovalovAleks May 8, 2024
14bb7e6
Merge branch 'master' into paddlepaddle_inference
IgorKonovalovAleks May 8, 2024
9368060
model path fix
IgorKonovalovAleks May 8, 2024
86b695e
Merge remote-tracking branch 'origin/paddlepaddle_inference' into pad…
IgorKonovalovAleks May 8, 2024
4dc1cff
Dockerfile added
IgorKonovalovAleks May 11, 2024
beeaed1
validation results
IgorKonovalovAleks Jun 9, 2024
8433b04
Merge branch 'master' into paddlepaddle_inference
IgorKonovalovAleks Sep 12, 2024
34d14b3
paddlepaddle url updated
IgorKonovalovAleks Sep 19, 2024
e8c8b19
paddlepaddle readme updates
IgorKonovalovAleks Oct 10, 2024
b4dbc87
Merge remote-tracking branch 'origin/paddlepaddle_inference' into pad…
IgorKonovalovAleks Oct 10, 2024
c0406bb
docker fix
IgorKonovalovAleks Oct 24, 2024
66f1e71
requested fixes
IgorKonovalovAleks Oct 26, 2024
7628abf
line length fix
IgorKonovalovAleks Oct 26, 2024
e94eb90
requested changes 2
IgorKonovalovAleks Oct 28, 2024
9141c43
general try-catch
IgorKonovalovAleks Oct 31, 2024
c28dacb
try-except format
IgorKonovalovAleks Nov 7, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ DLI supports inference using the following frameworks:
- [Spektral][spektral] (Python API).
- [RKNN][rknn] (C++ API).
- [ncnn][ncnn] (Python API).
- [PaddlePaddle][PaddlePaddle] (Python API).

More information about DLI is available on the web-site
([here][dli-ru-web-page] (in Russian)
Expand Down Expand Up @@ -95,6 +96,7 @@ p Learning Inference Benchmark //
- `TVM` is a directory of Dockerfiles for Apache TVM.
- `TensorFlow` is a directory of Dockerfiles for Intel® Optimizations
for TensorFlow.
- `PaddlePaddle` is a directory of Dockerfiles for PaddlePaddle.

- `docs` directory contains auxiliary documentation. Please, find
complete documentation at the [Wiki page][dli-wiki].
Expand Down Expand Up @@ -262,6 +264,7 @@ Report questions, issues and suggestions, using:
[spektral]: https://graphneural.network
[rknn]: https://github.com/rockchip-linux/rknn-toolkit2
[ncnn]: https://github.com/Tencent/ncnn
[PaddlePaddle]: https://www.paddlepaddle.org.cn/en
[benchmark-app]: https://github.com/openvinotoolkit/openvino/tree/master/samples/cpp/benchmark_app
[dli-ru-web-page]: http://hpc-education.unn.ru/dli-ru
[dli-web-page]: http://hpc-education.unn.ru/dli
Expand Down
26 changes: 26 additions & 0 deletions docker/PaddlePaddle/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
FROM ubuntu_for_dli

WORKDIR /root/
ARG PADDLE_VERSION=2.5.2
RUN pip3 install --upgrade pip && \
pip3 install opencv-python requests PyYAML docker

WORKDIR /tmp/
RUN mkdir resnet50_paddle
WORKDIR /tmp/resnet50_paddle/
RUN wget -q https://github.com/itlab-vision/itlab-vision-dl-benchmark-models/tree/main/paddlepaddle_models/resnet50/resnet50/inference.pdmodel
RUN wget -q https://github.com/itlab-vision/itlab-vision-dl-benchmark-models/tree/main/paddlepaddle_models/resnet50/resnet50/inference.pdiparams
WORKDIR /tmp/
RUN wget https://paddle-inference-dist.bj.bcebos.com/Paddle-Inference-Demo/resnet50.tgz
RUN tar xzf resnet50.tgz
RUN python3 -m pip install paddlepaddle==${PADDLE_VERSION} -i https://pypi.tuna.tsinghua.edu.cn/simple

WORKDIR /tmp/open_model_zoo/tools/accuracy_checker
COPY config_paddle.yml config_paddle.yml

RUN python3 setup.py install_core

RUN accuracy_check -c config_paddle.yml -m ../../../resnet50 -s sample

WORKDIR /tmp/

30 changes: 30 additions & 0 deletions docker/PaddlePaddle/config_paddle.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
models:
- name: resnet50
launchers:
- framework: paddle_paddle
device: cpu
model: inference.pdmodel
params: inference.pdiparams
adapter: classification

datasets:
- name: sample_dataset
data_source: sample_dataset/test
annotation_conversion:
converter: cifar
data_batch_file: cifar-10-batches-py/test_batch
convert_images: True
converted_images_dir: sample_dataset/test
num_classes: 10

preprocessing:
- type: resize
size: 224
- type: bgr_to_rgb
- type: normalization
mean: (127.5, 127.5, 127.5)
std: (127.5, 127.5, 127.5)

metrics:
- type: accuracy
top_k: 1
5 changes: 5 additions & 0 deletions requirements_frameworks.txt
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,10 @@ dgl==2.0.0
--find-links https://data.dgl.ai/wheels-test/repo.html
dglgo==0.0.2

tflite

paddlepaddle==2.6.0
--extra-index-url https://mirror.baidu.com/pypi/simple

ncnn
spektral==1.3.0
15 changes: 15 additions & 0 deletions results/paddlepaddle_models_checklist.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Model validation and performance analysis status for PaddlePaddle

## Public models (PaddleClas)

Represented deep models are available in [PaddleClas Repository][pcr].

### Image classification

Model | Availability in OMZ (2024.10.24) | Availability in the validation table |
-|-|-|
resnet-50|-|+|
PPLCNet_x1_0_infer|-|+|

<!-- LINKS -->
[pcr]: https://github.com/PaddlePaddle/PaddleClas/blob/release/2.5.2/docs/en/models/index.rst
53 changes: 53 additions & 0 deletions results/validation/validation_results_paddlepaddle.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
# Validation results for the models inferring using PaddlePaddle
valentina-kustikova marked this conversation as resolved.
Show resolved Hide resolved

## Image classification

### Test image #1

Data source: [ImageNet][imagenet]

Image resolution: 709 x 510

<div style='float: center'>
<img width="150" src="images\ILSVRC2012_val_00000023.JPEG"></img>
</div>

Model | Parameters | Python API |
-|-|-|
resnet-50 |Mean values - [123.675,116.28,103.53],<br>scale value - [58.395,57.12,57.375]|0.9931559 Granny Smith<br>0.0009120 piggy bank, penny bank<br>0.0007721 bell pepper<br>0.0007689 tennis ball<br>0.0005548 candle, taper, wax light|
PPLCNet_x1_0_infer |Mean values - [123.675,116.28,103.53],<br>scale value - [58.395,57.12,57.375]|0.2785943 Granny Smith<br>0.2241544 piggy bank, penny bank<br>0.0404602 saltshaker, salt shaker<br>0.0131707 soap dispenser<br>0.0114298 lemon|

### Test image #2

Data source: [ImageNet][imagenet]

Image resolution: 500 x 500

<div style='float: center'>
<img width="150" src="images\ILSVRC2012_val_00000247.JPEG">
</div>

Model | Parameters | Python API |
-|-|-|
resnet-50 |Mean values - [123.675,116.28,103.53],<br>scale value - [58.395,57.12,57.375]|0.9891654 junco, snowbird<br>0.0044086 chickadee<br>0.0033522 water ouzel, dipper<br>0.0014910 brambling, Fringilla montifringilla<br>0.0003624 indigo bunting, indigo finch, indigo bird, Passerina cyanea|
PPLCNet_x1_0_infer |Mean values - [123.675,116.28,103.53],<br>scale value - [58.395,57.12,57.375]|0.8259031 junco, snowbird<br>0.0340593 brambling, Fringilla montifringilla<br>0.0055266 chickadee<br>0.0050722 house finch, linnet, Carpodacus mexicanus<br>0.0034595 bulbul|

### Test image #3

Data source: [ImageNet][imagenet]

Image resolution: 333 x 500

<div style='float: center'>
<img width="150" src="images\ILSVRC2012_val_00018592.JPEG">
</div>

Model | Parameters | Python API |
-|-|-|
resnet-50 |Mean values - [123.675,116.28,103.53],<br>scale value - [58.395,57.12,57.375]|0.3656897 liner, ocean liner<br>0.1008371 container ship, containership, container vessel<br>0.0759774 dock, dockage, docking facility<br>0.0707850 lifeboat<br>0.0556011 breakwater, groin, groyne, mole, bulwark, seawall, jetty|
PPLCNet_x1_0_infer |Mean values - [123.675,116.28,103.53],<br>scale value - [58.395,57.12,57.375]|0.1249109 submarine, pigboat, sub, U-boat<br>0.1198353 breakwater, groin, groyne, mole, bulwark, seawall, jetty <br>0.0568103 liner, ocean liner<br>0.0351734 lifeboat<br>0.0326451 dock, dockage, docking facility|

<!-- LINKS -->
[imagenet]: http://www.image-net.org
[ms_coco]: http://cocodataset.org
[PASCAL_VOC_2012]: http://host.robots.ox.ac.uk/pascal/VOC/voc2012
4 changes: 3 additions & 1 deletion src/benchmark/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ the following frameworks:
- [Apache TVM][tvm] (Python API).
- [RKNN][rknn].
- [Spektral][spektral] (Python API).
- [PaddlePaddle][paddlepaddle] (Python API).

### Implemented algorithm

Expand Down Expand Up @@ -115,7 +116,7 @@ For **the throughput mode**, performance metrics are provided below.
**Note:** published tables contain only FPS indicators (until 06.2023
the table contained Batch FPS indicators).

### Metrics for Intel® Optimization for Caffe, Intel® Optimizations for TensorFlow, TensorFlow Lite, OpenCV, MXNet, PyTorch and ONNX Runtime
### Metrics for Intel® Optimization for Caffe, Intel® Optimizations for TensorFlow, TensorFlow Lite, OpenCV, MXNet, PyTorch, PaddlePaddle and ONNX Runtime

Inference performance evaluations for Intel® Optimization for Caffe,
Intel® Optimizations for TensorFlow, TensorFlow Lite, OpenCV, MXNet,
Expand Down Expand Up @@ -272,3 +273,4 @@ pip install openvino_dev[mxnet,caffe,caffe2,onnx,pytorch,tensorflow2]==<your ver
[tvm]: https://tvm.apache.org
[rknn]: https://github.com/rockchip-linux/rknpu2
[spektral]: https://graphneural.network
[paddlepaddle]: https://www.paddlepaddle.org.cn/en
3 changes: 3 additions & 0 deletions src/benchmark/config_parser_factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
from frameworks.known_frameworks import KnownFrameworks
from frameworks.openvino.openvino_parameters_parser import OpenVINOParametersParser
from frameworks.tensorflow.tensorflow_parameters_parser import TensorFlowParametersParser
from frameworks.paddlepaddle.paddlepaddle_parameters_parser import PaddlePaddleParametersParser
from frameworks.tensorflow_lite.tensorflow_lite_parameters_parser import TensorFlowLiteParametersParser
from frameworks.mxnet.mxnet_parameters_parser import MXNetParametersParser
from frameworks.opencv_dnn_python.opencv_dnn_python_parameters_parser import OpenCVDNNPythonParametersParser
Expand All @@ -19,6 +20,8 @@ def get_parameters_parser(framework):
return IntelCaffeParametersParser()
if framework == KnownFrameworks.tensorflow:
return TensorFlowParametersParser()
if framework == KnownFrameworks.paddlepaddle:
return PaddlePaddleParametersParser()
if framework == KnownFrameworks.openvino_dldt:
return OpenVINOParametersParser()
if framework == KnownFrameworks.onnx_runtime:
Expand Down
2 changes: 2 additions & 0 deletions src/benchmark/frameworks/framework_wrapper_registry.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
from .onnx_runtime.onnx_runtime_wrapper import OnnxRuntimeWrapper
from .onnx_runtime_python.onnx_runtime_python_wrapper import ONNXRuntimePythonWrapper
from .tensorflow_lite.tensorflow_lite_wrapper import TensorFlowLiteWrapper
from .paddlepaddle.paddlepaddle_wrapper import PaddlePaddleWrapper
from .tensorflow_lite_cpp.tensorflow_lite_cpp_wrapper import TensorFlowLiteCppWrapper
from .opencv_dnn_python.opencv_dnn_python_wrapper import OpenCVDNNPythonWrapper
from .mxnet.mxnet_wrapper import MXNetWrapper
Expand Down Expand Up @@ -42,6 +43,7 @@ def _get_wrappers(self):
self._framework_wrappers[IntelCaffeWrapper.framework_name] = IntelCaffeWrapper()
self._framework_wrappers[TensorFlowWrapper.framework_name] = TensorFlowWrapper()
self._framework_wrappers[OpenVINOWrapper.framework_name] = OpenVINOWrapper()
self._framework_wrappers[PaddlePaddleWrapper.framework_name] = PaddlePaddleWrapper()
self._framework_wrappers[OnnxRuntimeWrapper.framework_name] = OnnxRuntimeWrapper()
self._framework_wrappers[ONNXRuntimePythonWrapper.framework_name] = ONNXRuntimePythonWrapper()
self._framework_wrappers[TensorFlowLiteWrapper.framework_name] = TensorFlowLiteWrapper()
Expand Down
1 change: 1 addition & 0 deletions src/benchmark/frameworks/known_frameworks.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
class KnownFrameworks:
paddlepaddle = 'PaddlePaddle'
openvino_dldt = 'OpenVINO DLDT'
tensorflow = 'TensorFlow'
caffe = 'Caffe'
Expand Down
Empty file.
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
from ..config_parser.dependent_parameters_parser import DependentParametersParser
from ..config_parser.framework_parameters_parser import FrameworkParameters


class PaddlePaddleParametersParser(DependentParametersParser):
def parse_parameters(self, curr_test):
CONFIG_FRAMEWORK_DEPENDENT_TAG = 'FrameworkDependent'
CONFIG_FRAMEWORK_DEPENDENT_CHANNEL_SWAP_TAG = 'ChannelSwap'
CONFIG_FRAMEWORK_DEPENDENT_MEAN_TAG = 'Mean'
CONFIG_FRAMEWORK_DEPENDENT_INPUT_SCALE_TAG = 'InputScale'
CONFIG_FRAMEWORK_DEPENDENT_INPUT_SHAPE_TAG = 'InputShape'
CONFIG_FRAMEWORK_DEPENDENT_INPUT_NAMES_TAG = 'InputName'
CONFIG_FRAMEWORK_DEPENDENT_OUTPUT_NAMES_TAG = 'OutputNames'
CONFIG_FRAMEWORK_DEPENDENT_THREAD_COUNT_TAG = 'ThreadCount'
valentina-kustikova marked this conversation as resolved.
Show resolved Hide resolved
CONFIG_FRAMEWORK_DEPENDENT_GPU_MEM_SIZE_TAG = 'GPUMemSize'

dep_parameters_tag = curr_test.getElementsByTagName(CONFIG_FRAMEWORK_DEPENDENT_TAG)[0]

_channel_swap = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_CHANNEL_SWAP_TAG)[0].firstChild
_mean = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_MEAN_TAG)[0].firstChild
_input_scale = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_INPUT_SCALE_TAG)[0].firstChild
_input_shape = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_INPUT_SHAPE_TAG)[0].firstChild
_input_names = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_INPUT_NAMES_TAG)[0].firstChild
_output_names = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_OUTPUT_NAMES_TAG)[0].firstChild
_thread_count = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_THREAD_COUNT_TAG)[0].firstChild
_gpu_mem_size = dep_parameters_tag.getElementsByTagName(
CONFIG_FRAMEWORK_DEPENDENT_GPU_MEM_SIZE_TAG)[0].firstChild

return PaddlePaddleParameters(
channel_swap=_channel_swap.data if _channel_swap else None,
mean=_mean.data if _mean else None,
input_scale=_input_scale.data if _input_scale else None,
input_shapes=_input_shape.data if _input_shape else None,
input_name=_input_names.data if _input_names else None,
output_names=_output_names.data if _output_names else None,
thread_count=_thread_count.data if _thread_count else None,
gpu_mem_size=_gpu_mem_size.data if _gpu_mem_size else None,
)


class PaddlePaddleParameters(FrameworkParameters):
def __init__(self, channel_swap, mean, input_scale, input_shapes, output_names, input_name,
thread_count, gpu_mem_size):
self.channel_swap = None
self.mean = None
self.input_scale = None
self.input_shape = None
self.input_name = None
self.output_names = None
self.nthreads = None
self.gpu_mem_size = None

if self._parameter_is_not_none(channel_swap):
self.channel_swap = self._process_sequence_arg(channel_swap)
if self._parameter_is_not_none(mean):
self.mean = self._process_sequence_arg(mean)
if self._parameter_is_not_none(input_scale):
self.input_scale = self._process_sequence_arg(input_scale)
if self._parameter_is_not_none(input_shapes):
self.input_shape = self._process_sequence_arg(input_shapes)
if self._parameter_is_not_none(input_name):
self.input_name = input_name
if self._parameter_is_not_none(output_names):
self.output_names = output_names
if self._parameter_is_not_none(thread_count):
if self._int_value_is_correct(thread_count):
self.nthreads = thread_count
else:
raise ValueError('Threads count can only take integer value')
if self._parameter_is_not_none(gpu_mem_size):
self.output_names = gpu_mem_size

@staticmethod
def _process_sequence_arg(sequence):
if '[' not in sequence:
sequence = f'[{sequence}]'
if ',' not in sequence:
sequence = sequence.replace(' ', ',')
return sequence
67 changes: 67 additions & 0 deletions src/benchmark/frameworks/paddlepaddle/paddlepaddle_process.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
from pathlib import Path

from ..processes import ProcessHandler


class PaddlePaddleProcess(ProcessHandler):
benchmark_app_name = 'paddlepaddle_benchmark'
launcher_latency_units = 'seconds'

def __init__(self, test, executor, log):
super().__init__(test, executor, log)

@staticmethod
def create_process(test, executor, log):
return PaddlePaddleProcess(test, executor, log)

def get_performance_metrics(self):
return self.get_performance_metrics_from_json_report()

def _fill_command_line(self):
path_to_paddlepaddle_script = Path.joinpath(self.inference_script_root, 'inference_paddlepaddle.py')
python = ProcessHandler.get_cmd_python_version()

model = self._test.model.model
params = self._test.model.weight
dataset = self._test.dataset.path if self._test.dataset else None
batch = self._test.indep_parameters.batch_size
device = self._test.indep_parameters.device

common_params = (f'-m {model} -p {params} -i {dataset} -b {batch} -d {device} '
f'--report_path {self.report_path}')

common_params = self._add_optional_argument_to_cmd_line(common_params, '-i', dataset)

time_limit = self._test.indep_parameters.test_time_limit
common_params = self._add_optional_argument_to_cmd_line(common_params, '--time', time_limit)

channel_swap = self._test.dep_parameters.channel_swap
common_params = self._add_optional_argument_to_cmd_line(common_params, '--channel_swap', channel_swap)

mean = self._test.dep_parameters.mean
common_params = self._add_optional_argument_to_cmd_line(common_params, '--mean', mean)

input_scale = self._test.dep_parameters.input_scale
common_params = self._add_optional_argument_to_cmd_line(common_params, '--input_scale', input_scale)

input_shape = self._test.dep_parameters.input_shape
common_params = self._add_optional_argument_to_cmd_line(common_params, '--input_shapes', input_shape)

input_name = self._test.dep_parameters.input_name
common_params = self._add_optional_argument_to_cmd_line(common_params, '--input_names', input_name)

output_names = self._test.dep_parameters.output_names
common_params = self._add_optional_argument_to_cmd_line(common_params, '--output_names', output_names)

gpu_mem_size = self._test.dep_parameters.gpu_mem_size
common_params = (
self._add_optional_argument_to_cmd_line(common_params, '--memory_pool_init_size_mb', gpu_mem_size))

common_params = self._add_argument_to_cmd_line(common_params, '--raw_output', 'true')

command_line = f'{python} {path_to_paddlepaddle_script} {common_params}'

nthreads = self._test.dep_parameters.nthreads
command_line = self._add_optional_argument_to_cmd_line(command_line, '-nthreads', nthreads)

return command_line
15 changes: 15 additions & 0 deletions src/benchmark/frameworks/paddlepaddle/paddlepaddle_wrapper.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
from .paddlepaddle_process import PaddlePaddleProcess
from ..config_parser.test_reporter import Test
from ..framework_wrapper import FrameworkWrapper


class PaddlePaddleWrapper(FrameworkWrapper):
framework_name = 'PaddlePaddle'

@staticmethod
def create_process(test, executor, log, cpp_benchmark_path=None, **kwargs):
return PaddlePaddleProcess.create_process(test, executor, log)

@staticmethod
def create_test(model, dataset, indep_parameters, dep_parameters):
return Test(model, dataset, indep_parameters, dep_parameters)
Loading
Loading