安装

  • 网上找到的版本应该是这个speccpu2006-v1.0.1-newest.tar,在想要安装的目录下执行tar -xvf speccpu2006-v1.0.1-newest.tar就可以解压安装
  • 进入到目录里面cd speccpu2006-v1.0.1
  • 安装 spec ,./install.sh,如果安装出现错误,极有可能是有一些文件没有可执行文件,递归赋予可执行文件就行chmod -R a+x .,不会有问题的
  • 安装完成之后执行./shrc激活spec环境(以后每次重新打开一个 shell 会话的时候都需要激活一下)

构成

  • SPEC有两个部分组成,一个是数据,一个是代码(代码以项目的方式组织),运行需要指定数据以及项目
  • 数据有三个规格
    1. test(小型)
    2. train(中型)
    3. ref(大型)
  • 代码有以下选项
    1. int(整型运算性能)
    2. float,也叫 fp(浮点运算性能)
    3. all_c(全部 c 项目)
    4. all_cpp(全部 cpp 项目)
    5. all(全部项目)
    6. 特定项目,比如 453.povray

编译标准

  • C 语言要使用 -std=gnu89
  • CPP 要使用 -std=c++98
  • 如果要启用 address sanitizer,要注意防止 sanitizer 检测到错误的时候 abort 程序而导致 benchmark 提前终止,需要使用以下编译选项
    1
    
    -fsanitize=address -fsanitize-recover=address
    
    并且要注入环境变量ASAN_OPTIONS=halt_on_error=0:detect_leaks=0

配制

运行 spec 需要指定配制,在配制文件里面要声明 reportable = 1 才可以有结果输出

运行模式

spec 有两种运行模式,一个是 base ,基本模式,一般使用这个,一个是 peak ,性能模式,测试峰值性能极限

  • 关于这两个关键字的解释,要看下文如何看结果报告那一章节

运行命令

1
runspec --rebuild -c $name -a run -I -l --size $size -n $NUM_RUNS $PROJECT
  1. --rebuild:每次运行都重新编译,默认行为不是重新编译,而是类似 make -j,另外说一点,spec 使用的不是make,而是specmake
  2. -c:指定运行配制(config)
  3. -a:指定任务,有以下选项(action): - build - buildsetup - clean - clobber - configpp - scrub - report - run - setup - trash - validate
  4. -I:忽略任何中断
  5. -l:在执行过程中记录输出
  6. --size:选择数据集大小 <test | train | ref>
  7. -n:spec运行的趟数
  8. $PROJECT: <int | fp | all_c | all_cpp | all>

Fortran 错误

  • 由于某些项目是有部分使用 fortran 来实现的,所以如果没有安装 gfortran 的时候可能会导致其编译不了,解决方法有二
    1. 安装 gfortran
    2. FC=echo ,相当于直接告诉它不要编译这部分了,浪费时间的

日志位置

  • 运行完成之后在安装底层目录的 result 文件夹下可以看到运行日志以及结果
    1. 看结尾
      • 以 log 结尾的文件是一个完整运行日志,包括编译输出,运行输出,以及结果归纳
      • 以其他文件类型后缀结尾的都是测试结果归纳,只不过文件格式不一样,内容一样的,一般看txt就行
    2. 看开头
      • CINT 表示使用 C/C++ 编写的 int benchmark
      • CFP 表示使用 C/C++ 编写的 float benchmark
    3. 看中间
      • 中间是一个编号,遵循以时间为递增的规律
  • 另外在每个项目的文件下也会有单独的编译日志以及运行日志,例如
    • ls ./benchspec/CPU2006/400.perlbench/run/build_base_1.0000/这个目录下可以看到编译日志
      • 如果这个项目编译出错了,可以在这个目录下找到make.err日志
    • ls ./benchspec/CPU2006/400.perlbench/run/run_base_test_1.0000/这个目录下可以看到运行日志

