當前位置: 首頁>>代碼示例>>Java>>正文


Java IntMath類代碼示例

本文整理匯總了Java中com.google.common.math.IntMath的典型用法代碼示例。如果您正苦於以下問題:Java IntMath類的具體用法?Java IntMath怎麽用?Java IntMath使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


IntMath類屬於com.google.common.math包,在下文中一共展示了IntMath類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testWorstCase

import com.google.common.math.IntMath; //導入依賴的package包/類
public void testWorstCase() {
  int n = 2000000;
  int k = 200000;
  final long[] compareCalls = {0};
  Comparator<Integer> cmp =
      new Comparator<Integer>() {
        @Override
        public int compare(Integer o1, Integer o2) {
          compareCalls[0]++;
          return o1.compareTo(o2);
        }
      };
  TopKSelector<Integer> top = TopKSelector.least(k, cmp);
  top.offer(1);
  for (int i = 1; i < n; i++) {
    top.offer(0);
  }
  assertThat(top.topK()).containsExactlyElementsIn(Collections.nCopies(k, 0));
  assertThat(compareCalls[0]).isAtMost(10L * n * IntMath.log2(k, RoundingMode.CEILING));
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:21,代碼來源:TopKSelectorTest.java

示例2: generateCode

import com.google.common.math.IntMath; //導入依賴的package包/類
/**
 * <b>NOTE</b>: The generated code is not guaranteed to be unique. You should validate it with other generated
 * codes where uniqueness is required before using it.
 * @param requiredCodeLength
 * @return A random sequence of letters and/or numbers of the specified length
 * @throws IllegalArgumentException If the specified length is less than or equal to 0
 */
public String generateCode(int requiredCodeLength) throws IllegalArgumentException {
	if(requiredCodeLength <= 0)
		throw new IllegalArgumentException("Required code length must be positive");
	
	int randomBitLength = IntMath.checkedPow(requiredCodeLength, 2);
	
	String newReferralCode = new BigInteger(randomBitLength, random).toString(TO_STRING_RADIX);
	
	if(newReferralCode.length() > requiredCodeLength)
		return newReferralCode.substring(0, requiredCodeLength);
	else if(newReferralCode.length() < requiredCodeLength)
		return generateCode(requiredCodeLength);
	
	return newReferralCode;
}
 
開發者ID:BuaBook,項目名稱:buabook-common,代碼行數:23,代碼來源:RandomCodeGenerator.java

示例3: addToWorldChunks

import com.google.common.math.IntMath; //導入依賴的package包/類
public static void addToWorldChunks(Nation nation)
{
	for (Rect r : nation.getRegion().getRects())
	{
		if (!worldChunks.containsKey(r.getWorld()))
		{
			worldChunks.put(r.getWorld(), new Hashtable<Vector2i, ArrayList<Nation>>());
		}
		Hashtable<Vector2i, ArrayList<Nation>> chunks = worldChunks.get(r.getWorld());
		for (int i = IntMath.divide(r.getMinX(), 16, RoundingMode.FLOOR); i < IntMath.divide(r.getMaxX(), 16, RoundingMode.FLOOR) + 1; i++)
		{
			for (int j = IntMath.divide(r.getMinY(), 16, RoundingMode.FLOOR); j < IntMath.divide(r.getMaxY(), 16, RoundingMode.FLOOR) + 1; j++)
			{
				Vector2i vect = new Vector2i(i, j);
				if (!chunks.containsKey(vect))
				{
					chunks.put(vect, new ArrayList<Nation>());
				}
				if (!chunks.get(vect).contains(nation))
				{
					chunks.get(vect).add(nation);
				}
			}
		}
	}
}
 
開發者ID:Arckenver,項目名稱:Nations,代碼行數:27,代碼來源:DataHandler.java

示例4: createSlidingUnifier

import com.google.common.math.IntMath; //導入依賴的package包/類
public static PTOperator createSlidingUnifier(StreamMeta streamMeta, PhysicalPlan plan, int
    operatorApplicationWindowCount, int slidingWindowCount)
{
  int gcd = IntMath.gcd(operatorApplicationWindowCount, slidingWindowCount);
  OperatorMeta um = streamMeta.getSource()
      .getSlidingUnifier(operatorApplicationWindowCount / gcd, gcd, slidingWindowCount / gcd);
  PTOperator pu = plan.newOperator(um, um.getName());

  Operator unifier = um.getOperator();
  PortMappingDescriptor mergeDesc = new PortMappingDescriptor();
  Operators.describe(unifier, mergeDesc);
  if (mergeDesc.outputPorts.size() != 1) {
    throw new AssertionError("Unifier must have a single output port, instead found : " + mergeDesc.outputPorts);
  }
  pu.unifiedOperatorMeta = streamMeta.getSource().getOperatorMeta();
  pu.outputs.add(new PTOutput(mergeDesc.outputPorts.keySet().iterator().next(), streamMeta, pu));
  plan.newOpers.put(pu, unifier);
  return pu;
}
 
開發者ID:apache,項目名稱:apex-core,代碼行數:20,代碼來源:StreamMapping.java

示例5: OoaBFilter

import com.google.common.math.IntMath; //導入依賴的package包/類
/**
 * Constructs a OoaBFilter with an underlying array of the given size, rounded up to the next
 * power of two.
 *
 * This rounding occurs because the hashing is much faster on an array the size of a power of two.
 *
 * @param size The size of the underlying array.
 * @param bufSize The size of the buffers occupying each slot in the array.
 */
public OoaBFilter(int size, int bufSize) {
  if (size <= 0) {
    throw new IllegalArgumentException("array size must be greater than zero, was " + size);
  }
  if (size > MAX_SIZE) {
    throw new IllegalArgumentException(
        "array size may not be larger than 2**31-1, but will be rounded to larger. was " + size);
  }
  // round to the next largest power of two
  int poweredSize = IntMath.pow(2, IntMath.log2(size, RoundingMode.CEILING));
  this.sizeMask = poweredSize - 1;
  this.array = new ByteBuffer[poweredSize];

  // pre-allocate a ByteBuffer for each slot in the array
  int i = 0;
  while (i < poweredSize) {
    array[i] = ByteBuffer.allocate(bufSize);
    i++;
  }
}
 
開發者ID:automenta,項目名稱:spimedb,代碼行數:30,代碼來源:OoaBFilter.java

示例6: allGetterFlagsAreAccepted

import com.google.common.math.IntMath; //導入依賴的package包/類
@Test
public void allGetterFlagsAreAccepted() {
    final RequestLogAvailability[] values = RequestLogAvailability.values();
    final int end = IntMath.pow(2, values.length);
    for (int i = 0; i < end; i++) {
        int flags = 0;
        for (RequestLogAvailability v : values) {
            if ((i & 1 << v.ordinal()) != 0) {
                flags |= v.getterFlags();
            }
        }

        if (flags != 0) {
            assertThat(RequestLogAvailabilitySet.of(flags)).isNotEmpty();
        }
    }
}
 
開發者ID:line,項目名稱:armeria,代碼行數:18,代碼來源:RequestLogAvailabilitySetTest.java

示例7: run

import com.google.common.math.IntMath; //導入依賴的package包/類
@Override
public void run() {
  // TODO #93: Disable keep-alives for nodes that have a consensus server, as then the consensus will do the
  // keep-alives!
  int sleepTime = Math.max(IntMath.gcd(keepAliveMs, connectionIdleTimeMs), 1000);

  while (true) {
    try {
      synchronized (wait) {
        wait.wait(sleepTime);
      }
    } catch (InterruptedException e) {
      // interrupted, quielty say goodbye.
      return;
    }

    long curTime = System.nanoTime();

    executeTimeouts(curTime);

    if (curTime / keepAliveMs != previousKeepAliveDiv) {
      previousKeepAliveDiv = curTime / keepAliveMs;
      executeKeepAlives();
    }
  }
}
 
開發者ID:diqube,項目名稱:diqube,代碼行數:27,代碼來源:ConnectionPool.java

示例8: backOffWait

import com.google.common.math.IntMath; //導入依賴的package包/類
public void backOffWait(int retryCount) {
  // No wait if wait is disabled or this is first re-try
  if(retryCount <= 0 || backOff <= 0) {
    return;
  }

  // Wait time period
  int waitTime;

  // Current exponential back off
  try {
    waitTime = IntMath.checkedPow(backOff, retryCount);
  } catch (ArithmeticException e) {
    waitTime = MAX_BACKOFF_WAIT;
  }

  // Apply upper limit for the wait and finally wait
  waitTime = Math.min(waitTime, MAX_BACKOFF_WAIT);
  if (!ThreadUtil.sleep(waitTime)) {
    LOG.info("Backoff waiting was interrupted");
  }
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:23,代碼來源:Configs.java

示例9: splitToNChunks

import com.google.common.math.IntMath; //導入依賴的package包/類
/**
 * If there are fewer files than chunks, fewer than numChunks will be returned.
 */
private static Iterable<List<Map.Entry<Symbol, File>>> splitToNChunks(
    final ImmutableMap<Symbol, File> inputMap, int numChunks) {
  checkArgument(numChunks > 0);
  final List<Map.Entry<Symbol, File>> emptyChunk = ImmutableList.of();

  if (inputMap.isEmpty()) {
    return Collections.nCopies(numChunks, emptyChunk);
  }

  final int chunkSize = IntMath.divide(inputMap.size(), numChunks, RoundingMode.UP);
  final ImmutableList<List<Map.Entry<Symbol, File>>> chunks =
      ImmutableList.copyOf(splitToChunksOfFixedSize(inputMap, chunkSize));
  if (chunks.size() == numChunks) {
    return chunks;
  } else {
    // there weren't enough elements to make the desired number of chunks, so we need to
    // pad with empty chunks
    final int shortage = numChunks - chunks.size();
    final List<List<Map.Entry<Symbol, File>>> padding = Collections.nCopies(shortage, emptyChunk);
    return Iterables.concat(chunks, padding);
  }
}
 
開發者ID:BBN-E,項目名稱:bue-common-open,代碼行數:26,代碼來源:SplitCorpus.java

示例10: calculateSize

import com.google.common.math.IntMath; //導入依賴的package包/類
/**
 * The number of permutations with repeated elements is calculated as follows:
 *
 * <ul>
 *   <li>For an empty list, it is 1 (base case).
 *   <li>When r numbers are added to a list of n-r elements, the number of permutations is
 *       increased by a factor of (n choose r).
 * </ul>
 */
private static <E> int calculateSize(
    List<E> sortedInputList, Comparator<? super E> comparator) {
  int permutations = 1;
  int n = 1;
  int r = 1;
  while (n < sortedInputList.size()) {
    int comparison = comparator.compare(sortedInputList.get(n - 1), sortedInputList.get(n));
    if (comparison < 0) {
      // We move to the next non-repeated element.
      permutations = IntMath.saturatedMultiply(permutations, IntMath.binomial(n, r));
      r = 0;
      if (permutations == Integer.MAX_VALUE) {
        return Integer.MAX_VALUE;
      }
    }
    n++;
    r++;
  }
  return IntMath.saturatedMultiply(permutations, IntMath.binomial(n, r));
}
 
開發者ID:google,項目名稱:guava,代碼行數:30,代碼來源:Collections2.java

示例11: testCounts

import com.google.common.math.IntMath; //導入依賴的package包/類
@Test
public void testCounts() {
	String ascii = "abcdefghijklmnopqrstuvwxyz";
	String range = ascii.toLowerCase() + ascii.toUpperCase();
	int rangeA = IntMath.pow(range.length(), 1);
	assertEquals(rangeA, Iterables.size(new Mutator(range, 1, 1).mutate()));

	int rangeB = IntMath.pow(range.length(), 2) + rangeA;
	assertEquals(rangeB, Iterables.size(new Mutator(range, 1, 2).mutate()));

	int rangeC = IntMath.pow(range.length(), 3) + rangeB;
	assertEquals(rangeC, Iterables.size(new Mutator(range, 1, 3).mutate()));

	int rangeD = IntMath.pow(range.length(), 4) + rangeC;
	assertEquals(rangeD, Iterables.size(new Mutator(range, 1, 4).mutate()));
}
 
開發者ID:pfichtner,項目名稱:jcrunch,代碼行數:17,代碼來源:TestMutater.java

示例12: paintComponent

import com.google.common.math.IntMath; //導入依賴的package包/類
@Override
protected void paintComponent(Graphics g1)
{
	super.paintComponent(g1);
	Graphics2D g = (Graphics2D)g1;
	
	int cellsX = IntMath.divide(getWidth(), tileModel.getAvgTileWidth(), RoundingMode.UP);
	int cellsY = IntMath.divide(getHeight(), tileModel.getTileHeight(), RoundingMode.UP);
	tileModel.setMapWidth(cellsX);
	tileModel.setMapHeight(cellsY);
	
	// cut of partly draw hexagons
	g.clipRect(0, 0, tileModel.getWorldWidth(), tileModel.getWorldHeight());

	drawTiles(g);

	Object oldAAhint = g.getRenderingHint(RenderingHints.KEY_ANTIALIASING);
	g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);

	drawVectorField(g);
	drawSelection(g);

	g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, oldAAhint);

	g1.setClip(null);
}
 
