Jakarta-Common-Math使用笔记

转载 2013年12月05日 20:07:06
apache的math组件,尽管不常用,我今天也整理出来。
下载地址: http://commons.apache.org/math/
示例代码:
package demo;

import org.apache.commons.math.stat.descriptive.moment.GeometricMean;
import org.apache.commons.math.stat.descriptive.moment.Kurtosis;
import org.apache.commons.math.stat.descriptive.moment.Mean;
import org.apache.commons.math.stat.descriptive.moment.Skewness;
import org.apache.commons.math.stat.descriptive.moment.StandardDeviation;
import org.apache.commons.math.stat.descriptive.moment.Variance;
import org.apache.commons.math.stat.descriptive.rank.Max;
import org.apache.commons.math.stat.descriptive.rank.Min;
import org.apache.commons.math.stat.descriptive.rank.Percentile;
import org.apache.commons.math.stat.descriptive.summary.Product;
import org.apache.commons.math.stat.descriptive.summary.Sum;
import org.apache.commons.math.stat.descriptive.summary.SumOfSquares;

public class TestMathUserage ...{

   public static void main(String[] args) ...{

     double[] values = new double[] ...{ 0.33, 1.33, 0.27333, 0.3, 0.501,
         0.444, 0.44, 0.34496, 0.33, 0.3, 0.292, 0.667 };
     /**//*
     * System.out.println( "min: " + StatUtils.min( values ) );
     * System.out.println( "max: " + StatUtils.max( values ) );
     * System.out.println( "mean: " + StatUtils.mean( values ) ); // Returns
     * the arithmetic mean of the entries in the input array, or Double.NaN
     * if the array is empty System.out.println( "product: " +
     * StatUtils.product( values ) ); //Returns the product of the entries
     * in the input array, or Double.NaN if the array is empty.
     * System.out.println( "sum: " + StatUtils.sum( values ) ); //Returns
     * the sum of the values in the input array, or Double.NaN if the array
     * is empty. System.out.println( "variance: " + StatUtils.variance(
     * values ) ); // Returns the variance of the entries in the input
     * array, or Double.NaN if the array is empty.
     */

     Min min = new Min();
     Max max = new Max();
     Mean mean = new Mean(); // 算术平均值
     Product product = new Product();
     Sum sum = new Sum();
     Variance variance = new Variance();
     System.out.println("min: " + min.evaluate(values));
     System.out.println("max: " + max.evaluate(values));
     System.out.println("mean: " + mean.evaluate(values));
     System.out.println("product: " + product.evaluate(values));
     System.out.println("sum: " + sum.evaluate(values));
     System.out.println("variance: " + variance.evaluate(values));

     Percentile percentile = new Percentile(); // 百分位数
     GeometricMean geoMean = new GeometricMean(); // 几何平均数,n个正数的连乘积的n次算术根叫做这n个数的几何平均数
     Skewness skewness = new Skewness(); // Skewness();
     Kurtosis kurtosis = new Kurtosis(); // Kurtosis,峰度
     SumOfSquares sumOfSquares = new SumOfSquares(); // 平方和
     StandardDeviation StandardDeviation = new StandardDeviation();
     System.out.println("80 percentile value: "
         + percentile.evaluate(values, 80.0));
     System.out.println("geometric mean: " + geoMean.evaluate(values));
     System.out.println("skewness: " + skewness.evaluate(values));
     System.out.println("kurtosis: " + kurtosis.evaluate(values));
     System.out.println("sumOfSquares: " + sumOfSquares.evaluate(values));
     // 就是标准方差
     System.out.println("StandardDeviation: "
         + StandardDeviation.evaluate(values));
   }
}
 
几个主要功能类:
A.RandomData类:
package demo;

import org.apache.commons.math.random.RandomData;
import org.apache.commons.math.random.RandomDataImpl;

public class MathDemo ...{

   public static void main(String[] args) ...{

     RandomData randomData = new RandomDataImpl();
     for (int i = 0; i < 10; i++) ...{
       long value = randomData.nextLong(1, 100);
       System.out.println(value);
     }

     System.out.println("===============");

     for (int i = 0; i < 10; i++) ...{
       randomData = new RandomDataImpl();
       long value = randomData.nextLong(1, 100);
       System.out.println(value);
     }
   }
}
B.RealMatrix类,求解方程
2x + 3y - 2z = 1
-x + 7y + 6x = -2
4x - 3y - 5z = 1

package demo;

import java.io.IOException;

import org.apache.commons.math.linear.RealMatrix;
import org.apache.commons.math.linear.RealMatrixImpl;

public class MathDemo ...{

   public static void main(String[] args) throws IOException ...{

     double[][] coefficientsData = ...{...{2, 3, -2}, ...{-1, 7, 6}, ...{4, -3, -5}};
     RealMatrix coefficients = new RealMatrixImpl(coefficientsData);

     double[] constants = ...{1, -2, 1};
     double[] solution = coefficients.solve(constants);

     System.out.println(solution[0]);
     System.out.println(solution[1]);
     System.out.println(solution[2]);
   }
}

相关文章推荐

java曲线拟合commons-math3-3.6.1函数

需要的jar 包 commons-math3-3.6.1.jar jar包下载地址 API参考地址示例代码如下package cn.mingtong.testdistance;import o...
  • T1DMzks
  • T1DMzks
  • 2017年04月05日 17:58
  • 1264

commons math用户手册翻译(一)

翻译源址:http://commons.apache.org/proper/commons-math/userguide/index.html 1、math包版本3.6 2、commons-math包...
  • xf_87
  • xf_87
  • 2017年01月03日 12:43
  • 633

Jakarta-Common-Codec使用笔记

Jakarta-Common-Codec使用笔记   commons codec 提供 base64, hex, 及 metaphone, soundex 等编码演算。 下载...

Jakarta-Common-Digester使用笔记

  • 2009年12月05日 20:54
  • 758KB
  • 下载

Apache Jakarta Common Lang 3

Apache Jakarta Common Lang 介绍  无论你在开发哪中 Java 应用程序,都免不了要写很多工具类/工具函数。你可知道,有很多现成的工具类可用,并且代码质量都很不错,不用你写,...

Apache Common Math 3.2 API CHM文档

  • 2014年02月11日 17:09
  • 4.53MB
  • 下载

Apache Common Math 2.2 API CHM文档

  • 2011年08月06日 16:11
  • 5.42MB
  • 下载

Jakarta Commons HttpClient 学习笔记

虽然用telnet这样的程序都可把页面取回来,但是在与web服务器的交互中,如果涉及cookie或https或ssl等内容,一般功能相对完备的http客户端还是非常必要的。IE或NetScape等浏览...

Jakarta Commons Digester 学习笔记

  在windows下开发程序,用M$提供的接口处理.ini文件或管理注册表的键值是非常方便的。在java平台上开发程序,则习惯于以xml格式的文件来存放系统的配置信息,对这种文件的解析和处理,可以...
  • xinew
  • xinew
  • 2011年05月03日 21:49
  • 434

001-Jakarta Commons-Digester学习笔记

Digester原是Apache Jakarta Struts计划中的一部分,用来解析Web App中的XML配置文件,在开发一段时间之后,开发人员觉得这个小工具具有很普遍的使用场合,于是,将这个部分...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Jakarta-Common-Math使用笔记
举报原因:
原因补充:

(最多只允许输入30个字)