看日志

  • 有时候 spec 自带的结果汇总会不完整,因为有些程序有可能被 asan 终止之后在拉起就不被计分了,所有有时候得去日志里面翻找成功运行项目案例的运行时间,在上面提到的那个完整日志里面全局搜索关键字 success 就可以了(忽略大小写)

    • log2excel 脚本,这里是一个简单的将这些 success 项目信息转为 excel 表格的脚本,以及应该喂给这个脚本的 success 数据格式:

       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
      
      CC               = /root/asanopt/llvm-4.0.0-project/build/bin/clang    -std=gnu89 -fsanitize=address -fsanitize-recover=address -m64 -g
      CXX              = /root/asanopt/llvm-4.0.0-project/build/bin/clang++  -std=c++98 -fsanitize=address -fsanitize-recover=address -m64 -g
      
      400.perlbench base ref ratio=12.85, runtime=760.415379
      400.perlbench base ref ratio=14.33, runtime=681.948309
      400.perlbench base ref ratio=14.44, runtime=676.611816
      401.bzip2 base ref ratio=18.30, runtime=527.208650
      401.bzip2 base ref ratio=18.55, runtime=520.089746
      401.bzip2 base ref ratio=18.78, runtime=513.887221
      403.gcc base ref ratio=18.22, runtime=441.892276
      403.gcc base ref ratio=19.51, runtime=412.592274
      403.gcc base ref ratio=19.76, runtime=407.424780
      429.mcf base ref ratio=29.58, runtime=308.278307
      429.mcf base ref ratio=36.16, runtime=252.184882
      429.mcf base ref ratio=38.58, runtime=236.364282
      433.milc base ref ratio=20.98, runtime=437.482181
      433.milc base ref ratio=21.23, runtime=432.368999
      433.milc base ref ratio=21.41, runtime=428.706485
      444.namd base ref ratio=19.20, runtime=417.752721
      444.namd base ref ratio=19.35, runtime=414.419211
      444.namd base ref ratio=20.47, runtime=391.783225
      445.gobmk base ref ratio=21.42, runtime=489.668323
      445.gobmk base ref ratio=22.60, runtime=464.136214
      445.gobmk base ref ratio=22.85, runtime=458.984958
      447.dealII base ref ratio=27.67, runtime=413.422023
      447.dealII base ref ratio=28.80, runtime=397.228149
      447.dealII base ref ratio=30.58, runtime=374.084230
      450.soplex base ref ratio=28.75, runtime=290.083530
      450.soplex base ref ratio=31.28, runtime=266.656672
      450.soplex base ref ratio=32.73, runtime=254.838331
      453.povray base ref ratio=20.95, runtime=253.951463
      453.povray base ref ratio=21.30, runtime=249.714080
      453.povray base ref ratio=22.47, runtime=236.739422
      456.hmmer base ref ratio=14.50, runtime=643.463325
      456.hmmer base ref ratio=16.22, runtime=575.344854
      456.hmmer base ref ratio=16.35, runtime=570.789854
      458.sjeng base ref ratio=21.67, runtime=558.318427
      458.sjeng base ref ratio=24.55, runtime=492.913527
      458.sjeng base ref ratio=25.18, runtime=480.538434
      462.libquantum base ref ratio=62.08, runtime=333.748264
      462.libquantum base ref ratio=68.76, runtime=301.351093
      462.libquantum base ref ratio=73.88, runtime=280.453628
      464.h264ref base ref ratio=31.03, runtime=713.099006
      464.h264ref base ref ratio=33.94, runtime=652.062848
      464.h264ref base ref ratio=35.00, runtime=632.321436
      470.lbm base ref ratio=58.00, runtime=236.895693
      470.lbm base ref ratio=63.69, runtime=215.746827
      470.lbm base ref ratio=64.17, runtime=214.102158
      473.astar base ref ratio=17.80, runtime=394.369525
      473.astar base ref ratio=18.05, runtime=388.900111
      473.astar base ref ratio=18.77, runtime=374.065830
      482.sphinx3 base ref ratio=30.24, runtime=644.427922
      482.sphinx3 base ref ratio=30.28, runtime=643.674597
      482.sphinx3 base ref ratio=32.57, runtime=598.409849
      483.xalancbmk base ref ratio=20.32, runtime=339.625837
      483.xalancbmk base ref ratio=20.72, runtime=332.940290
      483.xalancbmk base ref ratio=21.84, runtime=315.878660
      998.specrand base ref ratio=119.83, runtime=0.083455
      998.specrand base ref ratio=122.88, runtime=0.081378
      998.specrand base ref ratio=123.67, runtime=0.080860
      999.specrand base ref ratio=122.42, runtime=0.081687
      999.specrand base ref ratio=123.98, runtime=0.080658
      999.specrand base ref ratio=124.79, runtime=0.080134
      
       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
      
      import re
      import sys
      from statistics import median
      from openpyxl import Workbook
      
      # 检查是否提供了文件名参数
      if len(sys.argv) != 2:
          print("用法: python process_data_to_excel.py <文件名>")
          sys.exit(1)
      
      # 获取用户输入的文件名
      filename = sys.argv[1]
      
      # 读取文件
      try:
          with open(filename, 'r') as file:
              data = file.readlines()
      except FileNotFoundError:
          print(f"文件 {filename} 未找到。")
          exit()
      
      # 跳过前三行
      data = data[3:]
      
      # 解析数据
      results = {}
      for line in data:
          line = line.strip()
          match = re.match(r'(\d+\.\w+)\s+base\s+ref\s+ratio=(\d+\.\d+),\s+runtime=(\d+\.\d+)', line)
          if match:
              name, ratio, runtime = match.groups()
              if name not in results:
                  results[name] = [[], []]
              results[name][0].append(float(ratio))
              results[name][1].append(float(runtime))
      
      # 创建 Excel 文件
      wb = Workbook()
      ws = wb.active
      ws.title = "Results"
      
      # 写入标题行
      ws.append(["Name", "Median Ratio", "Median Runtime"])
      
      # 写入数据(保留完整精度)
      for name, content in results.items():
          median_ratio = median(content[0])
          median_runtime = median(content[1])
          ws.append([name, median_ratio, median_runtime])
      
      # 保存 Excel 文件
      output_file = filename+".xlsx"
      wb.save(output_file)
      print(f"结果已保存到 {output_file}")
      
  • 要找出那些编译不成功的项目,只需要在完整日志里面全局搜索关键字 error building(忽略大小写)

  • 补充说明:

    • 999.specrand 999.specrand 这两个项目的数据不重要,因为这两个项目只是验证 spec 环境的完整性的,比如说能不能编译

