Linux上的基准程序

时间:2010-12-14 17:20:21

标签: linux benchmarking

对于作业,我们需要使用不同的优化和参数来对我们的实现进行基准测试。有没有一种可行的方法来对linux命令行(我知道时间)上的小程序进行基准测试,使用不同的参数,这样可以将时间数据作为CSV或类似的东西?输出可能是这样的:

Implementation      Time     
A                    23s
B with -O3 2Threads  15s 
B with -O3 4Threads  10s 

我很确定我在一些教授的幻灯片上看到过类似的东西,但是我不记得是谁或者什么时候......

1 个答案:

答案 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"