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


Java MathException類代碼示例

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


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

示例1: getSignificance

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Computes the significance of the difference between two correlations.
 * @see org.tud.sir.util.statistics.Significance.testCorrelations
 */
public static double getSignificance(double correlation1, double correlation2, int n1, int n2) throws MathException {
    
    // transform to Fisher Z-values
    double zv1 = FisherZTransformation.transform(correlation1);
    double zv2 = FisherZTransformation.transform(correlation2);

    // difference of the Z-values
    double zDifference = (zv1 - zv2) / Math.sqrt(2d) / Math.sqrt( (double)1/(n1-3) + (double)1/(n2-3));
    
    // get p value from the complementary error function
    double p = Erf.erfc( Math.abs(zDifference));
    return p;
}
 
開發者ID:dkpro,項目名稱:dkpro-statistics,代碼行數:18,代碼來源:Significance.java

示例2: generatePixelSignature

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Computes the relative probability of receiving a photon at the pixel. 
 * @param pixelX The pixel's x-position.
 * @param pixelY The pixel's y-position.
 * @return The probability of a photon hitting this pixel.
 * @throws org.apache.commons.math.MathException
 */
@Override
public double generatePixelSignature(int pixelX, int pixelY)
        throws MathException {
    final double sigma_0 = this.FWHM / 2.3548;
    final double zR = 2 * sigma_0 / this.numericalAperture; // Rayleigh range
    
    // Add the offset from the stage's position to the emitter's z-values
    double z;
    z = this.eZ + this.stageDisplacement;
    
    double sigma = sigma_0 * sqrt(1 + (z/ zR) * (z / zR));
    double denom = sqrt(2.0)*sigma;
    return 0.25 *(Erf.erf((pixelX - this.eX + 0.5)/denom) - 
                  Erf.erf((pixelX - this.eX - 0.5)/denom)) *
                 (Erf.erf((pixelY - this.eY + 0.5)/denom) -
                  Erf.erf((pixelY - this.eY - 0.5)/denom));
}
 
開發者ID:LEB-EPFL,項目名稱:SASS,代碼行數:25,代碼來源:Gaussian3D.java

示例3: computePhiMeasure

import org.apache.commons.math.MathException; //導入依賴的package包/類
public synchronized Double computePhiMeasure(long now) {
  if (latestHeartbeatMs == -1 || descriptiveStatistics.getN() < minimumSamples) {
    return null;
  }
  long delta = now - latestHeartbeatMs;
  try {
    double probability;
    if (distribution.equals("normal")) {
      double standardDeviation = descriptiveStatistics.getStandardDeviation();
      standardDeviation = standardDeviation < 0.1 ? 0.1 : standardDeviation;
      probability = new NormalDistributionImpl(descriptiveStatistics.getMean(), standardDeviation).cumulativeProbability(delta);
    } else {
      probability = new ExponentialDistributionImpl(descriptiveStatistics.getMean()).cumulativeProbability(delta);
    }
    final double eps = 1e-12;
    if (1 - probability < eps) {
      probability = 1.0;
    }
    return -1.0d * Math.log10(1.0d - probability);
  } catch (MathException | IllegalArgumentException e) {
    LOGGER.debug(e);
    return null;
  }
}
 
開發者ID:apache,項目名稱:incubator-gossip,代碼行數:25,代碼來源:FailureDetector.java

示例4: fst

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Perform the FST algorithm (including inverse).
 *
 * @param f the real data array to be transformed
 * @return the real transformed array
 * @throws MathException if any math-related errors occur
 * @throws IllegalArgumentException if any parameters are invalid
 */
