Skip to content

BuildingForMacOS_x86_64

Ilya Lavrenov edited this page Sep 17, 2022 · 18 revisions

Build on macOS* Systems for Intel CPU

This guide shows how to build OpenVINO Runtime for later inference on Intel CPU & MYRIAD devices.

The software was validated on:

  • macOS* 10.x, 11.x, 12.x x86 64-bit
  • macOS* 11.x, 12.x, arm64 (cross-compilation)

Table of content

Software Requirements

  • brew package manager to install additional dependencies. Use install brew guide to achieve this.
  • CMake* 3.13 or higher:
    % brew install cmake
  • Clang* compiler, git and other command line tools from Xcode* 10.1 or higher:
    % xcode-select --install
  • Python* 3.6 or higher for the OpenVINO Runtime Python API, Development tools (Model Optimizer, POT and others):
    % # let's have a look what python versions are available in brew
    % brew search python
    % # select preferred version of python based on available ones, e.g. 3.10
    % brew install [email protected]
    % # update pip and setuptools to newer versions
    % python3 -m pip install -U pip setuptools 
    In order to build OpenVINO Python API and Development tools as wheel packages, additionally install requirements:
    % python3 -m pip install -r src/bindings/python/wheel/requirements-dev.txt
    % python3 -m pip install cython
  • libusb library for MYRIAD device and pkg-config which is used to find libusb files:
    % brew install pkg-config libusb
  • (Optional) Latest version of TBB library. By default, OpenVINO downloads prebuilt version of TBB 2020.4 library, but if you want to use latest (add -DENABLE_SYSTEM_TBB=ON additionally to cmake configuration step):
    % brew install tbb

Build Steps

  1. (Get sources) Clone submodules:
% git clone https://github.com/openvinotoolkit/openvino.git
% cd openvino
% git submodule update --init
  1. Create a build folder:
%  mkdir build && cd build
  1. (CMake configure) OpenVINO project uses a CMake-based build system. In the created build directory, run cmake to fetch project dependencies and create build rules:
% cmake -DCMAKE_BUILD_TYPE=Release ..

Note: By default OpenVINO CMake scripts try to introspect the system and enable all possible functionality based on that. You can look at the CMake output and see warnings, which show that some functionality is turned off and the corresponding reason, guiding what to do to install additionally to enable unavailable functionality. Additionally, you can change CMake options to enable / disable some functionality, add / remove compilation flags, provide custom version of dependencies like TBB, PugiXML, OpenCV, Protobuf. Please, read CMake options for custom compilation for this information.

  1. (CMake build) Build OpenVINO project:
% cmake --build . --config Release --jobs=$(nproc --all)

All built binaries are located in <openvino_source_dir>/bin/intel64/Release/ and wheel packages are located in <openvino_build_dir>/wheels.

  1. (Optional install) Once you have built OpenVINO, you can install artifacts to a preferred location:
% cmake -DCMAKE_INSTALL_PREFIX=<installation location> -P cmake_install.cmake

Cross-compilation

Since OSX version 11.x and Xcode version 12.2, the Apple development tools allows to compile arm64 code on x86 hosts and vice-versa. Based on this, OpenVINO can be compiled even on Apple Silicon machines, then such artifacts can be run on both Intel CPU hosts and Apple Silicon hosts (using Rosetta). For this, first of all Rosetta must be installed:

% softwareupdate --install-rosetta

Then try to compile OpenVINO using the steps above, but adding -DCMAKE_OSX_ARCHITECTURES=x86_64 -DENABLE_INTEL_MYRIAD=OFF on cmake configure stage. But, don't enable any system library usage explicitly via CMake options, because they have arm64 architecture, e.g.:

% file /opt/homebrew/Cellar/tbb/2021.5.0_2/lib/libtbb.12.5.dylib
/opt/homebrew/Cellar/tbb/2021.5.0_2/lib/libtbb.12.5.dylib: Mach-O 64-bit dynamically linked shared library arm64

Note: using such way OpenVINO Intel CPU plugin can be cross-compiled, because MYRIAD plugin cannot be linked against arm64 version of libusb

Or you have to explicitly find / compile universal (or at least x86_64) dependencies by yourself and pass it to OpenVINO cmake scripts. E.g. compile oneTBB using additional option -DCMAKE_OSX_ARCHITECTURES="x86_64;arm64", install and then set export TBBROOT=<universal oneTBB install root> which will be used by OpenVINO.

Clone this wiki locally