看结果报告

  • 报告例子(1),从中间分开,可以划分为INT部分和FLOAT部分,这个报告来自于运行结束之后的终端输出:

     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
    
    Producing Reports
    mach: default
      ext: 1
        size: test
          set: int
            format: raw -> /root/spec2006/result/CINT2006.001.test.rsf
            format: ASCII -> /root/spec2006/result/CINT2006.001.test.txt
            format: Screen ->
    
                                      Estimated                       Estimated
                    Base     Base       Base        Peak     Peak       Peak
    Benchmarks      Ref.   Run Time     Ratio       Ref.   Run Time     Ratio
    -------------- ------  ---------  ---------    ------  ---------  ---------
    400.perlbench      --     6.96           -- S
    401.bzip2          --     6.18           -- S
    403.gcc            --     1.33           -- S
    429.mcf            --     2.05           -- S
    445.gobmk          --    19.0            -- S
    456.hmmer          --     3.27           -- S
    458.sjeng          --     4.78           -- S
    462.libquantum     --     0.0351         -- S
    464.h264ref        --    14.0            -- S
    471.omnetpp        --   393              -- S
    473.astar          --     8.30           -- S
    483.xalancbmk      --     0.120          -- S
     Est. SPECint_base2006                   --
     Est. SPECint2006                                                   Not Run
    
          set: fp
            format: raw -> /root/spec2006/result/CFP2006.001.test.rsf
            format: ASCII -> /root/spec2006/result/CFP2006.001.test.txt
            format: Screen ->
    
                                      Estimated                       Estimated
                    Base     Base       Base        Peak     Peak       Peak
    Benchmarks      Ref.   Run Time     Ratio       Ref.   Run Time     Ratio
    -------------- ------  ---------  ---------    ------  ---------  ---------
    410.bwaves                                  NR
    416.gamess                                  NR
    433.milc           --      6.52          -- S
    434.zeusmp                                  NR
    435.gromacs                                 NR
    436.cactusADM                               NR
    437.leslie3d                                NR
    444.namd           --      9.79          -- S
    447.dealII                                  NR
    450.soplex         --      0.024         -- S
    453.povray         --      0.875         -- S
    454.calculix                                NR
    459.GemsFDTD                                NR
    465.tonto                                   NR
    470.lbm            --      1.54          -- S
    481.wrf                                     NR
    482.sphinx3        --      1.22          -- S
     Est. SPECfp_base2006                    --
     Est. SPECfp2006                                                    Not Run
    
    • 例子(1)里面的INT 部分:

       1
       2
       3
       4
       5
       6
       7
       8
       9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      
            set: int
              format: raw -> /root/spec2006/result/CINT2006.001.test.rsf
              format: ASCII -> /root/spec2006/result/CINT2006.001.test.txt
              format: Screen ->
      
                                        Estimated                       Estimated
                      Base     Base       Base        Peak     Peak       Peak
      Benchmarks      Ref.   Run Time     Ratio       Ref.   Run Time     Ratio
      -------------- ------  ---------  ---------    ------  ---------  ---------
      400.perlbench      --     6.96           -- S
      401.bzip2          --     6.18           -- S
      403.gcc            --     1.33           -- S
      429.mcf            --     2.05           -- S
      445.gobmk          --    19.0            -- S
      456.hmmer          --     3.27           -- S
      458.sjeng          --     4.78           -- S
      462.libquantum     --     0.0351         -- S
      464.h264ref        --    14.0            -- S
      471.omnetpp        --   393              -- S
      473.astar          --     8.30           -- S
      483.xalancbmk      --     0.120          -- S
       Est. SPECint_base2006                   --
       Est. SPECint2006                                                   Not Run
      
    • 例子(1)的FP 部分:

       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
      
            set: fp
              format: raw -> /root/spec2006/result/CFP2006.001.test.rsf
              format: ASCII -> /root/spec2006/result/CFP2006.001.test.txt
              format: Screen ->
      
                                        Estimated                       Estimated
                      Base     Base       Base        Peak     Peak       Peak
      Benchmarks      Ref.   Run Time     Ratio       Ref.   Run Time     Ratio
      -------------- ------  ---------  ---------    ------  ---------  ---------
      410.bwaves                                  NR
      416.gamess                                  NR
      433.milc           --      6.52          -- S
      434.zeusmp                                  NR
      435.gromacs                                 NR
      436.cactusADM                               NR
      437.leslie3d                                NR
      444.namd           --      9.79          -- S
      447.dealII                                  NR
      450.soplex         --      0.024         -- S
      453.povray         --      0.875         -- S
      454.calculix                                NR
      459.GemsFDTD                                NR
      465.tonto                                   NR
      470.lbm            --      1.54          -- S
      481.wrf                                     NR
      482.sphinx3        --      1.22          -- S
       Est. SPECfp_base2006                    --
       Est. SPECfp2006                                                    Not Run
      
  • 报告例子(2),这个报告来自CINT的log,已经单独区分出了INT部分,所以不需要再从中间划开区分两部分

     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
    
                       SPEC(R) CINT2006 Summary
                                        -- --
                               Fri Nov 15 23:02:02 2024
    
    CPU2006 License #0     Test date: --           Hardware availability: --
    Test sponsor: --                               Software availability: --
    
                                      Estimated                       Estimated
                    Base     Base       Base        Peak     Peak       Peak
    Benchmarks      Ref.   Run Time     Ratio       Ref.   Run Time     Ratio
    -------------- ------  ---------  ---------    ------  ---------  ---------
    400.perlbench    9770        208       47.0 S                                  
    400.perlbench    9770        196       49.8 S                                  
    400.perlbench    9770        197       49.5 *                                  
    401.bzip2        9650        318       30.4 S                                  
    401.bzip2        9650        320       30.2 S                                  
    401.bzip2        9650        318       30.3 *                                  
    403.gcc          8050        173       46.6 S                                  
    403.gcc          8050        165       48.7 *                                  
    403.gcc          8050        165       48.8 S                                  
    429.mcf          9120        182       50.0 S                                  
    429.mcf          9120        176       51.9 *                                  
    429.mcf          9120        175       52.0 S                                  
    445.gobmk       10490        292       35.9 S                                  
    445.gobmk       10490        290       36.2 S                                  
    445.gobmk       10490        290       36.2 *                                  
    456.hmmer        9330        213       43.9 *                                  
    456.hmmer        9330        213       43.8 S                                  
    456.hmmer        9330        213       43.9 S                                  
    458.sjeng       12100        288       42.0 S                                  
    458.sjeng       12100        288       42.0 S                                  
    458.sjeng       12100        288       42.0 *                                  
    462.libquantum  20720        227       91.3 S                                  
    462.libquantum  20720        225       92.0 S                                  
    462.libquantum  20720        226       91.7 *                                  
    464.h264ref     22130        284       78.0 S                                  
    464.h264ref     22130        284       77.8 *                                  
    464.h264ref     22130        285       77.7 S                                  
    471.omnetpp      6250        239       26.2 S                                  
    471.omnetpp      6250        235       26.6 *                                  
    471.omnetpp      6250        234       26.7 S                                  
    473.astar        7020        263       26.7 S                                  
    473.astar        7020        265       26.5 S                                  
    473.astar        7020        265       26.5 *                                  
    483.xalancbmk    6900        138       49.9 *                                  
    483.xalancbmk    6900        138       49.9 S                                  
    483.xalancbmk    6900        138       50.0 S                                  
    ==============================================================================
    400.perlbench    9770        197       49.5 *                                  
    401.bzip2        9650        318       30.3 *                                  
    403.gcc          8050        165       48.7 *                                  
    429.mcf          9120        176       51.9 *                                  
    445.gobmk       10490        290       36.2 *                                  
    456.hmmer        9330        213       43.9 *                                  
    458.sjeng       12100        288       42.0 *                                  
    462.libquantum  20720        226       91.7 *                                  
    464.h264ref     22130        284       77.8 *                                  
    471.omnetpp      6250        235       26.6 *                                  
    473.astar        7020        265       26.5 *                                  
    483.xalancbmk    6900        138       49.9 *                                  
     Est. SPECint(R)_base2006              44.7
     Est. SPECint2006                                                   Not Run
    
  • 在这个报告(2)里面,每一个子项目都运行了三次,以等号划分线划分开上下两部分,等号上面是每一轮运行每个子项目的情况,等号下面是等号上面每个子项目取所有运行结果的中位数的汇报

  • 报告(1)以及(2)表头的关键字解释如下:

  1. BasePeak 的区别在于编译器优化选项的使用:
  • Base
    • 使用一组严格限制的编译器优化选项。
    • 所有基准测试必须使用相同的优化设置。
    • 更强调结果的可重复性和一致性。
  • Peak
    • 可以为每个基准测试单独选择优化选项。
    • 更倾向于追求单个基准的最佳性能。
    • 优化灵活性更高,但可能降低可重复性。
  1. 完整解释表格
