SHARK inference library and serving engine
Project description
shortfin - SHARK inference library and serving engine
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
Prerequisites
- Python 3.11+
Simple user installation
Install the latest stable version:
pip install shortfin
Developer guides
Quick start: install local packages and run tests
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/
Simple dev setup
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 --versionreads 3.11 or higher (3.12 preferred). - Run
./dev_me.pyto build and install theshortfinPython 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-compilerto run a small suite of model tests intended to exercise the runtime (or use a source build of IREE).pip install onnxto 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-device=hip --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.
Advanced build options
- 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
Native C++ builds
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).
Package Python release builds
-
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
Python dev builds
# 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 toDebugfor dev mode andReleaseotherwise.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)/../../ireeSHORTFIN_RUN_CTESTS=ON: Runsctestas part of the build. Useful for CI as it uses the version of ctest installed in the pip venv.
Running tests
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.
Python tests
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-device=hip --iree-hip-target=gfx1100"
Production library building
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
Miscellaneous build topics
Free-threaded Python
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())'
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file shortfin-3.6.0-cp313-cp313t-manylinux_2_28_x86_64.whl.
File metadata
- Download URL: shortfin-3.6.0-cp313-cp313t-manylinux_2_28_x86_64.whl
- Upload date:
- Size: 3.1 MB
- Tags: CPython 3.13t, manylinux: glibc 2.28+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f105fd290240c0be1aee65ac2a617cc169ffccd430dbd7e9590515fd79f36c6f
|
|
| MD5 |
c70c283922ce42202eec1de68e058840
|
|
| BLAKE2b-256 |
c1e022387e2dc0f497d6a416b092dc0839e1c226249649ca14d5162adff67da0
|
File details
Details for the file shortfin-3.6.0-cp313-cp313-manylinux_2_28_x86_64.whl.
File metadata
- Download URL: shortfin-3.6.0-cp313-cp313-manylinux_2_28_x86_64.whl
- Upload date:
- Size: 3.1 MB
- Tags: CPython 3.13, manylinux: glibc 2.28+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8ad631e598260fb0204ae34dede8152594d8dd7e40c14cd9639a0fc1b7cf5f43
|
|
| MD5 |
e8ccf0cd02fda1e322d5778ef628905f
|
|
| BLAKE2b-256 |
3de1bba913943b9693fec82eade2e66ec64ec65578326fcb3e75c9ed65649ce1
|
File details
Details for the file shortfin-3.6.0-cp312-cp312-manylinux_2_28_x86_64.whl.
File metadata
- Download URL: shortfin-3.6.0-cp312-cp312-manylinux_2_28_x86_64.whl
- Upload date:
- Size: 3.1 MB
- Tags: CPython 3.12, manylinux: glibc 2.28+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a78c03354922c3c64f17d9280aa874179e652cab84759d4bcc0f474145c1e982
|
|
| MD5 |
20bd2a145972f6353ec8f1f9f3dde71b
|
|
| BLAKE2b-256 |
3a58310904cf97156abe657fb4e324b1d187cc74f41f34d1f15ccc7e45fc4ee4
|
File details
Details for the file shortfin-3.6.0-cp311-cp311-manylinux_2_28_x86_64.whl.
File metadata
- Download URL: shortfin-3.6.0-cp311-cp311-manylinux_2_28_x86_64.whl
- Upload date:
- Size: 3.1 MB
- Tags: CPython 3.11, manylinux: glibc 2.28+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5fb6d6eb793a1672b33bb8826a7fe18591d178c16b7f5caf314fb02b621e7ea8
|
|
| MD5 |
229288df3bcb8defd7469d347636016d
|
|
| BLAKE2b-256 |
3114c78fce7360bcc535b0c89742bb3dc8efdd14ad506f44118661573f9ef0dc
|