[WIP] Added loop boundary optimization pass #8256
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: Build Catalyst Wheel on macOS (arm64) | |
on: | |
pull_request: | |
types: | |
- opened | |
- reopened | |
- synchronize | |
- labeled | |
- ready_for_review | |
push: | |
branches: [ main ] | |
schedule: | |
# Thursdays we test the standalone plugin | |
- cron: '35 4 * * 4' | |
workflow_dispatch: | |
workflow_call: | |
env: | |
MACOSX_DEPLOYMENT_TARGET: 14.0 | |
concurrency: | |
group: Build Catalyst Wheel on macOS (arm64)-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
check_if_wheel_build_required: | |
if: github.event.pull_request.draft == false | |
uses: ./.github/workflows/check-for-wheel-build.yml | |
constants: | |
needs: [check_if_wheel_build_required] | |
if: needs.check_if_wheel_build_required.outputs.build-wheels == 'true' | |
name: "Set build matrix" | |
uses: ./.github/workflows/constants.yaml | |
build-dependencies: | |
needs: [constants, check_if_wheel_build_required] | |
strategy: | |
fail-fast: false | |
matrix: | |
python_version: ["3.10"] | |
name: Build Dependencies (Python ${{ matrix.python_version }}) | |
runs-on: macos-latest | |
if: needs.check_if_wheel_build_required.outputs.build-wheels == 'true' | |
steps: | |
- name: Checkout Catalyst repo | |
uses: actions/checkout@v4 | |
# Python 3.10 was dropped from the GH images on macOS arm | |
- name: Install Python 3.10 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.10' | |
# Cache external project sources | |
# Hopefully these can be shared with the main check-catalyst action since we don't run this | |
# build in a container. | |
- name: Cache LLVM Source | |
id: cache-llvm-source | |
uses: actions/cache@v4 | |
with: | |
path: ${{ github.workspace }}/mlir/llvm-project | |
key: llvm-${{ needs.constants.outputs.llvm_version }}-default-source | |
enableCrossOsArchive: True | |
- name: Cache MHLO Source | |
id: cache-mhlo-source | |
uses: actions/cache@v4 | |
with: | |
path: ${{ github.workspace }}/mlir/mlir-hlo | |
key: mhlo-${{ needs.constants.outputs.mhlo_version }}-default-source | |
enableCrossOsArchive: True | |
- name: Cache Enzyme Source | |
id: cache-enzyme-source | |
uses: actions/cache@v4 | |
with: | |
path: ${{ github.workspace }}/mlir/Enzyme | |
key: enzyme-${{ needs.constants.outputs.enzyme_version }}-default-source | |
enableCrossOsArchive: True | |
- name: Clone LLVM Submodule | |
if: steps.cache-llvm-source.outputs.cache-hit != 'true' | |
uses: actions/checkout@v4 | |
with: | |
repository: llvm/llvm-project | |
ref: ${{ needs.constants.outputs.llvm_version }} | |
path: ${{ github.workspace }}/mlir/llvm-project | |
- name: Clone MHLO Submodule | |
if: steps.cache-mhlo-source.outputs.cache-hit != 'true' | |
uses: actions/checkout@v4 | |
with: | |
repository: tensorflow/mlir-hlo | |
ref: ${{ needs.constants.outputs.mhlo_version }} | |
path: ${{ github.workspace }}/mlir/mlir-hlo | |
- name: Clone Enzyme Submodule | |
if: steps.cache-enzyme-source.outputs.cache-hit != 'true' | |
uses: actions/checkout@v4 | |
with: | |
repository: EnzymeAD/Enzyme | |
ref: ${{ needs.constants.outputs.enzyme_version }} | |
path: ${{ github.workspace }}/mlir/Enzyme | |
# Cache external project builds | |
- name: Restore LLVM Build | |
id: cache-llvm-build | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/llvm-build | |
key: ${{ runner.os }}-${{ runner.arch }}-llvm-${{ needs.constants.outputs.llvm_version }}-${{matrix.python_version}}-wheel-build | |
- name: Restore MHLO Build | |
id: cache-mhlo-build | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/mhlo-build | |
key: ${{ runner.os }}-${{ runner.arch }}-mhlo-${{ needs.constants.outputs.mhlo_version }}-wheel-build | |
lookup-only: True | |
- name: Restore Enzyme Build | |
id: cache-enzyme-build | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/enzyme-build | |
key: ${{ runner.os }}-${{ runner.arch }}-enzyme-${{ needs.constants.outputs.llvm_version }}-${{ needs.constants.outputs.enzyme_version }}-wheel-build | |
lookup-only: True | |
- name: Setup Python version | |
# There are multiple Python versions installed on the GitHub image, 3.10 - 3.12 is already | |
# available under /Library/Frameworks/Python.framework/Versions/, but homebrew also provides | |
# 3.11 and 3.12. Make sure to consistently use the system versions. | |
run: | | |
echo /Library/Frameworks/Python.framework/Versions/${{ matrix.python_version }}/bin >> $GITHUB_PATH | |
- name: Install Dependencies (Python) | |
run: | | |
python${{ matrix.python_version }} -m pip install numpy nanobind pybind11 PyYAML cmake ninja | |
- name: Build LLVM / MLIR | |
if: steps.cache-llvm-build.outputs.cache-hit != 'true' | |
run: | | |
PYTHON=$(which python${{ matrix.python_version }}) \ | |
LLVM_BUILD_DIR="$GITHUB_WORKSPACE/llvm-build" \ | |
LLVM_TARGETS="check-mlir" \ | |
ENABLE_ZLIB=FORCE_ON \ | |
make llvm | |
- name: Save LLVM Build | |
id: save-llvm-build | |
if: steps.cache-llvm-build.outputs.cache-hit != 'true' | |
uses: actions/cache/save@v4 | |
with: | |
path: ${{ github.workspace }}/llvm-build | |
key: ${{ runner.os }}-${{ runner.arch }}-llvm-${{ needs.constants.outputs.llvm_version }}-${{matrix.python_version}}-wheel-build | |
- name: Build MHLO Dialect | |
if: steps.cache-mhlo-build.outputs.cache-hit != 'true' | |
run: | | |
export PATH=$GITHUB_WORKSPACE/llvm-build/bin:$PATH | |
export TARGET_FILE=mlir/mlir-hlo/mhlo/transforms/CMakeLists.txt | |
export PATCH_FILE=mlir/patches/mhlo-Add-PassesIncGen-in-transforms-CMakeList.patch | |
if patch --dry-run -p1 -N $TARGET_FILE $PATCH_FILE > /dev/null 2>&1; then patch -p1 $TARGET_FILE $PATCH_FILE; fi | |
cmake -S mlir/mlir-hlo -B $GITHUB_WORKSPACE/mhlo-build -G Ninja \ | |
-DCMAKE_BUILD_TYPE=Release \ | |
-DLLVM_ENABLE_ASSERTIONS=ON \ | |
-DMLIR_DIR="$GITHUB_WORKSPACE/llvm-build/lib/cmake/mlir" \ | |
-DPython3_EXECUTABLE=$(which python${{ matrix.python_version }}) \ | |
-DLLVM_ENABLE_LLD=OFF \ | |
-DLLVM_ENABLE_ZLIB=FORCE_ON \ | |
-DLLVM_ENABLE_ZSTD=OFF \ | |
-DCMAKE_CXX_VISIBILITY_PRESET=default | |
cmake --build $GITHUB_WORKSPACE/mhlo-build --target check-mlir-hlo | |
- name: Save MHLO Build | |
id: save-mhlo-build | |
if: steps.cache-mhlo-build.outputs.cache-hit != 'true' | |
uses: actions/cache/save@v4 | |
with: | |
path: ${{ github.workspace }}/mhlo-build | |
key: ${{ runner.os }}-${{ runner.arch }}-mhlo-${{ needs.constants.outputs.mhlo_version }}-wheel-build | |
- name: Build Enzyme | |
if: steps.cache-enzyme-build.outputs.cache-hit != 'true' | |
run: | | |
cmake -S mlir/Enzyme/enzyme -B $GITHUB_WORKSPACE/enzyme-build -G Ninja \ | |
-DCMAKE_BUILD_TYPE=Release \ | |
-DLLVM_DIR="$GITHUB_WORKSPACE/llvm-build/lib/cmake/llvm" \ | |
-DENZYME_STATIC_LIB=ON \ | |
-DCMAKE_CXX_VISIBILITY_PRESET=default | |
cmake --build $GITHUB_WORKSPACE/enzyme-build --target EnzymeStatic-19 | |
- name: Save Enzyme Build | |
id: save-enzyme-build | |
if: steps.cache-enzyme-build.outputs.cache-hit != 'true' | |
uses: actions/cache/save@v4 | |
with: | |
path: ${{ github.workspace }}/enzyme-build | |
key: ${{ runner.os }}-${{ runner.arch }}-enzyme-${{ needs.constants.outputs.llvm_version }}-${{ needs.constants.outputs.enzyme_version }}-wheel-build | |
catalyst-macos-wheels-arm64: | |
needs: [constants, build-dependencies] | |
strategy: | |
fail-fast: false | |
matrix: | |
python_version: ${{ fromJson(needs.constants.outputs.python_versions) }} | |
name: Build Wheels (Python ${{ matrix.python_version }}) | |
runs-on: macos-latest | |
steps: | |
- name: Checkout Catalyst repo | |
uses: actions/checkout@v4 | |
# Python 3.10 was dropped from the GH images on macOS arm | |
- name: Install Python 3.10 | |
uses: actions/setup-python@v5 | |
if: ${{ matrix.python_version }} == '3.10' | |
with: | |
python-version: '3.10' | |
- name: Install Dependencies (System) | |
run: | | |
brew install libomp | |
- name: Setup Python version | |
# There are multiple Python versions installed on the GitHub image, 3.10 - 3.12 is already | |
# available under /Library/Frameworks/Python.framework/Versions/, but homebrew also provides | |
# 3.11 and 3.12. Make sure to consistently use the system versions. | |
run: | | |
echo /Library/Frameworks/Python.framework/Versions/${{ matrix.python_version }}/bin >> $GITHUB_PATH | |
- name: Install Dependencies (Python) | |
run: | | |
python${{ matrix.python_version }} -m pip install numpy nanobind pybind11 PyYAML cmake ninja delocate | |
- name: Get Cached LLVM Source | |
id: cache-llvm-source | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/mlir/llvm-project | |
key: llvm-${{ needs.constants.outputs.llvm_version }}-default-source | |
enableCrossOsArchive: True | |
fail-on-cache-miss: True | |
- name: Get Cached LLVM Build | |
id: cache-llvm-build | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/llvm-build | |
key: ${{ runner.os }}-${{ runner.arch }}-llvm-${{ needs.constants.outputs.llvm_version }}-3.10-wheel-build | |
fail-on-cache-miss: True | |
- name: Get Cached MHLO Source | |
id: cache-mhlo-source | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/mlir/mlir-hlo | |
key: mhlo-${{ needs.constants.outputs.mhlo_version }}-default-source | |
enableCrossOsArchive: True | |
fail-on-cache-miss: True | |
- name: Get Cached MHLO Build | |
id: cache-mhlo-build | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/mhlo-build | |
key: ${{ runner.os }}-${{ runner.arch }}-mhlo-${{ needs.constants.outputs.mhlo_version }}-wheel-build | |
fail-on-cache-miss: True | |
- name: Get Cached Enzyme Source | |
id: cache-enzyme-source | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/mlir/Enzyme | |
key: enzyme-${{ needs.constants.outputs.enzyme_version }}-default-source | |
enableCrossOsArchive: True | |
fail-on-cache-miss: True | |
- name: Get Cached Enzyme Build | |
id: cache-enzyme-build | |
uses: actions/cache/restore@v4 | |
with: | |
path: ${{ github.workspace }}/enzyme-build | |
key: ${{ runner.os }}-${{ runner.arch }}-enzyme-${{ needs.constants.outputs.llvm_version }}-${{ needs.constants.outputs.enzyme_version }}-wheel-build | |
fail-on-cache-miss: True | |
# Build Catalyst-Runtime | |
- name: Build Catalyst-Runtime | |
run: | | |
# On GH images, gfortran is only available as a specific version. | |
export FC=gfortran-14 | |
cmake -S runtime -B $GITHUB_WORKSPACE/runtime-build -G Ninja \ | |
-DCMAKE_BUILD_TYPE=Release \ | |
-DCMAKE_LIBRARY_OUTPUT_DIRECTORY="$GITHUB_WORKSPACE/runtime-build/lib" \ | |
-DPython_EXECUTABLE=$(which python${{ matrix.python_version }}) \ | |
-DENABLE_OPENQASM=ON | |
cmake --build $GITHUB_WORKSPACE/runtime-build --target rt_capi rtd_openqasm rtd_null_qubit | |
- name: Test Catalyst-Runtime | |
run: | | |
python${{ matrix.python_version }} -m pip install 'amazon-braket-pennylane-plugin>1.27.1' | |
cmake --build $GITHUB_WORKSPACE/runtime-build --target runner_tests_openqasm | |
$GITHUB_WORKSPACE/runtime-build/tests/runner_tests_openqasm | |
# Build OQC-Runtime | |
- name: Build OQC-Runtime | |
run: | | |
OQC_BUILD_DIR="$GITHUB_WORKSPACE/oqc-build" \ | |
RT_BUILD_DIR="$GITHUB_WORKSPACE/runtime-build" \ | |
PYTHON=$(which python${{ matrix.python_version }}) \ | |
make oqc | |
# Build OQD-Runtime | |
- name: Build OQD-Runtime | |
run: | | |
OQD_BUILD_DIR="$GITHUB_WORKSPACE/oqd-build" \ | |
RT_BUILD_DIR="$GITHUB_WORKSPACE/runtime-build" \ | |
PYTHON=$(which python${{ matrix.python_version }}) \ | |
make oqd | |
# Build Quantum and Gradient Dialects | |
- name: Build MLIR Dialects | |
run: | | |
cmake -S mlir -B $GITHUB_WORKSPACE/quantum-build -G Ninja \ | |
-DCMAKE_BUILD_TYPE=Release \ | |
-DLLVM_ENABLE_ASSERTIONS=ON \ | |
-DQUANTUM_ENABLE_BINDINGS_PYTHON=ON \ | |
-DPython3_EXECUTABLE=$(which python${{ matrix.python_version }}) \ | |
-DPython3_NumPy_INCLUDE_DIRS=$(python${{ matrix.python_version }} -c "import numpy as np; print(np.get_include())") \ | |
-DMLIR_DIR="$GITHUB_WORKSPACE/llvm-build/lib/cmake/mlir" \ | |
-DMHLO_DIR="$GITHUB_WORKSPACE/mhlo-build/lib/cmake/mlir-hlo" \ | |
-DMHLO_BINARY_DIR="$GITHUB_WORKSPACE/mhlo-build/bin" \ | |
-DEnzyme_DIR="$GITHUB_WORKSPACE/enzyme-build" \ | |
-DENZYME_SRC_DIR="$GITHUB_WORKSPACE/mlir/Enzyme" \ | |
-DLLVM_ENABLE_ZLIB=FORCE_ON \ | |
-DLLVM_ENABLE_ZSTD=OFF \ | |
-DLLVM_ENABLE_LLD=OFF \ | |
-DLLVM_DIR="$GITHUB_WORKSPACE/llvm-build/lib/cmake/llvm" | |
cmake --build $GITHUB_WORKSPACE/quantum-build --target check-dialects catalyst-cli | |
- name: Build Plugin wheel | |
# Run only on Thursday at the given time | |
if: github.event.schedule == '35 4 * * 4' | |
run: | | |
MLIR_DIR="$GITHUB_WORKSPACE/llvm-build/lib/cmake/mlir" \ | |
LLVM_BUILD_DIR="$GITHUB_WORKSPACE/llvm-build" \ | |
make plugin-wheel | |
- name: Build wheel | |
run: | | |
PYTHON=python${{ matrix.python_version }} \ | |
LLVM_BUILD_DIR="$GITHUB_WORKSPACE/llvm-build" \ | |
MHLO_BUILD_DIR="$GITHUB_WORKSPACE/mhlo-build" \ | |
DIALECTS_BUILD_DIR="$GITHUB_WORKSPACE/quantum-build" \ | |
RT_BUILD_DIR="$GITHUB_WORKSPACE/runtime-build" \ | |
OQC_BUILD_DIR="$GITHUB_WORKSPACE/oqc-build" \ | |
OQD_BUILD_DIR="$GITHUB_WORKSPACE/oqd-build" \ | |
ENZYME_BUILD_DIR="$GITHUB_WORKSPACE/enzyme-build" \ | |
make wheel | |
- name: Repair wheel using delocate-wheel | |
run: | | |
# ignore-missing-dependencies only ignores libopenblas.dylib | |
delocate-wheel --require-archs=arm64 -w ./wheel -v dist/*.whl --ignore-missing-dependencies -vv | |
- name: Upload Wheel Artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: catalyst-macos_arm64-wheel-py-${{ matrix.python_version }}.zip | |
path: ${{ github.workspace }}/wheel/ | |
retention-days: 14 | |
- name: Upload Standalone Plugin Wheel Artifact | |
# Run only on Thursday at the given time | |
if: github.event.schedule == '35 4 * * 4' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: standalone-plugin-macos_arm64-wheel-py-${{ matrix.python_version }}.zip | |
path: ${{ github.workspace }}/standalone_plugin_wheel/dist | |
retention-days: 14 | |
test-wheels: | |
needs: [constants, catalyst-macos-wheels-arm64] | |
strategy: | |
fail-fast: false | |
matrix: | |
python_version: ${{ fromJson(needs.constants.outputs.python_versions) }} | |
# To check all wheels for supported python3 versions | |
name: Test Wheels (Python ${{ matrix.python_version }}) on Mac arm64 | |
runs-on: macos-latest | |
steps: | |
- name: Checkout Catalyst repo | |
uses: actions/checkout@v4 | |
# Python 3.10 was dropped from the GH images on macOS arm | |
- name: Install Python 3.10 | |
uses: actions/setup-python@v5 | |
if: ${{ matrix.python_version }} == '3.10' | |
with: | |
python-version: '3.10' | |
- name: Download Wheel Artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: catalyst-macos_arm64-wheel-py-${{ matrix.python_version }}.zip | |
path: ${{ github.workspace }}/dist | |
- name: Download Standalone Plugin Wheel Artifact | |
# Run only on Thursday at the given time | |
if: github.event.schedule == '35 4 * * 4' | |
uses: actions/download-artifact@v4 | |
with: | |
name: standalone-plugin-macos_arm64-wheel-py-${{ matrix.python_version }}.zip | |
path: ${{ github.workspace }}/standalone_plugin_wheel/wheel | |
- name: Setup Python version | |
# There are multiple Python versions installed on the GitHub image, 3.10 - 3.12 is already | |
# available under /Library/Frameworks/Python.framework/Versions/, but homebrew also provides | |
# 3.11 and 3.12. Make sure to consistently use the system versions. | |
run: | | |
echo /Library/Frameworks/Python.framework/Versions/${{ matrix.python_version }}/bin >> $GITHUB_PATH | |
- name: Install Python dependencies | |
run: | | |
# During the 0.10.0 release cycle we discovered that having exactly 2700 test items distributed on | |
# exactly 3 cores (e.g. GH M1 runner) produces a lot of test failures. Randomizing the test order | |
# (pytest-randomly) fixes the issue for now. | |
python${{ matrix.python_version }} -m pip install pytest pytest-xdist pytest-mock pytest-randomly | |
- name: Install PennyLane Plugins | |
run: | | |
python${{ matrix.python_version }} -m pip install PennyLane-Lightning-Kokkos | |
python${{ matrix.python_version }} -m pip install 'amazon-braket-pennylane-plugin>1.27.1' | |
- name: Install OQC client | |
run: | | |
python${{ matrix.python_version }} -m pip install oqc-qcaas-client | |
- name: Install Catalyst | |
run: | | |
python${{ matrix.python_version }} -m pip install dist/*.whl --extra-index-url https://test.pypi.org/simple | |
- name: Install Standalone Plugin | |
# Run only on Thursday at the given time | |
if: github.event.schedule == '35 4 * * 4' | |
run: | | |
python${{ matrix.python_version }} -m pip install standalone_plugin_wheel/wheel/*.whl --no-deps | |
- name: Run Python Pytest Tests | |
run: | | |
python${{ matrix.python_version }} -m pytest frontend/test/pytest -n auto | |
python${{ matrix.python_version }} -m pytest frontend/test/pytest --backend="lightning.kokkos" -n auto | |
python${{ matrix.python_version }} -m pytest frontend/test/async_tests -p no:randomly | |
python${{ matrix.python_version }} -m pytest frontend/test/pytest --runbraket=LOCAL -n auto | |
python${{ matrix.python_version }} -m pytest frontend/test/test_oqc/oqc -n auto | |
- name: Run Standalone Plugin Tests | |
# Run only on Thursday at the given time | |
if: github.event.schedule == '35 4 * * 4' | |
run: | | |
python${{ matrix.python_version }} -m pytest standalone_plugin_wheel/standalone_plugin/test -n auto |