字段解释
Base Ref.官方标准硬件在 Base 配置下的参考运行时间。
Base Run Time你的系统在 Base 配置下实际运行该基准所需的时间。
Base Ratio性能比值,Base Ref. / Base Run Time,数值越大表示性能越好。
Peak Ref.官方标准硬件在 Peak 配置下的参考运行时间(一般等于 Base Ref.)。
Peak Run Time你的系统在 Peak 配置下实际运行该基准所需的时间。
Peak Ratio性能比值,Peak Ref. / Peak Run Time,数值越大表示性能越好。
  1. 关于 Estimated Based Ratio 这一列后面的状态列举及解释,看报告(2)做辅助理解:
  • S:成功运行
  • *:成功运行并且被选为中位数
  • NR:没有运行(Not Run)
  • CE:编译错误(Compile Error)
  • `VE`:验证错误(Verification Error),这意味着在测试过程中,程序运行没有出现运行时错误,但是其输出结果与预期结果不一致,无法通过验证

关于 Patch

  • 有时候 spec 的源码可能有问题,需要自己手动修正错误,修改源码
  • 在这种情况下,将修改过后的spec重新打包再分发是不可以的,在安装这个修改版本的时候会因为 spec 自带的 checksum 而没有办法通过检验
  • 解决方法:
    • 把修改的部分变成 patch
    • 在安装 spec 完成之后再把 patch 给打上去

SPEC 官方链接直达

  1. SPEC CPU 2006 购买
  2. SPEC CPU 2006 官方文档导航
  3. SPEC CPU 2006 安装使用详解,与本文大部分内容重合
  4. SPEC CPU 2006 配制文件选项详解
  5. SPEC CPU 2006 设计哲学与实现方法
  6. SPEC CPU 2006 命令选项详解
  7. SPEC CPU 2006 里面各个子项目的介绍,点击进网页之后拉到最下面,或者搜索关键字“Benchmark Documentation”(忽略大小写)