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


Java DoubleMath.roundToLong方法代碼示例

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


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

示例1: getInterval

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
/**
 * recalculate interval if total number of partitions greater than maximum number of allowed partitions
 *
 * @param low watermark value
 * @param high watermark value
 * @param partition interval
 * @param Maximum number of allowed partitions
 * @return calculated interval
 */
private long getInterval(long lowWatermarkValue, long highWatermarkValue, long partitionInterval, int maxIntervals) {
  if (lowWatermarkValue > highWatermarkValue) {
    LOG.info("lowWatermarkValue: " + lowWatermarkValue + " is greater than highWatermarkValue: "
        + highWatermarkValue);

    return 0;
  }
  long outputInterval = partitionInterval;
  boolean longOverflow = false;
  long totalIntervals = Long.MAX_VALUE;
  try {
    totalIntervals = DoubleMath.roundToLong((double) highWatermarkValue / partitionInterval
        - (double) lowWatermarkValue / partitionInterval, RoundingMode.CEILING);
  } catch (java.lang.ArithmeticException e) {
    longOverflow = true;
  }
  if (longOverflow || totalIntervals > maxIntervals) {
      outputInterval = DoubleMath.roundToLong((double) highWatermarkValue / maxIntervals
          - (double) lowWatermarkValue / maxIntervals, RoundingMode.CEILING);

  }
  return outputInterval;
}
 
開發者ID:Hanmourang,項目名稱:Gobblin,代碼行數:33,代碼來源:SimpleWatermark.java

示例2: getInterval

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
/**
 * recalculate interval if total number of partitions greater than maximum number of allowed partitions
 *
 * @param low watermark value
 * @param high watermark value
 * @param partition interval
 * @param Maximum number of allowed partitions
 * @return calculated interval
 */
private static long getInterval(long lowWatermarkValue, long highWatermarkValue, long partitionInterval,
    int maxIntervals) {
  if (lowWatermarkValue > highWatermarkValue) {
    LOG.info(
        "lowWatermarkValue: " + lowWatermarkValue + " is greater than highWatermarkValue: " + highWatermarkValue);

    return 0;
  }
  long outputInterval = partitionInterval;
  boolean longOverflow = false;
  long totalIntervals = Long.MAX_VALUE;
  try {
    totalIntervals = DoubleMath.roundToLong(
        (double) highWatermarkValue / partitionInterval - (double) lowWatermarkValue / partitionInterval,
        RoundingMode.CEILING);
  } catch (java.lang.ArithmeticException e) {
    longOverflow = true;
  }
  if (longOverflow || totalIntervals > maxIntervals) {
    outputInterval = DoubleMath.roundToLong(
        (double) highWatermarkValue / maxIntervals - (double) lowWatermarkValue / maxIntervals, RoundingMode.CEILING);

  }
  return outputInterval;
}
 
開發者ID:apache,項目名稱:incubator-gobblin,代碼行數:35,代碼來源:SimpleWatermark.java

示例3: startPublishingTimer

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
synchronized void startPublishingTimer() {
    if (state.get() == State.Closed) return;

    lifetimeCounter--;

    if (lifetimeCounter < 1) {
        logger.debug("[id={}] lifetime expired.", subscriptionId);

        setState(State.Closing);
    } else {
        long interval = DoubleMath.roundToLong(publishingInterval, RoundingMode.UP);

        subscriptionManager.getServer().getScheduledExecutorService().schedule(
                this::onPublishingTimer,
                interval,
                TimeUnit.MILLISECONDS
        );
    }
}
 
開發者ID:digitalpetri,項目名稱:ua-server-sdk,代碼行數:20,代碼來源:Subscription.java

示例4: approximateElementCount

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
/**
 * Returns an estimate for the total number of distinct elements that have been added to this
 * Bloom filter. This approximation is reasonably accurate if it does not exceed the value of
 * {@code expectedInsertions} that was used when constructing the filter.
 *
 * @since 22.0
 */
