summaryrefslogtreecommitdiff
path: root/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta
diff options
context:
space:
mode:
Diffstat (limited to 'src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta')
-rw-r--r--src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/BestFitEstimator.java10
-rw-r--r--src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/TrimmedEstimator.java15
-rw-r--r--src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/WinsorisingEstimator.java17
-rw-r--r--src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/package-info.java23
4 files changed, 45 insertions, 20 deletions
diff --git a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/BestFitEstimator.java b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/BestFitEstimator.java
index dee3cbb3..8d57e0b7 100644
--- a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/BestFitEstimator.java
+++ b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/BestFitEstimator.java
@@ -87,11 +87,11 @@ import de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizer;
*
* @author Erich Schubert
*
- * @apiviz.composedOf MOMDistributionEstimator
- * @apiviz.composedOf MADDistributionEstimator
- * @apiviz.composedOf LMMDistributionEstimator
- * @apiviz.composedOf LogMOMDistributionEstimator
- * @apiviz.composedOf LogMADDistributionEstimator
+ * @apiviz.uses MOMDistributionEstimator
+ * @apiviz.uses MADDistributionEstimator
+ * @apiviz.uses LMMDistributionEstimator
+ * @apiviz.uses LogMOMDistributionEstimator
+ * @apiviz.uses LogMADDistributionEstimator
*/
public class BestFitEstimator implements DistributionEstimator<Distribution> {
/**
diff --git a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/TrimmedEstimator.java b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/TrimmedEstimator.java
index 5c1cf448..a78d9760 100644
--- a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/TrimmedEstimator.java
+++ b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/TrimmedEstimator.java
@@ -31,8 +31,7 @@ import de.lmu.ifi.dbs.elki.utilities.datastructures.arraylike.ArrayLikeUtil;
import de.lmu.ifi.dbs.elki.utilities.datastructures.arraylike.NumberArrayAdapter;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizer;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.OptionID;
-import de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints.GreaterConstraint;
-import de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints.LessConstraint;
+import de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints.CommonConstraints;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.DoubleParameter;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.ObjectParameter;
@@ -43,6 +42,8 @@ import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.ObjectParameter;
*
* @author Erich Schubert
*
+ * @apiviz.uses DistributionEstimator
+ *
* @param <D> Distribution type
*/
public class TrimmedEstimator<D extends Distribution> implements DistributionEstimator<D> {
@@ -75,7 +76,7 @@ public class TrimmedEstimator<D extends Distribution> implements DistributionEst
final int cut = ((int) (len * trim)) >> 1;
// X positions of samples
double[] x = new double[len];
- for (int i = 0; i < len; i++) {
+ for(int i = 0; i < len; i++) {
final double val = adapter.getDouble(data, i);
x[i] = val;
}
@@ -136,14 +137,14 @@ public class TrimmedEstimator<D extends Distribution> implements DistributionEst
protected void makeOptions(Parameterization config) {
super.makeOptions(config);
ObjectParameter<DistributionEstimator<D>> innerP = new ObjectParameter<>(INNER_ID, DistributionEstimator.class);
- if (config.grab(innerP)) {
+ if(config.grab(innerP)) {
inner = innerP.instantiateClass(config);
}
DoubleParameter trimP = new DoubleParameter(TRIM_ID);
- trimP.addConstraint(new GreaterConstraint(0.));
- trimP.addConstraint(new LessConstraint(0.5));
- if (config.grab(trimP)) {
+ trimP.addConstraint(CommonConstraints.GREATER_THAN_ZERO_DOUBLE);
+ trimP.addConstraint(CommonConstraints.LESS_THAN_HALF_DOUBLE);
+ if(config.grab(trimP)) {
trim = trimP.doubleValue();
}
}
diff --git a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/WinsorisingEstimator.java b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/WinsorisingEstimator.java
index 0ef6318d..47fe427e 100644
--- a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/WinsorisingEstimator.java
+++ b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/WinsorisingEstimator.java
@@ -31,8 +31,7 @@ import de.lmu.ifi.dbs.elki.utilities.datastructures.arraylike.NumberArrayAdapter
import de.lmu.ifi.dbs.elki.utilities.documentation.Reference;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.AbstractParameterizer;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.OptionID;
-import de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints.GreaterConstraint;
-import de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints.LessConstraint;
+import de.lmu.ifi.dbs.elki.utilities.optionhandling.constraints.CommonConstraints;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.DoubleParameter;
import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.ObjectParameter;
@@ -53,6 +52,8 @@ import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameters.ObjectParameter;
*
* @author Erich Schubert
*
+ * @apiviz.uses DistributionEstimator
+ *
* @param <D> Distribution type
*/
@Reference(authors = "C. Hastings, F. Mosteller, J. W. Tukey, C. P. Winsor", title = "Low moments for small samples: a comparative study of order statistics", booktitle = "The Annals of Mathematical Statistics, 18(3)", url = "http://dx.doi.org/10.1214/aoms/1177730388")
@@ -86,7 +87,7 @@ public class WinsorisingEstimator<D extends Distribution> implements Distributio
final int cut = ((int) (len * winsorize)) >> 1;
// X positions of samples
double[] x = new double[len];
- for (int i = 0; i < len; i++) {
+ for(int i = 0; i < len; i++) {
final double val = adapter.getDouble(data, i);
x[i] = val;
}
@@ -95,7 +96,7 @@ public class WinsorisingEstimator<D extends Distribution> implements Distributio
double max = QuickSelect.quickSelect(x, cut, len, len - 1 - cut);
// Winsorize by replacing the smallest and largest values.
// QuickSelect ensured that these are correctly in place.
- for (int i = 0, j = len - 1; i < cut; i++, j--) {
+ for(int i = 0, j = len - 1; i < cut; i++, j--) {
x[i] = min;
x[j] = max;
}
@@ -146,14 +147,14 @@ public class WinsorisingEstimator<D extends Distribution> implements Distributio
protected void makeOptions(Parameterization config) {
super.makeOptions(config);
ObjectParameter<DistributionEstimator<D>> innerP = new ObjectParameter<>(INNER_ID, DistributionEstimator.class);
- if (config.grab(innerP)) {
+ if(config.grab(innerP)) {
inner = innerP.instantiateClass(config);
}
DoubleParameter trimP = new DoubleParameter(WINSORIZE_ID);
- trimP.addConstraint(new GreaterConstraint(0.));
- trimP.addConstraint(new LessConstraint(0.5));
- if (config.grab(trimP)) {
+ trimP.addConstraint(CommonConstraints.GREATER_THAN_ZERO_DOUBLE);
+ trimP.addConstraint(CommonConstraints.LESS_THAN_HALF_DOUBLE);
+ if(config.grab(trimP)) {
winsorize = trimP.doubleValue();
}
}
diff --git a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/package-info.java b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/package-info.java
index c4b75f2d..c06be5d7 100644
--- a/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/package-info.java
+++ b/src/de/lmu/ifi/dbs/elki/math/statistics/distribution/estimator/meta/package-info.java
@@ -3,4 +3,27 @@
*
* @author Erich Schubert
*/
+
+/*
+ This file is part of ELKI:
+ Environment for Developing KDD-Applications Supported by Index-Structures
+
+ Copyright (C) 2013
+ Ludwig-Maximilians-Universität München
+ Lehr- und Forschungseinheit für Datenbanksysteme
+ ELKI Development Team
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Affero General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU Affero General Public License for more details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
package de.lmu.ifi.dbs.elki.math.statistics.distribution.estimator.meta; \ No newline at end of file