forked from tj-sun/firedrake-vectorization
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_many_oneforms.sh
executable file
·69 lines (68 loc) · 1.88 KB
/
run_many_oneforms.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#!/bin/bash
arch='haswell'
# arch="skylake"
hyperthreading=0
compiler=('gcc' 'clang' 'icc')
# compiler=('icc')
if [ $arch == "haswell" ]
then
batchsize=(1 4) # 1: not vectorize, 4: vectorize by 4
if [ $hyperthreading == 1 ]
then
export TJ_NP=16 # number of processes
export TJ_MPI_MAP_BY="hwthread"
else
export TJ_NP=8
export TJ_MPI_MAP_BY="core"
fi
else
batchsize=(1 8)
if [ $hyperthreading == 1 ]
then
export TJ_NP=32
export TJ_MPI_MAP_BY="hwthread"
else
export TJ_NP=16
export TJ_MPI_MAP_BY="core"
fi
fi
mesh=('quad' 'tri' 'hex' 'tet')
# mesh=('tet')
form=('helmholtz' 'mass' 'laplacian' 'elasticity' 'hyperelasticity')
# form=('helmholtz')
vs=('omp' 've') # vectorization strategy
# vs=('omp')
export PYOP2_TIME=1 # switch on timing mode
for v in ${vs[@]}
do
for m in ${mesh[@]}
do
for f in ${form[@]}
do
for bs in ${batchsize[@]}
do
for comp in ${compiler[@]}
do
export TJ_FORM=$f
export TJ_MESH=$m
export PYOP2_SIMD_WIDTH=$bs
export PYOP2_VECT_STRATEGY=$v
export OMPI_CC=$comp
export MPICH_CC=$comp
export PYOP2_CFLAGS="-march=native"
if [ $comp == "icc" ]
then
if [ $arch == "haswell" ]
then
export PYOP2_CFLAGS="-xcore-avx2"
else
export PYOP2_CFLAGS="-xcore-avx512 -qopt-zmm-usage=high"
fi
fi
python run_oneforms.py --prefix "$arch"_ --suffix "_$comp"
firedrake-clean
done
done
done
done
done