public long approximateElementCount() {
  long bitSize = bits.bitSize();
  long bitCount = bits.bitCount();

  /**
   * Each insertion is expected to reduce the # of clear bits by a factor of
   * `numHashFunctions/bitSize`. So, after n insertions, expected bitCount is `bitSize * (1 - (1 -
   * numHashFunctions/bitSize)^n)`. Solving that for n, and approximating `ln x` as `x - 1` when x
   * is close to 1 (why?), gives the following formula.
   */
  double fractionOfBitsSet = (double) bitCount / bitSize;
  return DoubleMath.roundToLong(
      -Math.log1p(-fractionOfBitsSet) * bitSize / numHashFunctions, RoundingMode.HALF_UP);
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:22,代碼來源:BloomFilter.java

示例5: getBucketsNeeded

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
/**
 * Calculates how many buckets are needed to hold the chosen number of keys,
 * taking the standard load factor into account.
 * 
 * @param maxKeys
 *            the number of keys the filter is expected to hold before
 *            insertion failure.
 * @return The number of buckets needed
 */
static long getBucketsNeeded(long maxKeys,double loadFactor,int bucketSize) {
	/*
	 * force a power-of-two bucket count so hash functions for bucket index
	 * can hashBits%numBuckets and get randomly distributed index. See wiki
	 * "Modulo Bias". Only time we can get perfectly distributed index is
	 * when numBuckets is a power of 2.
	 */
	long bucketsNeeded = DoubleMath.roundToLong((1.0 / loadFactor) * maxKeys / bucketSize, RoundingMode.UP);
	// get next biggest power of 2
	long bitPos = Long.highestOneBit(bucketsNeeded);
	if (bucketsNeeded > bitPos)
		bitPos = bitPos << 1;
	return bitPos;
}
 
開發者ID:MGunlogson,項目名稱:CuckooFilter4J,代碼行數:24,代碼來源:Utils.java

示例6: onPublishingTimer

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
/**
 * The publishing timer has elapsed.
 */
synchronized void onPublishingTimer() {
    State state = this.state.get();

    logger.trace("[id={}] onPublishingTimer(), state={}, keep-alive={}, lifetime={}",
        subscriptionId, state, keepAliveCounter, lifetimeCounter);

    long startNanos = System.nanoTime();

    if (state == State.Normal) {
        timerHandler.whenNormal();
    } else if (state == State.KeepAlive) {
        timerHandler.whenKeepAlive();
    } else if (state == State.Late) {
        timerHandler.whenLate();
    } else if (state == State.Closed) {
        logger.debug("[id={}] onPublish(), state={}", subscriptionId, state); // No-op.
    } else {
        throw new RuntimeException("unhandled subscription state: " + state);
    }

    long elapsedNanos = System.nanoTime() - startNanos;
    long elapsedMillis = TimeUnit.MILLISECONDS.convert(elapsedNanos, TimeUnit.NANOSECONDS);

    long adjustedInterval = DoubleMath.roundToLong(publishingInterval - elapsedMillis, RoundingMode.UP);

    startPublishingTimer(adjustedInterval);
}
 
開發者ID:eclipse,項目名稱:milo,代碼行數:31,代碼來源:Subscription.java

示例7: roundToLong

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
@Benchmark long roundToLong(int reps) {
  long tmp = 0;
  for (int i = 0; i < reps; i++) {
    int j = i & ARRAY_MASK;
    tmp += DoubleMath.roundToLong(doubleInLongRange[j], mode);
  }
  return tmp;
}
 
開發者ID:sander120786,項目名稱:guava-libraries,代碼行數:9,代碼來源:DoubleMathRoundingBenchmark.java

示例8: init

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
void init() {
  if (simulator.isPresent() && rm.isPresent()) {
    int max = 0;
    for (final List<Point> ps : points) {
      max = Math.max(max, ps.size());
    }
    final int num = max;
    for (int i = 0; i < num; i++) {
      final long duration = DoubleMath.roundToLong(
          (FactoryExample.SERVICE_DURATION / 2d)
              + (rng.nextDouble() * FactoryExample.SERVICE_DURATION),
          RoundingMode.CEILING);

      final Point rnd = rndBorder();
      Point dest;
      if (i >= points.get(0).size()) {
        dest = rndBorder();
      } else {
        dest = points.get(0).get(i);
        occupiedPositions.add(dest);
      }

      final BoxHandle bh = new BoxHandle(i);
      final Box b = new Box(rnd, dest, duration, bh);
      bh.box = b;

      boxes.add(bh);
      simulator.get().register(boxes.get(boxes.size() - 1).box);
    }
  }
}
 
開發者ID:JDevlieghere,項目名稱:MAS,代碼行數:32,代碼來源:AgvModel.java

示例9: handleEvent

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
@Override
public void handleEvent(Event e) {
  if (e.getEventType() == SimulatorEventType.CONFIGURED) {
    init();
  } else {
    final PDPModelEvent event = (PDPModelEvent) e;
    if (e.getEventType() == PDPModelEventType.END_PICKUP) {
      occupiedPositions.remove(((Box) event.parcel).origin);
    }
    if (e.getEventType() == PDPModelEventType.END_DELIVERY) {
      final long duration = DoubleMath.roundToLong(
          (FactoryExample.SERVICE_DURATION / 2d)
              + (rng.nextDouble() * FactoryExample.SERVICE_DURATION),
          RoundingMode.CEILING);
      simulator.get().unregister(event.parcel);

      final BoxHandle bh = ((Box) event.parcel).boxHandle;
      bh.wordIndex = (bh.wordIndex + 1) % points.size();

      Point dest;
      if (bh.index >= points.get(bh.wordIndex).size()) {
        dest = rndBorder();
      } else {
        dest = points.get(bh.wordIndex).get(bh.index);
        occupiedPositions.add(dest);
      }

      final Box b = new Box(event.parcel.getDestination(), dest, duration, bh);
      bh.box = b;

      simulator.get().register(b);
    }
  }
}
 
開發者ID:JDevlieghere,項目名稱:MAS,代碼行數:35,代碼來源:AgvModel.java

示例10: computeTravelTime

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
public long computeTravelTime(Point from, Point to) {
  final double speedKMH = vehicle.getDto().getSpeed();

  final double distKM = Point.distance(from, to);

  final double travelTimeH = distKM / speedKMH;
  // convert to nanoseconds
  return DoubleMath.roundToLong(travelTimeH * H_TO_NS,
    RoundingMode.HALF_DOWN);
}
 
開發者ID:rinde,項目名稱:RinLog,代碼行數:11,代碼來源:Vehicle.java

示例11: startPublishingTimer

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
synchronized void startPublishingTimer() {
    long interval = DoubleMath.roundToLong(publishingInterval, RoundingMode.UP);

    startPublishingTimer(interval);
}
 
開發者ID:eclipse,項目名稱:milo,代碼行數:6,代碼來源:Subscription.java

示例12: ScheduledUpdate

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
private ScheduledUpdate(double samplingInterval, List<DataItem> items) {
    this.samplingInterval = DoubleMath.roundToLong(samplingInterval, RoundingMode.UP);
    this.items = items;
}
 
開發者ID:eclipse,項目名稱:milo,代碼行數:5,代碼來源:SubscriptionModel.java

示例13: coerceDoubleToLongComparison

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
private static Expression coerceDoubleToLongComparison(NormalizedSimpleComparison normalized)
{
    checkArgument(normalized.getValue().getType().equals(DOUBLE), "Value should be of DOUBLE type");
    checkArgument(!normalized.getValue().isNull(), "Value should not be null");
    QualifiedNameReference reference = normalized.getNameReference();
    Double value = (Double) normalized.getValue().getValue();

    switch (normalized.getComparisonType()) {
        case GREATER_THAN_OR_EQUAL:
        case LESS_THAN:
            return new ComparisonExpression(normalized.getComparisonType(), reference, toExpression(DoubleMath.roundToLong(value, CEILING), BIGINT));

        case GREATER_THAN:
        case LESS_THAN_OR_EQUAL:
            return new ComparisonExpression(normalized.getComparisonType(), reference, toExpression(DoubleMath.roundToLong(value, FLOOR), BIGINT));

        case EQUAL:
            Long equalValue = DoubleMath.roundToLong(value, FLOOR);
            if (equalValue.doubleValue() != value) {
                // Return something that is false for all non-null values
                return and(new ComparisonExpression(EQUAL, reference, new LongLiteral("0")),
                        new ComparisonExpression(NOT_EQUAL, reference, new LongLiteral("0")));
            }
            return new ComparisonExpression(normalized.getComparisonType(), reference, toExpression(equalValue, BIGINT));

        case NOT_EQUAL:
            Long notEqualValue = DoubleMath.roundToLong(value, FLOOR);
            if (notEqualValue.doubleValue() != value) {
                // Return something that is true for all non-null values
                return or(new ComparisonExpression(EQUAL, reference, new LongLiteral("0")),
                        new ComparisonExpression(NOT_EQUAL, reference, new LongLiteral("0")));
            }
            return new ComparisonExpression(normalized.getComparisonType(), reference, toExpression(notEqualValue, BIGINT));

        case IS_DISTINCT_FROM:
            Long distinctValue = DoubleMath.roundToLong(value, FLOOR);
            if (distinctValue.doubleValue() != value) {
                return TRUE_LITERAL;
            }
            return new ComparisonExpression(normalized.getComparisonType(), reference, toExpression(distinctValue, BIGINT));

        default:
            throw new AssertionError("Unhandled type: " + normalized.getComparisonType());
    }
}
 
開發者ID:y-lan,項目名稱:presto,代碼行數:46,代碼來源:DomainTranslator.java

示例14: generate

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
@Override
public void generate(long seed, Parcel.Builder parcelBuilder,
    TravelTimes travelTimes, long endTime) {
  rng.setSeed(seed);
  final long orderAnnounceTime = parcelBuilder.getOrderAnnounceTime();
  final Point pickup = parcelBuilder.getPickupLocation();
  final Point delivery = parcelBuilder.getDeliveryLocation();

  final long pickupToDeliveryTT = travelTimes.getShortestTravelTime(pickup,
    delivery);
  final long deliveryToDepotTT = travelTimes
    .getTravelTimeToNearestDepot(delivery);

  // compute range of possible openings
  long pickupOpening;
  if (urgency > MINIMAL_PICKUP_TW_LENGTH) {

    // possible values range from 0 .. n
    // where n = urgency - MINIMAL_PICKUP_TW_LENGTH
    pickupOpening = orderAnnounceTime + DoubleMath.roundToLong(
      pickupTWopening.get(rng.nextLong())
        * (urgency - MINIMAL_PICKUP_TW_LENGTH),
      RoundingMode.HALF_UP);
  } else {
    pickupOpening = orderAnnounceTime;
  }
  final TimeWindow pickupTW = TimeWindow.create(pickupOpening,
    orderAnnounceTime + urgency);
  parcelBuilder.pickupTimeWindow(pickupTW);

  // find boundaries
  final long minDeliveryOpening = pickupTW.begin()
    + parcelBuilder.getPickupDuration() + pickupToDeliveryTT;

  final long maxDeliveryClosing = endTime - deliveryToDepotTT
    - parcelBuilder.getDeliveryDuration();
  long maxDeliveryOpening = maxDeliveryClosing - MINIMAL_DELIVERY_TW_LENGTH;
  if (maxDeliveryOpening < minDeliveryOpening) {
    maxDeliveryOpening = minDeliveryOpening;
  }

  final double openingRange = maxDeliveryOpening - minDeliveryOpening;
  final long deliveryOpening = minDeliveryOpening
    + DoubleMath.roundToLong(deliveryTWopening.get(rng.nextLong())
      * openingRange,
      RoundingMode.HALF_DOWN);

  final long minDeliveryClosing = Math.min(Math.max(pickupTW.end()
    + parcelBuilder.getPickupDuration() + pickupToDeliveryTT,
    deliveryOpening + MINIMAL_DELIVERY_TW_LENGTH), maxDeliveryClosing);

  final double closingRange = maxDeliveryClosing - minDeliveryClosing;
  final long deliveryClosing = minDeliveryClosing
    + DoubleMath.roundToLong(deliveryTWlength.get(rng.nextLong())
      * closingRange,
      RoundingMode.HALF_DOWN);

  final long latestDelivery = endTime - deliveryToDepotTT
    - parcelBuilder.getDeliveryDuration();

  final TimeWindow deliveryTW = TimeWindow.create(deliveryOpening,
    deliveryClosing);

  checkArgument(deliveryOpening >= minDeliveryOpening);
  checkArgument(deliveryOpening + deliveryTW.length() <= latestDelivery);
  checkArgument(pickupTW.end() + parcelBuilder.getPickupDuration()
    + pickupToDeliveryTT <= deliveryOpening + deliveryTW.length());

  parcelBuilder.deliveryTimeWindow(deliveryTW);
}
 
開發者ID:rinde,項目名稱:pdptw-dataset-generator,代碼行數:71,代碼來源:DatasetGenerator.java

示例15: roundDoubleToLong

import com.google.common.math.DoubleMath; //導入方法依賴的package包/類
@SuppressWarnings("SameParameterValue")
public static long roundDoubleToLong(double value, RoundingMode roundingMode) {
    return DoubleMath.roundToLong(value, roundingMode);
}
 
開發者ID:bisq-network,項目名稱:exchange,代碼行數:5,代碼來源:MathUtils.java


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