-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_time.sh
51 lines (45 loc) · 1.35 KB
/
run_time.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
#!/bin/bash
# NBODY parameters for running the binary
DT=0.01f
STEPS=500
THREADS_PER_BLOCK=1024
INPUT_DIR="inputs"
OUTPUT_DIR="outputs"
GEN_BIN="./commons/gen"
NBODY_BIN="./step2/nbody"
RESULT_FILE="step2/times.txt"
# Check whether exists OUTPUT FILE to store the results
if [ ! -d "$RESULT_FILE" ]; then
touch ${RESULT_FILE}
fi
# Delete the OUT FILE to store the results
> ${RESULT_FILE}
# Check whether exists INPUT directory
if [ ! -d "$INPUT_DIR" ]; then
mkdir "$INPUT_DIR"
fi
# Check whether exists OUTPUT directory
if [ ! -d "$OUTPUT_DIR" ]; then
mkdir "$OUTPUT_DIR"
fi
# Check whether INPUT directory is empty
if [ "$(ls -A $INPUT_DIR)" ]; then
rm -- "${INPUT_DIR}"/*
fi
# Check whether OUTPUT directory is empty
if [ "$(ls -A $OUPUT_DIR)""step0/times.txt" ]; then
rm -- "${OUTPUT_DIR}"/*
fi
# Generate INPUT files with available generator
for i in {1..30}; do
${GEN_BIN} $((i*1024)) "${INPUT_DIR}/$((i*1024)).h5"
done
# Run the individual INPUT files and write the measured time to the file
for i in {1..30}; do
IN_FILE="${INPUT_DIR}/$((i*1024)).h5"
OUT_FILE="${OUTPUT_DIR}/$((i*1024)).h5"
OUT=$(${NBODY_BIN} $((i*1024)) ${DT} ${STEPS} ${THREADS_PER_BLOCK} 20 4096 128 ${IN_FILE} ${OUT_FILE})
TIME="$(echo "$OUT" | sed -n '8 p' | cut -d' ' -f2)"
RESULT="$(printf "$((i)) * 1024 \t\t\t %g\n" ${TIME})"
echo "$RESULT" >> "${RESULT_FILE}"
done