I collected some perf data for further analysis.

I run a simple arithmetic multi-core benchmark.
The benchmark is 100% CPU bound - it adds 2 integers.

perf record java -jar target/benchmarks.jar 
org.ttnr.pmato.e2.cpumem.ArithmeticsBenchmark.add -wi 0 -i 40 -t 4 -f 1
# JMH version: 1.21
# VM version: JDK 1.8.0_181, Java HotSpot(TM) 64-Bit Server VM, 25.181-b13
# VM invoker: /opt/jdk1.8.0_181/jre/bin/java
# VM options: <none>
# Warmup: <none>
# Measurement: 40 iterations, 1 s each
# Timeout: 10 min per iteration
# Threads: 4 threads, will synchronize iterations
# Benchmark mode: Average time, time/op
# Benchmark: org.ttnr.pmato.e2.cpumem.ArithmeticsBenchmark.add

# Run progress: 0,00% complete, ETA 00:00:40
# Fork: 1 of 1
Iteration   1: 2,246 ±(99.9%) 0,648 ns/op  // <-------  3.5+ GHz when started
Iteration   2: 2,181 ±(99.9%) 0,196 ns/op
Iteration   3: 2,262 ±(99.9%) 2,673 ns/op
Iteration   4: 2,296 ±(99.9%) 2,751 ns/op
Iteration   5: 3,004 ±(99.9%) 3,518 ns/op
Iteration   6: 5,468 ±(99.9%) 0,159 ns/op  // <------- sudden performance drop
Iteration   7: 6,372 ±(99.9%) 0,620 ns/op  // <------- now 1.3-1.5 GHz
Iteration   8: 6,389 ±(99.9%) 4,850 ns/op
Iteration   9: 5,363 ±(99.9%) 0,223 ns/op
Iteration  10: 5,174 ±(99.9%) 0,584 ns/op
Iteration  11: 5,093 ±(99.9%) 0,414 ns/op
Iteration  12: 5,069 ±(99.9%) 0,127 ns/op
Iteration  13: 5,070 ±(99.9%) 0,559 ns/op
Iteration  14: 4,927 ±(99.9%) 0,080 ns/op
Iteration  15: 5,045 ±(99.9%) 0,033 ns/op
Iteration  16: 5,052 ±(99.9%) 0,162 ns/op
Iteration  17: 4,964 ±(99.9%) 0,063 ns/op
Iteration  18: 4,979 ±(99.9%) 0,058 ns/op
Iteration  19: 4,992 ±(99.9%) 0,147 ns/op
Iteration  20: 4,955 ±(99.9%) 0,083 ns/op
Iteration  21: 5,061 ±(99.9%) 0,462 ns/op
Iteration  22: 5,004 ±(99.9%) 0,264 ns/op
Iteration  23: 4,966 ±(99.9%) 0,207 ns/op
Iteration  24: 4,950 ±(99.9%) 0,125 ns/op
Iteration  25: 4,925 ±(99.9%) 0,553 ns/op
Iteration  26: 4,961 ±(99.9%) 0,138 ns/op
Iteration  27: 4,921 ±(99.9%) 0,188 ns/op
Iteration  28: 4,980 ±(99.9%) 0,372 ns/op
Iteration  29: 4,899 ±(99.9%) 0,119 ns/op
Iteration  30: 4,884 ±(99.9%) 0,314 ns/op
Iteration  31: 4,878 ±(99.9%) 0,194 ns/op
Iteration  32: 4,962 ±(99.9%) 0,997 ns/op
Iteration  33: 4,958 ±(99.9%) 0,280 ns/op
Iteration  34: 4,889 ±(99.9%) 0,162 ns/op
Iteration  35: 5,018 ±(99.9%) 0,201 ns/op
Iteration  36: 5,002 ±(99.9%) 0,229 ns/op
Iteration  37: 4,927 ±(99.9%) 0,088 ns/op
Iteration  38: 4,935 ±(99.9%) 0,114 ns/op
Iteration  39: 4,976 ±(99.9%) 0,284 ns/op
Iteration  40: 4,925 ±(99.9%) 0,128 ns/op


Result "org.ttnr.pmato.e2.cpumem.ArithmeticsBenchmark.add":
  4,748 ±(99.9%) 0,541 ns/op [Average]
  (min, avg, max) = (2,181, 4,748, 6,389), stdev = 0,962
  CI (99.9%): [4,207, 5,289] (assumes normal distribution)

-- 
You received this bug notification because you are a member of Ubuntu
Bugs, which is subscribed to Ubuntu.
https://bugs.launchpad.net/bugs/1797802

Title:
  Erratic behavior of intel pstate CPU frequency control

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1797802/+subscriptions

-- 
ubuntu-bugs mailing list
ubuntu-bugs@lists.ubuntu.com
https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs

Reply via email to