/* * Copyright (C) 2012 The Guava Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.google.common.collect; import java.util.Collection; import java.util.Collections; import java.util.HashSet; import java.util.LinkedHashSet; import java.util.Map; import java.util.Random; import java.util.Set; import java.util.SortedMap; import java.util.TreeSet; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentSkipListMap; /** * Helper classes for various benchmarks. * * @author Christopher Swenson */ final class BenchmarkHelpers { /** * So far, this is the best way to test various implementations of {@link Set} subclasses. */ public enum SetImpl { Hash { @Override > Set create(Collection contents) { return new HashSet(contents); } }, LinkedHash { @Override > Set create(Collection contents) { return new LinkedHashSet(contents); } }, Tree { @Override > Set create(Collection contents) { return new TreeSet(contents); } }, Unmodifiable { @Override > Set create(Collection contents) { return Collections.unmodifiableSet(new HashSet(contents)); } }, Synchronized { @Override > Set create(Collection contents) { return Collections.synchronizedSet(new HashSet(contents)); } }, Immutable { @Override > Set create(Collection contents) { return ImmutableSet.copyOf(contents); } }, ImmutableSorted { @Override > Set create(Collection contents) { return ImmutableSortedSet.copyOf(contents); } }, ; abstract > Set create(Collection contents); } public enum ListMultimapImpl { ArrayList { @Override ListMultimap create(Multimap contents) { return ArrayListMultimap.create(contents); } }, LinkedList { @Override ListMultimap create(Multimap contents) { return LinkedListMultimap.create(contents); } }, ImmutableList { @Override ListMultimap create(Multimap contents) { return ImmutableListMultimap.copyOf(contents); } }; abstract ListMultimap create(Multimap contents); } public enum SetMultimapImpl { Hash { @Override , V extends Comparable> SetMultimap create( Multimap contents) { return HashMultimap.create(contents); } }, LinkedHash { @Override , V extends Comparable> SetMultimap create( Multimap contents) { return LinkedHashMultimap.create(contents); } }, Tree { @Override , V extends Comparable> SetMultimap create( Multimap contents) { return TreeMultimap.create(contents); } }, ImmutableSet { @Override , V extends Comparable> SetMultimap create( Multimap contents) { return ImmutableSetMultimap.copyOf(contents); } }; abstract , V extends Comparable> SetMultimap create( Multimap contents); } public enum MapImpl { Hash { @Override Map create(Map map) { return Maps.newHashMap(map); } }, LinkedHash { @Override Map create(Map map) { return Maps.newLinkedHashMap(map); } }, ConcurrentHash { @Override Map create(Map map) { return new ConcurrentHashMap(map); } }, Immutable { @Override Map create(Map map) { return ImmutableMap.copyOf(map); } }; abstract Map create(Map map); } enum SortedMapImpl { Tree { @Override , V> SortedMap create(Map map) { SortedMap result = Maps.newTreeMap(); result.putAll(map); return result; } }, ConcurrentSkipList { @Override , V> SortedMap create(Map map) { return new ConcurrentSkipListMap(map); } }, ImmutableSorted { @Override , V> SortedMap create(Map map) { return ImmutableSortedMap.copyOf(map); } }; abstract , V> SortedMap create(Map map); } enum BiMapImpl { Hash{ @Override BiMap create(BiMap map) { return HashBiMap.create(map); } }, Immutable { @Override BiMap create(BiMap map) { return ImmutableBiMap.copyOf(map); } }; abstract BiMap create(BiMap map); } enum MultisetImpl { Hash { @Override Multiset create(Multiset contents) { return HashMultiset.create(contents); } }, LinkedHash { @Override Multiset create(Multiset contents) { return LinkedHashMultiset.create(contents); } }, ConcurrentHash { @Override Multiset create(Multiset contents) { return ConcurrentHashMultiset.create(contents); } }, Immutable { @Override Multiset create(Multiset contents) { return ImmutableMultiset.copyOf(contents); } }; abstract Multiset create(Multiset contents); } enum SortedMultisetImpl { Tree { @Override > SortedMultiset create(Multiset contents) { return TreeMultiset.create(contents); } }, ImmutableSorted { @Override > SortedMultiset create(Multiset contents) { return ImmutableSortedMultiset.copyOf(contents); } }; abstract > SortedMultiset create(Multiset contents); } enum TableImpl { HashBased { @Override , C extends Comparable, V> Table create( Table contents) { return HashBasedTable.create(contents); } }, TreeBased { @Override , C extends Comparable, V> Table create( Table contents) { Table table = TreeBasedTable.create(); table.putAll(contents); return table; } }, Array { @Override , C extends Comparable, V> Table create( Table contents) { if (contents.isEmpty()) { return ImmutableTable.of(); } else { return ArrayTable.create(contents); } } }, Immutable { @Override , C extends Comparable, V> Table create( Table contents) { return ImmutableTable.copyOf(contents); } }; abstract , C extends Comparable, V> Table create(Table contents); } public enum Value { INSTANCE; } public enum ListSizeDistribution { UNIFORM_0_TO_2(0, 2), UNIFORM_0_TO_9(0, 9), ALWAYS_0(0, 0), ALWAYS_10(10, 10); final int min; final int max; private ListSizeDistribution(int min, int max) { this.min = min; this.max = max; } public int chooseSize(Random random) { return random.nextInt(max - min + 1) + min; } } }