開發者ID:igd-iva,項目名稱:colormap-explorer,代碼行數:27,代碼來源:DecomposedPanel.java

示例13: getTilesInRect

import com.google.common.math.IntMath; //導入依賴的package包/類
@Override
public List<Tile> getTilesInRect(int worldX0, int worldY0, int worldX1, int worldY1)
{
	int x0 = IntMath.divide(worldX0, tileWidth, RoundingMode.FLOOR);
	int y0 = IntMath.divide(worldY0, tileHeight, RoundingMode.FLOOR);
	int x1 = IntMath.divide(worldX1, tileWidth, RoundingMode.FLOOR);
	int y1 = IntMath.divide(worldY1, tileHeight, RoundingMode.FLOOR);
	
	// Restrict to map bounds
	int minX = Math.max(x0, 0);
	int maxX = Math.min(x1, mapWidth - 1);
	int minY = Math.max(y0, 0);
	int maxY = Math.min(y1, mapHeight - 1);

	List<Tile> result = new ArrayList<Tile>();

	for (int y = minY; y <= maxY; y++)
	{
		for (int x = minX; y <= maxX; x++)
		{
			result.add(getTile(x, y));
		}
	}

	return result;
}
 
開發者ID:igd-iva,項目名稱:colormap-explorer,代碼行數:27,代碼來源:RectTileModel.java

