LLVM Clang 3.4 Compiler Optimization Levels

Benchmarking LLVM/Clang compiler optimization levels for a future article on phoronix.com.

Compare your own system(s) to this result file with the Phoronix Test Suite by running the command: phoronix-test-suite benchmark 1307304-SO-CLANGLEVE44
Jump To Table - Results

View

Do Not Show Noisy Results
Do Not Show Results With Incomplete Data
Do Not Show Results With Little Change/Spread
List Notable Results
Show Result Confidence Charts
Allow Limiting Results To Certain Suite(s)

Statistics

Show Overall Harmonic Mean(s)
Show Overall Geometric Mean
Show Wins / Losses Counts (Pie Chart)
Normalize Results
Remove Outliers Before Calculating Averages

Graph Settings

Force Line Graphs Where Applicable
Convert To Scalar Where Applicable
Prefer Vertical Bar Graphs

Multi-Way Comparison

Condense Multi-Option Tests Into Single Result Graphs

Table

Show Detailed System Result Table

Run Management

Highlight
Result
Toggle/Hide
Result
Result
Identifier
View Logs
Performance Per
Dollar
Date
Run
  Test
  Duration
-O0
July 29 2013
 
-O1
July 29 2013
 
-O2
July 29 2013
 
-Os
July 29 2013
 
-O3
July 28 2013
 
-Ofast
July 29 2013
 
Invert Behavior (Only Show Selected Data)
 

Only show results where is faster than
Only show results matching title/arguments (delimit multiple options with a comma):
Do not show results matching title/arguments (delimit multiple options with a comma):


LLVM Clang 3.4 Compiler Optimization LevelsOpenBenchmarking.orgPhoronix Test SuiteIntel Core i7 720Q @ 1.60GHz (8 Cores)LENOVO 4318CTOIntel Core DMI4096MB160GB INTEL SSDSA2M160NVIDIA Quadro FX 880M 1024MB (405/324MHz)Conexant CX20585Intel 82577LM Gigabit Connection + Intel Centrino Ultimate-N 6300Ubuntu 13.103.11.0-031100rc2-generic (x86_64)Xfce 4.10X Server 1.14.2nouveau 1.0.83.0 Mesa 9.1.4 Gallium 0.4Clang 3.4 (SVN 187338) + LLVM 3.4svnext41600x900ProcessorMotherboardChipsetMemoryDiskGraphicsAudioNetworkOSKernelDesktopDisplay ServerDisplay DriverOpenGLCompilerFile-SystemScreen ResolutionLLVM Clang 3.4 Compiler Optimization Levels PerformanceSystem Logs- Optimized build; Built Jul 28 2013 (21:43:17); Default target: x86_64-unknown-linux-gnu; Host CPU: corei7 - Scaling Governor: acpi-cpufreq ondemand

-O0-O1-O2-Os-O3-OfastLogarithmic Result OverviewPhoronix Test SuiteHimeno BenchmarkFLAC Audio EncodingTimed HMMer SearchN-QueensLAME MP3 EncodingGraphicsMagickTimed ImageMagick CompilationSmallptC-RayTimed PHP CompilationSciMark

LLVM Clang 3.4 Compiler Optimization Levelshmmer: Pfam Database Searchscimark2: Fast Fourier Transformgraphics-magick: Blurgraphics-magick: Sharpengraphics-magick: Resizinggraphics-magick: HWB Color Spacegraphics-magick: Local Adaptive Thresholdinghimeno: Poisson Pressure Solverbuild-imagemagick: Time To Compilebuild-php: Time To Compilec-ray: Total Timesmallpt: Global Illumination Renderer; 100 Samplesencode-flac: WAV To FLACencode-mp3: WAV To MP3n-queens: Elapsed Time-O0-O1-O2-Os-O3-Ofast89.33189.30221024368127.9523.1418.55208.5377044.1267.471083.8830.89189.1053356681311105.3657.3731.28100.1141011.2623.55386.2127.31189.7253366680321129.5665.3035.51103.772929.0022.72343.1828.68190.1452366679301102.6863.3333.44104.7232011.1623.04331.7227.33173.5753366680321055.0865.8841.9775.982938.8622.64345.3827.10188.0653366797311128.5066.5542.1593.632758.8522.00343.65OpenBenchmarking.org

