The shortfin project is SHARK's open source, high performance inference library and serving engine. Shortfin consists of these major components:
- The "libshortfin" inference library written in C/C++ and built on IREE
- Python bindings for the underlying inference library
- Example applications in 'shortfin_apps' built using the python bindings
- Python 3.11+
Install the latest stable version:
pip install shortfin
After cloning this repository, from the shortfin/
directory:
pip install -e .
Install test requirements:
pip install -r requirements-tests.txt
Run tests:
pytest -s tests/
We recommend this development setup for core contributors:
- Check out this repository as a sibling to IREE if you already have an IREE source checkout. Otherwise, a pinned version will be downloaded for you
- Ensure that
python --version
reads 3.11 or higher (3.12 preferred). - Run
./dev_me.py
to build and install theshortfin
Python package with both a tracing-enabled and default build. Run it again to do an incremental build and delete thebuild/
directory to start over - Run tests with
python -m pytest -s tests/
- Test optional features:
pip install iree-base-compiler
to run a small suite of model tests intended to exercise the runtime (or use a source build of IREE).pip install onnx
to run some more model tests that depend on downloading ONNX models- Run tests on devices other than the CPU with flags like:
--system amdgpu --compile-flags="--iree-hal-target-backends=rocm --iree-hip-target=gfx1100"
- Use the tracy instrumented runtime to collect execution traces:
export SHORTFIN_PY_RUNTIME=tracy
Refer to the advanced build options below for other scenarios.
- Native C++ build
- Local Python release build
- Package Python release build
- Python dev build
Prerequisites
- A modern C/C++ compiler, such as clang 18 or gcc 12
- A modern Python, such as Python 3.12
cmake -GNinja -S. -Bbuild \
-DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++ \
-DCMAKE_LINKER_TYPE=LLD
cmake --build build --target all
If Python bindings are enabled in this mode (-DSHORTFIN_BUILD_PYTHON_BINDINGS=ON
),
then pip install -e build/
will install from the build dir (and support
build/continue).
-
To build wheels for Linux using a manylinux Docker container:
sudo ./build_tools/build_linux_package.sh
-
To build a wheel for your host OS/arch manually:
# Build shortfin.*.whl into the dist/ directory # e.g. `shortfin-0.9-cp312-cp312-linux_x86_64.whl` python3 -m pip wheel -v -w dist . # Install the built wheel. python3 -m pip install dist/*.whl
# Install build system pre-reqs (since we are building in dev mode, this
# is not done for us). See source of truth in pyproject.toml:
pip install setuptools wheel
# Optionally install cmake and ninja if you don't have them or need a newer
# version. If doing heavy development in Python, it is strongly recommended
# to install these natively on your system as it will make it easier to
# switch Python interpreters and build options (and the launcher in debug/asan
# builds of Python is much slower). Note CMakeLists.txt for minimum CMake
# version, which is usually quite recent.
pip install cmake ninja
SHORTFIN_DEV_MODE=ON pip install --no-build-isolation -v -e .
Note that the --no-build-isolation
flag is useful in development setups
because it does not create an intermediate venv that will keep later
invocations of cmake/ninja from working at the command line. If just doing
a one-shot build, it can be ommitted.
Once built the first time, cmake
, ninja
, and ctest
commands can be run
directly from build/cmake
and changes will apply directly to the next
process launch.
Several optional environment variables can be used with setup.py:
SHORTFIN_CMAKE_BUILD_TYPE=Debug
: Sets the CMAKE_BUILD_TYPE. Defaults toDebug
for dev mode andRelease
otherwise.SHORTFIN_ENABLE_ASAN=ON
: Enables an ASAN build. Requires a Python runtime setup that is ASAN clean (either by env vars to preload libraries or set suppressions or a dev build of Python with ASAN enabled).SHORTFIN_IREE_SOURCE_DIR=$(pwd)/../../iree
SHORTFIN_RUN_CTESTS=ON
: Runsctest
as part of the build. Useful for CI as it uses the version of ctest installed in the pip venv.
The project uses a combination of ctest for native C++ tests and pytest. Much
of the functionality is only tested via the Python tests, using the
_shortfin.lib
internal implementation directly. In order to run these tests,
you must have installed the Python package as per the above steps.
Which style of test is used is pragmatic and geared at achieving good test coverage with a minimum of duplication. Since it is often much more expensive to build native tests of complicated flows, many things are only tested via Python. This does not preclude having other language bindings later, but it does mean that the C++ core of the library must always be built with the Python bindings to test the most behavior. Given the target of the project, this is not considered to be a significant issue.
Run platform independent tests only:
pytest tests/
Run tests including for a specific platform (in this example, a gfx1100 AMDGPU):
(note that not all tests are system aware yet and some may only run on the CPU)
pytest tests/ --system amdgpu \
--compile-flags="--iree-hal-target-backends=rocm --iree-hip-target=gfx1100"
In order to build a production library, additional build steps are typically recommended:
- Compile all deps with the same compiler/linker for LTO compatibility
- Provide library dependencies manually and compile them with LTO
- Compile dependencies with
-fvisibility=hidden
- Enable LTO builds of libshortfin
- Set flags to enable symbol versioning
Support for free-threaded Python builds (aka. "nogil") is in progress. It
is currently being tested via CPython 3.13 with the --disable-gil
option set.
There are multiple ways to acquire such an environment:
-
Generally, see the documentation at https://py-free-threading.github.io/installing_cpython/
-
If using
pyenv
:# Install a free-threaded 3.13 version. pyenv install 3.13t # Test (should print "False"). pyenv shell 3.13t python -c 'import sys; print(sys._is_gil_enabled())'