protected double[] fst(double f[]) throws MathException,
    IllegalArgumentException {

    double A, B, x[], F[] = new double[f.length];

    FastFourierTransformer.verifyDataSet(f);
    if (f[0] != 0.0) {
        throw new IllegalArgumentException
            ("The first element is not zero: " + f[0]);
    }
    int N = f.length;
    if (N == 1) {       // trivial case
        F[0] = 0.0;
        return F;
    }

    // construct a new array and perform FFT on it
    x = new double[N];
    x[0] = 0.0;
    x[N >> 1] = 2.0 * f[N >> 1];
    for (int i = 1; i < (N >> 1); i++) {
        A = Math.sin(i * Math.PI / N) * (f[i] + f[N-i]);
        B = 0.5 * (f[i] - f[N-i]);
        x[i] = A + B;
        x[N-i] = A - B;
    }
    FastFourierTransformer transformer = new FastFourierTransformer();
    Complex y[] = transformer.transform(x);

    // reconstruct the FST result for the original array
    F[0] = 0.0;
    F[1] = 0.5 * y[0].getReal();
    for (int i = 1; i < (N >> 1); i++) {
        F[2*i] = -y[i].getImaginary();
        F[2*i+1] = y[i].getReal() + F[2*i-1];
    }

    return F;
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:48,代碼來源:FastSineTransformer.java

示例5: SimpleNoiseDistribution

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Constructor.
 * 
 * @param peakList the peak list
 * 
 * @throws MathException thrown if a math error occurs
 */
public SimpleNoiseDistribution(HashMap<Double, Peak> peakList) throws MathException {

    ArrayList<Double> intensitiesLog = new ArrayList<Double>(peakList.size());
    for (Peak peak : peakList.values()) {
        double log = FastMath.log10(peak.intensity);
        intensitiesLog.add(log);
    }
    Collections.sort(intensitiesLog);
    intensityLogDistribution = NonSymmetricalNormalDistribution.getRobustNonSymmetricalNormalDistributionFromSortedList(intensitiesLog);

    orderedBins = new int[nBins - 1];
    pLog = new double[nBins - 1];
    binSize = 1.0 / nBins;

    for (int i = 1; i < nBins; i++) {
        double p = binSize * i;
        double x = intensityLogDistribution.getValueAtDescendingCumulativeProbability(p);
        orderedBins[i - 1] = (int) FastMath.pow(10, x);
        pLog[i - 1] = FastMath.log10(p);
    }
}
 
開發者ID:compomics,項目名稱:compomics-utilities,代碼行數:29,代碼來源:SimpleNoiseDistribution.java

示例6: testExpm1Function2

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Test of solver for the exponential function using solve2().
 * <p>
 * It takes 25 to 50 iterations for the last two tests to converge.
 */
public void testExpm1Function2() throws MathException {
    UnivariateRealFunction f = new Expm1Function();
    MullerSolver solver = new MullerSolver(f);
    double min, max, expected, result, tolerance;

    min = -1.0; max = 2.0; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve2(min, max);
    assertEquals(expected, result, tolerance);

    min = -20.0; max = 10.0; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve2(min, max);
    assertEquals(expected, result, tolerance);

    min = -50.0; max = 100.0; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve2(min, max);
    assertEquals(expected, result, tolerance);
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:29,代碼來源:MullerSolverTest.java

示例7: testConstants

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * tests the value of a constant polynomial.
 *
 * <p>value of this is 2.5 everywhere.</p>
 */
public void testConstants() throws MathException {
    double[] c = { 2.5 };
    PolynomialFunction f = new PolynomialFunction( c );

    // verify that we are equal to c[0] at several (nonsymmetric) places
    assertEquals( f.value( 0.0), c[0], tolerance );
    assertEquals( f.value( -1.0), c[0], tolerance );
    assertEquals( f.value( -123.5), c[0], tolerance );
    assertEquals( f.value( 3.0), c[0], tolerance );
    assertEquals( f.value( 456.89), c[0], tolerance );
    
    assertEquals(f.degree(), 0);
    assertEquals(f.derivative().value(0), 0, tolerance);
    
    assertEquals(f.polynomialDerivative().derivative().value(0), 0, tolerance);
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:22,代碼來源:PolynomialFunctionTest.java

示例8: testLargeMeanCumulativeProbability

import org.apache.commons.math.MathException; //導入依賴的package包/類
public void testLargeMeanCumulativeProbability() {
    PoissonDistribution dist = new PoissonDistributionImpl(1.0);
    double mean = 1.0;
    while (mean <= 10000000.0) {
        dist.setMean(mean);
        
        double x = mean * 2.0;
        double dx = x / 10.0;
        while (x >= 0) {
            try {
                dist.cumulativeProbability(x);
            } catch (MathException ex) {
                fail("mean of " + mean + " and x of " + x + " caused " + ex.getMessage());
            }
            x -= dx;
        }
        
        mean *= 10.0;
    }
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:21,代碼來源:PoissonDistributionTest.java

示例9: testLargeMeanInverseCumulativeProbability

import org.apache.commons.math.MathException; //導入依賴的package包/類
public void testLargeMeanInverseCumulativeProbability() {
    PoissonDistribution dist = new PoissonDistributionImpl(1.0);
    double mean = 1.0;
    while (mean <= 10000000.0) {
        dist.setMean(mean);
        
        double p = 0.1;
        double dp = p;
        while (p < 1.0) {
            try {
                dist.inverseCumulativeProbability(p);
            } catch (MathException ex) {
                fail("mean of " + mean + " and p of " + p + " caused " + ex.getMessage());
            }
            p += dp;
        }
        
        mean *= 10.0;
    }
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:21,代碼來源:PoissonDistributionTest.java

示例10: findDifferentia

import org.apache.commons.math.MathException; //導入依賴的package包/類
public List<InferredClassDefinition> findDifferentia(OWLClass child, OWLClass parent, OWLClass diffClassRoot) throws UnknownOWLClassException, MathException {

		List<InferredClassDefinition> results = new Vector<InferredClassDefinition>();
		LOG.info("Finding: "+child+" against "+parent);
		for (OWLClass differentiaClass : sim.getReasoner()
				.getSubClasses(diffClassRoot, false).getFlattened()) {
			//LOG.info("  Testing: "+enrichedClass);
			if (differentiaClass.isBottomEntity()) {
				continue;
			}
			if (sim.getNumElementsForAttribute(differentiaClass) == 0) {
				LOG.info("Skipping: "+differentiaClass);
				continue;
			}
			InferredClassDefinition r = calculateGenusDifferentiaEnrichment(child, parent,
					differentiaClass);
			if (r != null)
				results.add(r);
		}
		Collections.sort(results);
		return results;
	}
 
開發者ID:owlcollab,項目名稱:owltools,代碼行數:23,代碼來源:ClassDifferentiaLearner.java

示例11: cumulativeProbability

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * For this distribution, X, this method returns P(X &le; x).
 * @param x the value at which the PDF is evaluated.
 * @return PDF for this distribution. 
 * @throws MathException if the cumulative probability can not be
 *            computed due to convergence or other numerical errors.
 */
public double cumulativeProbability(int x) throws MathException {
    double ret;
    if (x < 0) {
        ret = 0.0;
    } else if (x >= getNumberOfTrials()) {
        ret = 1.0;
    } else {
        ret =
            1.0 - Beta.regularizedBeta(
                    getProbabilityOfSuccess(),
                    x + 1.0,
                    getNumberOfTrials() - x);
    }
    return ret;
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:23,代碼來源:BinomialDistributionImpl.java

示例12: exhaustiveTestOnGO

import org.apache.commons.math.MathException; //導入依賴的package包/類
@Test
public void exhaustiveTestOnGO() throws IOException, OWLOntologyCreationException, OWLOntologyStorageException, MathException {
	/*
	ParserWrapper pw = new ParserWrapper();
	sourceOntol = pw.parseOBO(getResourceIRIString("go-subset-t1.obo"));
	g = new OWLGraphWrapper(sourceOntol);
	IRI vpIRI = g.getOWLObjectPropertyByIdentifier("GOTESTREL:0000001").getIRI();
	TableToAxiomConverter ttac = new TableToAxiomConverter(g);
	ttac.config.axiomType = AxiomType.CLASS_ASSERTION;
	ttac.config.property = vpIRI;
	ttac.config.isSwitchSubjectObject = true;
	ttac.parse("src/test/resources/simplegaf-t1.txt");

	OWLPrettyPrinter pp = new OWLPrettyPrinter(g);
	
	AutomaticSimPreProcessor pproc = new AutomaticSimPreProcessor();
	pproc.setInputOntology(sourceOntol);
	pproc.setOutputOntology(sourceOntol);
	pproc.preprocess();
	*/
}
 
開發者ID:owlcollab,項目名稱:owltools,代碼行數:22,代碼來源:ExhaustiveSimPreProcessorTest.java

示例13: testQuantileCM

import org.apache.commons.math.MathException; //導入依賴的package包/類
private static void testQuantileCM(double y, double shape, double scale) {

        long time = System.currentTimeMillis();

        double value = 0;
        try {
            for (int i = 0; i < 1000; i++) {
                value = (new org.apache.commons.math.distribution.GammaDistributionImpl(shape, scale)).inverseCumulativeProbability(y);
            }
            value = (new org.apache.commons.math.distribution.GammaDistributionImpl(shape, scale)).inverseCumulativeProbability(y);
        } catch (MathException e) {
            e.printStackTrace();
        }
        long elapsed = System.currentTimeMillis() - time;


        System.out.println("commons.maths inverseCDF, "+ y +", for shape=" + shape + ", scale=" + scale
                + " : " + value + ", time=" + elapsed + "ms");

    }
 
開發者ID:beast-dev,項目名稱:beast-mcmc,代碼行數:21,代碼來源:GammaDistribution.java

示例14: testExpm1Function

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Test of solver for the exponential function.
 */
public void testExpm1Function() throws MathException {
    UnivariateRealFunction f = new Expm1Function();
    UnivariateRealSolver solver = new RiddersSolver(f);
    double min, max, expected, result, tolerance;

    min = -1.0; max = 2.0; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve(min, max);
    assertEquals(expected, result, tolerance);

    min = -20.0; max = 10.0; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve(min, max);
    assertEquals(expected, result, tolerance);

    min = -50.0; max = 100.0; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve(min, max);
    assertEquals(expected, result, tolerance);
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:27,代碼來源:RiddersSolverTest.java

示例15: testQuinticFunction

import org.apache.commons.math.MathException; //導入依賴的package包/類
/**
 * Test of solver for the quintic function.
 */
public void testQuinticFunction() throws MathException {
    UnivariateRealFunction f = new QuinticFunction();
    UnivariateRealSolver solver = new MullerSolver(f);
    double min, max, expected, result, tolerance;

    min = -0.4; max = 0.2; expected = 0.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve(min, max);
    assertEquals(expected, result, tolerance);

    min = 0.75; max = 1.5; expected = 1.0;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve(min, max);
    assertEquals(expected, result, tolerance);

    min = -0.9; max = -0.2; expected = -0.5;
    tolerance = Math.max(solver.getAbsoluteAccuracy(),
                Math.abs(expected * solver.getRelativeAccuracy()));
    result = solver.solve(min, max);
    assertEquals(expected, result, tolerance);
}
 
開發者ID:cacheonix,項目名稱:cacheonix-core,代碼行數:27,代碼來源:MullerSolverTest.java


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