Timed HMMer Search

This test searches through the Pfam database of profile hidden markov models. The search finds the domain structure of Drosophila Sevenless protein. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterTimed HMMer Search 2.3.2Pfam Database Search-O0-O1-O2-Os-O3-Ofast20406080100SE +/- 0.46, N = 3SE +/- 0.03, N = 3SE +/- 0.05, N = 3SE +/- 0.06, N = 3SE +/- 0.02, N = 3SE +/- 0.04, N = 389.3330.8927.3128.6827.3327.10-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pthread -lhmmer -lsquid -lm

SciMark

This test runs the ANSI C version of SciMark 2.0, which is a benchmark for scientific and numerical computing developed by programmers at the National Institute of Standards and Technology. This test is made up of Fast Foruier Transform, Jacobi Successive Over-relaxation, Monte Carlo, Sparse Matrix Multiply, and dense LU matrix factorization benchmarks. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMflops, More Is BetterSciMark 2.0Computational Test: Fast Fourier Transform-O0-O1-O2-Os-O3-Ofast4080120160200SE +/- 0.00, N = 4SE +/- 0.52, N = 4SE +/- 0.24, N = 4SE +/- 0.00, N = 4SE +/- 0.61, N = 4SE +/- 0.41, N = 4189.30189.10189.72190.14173.57188.06-O0-O1-O2-Os-O3-Ofast1. (CXX) g++ options: -march=native

GraphicsMagick

OpenBenchmarking.orgIterations Per Minute, More Is BetterGraphicsMagick 1.3.16Operation: Blur-O0-O1-O2-Os-O3-Ofast1224364860SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3225353525353-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pthread -lXext -lSM -lICE -lX11 -lxml2 -lz -lm -lpthread

OpenBenchmarking.orgIterations Per Minute, More Is BetterGraphicsMagick 1.3.16Operation: Sharpen-O0-O1-O2-Os-O3-Ofast816243240SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3103536363636-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pthread -lXext -lSM -lICE -lX11 -lxml2 -lz -lm -lpthread

OpenBenchmarking.orgIterations Per Minute, More Is BetterGraphicsMagick 1.3.16Operation: Resizing-O0-O1-O2-Os-O3-Ofast1530456075SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.33, N = 3246666666667-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pthread -lXext -lSM -lICE -lX11 -lxml2 -lz -lm -lpthread

OpenBenchmarking.orgIterations Per Minute, More Is BetterGraphicsMagick 1.3.16Operation: HWB Color Space-O0-O1-O2-Os-O3-Ofast20406080100SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3368180798097-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pthread -lXext -lSM -lICE -lX11 -lxml2 -lz -lm -lpthread

OpenBenchmarking.orgIterations Per Minute, More Is BetterGraphicsMagick 1.3.16Operation: Local Adaptive Thresholding-O0-O1-O2-Os-O3-Ofast714212835SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 383132303231-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pthread -lXext -lSM -lICE -lX11 -lxml2 -lz -lm -lpthread

Himeno Benchmark

The Himeno benchmark is a linear solver of pressure Poisson using a point-Jacobi method. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgMFLOPS, More Is BetterHimeno Benchmark 3.0Poisson Pressure Solver-O0-O1-O2-Os-O3-Ofast2004006008001000SE +/- 0.03, N = 3SE +/- 0.14, N = 3SE +/- 0.39, N = 3SE +/- 0.03, N = 3SE +/- 5.78, N = 3SE +/- 0.36, N = 3127.951105.361129.561102.681055.081128.50-O0-O1-O2-Os-Ofast1. (CC) gcc options: -O3 -march=native

Timed ImageMagick Compilation

