在现代PC上解读Dhrystone基准测试结果

时间:2015-01-21 17:09:19

标签: c benchmarking

首先,我会对我所做的事情进行一次尝试。

我从这里下载了dhry.h dhry_1.c和dhry_2.c: http://giga.cps.unizar.es/~spd/src/other/dhry/

然后我根据这个做了一些更正(以便我编译):

https://github.com/maximeh/buildroot/blob/master/package/dhrystone/dhrystone-2-HZ.patch

这个

Errors while compiling dhrystone in unix

我使用以下命令行编译了文件:

gcc dhry_1.c dhry_2.c -O2 -o run

我最终输入的运行次数为1000000000

等等。我编译了四个不同的优化级别,我得到了DMIPS的这些值(根据http://en.wikipedia.org/wiki/Dhrystone这是每秒的Dhrystones除以1757):

O0:8112 O1:16823.9 O2:22977.5 O3:23164.5(这些代表编译器标志,如-O2是优化级别2,O0是无)。

这将提供以下DMIPS / MHz(我的处理器的基频为3.4 GHz):

2.3859 4.9482 6.7581 6.8131

然而,我得到的感觉6.7是低的方式。根据我所读到的,A15在3.5到4 DMIPS / MHz之间,第三代I7只有两倍?不应该高得多吗?

任何人都可以告诉我,如果他们可以看到我可能做错了吗?或者我可能错误地解释了结果?

1 个答案:

答案 0 :(得分:5)

除了广泛的画笔处理外,您无法比较不同编译器生成的基准测试结果。作为第一个标准基准(Whetstone)的设计权威,我可以建议将计算机制造商的内部编译器的结果进行比较更不安全。在小型机时代,制造商发现Whetstone基准测试的各个部分可以进行优化,将分数提高一倍。我安排了更改和更详细的结果,以避免以后突出显示优化。

以下是我原版(1990年代)Dhrystone基准测试中PC的示例结果。有关详细信息,请参阅更多结果和(免费)执行和源文件:

http://www.roylongbottom.org.uk/dhrystone%20results.htm

还包括并使用相同的源代码编译,来自后来的MS编译器,一些来自Linux和Android,来自ARM CPU,另外一个来自Intel Atom,来自Houdini兼容层。我更喜欢VAX MIPS这个术语而不是DMIPS,因为1757除数是DEC VAX 11/780的结果。无论如何,还显示了MIPS / MHz计算。注意编译器的差异以及Android ARM CPU上的特别低的比率。

                          Dhry1   Dhry1   Dhry2   Dhry2     Dhry2
                            Opt   NoOpt     Opt   NoOpt       Opt
                            VAX     VAX     VAX     VAX     MIPS/
CPU                 MHz    MIPS    MIPS    MIPS    MIPS       MHz

AMD 80386            40    17.5    4.32    13.7    4.53       0.3
80486 DX2            66    45.1      12    35.3    12.4       0.5
Pentium             100     169    31.8     122    32.2       1.2
Pentium Pro         200     373    92.4     312    91.9       1.6
Pentium II          300     544     132     477     136       1.6
Pentium III         450     846     197     722     203       1.6
Pentium 4          1900    2593     261    2003     269       1.1
Atom               1666    2600     772    1948     780       1.2
Athlon 64          2211    5798    1348    4462    1312       2.0
Core 2 Duo 1 CP    2400    7145    1198    6446    1251       2.7
Phenom II 1 CP     3000    9462    2250    7615    2253       2.5
Core i7 4820K      3900   14776    2006   11978    2014       3.1

Later Intel Compiler
Pentium 4          1900    2613            1795               0.9
Athlon 64          2211    6104            3720               1.7
Core 2 Duo         2400    8094            5476               2.3
Phenom II          3000    9768            6006               2.0
Core i7 4820K      3900   15587           10347               2.7

Linux Ubuntu GCC Compiler
Atom               1666    5485    1198    2055    1194       1.2
Athlon 64          2211    9034    2286    4580    2347       2.1
Core 2 Duo         2400   13599    3428    5852    3348       2.4
Phenom II          3000   13406    3368    6676    3470       2.2
Core i7 4820K      3900   29277    7108   16356    7478       4.2

ARM Android NDK
926EJ               800                     356     196       0.4
v7-A9              1500                    1650     786       1.1
v7-A15             1700                    3189    1504       1.9

Atom Houdini       1866                    1840    1310       1.0