对于作业,我们需要使用不同的优化和参数来对我们的实现进行基准测试。有没有一种可行的方法来对linux命令行(我知道时间)上的小程序进行基准测试,使用不同的参数,这样可以将时间数据作为CSV或类似的东西?输出可能是这样的:
Implementation Time
A 23s
B with -O3 2Threads 15s
B with -O3 4Threads 10s
我很确定我在一些教授的幻灯片上看到过类似的东西,但是我不记得是谁或者什么时候......
答案 0 :(得分:6)
为什么不在time
脚本中使用bash
命令,例如:
#!/bin/bash
NPROG=`cat proglist | wc -l`
for i in `seq 1 ${NPROG}`
do
PROG=`sed -n "${i}p" proglist`
ARG=`sed -n "${i}p" arglist`
TIME=`{ time ${PROG} ${ARG}; } 2>&1 | grep real | awk '{print $2}'`
echo "${TIME} ${PROG} ${ARG}"
done
其中proglist
是包含要执行的程序的文本文件
A
B
B
和arglist
是一个包含参数的文本文件,如:
-a 1 -b 2
-f "foo"
-f "bar"
脚本的输出看起来像:
0m32.000s A -a 1 -b 2
1m12.000s B -f "foo"
5m38.000s B -f "bar"