Skip to content

Commit 02c87ab

Browse files
committed
Added benchmarks to ci
1 parent 26278b9 commit 02c87ab

File tree

1 file changed

+76
-0
lines changed

1 file changed

+76
-0
lines changed

.github/workflows/benchmarks.yml

Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
name: Linux
2+
on:
3+
workflow_dispatch:
4+
pull_request:
5+
push:
6+
branches: [master]
7+
concurrency:
8+
group: ${{ github.workflow }}-${{ github.job }}-${{ github.ref }}
9+
cancel-in-progress: true
10+
defaults:
11+
run:
12+
shell: bash -e -l {0}
13+
jobs:
14+
build:
15+
runs-on: ubuntu-24.04
16+
name: ${{ matrix.sys.compiler }} ${{ matrix.sys.version }} - ${{ matrix.sys.name }}
17+
strategy:
18+
fail-fast: false
19+
matrix:
20+
sys:
21+
- {compiler: clang, version: '20', name: xsimd, flags: -DXTENSOR_USE_XSIMD=ON}
22+
- {compiler: clang, version: '20', name: xsimd-tbb, flags: -DXTENSOR_USE_XSIMD=ON -DXTENSOR_USE_TBB=ON}
23+
- {compiler: gcc, version: '14', name: xsimd, flags: -DXTENSOR_USE_XSIMD=ON}
24+
- {compiler: gcc, version: '14', name: xsimd-tbb, flags: -DXTENSOR_USE_XSIMD=ON -DXTENSOR_USE_TBB=ON}
25+
26+
steps:
27+
- name: Install GCC
28+
if: matrix.sys.compiler == 'gcc'
29+
uses: egor-tensin/setup-gcc@v1
30+
with:
31+
version: ${{matrix.sys.version}}
32+
platform: x64
33+
34+
- name: Install LLVM and Clang
35+
if: matrix.sys.compiler == 'clang'
36+
run: |
37+
wget https://apt.llvm.org/llvm.sh
38+
chmod +x llvm.sh
39+
sudo ./llvm.sh ${{matrix.sys.version}}
40+
sudo apt-get install -y clang-tools-${{matrix.sys.version}}
41+
sudo update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-${{matrix.sys.version}} 200
42+
sudo update-alternatives --install /usr/bin/clang clang /usr/bin/clang-${{matrix.sys.version}} 200
43+
sudo update-alternatives --install /usr/bin/clang-scan-deps clang-scan-deps /usr/bin/clang-scan-deps-${{matrix.sys.version}} 200
44+
sudo update-alternatives --set clang /usr/bin/clang-${{matrix.sys.version}}
45+
sudo update-alternatives --set clang++ /usr/bin/clang++-${{matrix.sys.version}}
46+
sudo update-alternatives --set clang-scan-deps /usr/bin/clang-scan-deps-${{matrix.sys.version}}
47+
48+
- name: Checkout code
49+
uses: actions/checkout@v3
50+
51+
- name: Set conda environment
52+
uses: mamba-org/setup-micromamba@main
53+
with:
54+
environment-name: myenv
55+
environment-file: environment-dev.yml
56+
init-shell: bash
57+
cache-downloads: true
58+
create-args: |
59+
${{ (matrix.sys.name == 'tbb' || matrix.sys.name == 'xsimd-tbb' ) && 'tbb-devel' || '' }}
60+
61+
- name: Configure using CMake
62+
run: |
63+
if [[ "${{matrix.sys.compiler}}" = "gcc" ]]; then export CC=gcc-${{matrix.sys.version}}; export CXX=g++-${{matrix.sys.version}}; else export CC=clang; export CXX=clang++; fi
64+
cmake -G Ninja -Bbuild -DCMAKE_C_COMPILER=$CC -DCMAKE_CXX_COMPILER=$CXX -DCMAKE_INSTALL_PREFIX=$CONDA_PREFIX -DBUILD_BENCHMARKS=ON ${{ matrix.sys.flags }}
65+
66+
- name: Install
67+
working-directory: build
68+
run: cmake --install .
69+
70+
- name: Build
71+
working-directory: build
72+
run: cmake --build . --target benchmark_xtensor --parallel 8
73+
74+
- name: Run tests
75+
working-directory: build/benchmark
76+
run: benchmark_xtensor

0 commit comments

Comments
 (0)