-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtest_all.sh
executable file
·84 lines (75 loc) · 2.5 KB
/
test_all.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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/usr/bin/env bash
#ISA="XpulpNN"
ISA="XpulpV2"
BW="32bit"
#BW="64bit"
TEST='conv_like'
#TEST='lnq'
#TEST='ap'
#TEST='mp'
precs=(2 4 8)
sgn=(0 1)
cd ${ISA}/${BW}/test
rm -f errors.txt
if [ ${TEST} = 'conv_like' ]; then
# conv, dw, pw, linear_quant
for si in ${sgn[@]}; do
for so in ${sgn[@]}; do
for pi in ${precs[@]}; do
for po in ${precs[@]}; do
for pw in ${precs[@]}; do
echo "precision: ${pi}${po}${pw} sign: ${si}${so}"
rm -f BUILD/PULP/GCC_RISCV/test/test* && make build -j8 kernel=${pi}${po}${pw} signed=${si}${so}
if ! make all run | grep -q "errors: 0"; then
echo -e "prec ${pi}${po}${pw}, sgn ${si}${so}\n" >> errors.txt
fi
done
done
done
done
done
fi
if [ ${TEST} = 'lnq' ]; then
# linear_quant
for si in ${sgn[@]}; do
for pi in ${precs[@]}; do
for pw in ${precs[@]}; do
if ! [ ${pi} = 2 -a ${pw} = 4 ] ; then
echo "precision: ${pi}${pw} sign: ${si}${so}"
rm -f BUILD/PULP/GCC_RISCV/test/test* && make build -j8 kernel=${pi}${pw} signed=${si}
if ! make all run | grep -q "errors: 0"; then
echo -e "prec ${pi}${pw}, sgn ${si}\n" >> errors.txt
fi
fi
done
done
done
fi
if [ ${TEST} = 'mp' ]; then
# maxpool
for si in ${sgn[@]}; do
for pi in ${precs[@]}; do
echo "precision: ${pi} sign: ${si}"
rm -f BUILD/PULP/GCC_RISCV/test/test* && make build -j8 kernel=${pi} signed=${si}
if ! make all run | grep -q "errors: 0"; then
echo -e "prec ${pi}, sgn ${si}\n" >> errors.txt
fi
done
done
fi
if [ ${TEST} = 'ap' ]; then
# average pool
for si in ${sgn[@]}; do
for so in ${sgn[@]}; do
for pi in ${precs[@]}; do
for po in ${precs[@]}; do
echo "precision: ${pi}${po} sign: ${si}${so}"
rm -f BUILD/PULP/GCC_RISCV/test/test* && make build -j8 kernel=${pi}${po}${pw} signed=${si}${so}
if ! make all run | grep -q "errors: 0"; then
echo -e "prec ${pi}${po}, sgn ${si}${so}\n" >> errors.txt
fi
done
done
done
done
fi