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


Java SummaryStatistics.getVariance方法代碼示例

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


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

示例1: getStats

import org.apache.commons.math3.stat.descriptive.SummaryStatistics; //導入方法依賴的package包/類
private static Stats getStats(FloatColumn values, SummaryStatistics summaryStatistics) {
    Stats stats = new Stats("Column: " + values.name());
    stats.min = (float) summaryStatistics.getMin();
    stats.max = (float) summaryStatistics.getMax();
    stats.n = summaryStatistics.getN();
    stats.sum = summaryStatistics.getSum();
    stats.variance = summaryStatistics.getVariance();
    stats.populationVariance = summaryStatistics.getPopulationVariance();
    stats.quadraticMean = summaryStatistics.getQuadraticMean();
    stats.geometricMean = summaryStatistics.getGeometricMean();
    stats.mean = summaryStatistics.getMean();
    stats.standardDeviation = summaryStatistics.getStandardDeviation();
    stats.sumOfLogs = summaryStatistics.getSumOfLogs();
    stats.sumOfSquares = summaryStatistics.getSumsq();
    stats.secondMoment = summaryStatistics.getSecondMoment();
    return stats;
}
 
開發者ID:jtablesaw,項目名稱:tablesaw,代碼行數:18,代碼來源:Stats.java

示例2: getKernel

import org.apache.commons.math3.stat.descriptive.SummaryStatistics; //導入方法依賴的package包/類
/**
 * The within-bin smoothing kernel. Returns a Gaussian distribution
 * parameterized by {@code bStats}, unless the bin contains only one
 * observation, in which case a constant distribution is returned.
 *
 * @param bStats summary statistics for the bin
 * @return within-bin kernel parameterized by bStats
 */
protected RealDistribution getKernel(SummaryStatistics bStats) {
    if (bStats.getN() == 1 || bStats.getVariance() == 0) {
        return new ConstantRealDistribution(bStats.getMean());
    } else {
        return new NormalDistribution(randomData.getRandomGenerator(),
            bStats.getMean(), bStats.getStandardDeviation(),
            NormalDistribution.DEFAULT_INVERSE_ABSOLUTE_ACCURACY);
    }
}
 
開發者ID:biocompibens,項目名稱:SME,代碼行數:18,代碼來源:EmpiricalDistribution.java

示例3: meanTest

import org.apache.commons.math3.stat.descriptive.SummaryStatistics; //導入方法依賴的package包/類
/**
 * Runs the mean test for the specified instance of Random.
 * @param random The RNG instance to test.
 * @param doAssert Flag to indicate whether result should be asserted or simply logged.
 */
private void meanTest(Random random, boolean doAssert) {
	final String methodName = "meanTest : ";
	
	ndigits = new int[10];
	// Initialize the array
	for (int i = 0; i < 10; i++) {
		ndigits[i] = 0;
	}
	double x;
	int n;
	
	SummaryStatistics stats = new SummaryStatistics();

	long start = System.currentTimeMillis();
	// Test the random number generator a whole lot
	for (long i = 0; i < values; i++) {
		// generate a new random number between 0 and 9
		x = random.nextDouble() * 10.0;
		n = (int) x;
		stats.addValue(n);
		// count the digits in the random number
		ndigits[n]++;
	}
	long end = System.currentTimeMillis();

	LOGGER.info("{} Time: {}ms", methodName, end - start);
	LOGGER.info("{} Distribution:", methodName);
	// Print the results
	for (int i = 0; i < 10; i++) {
		LOGGER.info("{} {}: {}", methodName, i, ndigits[i]);
	}
	double sampleMean = stats.getMean();
	double sampleVar = stats.getVariance();
	double meanDiff = (sampleMean - mean)/mean;
	LOGGER.info("{} mean: {}, diff: {}", methodName, sampleMean, meanDiff);
	LOGGER.info("{} sd: {}", methodName, stats.getStandardDeviation());
	LOGGER.info("{} var: {}", methodName, sampleVar);
	// Verify results.
	boolean varResult = sampleVar < var;
	String varMsg = "Random Variance exceeds max expectation!";
	boolean ci99Result = sampleMean >= smLowerRng3SD
			&& sampleMean <= smUpperRng3SD;
	String ci99Msg = "Random 99.7% CI test failed!";
	boolean ci95Result = sampleMean >= smLowerRng2SD
			&& sampleMean <= smUpperRng2SD;
	String ci95Msg = "Random 95% CI test failed!";
	if (doAssert) {
		assertTrue(varMsg, varResult);
		assertTrue(ci99Msg, ci99Result);
		assertTrue(ci95Msg, ci95Result);
	}
	else {
		if (!varResult) {
			LOGGER.warn("{} {}", methodName, varMsg);
		}
		if (!ci99Result) {
			LOGGER.warn("{} {}", methodName, ci99Msg);
		}
		if (!ci95Result) {
			LOGGER.warn("{} {}", methodName, ci95Msg);
		}
	}
}
 
