Path: blob/master/test/micro/org/openjdk/bench/vm/compiler/ModPowerOf2.java
41161 views
/*1* Copyright (c) 2021, Alibaba Group Holding Limited. All Rights Reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*22*/23package org.openjdk.bench.vm.compiler;2425import org.openjdk.jmh.annotations.Benchmark;26import org.openjdk.jmh.annotations.BenchmarkMode;27import org.openjdk.jmh.annotations.Mode;28import org.openjdk.jmh.annotations.OutputTimeUnit;29import org.openjdk.jmh.annotations.Scope;30import org.openjdk.jmh.annotations.Setup;31import org.openjdk.jmh.annotations.State;32import org.openjdk.jmh.annotations.Warmup;3334import java.util.Random;35import java.util.concurrent.TimeUnit;3637/**38* Test for x % 2^n (n is constant)39*/40@BenchmarkMode(Mode.AverageTime)41@Warmup(iterations = 5, time = 500, timeUnit = TimeUnit.MILLISECONDS)42@OutputTimeUnit(TimeUnit.NANOSECONDS)43@State(Scope.Thread)44public class ModPowerOf2 {45@Benchmark46public int testPositivePowerOf2() {47int sum = 0;48for (int i = 0; i < 1000; i++) {49sum += i % 1;50sum += i % 2;51sum += i % 4;52sum += i % 8;53sum += i % 16;54sum += i % 32;55sum += i % 64;56sum += i % 128;57sum += i % 256;58sum += i % 512;59sum += i % 1024;60sum += i % 2048;61sum += i % 4096;62sum += i % 8192;63sum += i % 16384;64sum += i % 32768;65sum += i % 65536;66}67return sum;68}6970@Benchmark71public int testNegativePowerOf2() {72int sum = 0;73for (int i = 0; i < 1000; i++) {74sum += i % -1;75sum += i % -2;76sum += i % -4;77sum += i % -8;78sum += i % -16;79sum += i % -32;80sum += i % -64;81sum += i % -128;82sum += i % -256;83sum += i % -512;84sum += i % -1024;85sum += i % -2048;86sum += i % -4096;87sum += i % -8192;88sum += i % -16384;89sum += i % -32768;90sum += i % -65536;91}92return sum;93}9495@Benchmark96public int testMixedPowerOf2() {97int sum = 0;98for (int i = 0; i < 1000; i++) {99sum += i % -1;100sum += i % 1;101sum += i % -2;102sum += i % 2;103sum += i % -4;104sum += i % 4;105sum += i % -8;106sum += i % 8;107sum += i % -16;108sum += i % 16;109sum += i % -32;110sum += i % 32;111sum += i % -64;112sum += i % 64;113sum += i % -128;114sum += i % 128;115sum += i % -256;116sum += i % 256;117sum += i % -512;118sum += i % 512;119sum += i % -1024;120sum += i % 1024;121sum += i % -2048;122sum += i % 2048;123sum += i % -4096;124sum += i % 4096;125sum += i % -8192;126sum += i % 8192;127sum += i % -16384;128sum += i % 16384;129sum += i % -32768;130sum += i % 32768;131sum += i % -65536;132sum += i % 65536;133}134return sum;135}136}137138139