Skip to content
This repository has been archived by the owner on Mar 1, 2023. It is now read-only.

Latest commit

 

History

History
84 lines (62 loc) · 5 KB

conditional_compilation.md

File metadata and controls

84 lines (62 loc) · 5 KB

OpenVINO Conditional Compilation

Contents

Introduction

Conditional compilation can significantly reduce OpenVINO™ binaries size by excluding unnecessary components for particular models inference. The following components can be excluded from the build:

  • Openrations and graph transformations in OpenVINO and plugins
  • jit kernels in a CPU plugin
  • arbitrary code that is not used for particular model inference

However, conditional compilation has a significant drawback - the resulting OpenVINO Runtime will work only with a limited set of models and devices.

There are 2 conditional compilation build stages: SELECTIVE_BUILD=COLLECT and SELECTIVE_BUILD=ON.

SELECTIVE_BUILD=COLLECT enables analyzed mode for annotated code regions, it can provide capability with the help of itt to collect some statistic data. Once this stage is completed, user need run openvino sample(such as benchmark_app) to generate actual statistic data and run itt_collector tool to dump them into cvs files. This statge can be enabled during build OpenVINO with options -DSELECTIVE_BUILD=COLLECT -DENABLE_PROFILING_ITT=ON

SELECTIVE_BUILD=ON excludes all annotated inactive code region out of compiled binaries with help of cvs files generated by itt_collector tool. It is done by a header file which generated from the cvs files. This stage need build OpenVINO with option -DSELECTIVE_BUILD=ON -DENABLE_PROFILING_ITT=OFF -DSELECTIVE_BUILD_STAT=<cc_data.csv>. Notice: -DENABLE_PROFILING_ITT=OFF is not must, if user wants to have ITT counters in final application, he can set it ON: -DENABLE_PROFILING_ITT=ON.

Note: If above options are not enabled, conditional compilation will be OFF and default behavior is kept, all features of OpenVINO are enabled. You can ignore SELECTIVE_BUILD or set option -DSELECTIVE_BUILD=OFF

Setup environment

To take advantage of conditional compilation, install the following tools:

Building for different models

Conditional compilation has two stages:

  • Collecting information about code usage
  • Building the result binaries without unused components or parts
flowchart LR
    subgraph collect[Collect statistic]
    cmake_collect[mkdir build\ncd build\ncmake -DENABLE_PROFILING_ITT=ON -DSELECTIVE_BUILD=COLLECT ..]
    build_collect[cmake --build .\ncmake --build . --target sea_itt_lib]
    run_collect["python ../thirdparty/itt_collector/runtool/sea_runtool.py --bindir ${OPENVINO_LIBRARY_DIR} \ \n-o ${MY_MODEL_RESULT} ! ./benchmark_app -niter 1 -nireq 1 -m ${MY_MODEL}.xml\n..."]
    cmake_collect-->build_collect
    build_collect-->run_collect
    run_collect-->run_collect
    end
    subgraph result[Build cutted OpenVINO]
    cmake_res["cmake -DSELECTIVE_BUILD=ON \ \n-DSELECTIVE_BUILD_STAT=${ABSOLUTE_PATH_TO_STATISTICS_FILES}/*.csv \ \n -DENABLE_PROFILING_ITT=OFF .."]
    build_res[cmake --build .]
    cmake_res-->build_res
    end
    collect --> result
Loading

To apply conditional compilation, follow the steps below:

  1. Perform code usage analysis:
    1. Run the CMake tool with the following options: -DENABLE_PROFILING_ITT=ON -DSELECTIVE_BUILD=COLLECT.
    2. Select several models to be used in a specific application or target device.
    3. Use the sea_itt_lib target to build the ITT collector.
    4. Run the target application under the ITT collector for code usage analysis for each model. Statistics are generated in the .csv format.
      python thirdparty/itt_collector/runtool/sea_runtool.py --bindir ${OPENVINO_LIBRARY_DIR} -o ${MY_MODEL_RESULT} ! ./benchmark_app -niter 1 -nireq 1 -m ${MY_MODEL}.xml
  2. Build the resulting binaries:
    1. Run the CMake tool with the following options: -DSELECTIVE_BUILD=ON -DSELECTIVE_BUILD_STAT=${ABSOLUTE_PATH_TO_STATISTICS_FILES}/*.csv -DENABLE_PROFILING_ITT=OFF
    2. cmake --build <cmake_build_directory>

The -niter 1 -nireq 1 flags are highly recommended for the benchmark_app. Otherwise, the trace files will be very large. If you are using an application other than benchmark_app, remember to limit the number of inference requests and iterations.

Building for devices with different ISA

Building for devices with different ISA is quite similar to building for different models (see the previous chapter). The differences are only in the code usage analysis step. The analysis step should be performed on target devices and all CSV files with statistics should be copied to the build machine. These files will be used for the final build.

Limitations

  • Currently, Ninja build system is not supported for the conditional compilation build.

See also