示例14: getInteger

import com.google.common.math.IntMath; //導入依賴的package包/類
protected static int getInteger(byte[] b) {
    int sum = 0;
    for (int i = 0; i < b.length; i++) {
        final int reverseIndex = b.length - 1 - i;
        final int factor = IntMath.pow(256, reverseIndex);
        final int base = UnsignedBytes.toInt(b[i]);
        sum += base * factor;
    }
    return sum;
}
 
開發者ID:kaspersorensen,項目名稱:kafka-record-updater,代碼行數:11,代碼來源:SegmentFileUpdater.java

示例15: CartesianList

import com.google.common.math.IntMath; //導入依賴的package包/類
CartesianList(ImmutableList<List<E>> axes) {
  this.axes = axes;
  int[] axesSizeProduct = new int[axes.size() + 1];
  axesSizeProduct[axes.size()] = 1;
  try {
    for (int i = axes.size() - 1; i >= 0; i--) {
      axesSizeProduct[i] = IntMath.checkedMultiply(axesSizeProduct[i + 1], axes.get(i).size());
    }
  } catch (ArithmeticException e) {
    throw new IllegalArgumentException(
        "Cartesian product too large; must have size at most Integer.MAX_VALUE");
  }
  this.axesSizeProduct = axesSizeProduct;
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:15,代碼來源:CartesianList.java


注:本文中的com.google.common.math.IntMath類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。