本文整理汇总了Java中org.apache.commons.math3.fitting.WeightedObservedPoints类的典型用法代码示例。如果您正苦于以下问题:Java WeightedObservedPoints类的具体用法?Java WeightedObservedPoints怎么用?Java WeightedObservedPoints使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
WeightedObservedPoints类属于org.apache.commons.math3.fitting包,在下文中一共展示了WeightedObservedPoints类的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: getSlope
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
private double getSlope(Hashtable<Integer,Double> points)
{
WeightedObservedPoints obs=new WeightedObservedPoints();
Enumeration e=points.keys();
int key;
while (e.hasMoreElements())
{
key=(int)e.nextElement();
obs.add(key,points.get(key));
}
PolynomialCurveFitter fitter=PolynomialCurveFitter.create(1);
double[] coeff=fitter.fit(obs.toList());
BigDecimal bd = new BigDecimal(coeff[1]);
BigDecimal slope=bd.setScale(3,BigDecimal.ROUND_HALF_UP);
return slope.doubleValue()*10;
}
示例2: fit
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
public void fit(String path) throws IOException {
final WeightedObservedPoints obs = new WeightedObservedPoints();
try(BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(new File(path))))) {
String line = br.readLine();
while (line != null) {
String[] point = line.split(" ");
double x = Double.parseDouble(point[0]);
double y = Double.parseDouble(point[1]);
obs.add(x, y);
line = br.readLine();
}
} catch (IOException e) {
throw e;
}
final PolynomialCurveFitter fitter = PolynomialCurveFitter.create(5);
final double[] coeff = fitter.fit(obs.toList());
StringBuilder res = new StringBuilder();
for (int i = coeff.length - 1; i >= 0; i--) {
res.append(coeff[i]).append(":");
}
System.out.println(res.substring(0, res.length() - 1));
}
示例3: smooth
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
@Override
public double[] smooth(double[] sourceX, double[] noisyY, double[] estimateX, double parameter) {
int degree = (int)Math.round(parameter);
if(degree < 1 || degree > sourceX.length) {
throw new IllegalArgumentException("Degree must be between 1 and number of data points.");
}
if(sourceX.length != noisyY.length) {
throw new IllegalArgumentException("X and Y input must have the same length.");
}
PolynomialCurveFitter curveFitter = PolynomialCurveFitter.create(degree).withMaxIterations(10000);
WeightedObservedPoints points = new WeightedObservedPoints();
for(int i = 0; i < sourceX.length; i++) {
points.add(sourceX[i], noisyY[i]);
}
PolynomialFunction func = new PolynomialFunction(curveFitter.fit(points.toList()));
double[] result = new double[estimateX.length];
for(int i = 0; i < estimateX.length; i++) {
result[i] = func.value(estimateX[i]);
}
return result;
}
示例4: detrend
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
public static void detrend(List<double[]> set, int detrendPolynomial) {
PolynomialCurveFitter p = PolynomialCurveFitter.create(detrendPolynomial);
WeightedObservedPoints wop = new WeightedObservedPoints();
for(int i = 0; i < set.size(); i++) {
wop.add(set.get(i)[0], set.get(i)[1]);
}
double[] coeff = p.fit(wop.toList());
for(int h = 0; h < set.size(); h++) {
double val = set.get(h)[0];
double off = 0;
for(int i = detrendPolynomial; i >= 0; i--) {
off += coeff[i] * Math.pow(val, i);
}
set.set(h, new double[]{set.get(h)[0], set.get(h)[1]-off});
}
}
示例5: isLinearCoeffDiff
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
private boolean isLinearCoeffDiff(double[] input, int centerIndex) {
double xStep = 2.0 / (input.length + 1);
WeightedObservedPoints firstHalf = new WeightedObservedPoints();
WeightedObservedPoints secondHalf = new WeightedObservedPoints();
for (int i = 0; i < input.length; i++) {
if (i <= centerIndex) {
firstHalf.add(i * xStep, input[i]);
}
if (i >= centerIndex) {
secondHalf.add((i - centerIndex) * xStep, input[i]);
}
}
PolynomialCurveFitter fitter = PolynomialCurveFitter.create(1);
double[] firstHalfCoeffs = fitter.fit(firstHalf.toList());
double[] secondHalfCoeffs = fitter.fit(secondHalf.toList());
double firstHalfCoeff = firstHalfCoeffs[1];
double secondHalfCoeff = secondHalfCoeffs[1];
return firstHalfCoeff * secondHalfCoeff < 0;
}
示例6: fittingNormalDistribution
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
public static double[] fittingNormalDistribution(List<Point> list) {
final WeightedObservedPoints obs = new WeightedObservedPoints();
for (int i = 0; i < list.size(); i++) {
obs.add(list.get(i).x, list.get(i).y);
}
final double[] result = GaussianCurveFitter.create().fit(obs.toList());
return result;
// result[0] = norm;
// result[1] = mean;
// result[2] = sigma;
}
示例7: fitCurve
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
private double[] fitCurve(
final List<ValuePair<DoubleType, DoubleType>> pairs)
{
if (!allValuesFinite(pairs)) {
return new double[2];
}
final WeightedObservedPoints points = toWeightedObservedPoints(pairs);
final PolynomialCurveFitter curveFitter = PolynomialCurveFitter.create(1);
return curveFitter.fit(points.toList());
}
示例8: toWeightedObservedPoints
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
private WeightedObservedPoints toWeightedObservedPoints(
final List<ValuePair<DoubleType, DoubleType>> pairs)
{
WeightedObservedPoints points = new WeightedObservedPoints();
pairs.forEach(pair -> points.add(pair.a.get(), pair.b.get()));
return points;
}
示例9: fitPolynomialToData
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
/**
* Get fitting coefficients for N degree polynomial.
* @param x
* @param y
* @param degree
* @param reverseCoefficients
* @return Fitting coefficients.
*/
public double[] fitPolynomialToData(double[] x, double[] y, int degree, boolean reverseCoefficients) {
WeightedObservedPoints obs = new WeightedObservedPoints();
for (int i = 0; i < x.length; i++) {
obs.add(1, x[i], y[i]);
}
PolynomialCurveFitter fitter = PolynomialCurveFitter.create(degree);
double[] coefficients = fitter.fit(obs.toList());
if (reverseCoefficients) {
return reverseDoublePrimitiveArray(coefficients);
} else {
return coefficients;
}
}
示例10: harmonicDetrend
import org.apache.commons.math3.fitting.WeightedObservedPoints; //导入依赖的package包/类
public static void harmonicDetrend(List<double[]> set) {
HarmonicCurveFitter p = HarmonicCurveFitter.create();
WeightedObservedPoints wop = new WeightedObservedPoints();
for(int i = 0; i < set.size(); i++) {
wop.add(set.get(i)[0], set.get(i)[1]);
}
double[] coeff = p.fit(wop.toList());
for(int h = 0; h < set.size(); h++) {
double val = set.get(h)[0];
double off = coeff[0] * Math.sin(2*Math.PI*coeff[1]*val + coeff[2]);
set.set(h, new double[]{val, set.get(h)[1]-off});
}
}