開發者ID:hpadmanabhan,項目名稱:rdrand-util,代碼行數:69,代碼來源:RdRandRandomTest.java

示例4: testRdRandRandomMean

import org.apache.commons.math3.stat.descriptive.SummaryStatistics; //導入方法依賴的package包/類
/**
 * Tests RdRandRandom by verifying the average of the distribution of digits 0-9
 * over 100 million values. Also runs the test for Random and SecureRandom for
 * reference.
 * Based on Mean Test outlined in <i>Beautiful Testing</i> published by O'Reilly.
 * @throws GeneralSecurityException 
 * @throws SeedException 
 */
@Test
public final void testRdRandRandomMean() throws GeneralSecurityException, SeedException {
	final String methodName = "testRdRandRandom : ";
	
	SummaryStatistics stats = new SummaryStatistics();
	// Initialize the array
	ndigits = new int[10];
	for (int i = 0; i < 10; i++) {
		ndigits[i] = 0;
		stats.addValue(i);
	}
			
	// Calculate the confidence intervals to assert.
	mean = stats.getMean();
	stdDev = stats.getStandardDeviation();
	var = stats.getVariance();
	LOGGER.info("{} Normal mean: {}", methodName, mean);
	LOGGER.info("{} Normal std: {}", methodName, stdDev);
	LOGGER.info("{} Normal var: {}", methodName, var);
	// 99.7% CI is within 3 std.
	double expectedDev3SD = 3 * stdDev / Math.sqrt(values);
	smLowerRng3SD = mean - expectedDev3SD;
	smUpperRng3SD = mean + expectedDev3SD;
	// 95% CI is within 2 std.
	double expectedDev2SD = 2 * stdDev / Math.sqrt(values);
	smLowerRng2SD = mean - expectedDev2SD;
	smUpperRng2SD = mean + expectedDev2SD;
	LOGGER.info("{} Generating {} values.", methodName, values);
	LOGGER.info(
			"{} Sample mean expected in range {} - {} 99.7% of the times.",
			methodName, smLowerRng3SD, smUpperRng3SD);
	LOGGER.info(
			"{} Sample mean expected in range {} - {} 95% of the times.",
			methodName, smLowerRng2SD, smUpperRng2SD);
	
	LOGGER.info("{} Running for Random..", methodName);
	Random random = new Random();
	meanTest(random, false);

	LOGGER.info("{} Running for RdRand..", methodName);
	random = new RdRandRandom();
	meanTest(random, true);
	
	LOGGER.info("{} Running for SecureRandom..", methodName);
	random = new SecureRandom();
	meanTest(random, false);
	
	LOGGER.info("{} Running Uncommons Maths AESCounterRNG using RdRandSeedGenerator..", methodName);
	random = new AESCounterRNG(new RdRandSeedGenerator());
	meanTest(random, false);
}
 
開發者ID:hpadmanabhan,項目名稱:rdrand-util,代碼行數:60,代碼來源:RdRandRandomTest.java


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