-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtester5.sh
More file actions
executable file
·89 lines (80 loc) · 2.55 KB
/
tester5.sh
File metadata and controls
executable file
·89 lines (80 loc) · 2.55 KB
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
85
86
87
88
89
#! /bin/bash
RED="\033[31m"
GREEN="\033[32m"
ENDCOLOR="\033[0m"
NB_VALS=5
MAX_NB_MOVES=0
MAX_TEST_ID=0
N=1.38
# LIMIT=$(bc -l <<< "e($N*l($NB_VALS))")
LIMIT=12
INT_LIMIT=${LIMIT%.1}
NB_CASES_ABOVE_LIMIT=0
ITERATIONS=1
PERMUTATIONS_FILE=5_permutations_numbered.txt
LOG_FILE=sore_thumbs_$NB_VALS.log
PS_TEMPFILE=tester_temp_$NB_VALS.log
echo -e "${GREEN}Testing for ${NB_VALS} values ${ENDCOLOR}"
for i in {1..120}
do
export ARG=$(awk -F: -v i=$i 'NR==i{printf $2;}' $PERMUTATIONS_FILE)
./push_swap $ARG > $PS_TEMPFILE
NB_MOVES=$(< $PS_TEMPFILE wc -l | sed 's/ //g');
if [ $(< $PS_TEMPFILE ./checker_Mac $ARG | grep -q KO) ];
then
echo "Error!"
echo "Error!" >> $LOG_FILE
echo $ARG >> $LOG_FILE
echo "nb_moves:" >> $LOG_FILE
echo $NB_MOVES >> $LOG_FILE
break
fi
if [ $(echo "$NB_MOVES >= $LIMIT" | bc) -eq 1 ];
then
echo "Test #"$i":" $NB_MOVES "[$(cat $PS_TEMPFILE | ./checker_Mac $ARG)]" >> $LOG_FILE
echo $ARG >> $LOG_FILE
echo "" >> $LOG_FILE
let NB_CASES_ABOVE_LIMIT+=1;
fi
if [ $(echo $NB_MOVES ">" $MAX_NB_MOVES | bc) -eq 1 ];
then
echo "Test #"$i":" $NB_MOVES "[$(cat $PS_TEMPFILE | ./checker_Mac $ARG)]" >> $LOG_FILE
echo "$ARG" >> $LOG_FILE
echo "" >> $LOG_FILE
MAX_NB_MOVES=$NB_MOVES;
MAX_TEST_ID=$i;
fi
if [ $(< $PS_TEMPFILE ./checker_Mac $ARG | grep OK) ];
then
echo -e "$ARG: ${GREEN}${NB_MOVES} "[$(cat $PS_TEMPFILE | ./checker_Mac $ARG)]"${ENDCOLOR}"
else
echo -e "$ARG: ${RED}${NB_MOVES} "[$(cat $PS_TEMPFILE | ./checker_Mac $ARG)]"${ENDCOLOR}"
fi
let SUM+=$NB_MOVES;
let ITERATIONS+=1;
let i+=1;
done
rm $PS_TEMPFILE
echo "Nb tests done:" $(($ITERATIONS - 1))
if [ $(echo "$(($SUM / ($ITERATIONS - 1))) < ${LIMIT}" | bc) -eq 1 ];
then
echo -e "${GREEN}Average nb of moves: $(($SUM / ($ITERATIONS - 1)))${ENDCOLOR}"
else
echo -e "${RED}Average nb of moves: $(($SUM / ($ITERATIONS - 1)))${ENDCOLOR}"
fi
if [ $(echo $MAX_NB_MOVES "<" $LIMIT | bc) -eq 1 ];
then
echo -e "${GREEN}Worst nb of moves: ${MAX_NB_MOVES}${ENDCOLOR}"
else
echo -e "${RED}Worst nb of moves: ${MAX_NB_MOVES}${ENDCOLOR}"
fi
if [ $NB_CASES_ABOVE_LIMIT -eq 0 ];
then
printf "${GREEN}%s %.0f %s %d\n${ENDCOLOR}" "Nb of moves above" $LIMIT ":" $NB_CASES_ABOVE_LIMIT
else
printf "${RED}%s %.0f %s %d\n${ENDCOLOR}" "Nb of moves above" $LIMIT ":" $NB_CASES_ABOVE_LIMIT
fi
echo "Nb tests done:" $ITERATIONS >> $LOG_FILE
echo "Average nb of moves: $(($SUM / ($ITERATIONS - 1)))" >> $LOG_FILE
echo "(Test #"$MAX_TEST_ID") Worst nb of moves:" $MAX_NB_MOVES >> $LOG_FILE
printf "%s %.0f %s %d\n" "Nb of moves above" $LIMIT ":" $NB_CASES_ABOVE_LIMIT >> $LOG_FILE