OpenBenchmarking.orgSeconds, Fewer Is BetterTimed ImageMagick Compilation 6.8.1-10Time To Compile-O0-O1-O2-Os-O3-Ofast1530456075SE +/- 0.03, N = 3SE +/- 0.11, N = 3SE +/- 0.22, N = 3SE +/- 0.14, N = 3SE +/- 0.18, N = 3SE +/- 0.12, N = 323.1457.3765.3063.3365.8866.55

Timed PHP Compilation

OpenBenchmarking.orgSeconds, Fewer Is BetterTimed PHP Compilation 5.2.9Time To Compile-O0-O1-O2-Os-O3-Ofast1020304050SE +/- 0.01, N = 3SE +/- 0.02, N = 3SE +/- 0.07, N = 3SE +/- 0.01, N = 3SE +/- 0.10, N = 3SE +/- 0.03, N = 318.5531.2835.5133.4441.9742.15-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -march=native -pedantic -ldl -lz -lm

C-Ray

This is a test of C-Ray, a simple raytracer designed to test the floating-point CPU performance. This test is multi-threaded (16 threads per core), will shoot 8 rays per pixel for anti-aliasing, and will generate a 1600 x 1200 image. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterC-Ray 1.1Total Time-O0-O1-O2-Os-O3-Ofast50100150200250SE +/- 0.07, N = 3SE +/- 0.01, N = 3SE +/- 0.02, N = 3SE +/- 0.04, N = 3SE +/- 0.04, N = 3SE +/- 0.03, N = 3208.53100.11103.77104.7275.9893.63-O0-O1-O2-Os-Ofast1. (CC) gcc options: -lm -lpthread -O3 -march=native

Smallpt

Smallpt is a C++ global illumination renderer written in less than 100 lines of code. Global illumination is done via unbiased Monte Carlo path tracing and there is multi-threading support via the OpenMP library. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterSmallpt 1.0Global Illumination Renderer; 100 Samples-O0-O1-O2-Os-O3-Ofast170340510680850SE +/- 0.58, N = 3SE +/- 0.33, N = 3SE +/- 0.88, N = 3SE +/- 1.67, N = 3SE +/- 0.58, N = 3SE +/- 0.33, N = 3770410292320293275-O0-O1-O2-Os-O3-Ofast1. (CXX) g++ options: -fopenmp -march=native

FLAC Audio Encoding

OpenBenchmarking.orgSeconds, Fewer Is BetterFLAC Audio Encoding 1.3.0WAV To FLAC-O0-O1-O2-Os-O3-Ofast1020304050SE +/- 0.02, N = 5SE +/- 0.05, N = 5SE +/- 0.01, N = 5SE +/- 0.01, N = 5SE +/- 0.01, N = 5SE +/- 0.01, N = 544.1211.269.0011.168.868.85-O0-O1-O2-Os-O3-Ofast1. (CXX) g++ options: -march=native -fvisibility=hidden -logg -lm

LAME MP3 Encoding

LAME is an MP3 encoder licensed under the LGPL. This test measures the time required to encode a WAV file to MP3 format. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterLAME MP3 Encoding 3.99.3WAV To MP3-O0-O1-O2-Os-O3-Ofast1530456075SE +/- 0.02, N = 5SE +/- 0.01, N = 5SE +/- 0.01, N = 5SE +/- 0.01, N = 5SE +/- 0.02, N = 5SE +/- 0.01, N = 567.4723.5522.7223.0422.6422.00-O0-O1-O2-Os-O3-Ofast1. (CC) gcc options: -pipe -march=native -lm

N-Queens

This is a test of the OpenMP version of a test that solves the N-queens problem. The board problem size is 18. Learn more via the OpenBenchmarking.org test page.

OpenBenchmarking.orgSeconds, Fewer Is BetterN-Queens 1.0Elapsed Time-O0-O1-O2-Os-O3-Ofast2004006008001000SE +/- 0.13, N = 3SE +/- 0.00, N = 3SE +/- 0.03, N = 3SE +/- 0.13, N = 3SE +/- 0.89, N = 3SE +/- 0.04, N = 31083.88386.21343.18331.72345.38343.65-O0-O1-O2-Os-Ofast1. (CC) gcc options: -static -fopenmp -O3 -march=native