Accept variable-length batch prompts for Whisper #2919
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
push: | |
branches: | |
- master | |
tags: | |
- v* | |
pull_request: | |
branches: | |
- master | |
jobs: | |
build-and-test-cpp-x86_64: | |
runs-on: ${{ matrix.os }} | |
env: | |
CT2_VERBOSE: 1 | |
strategy: | |
matrix: | |
os: [ubuntu-20.04] | |
backend: [mkl, dnnl] | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- name: Install Intel oneAPI | |
if: startsWith(matrix.os, 'ubuntu') | |
run: | | |
wget https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB | |
sudo apt-key add *.PUB | |
sudo sh -c 'echo "deb https://apt.repos.intel.com/oneapi all main" > /etc/apt/sources.list.d/oneAPI.list' | |
sudo apt-get update | |
- name: Configure with MKL | |
if: startsWith(matrix.os, 'ubuntu') && matrix.backend == 'mkl' | |
env: | |
CT2_USE_MKL: 1 | |
MKL_VERSION: 2023.0.0 | |
run: | | |
sudo apt-get install -y intel-oneapi-mkl-devel-$MKL_VERSION | |
cmake -DCMAKE_INSTALL_PREFIX=$PWD/install -DBUILD_TESTS=ON . | |
- name: Configure with DNNL | |
if: startsWith(matrix.os, 'ubuntu') && matrix.backend == 'dnnl' | |
env: | |
DNNL_VERSION: 2023.0.0-25399 | |
run: | | |
sudo apt-get install -y intel-oneapi-dnnl-devel=$DNNL_VERSION intel-oneapi-dnnl=$DNNL_VERSION | |
cmake -DCMAKE_INSTALL_PREFIX=$PWD/install -DBUILD_TESTS=ON -DWITH_MKL=OFF -DOPENMP_RUNTIME=COMP -DWITH_DNNL=ON . | |
- name: Build | |
run: | | |
make install | |
- name: Download test data | |
working-directory: tests/data/models | |
run: | | |
wget https://opennmt-models.s3.amazonaws.com/pi_lm_step_5000.pt | |
wget https://opennmt-models.s3.amazonaws.com/transliteration-aren-all.tar.gz | |
tar xf transliteration-aren-all.tar.gz | |
- name: Test MKL | |
if: matrix.backend == 'mkl' | |
env: | |
CT2_USE_MKL: 1 | |
run: | | |
tests/ctranslate2_test tests/data | |
- name: Test DNNL | |
if: matrix.backend == 'dnnl' | |
run: | | |
tests/ctranslate2_test tests/data | |
build-and-test-cpp-aarch64: | |
runs-on: ubuntu-20.04 | |
env: | |
CT2_VERBOSE: 1 | |
strategy: | |
matrix: | |
backend: [openblas] | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- name: Install cross compiler and emulator | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y g++-aarch64-linux-gnu gfortran-aarch64-linux-gnu qemu-user-static | |
- name: Build with OpenBLAS and Ruy | |
if: matrix.backend == 'openblas' | |
run: | | |
wget https://github.com/xianyi/OpenBLAS/archive/v0.3.13.tar.gz | |
tar xzvf v0.3.13.tar.gz | |
cd OpenBLAS-0.3.13 | |
make TARGET=ARMV8 CC=aarch64-linux-gnu-gcc FC=aarch64-linux-gnu-gfortran HOSTCC=gcc NO_LAPACK=1 -j $(nproc) | |
sudo make PREFIX=/usr/aarch64-linux-gnu install | |
cd .. | |
cmake \ | |
-DCMAKE_SYSTEM_NAME=Linux \ | |
-DCMAKE_SYSTEM_PROCESSOR=aarch64 \ | |
-DCMAKE_C_COMPILER=aarch64-linux-gnu-gcc \ | |
-DCMAKE_CXX_COMPILER=aarch64-linux-gnu-g++ \ | |
-DCMAKE_FIND_ROOT_PATH=/usr/aarch64-linux-gnu \ | |
-DOPENMP_RUNTIME=COMP \ | |
-DCMAKE_INSTALL_PREFIX=$PWD/install \ | |
-DWITH_MKL=OFF \ | |
-DWITH_OPENBLAS=ON \ | |
-DWITH_RUY=ON \ | |
-DBUILD_TESTS=ON \ | |
. | |
make -j $(nproc) install | |
- name: Download test data | |
run: | | |
wget https://opennmt-models.s3.amazonaws.com/transliteration-aren-all.tar.gz | |
tar xf transliteration-aren-all.tar.gz -C tests/data/models/ | |
- name: Test | |
run: | | |
tests/ctranslate2_test tests/data | |
env: | |
QEMU_LD_PREFIX: /usr/aarch64-linux-gnu | |
build-python-wheels: | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-20.04, windows-2019] | |
arch: [auto64] | |
include: | |
- os: ubuntu-20.04 | |
arch: aarch64 | |
- os: macos-12 | |
arch: arm64 | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- uses: docker/setup-qemu-action@v2 | |
if: ${{ matrix.arch == 'aarch64' }} | |
name: Set up QEMU | |
- name: Build wheels | |
uses: pypa/[email protected] | |
with: | |
package-dir: python | |
output-dir: python/wheelhouse | |
env: | |
CIBW_ENVIRONMENT_PASS_LINUX: CIBW_ARCHS | |
CIBW_ENVIRONMENT_WINDOWS: CTRANSLATE2_ROOT='${{ github.workspace }}\install' | |
CIBW_ENVIRONMENT_MACOS: CTRANSLATE2_ROOT='/usr/local' | |
CIBW_BEFORE_ALL_LINUX: python/tools/prepare_build_environment_linux.sh | |
CIBW_BEFORE_ALL_MACOS: python/tools/prepare_build_environment_macos.sh | |
CIBW_BEFORE_ALL_WINDOWS: bash python/tools/prepare_build_environment_windows.sh | |
CIBW_BEFORE_BUILD: pip install -r python/install_requirements.txt | |
CIBW_MANYLINUX_X86_64_IMAGE: manylinux2014 | |
CIBW_MANYLINUX_AARCH64_IMAGE: manylinux2014 | |
CIBW_ARCHS: ${{ matrix.arch }} | |
CIBW_SKIP: pp* *-musllinux_* | |
- name: Upload Python wheels | |
uses: actions/upload-artifact@v3 | |
with: | |
name: python-wheels | |
path: python/wheelhouse | |
# We could test the Python wheels using cibuildwheel but we prefer to run the tests outside | |
# the build environment to ensure wheels correctly embed all dependencies. | |
test-python-wheels: | |
needs: [build-python-wheels] | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-20.04, windows-2019] | |
steps: | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v4 | |
with: | |
python-version: 3.8 | |
- uses: actions/checkout@v3 | |
- name: Prepare test environment | |
shell: bash | |
run: | | |
./python/tools/prepare_test_environment.sh | |
- name: Download Python wheels | |
uses: actions/download-artifact@v3 | |
with: | |
name: python-wheels | |
- name: Install wheel | |
if: startsWith(matrix.os, 'ubuntu') | |
run: | | |
pip install *cp38*manylinux*x86_64.whl | |
- name: Install wheel | |
if: startsWith(matrix.os, 'windows') | |
shell: bash | |
run: | | |
pip install *cp38*win*.whl | |
- name: Run tests | |
shell: bash | |
run: | | |
pytest -v python/tests/ | |
check-python-style: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v4 | |
with: | |
python-version: 3.8 | |
- name: Install dependencies | |
run: | | |
python -m pip install black==22.* flake8==3.8.* isort==5.* | |
- name: Check code format with Black | |
working-directory: python | |
run: | | |
black --check . | |
- name: Check imports order with isort | |
working-directory: python | |
run: | | |
isort --check-only . | |
- name: Check code style with Flake8 | |
working-directory: python | |
if: ${{ always() }} | |
run: | | |
flake8 . | |
publish-python-wheels-on-pypi: | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | |
needs: [build-and-test-cpp-x86_64, build-python-wheels, test-python-wheels, check-python-style] | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Download Python wheels | |
uses: actions/download-artifact@v3 | |
with: | |
name: python-wheels | |
- name: Publish Python wheels to PyPI | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
user: __token__ | |
password: ${{ secrets.PYPI_API_TOKEN }} | |
packages-dir: . | |
build-and-push-docker-images: | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- name: Build Docker images | |
run: | | |
./docker/build_all.sh | |
- name: Login to DockerHub | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Push Docker images | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | |
run: | | |
./docker/build_all.sh ${GITHUB_REF##*/v} 1 | |
build-and-deploy-docs: | |
runs-on: ubuntu-latest | |
needs: [check-python-style, build-python-wheels] | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v4 | |
with: | |
python-version: 3.8 | |
- name: Download CTranslate2 wheels | |
uses: actions/download-artifact@v3 | |
with: | |
name: python-wheels | |
- name: Install CTranslate2 wheel | |
run: | | |
pip install *cp38*manylinux*x86_64.whl | |
- name: Install dependencies to build docs | |
working-directory: docs | |
run: | | |
python -m pip install -r requirements.txt | |
- name: Build docs | |
working-directory: docs | |
run: | | |
python generate.py python | |
sphinx-build . build | |
- name: Deploy docs | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | |
uses: JamesIves/github-pages-deploy-action@v4 | |
with: | |
folder: docs/build | |
clean: true |