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


Java Parameterization.reportError方法代碼示例

本文整理匯總了Java中de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization.reportError方法的典型用法代碼示例。如果您正苦於以下問題:Java Parameterization.reportError方法的具體用法?Java Parameterization.reportError怎麽用?Java Parameterization.reportError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization的用法示例。


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

示例1: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  IntParameter dimlatP = new IntParameter(LATDIM_ID) //
      .addConstraint(CommonConstraints.GREATER_EQUAL_ZERO_INT);
  if(config.grab(dimlatP)) {
    dimlat = dimlatP.getValue();
  }
  IntParameter dimlngP = new IntParameter(LNGDIM_ID) //
      .addConstraint(CommonConstraints.GREATER_EQUAL_ZERO_INT);
  if(config.grab(dimlngP)) {
    dimlng = dimlngP.getValue();
  }
  // Non-formalized parameter constraint:
  if(dimlat == dimlng) {
    config.reportError(new WrongParameterValueException("Parameters " + dimlatP.getName() + " and " + dimlngP.getName() + " should be different columns."));
  }
  ObjectParameter<EarthModel> modelP = new ObjectParameter<>(EarthModel.MODEL_ID, EarthModel.class, SphericalVincentyEarthModel.class);
  if(config.grab(modelP)) {
    model = modelP.instantiateClass(config);
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:23,代碼來源:DimensionSelectingLatLngDistanceFunction.java

示例2: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  DoubleListParameter minimaP = new DoubleListParameter(MINIMA_ID) //
      .setOptional(true);
  if(config.grab(minimaP)) {
    minima = minimaP.getValue().clone();
  }
  DoubleListParameter maximaP = new DoubleListParameter(MAXIMA_ID) //
      .setOptional(!minimaP.isDefined());
  if(config.grab(maximaP)) {
    maxima = maximaP.getValue().clone();
  }
  // Non-formalized parameter constraint:
  if(minima != null && maxima != null && minima.length != maxima.length) {
    config.reportError(new WrongParameterValueException("Parameters " + minimaP.getName() + " and " + maximaP.getName() + " must have the same number of values."));
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:19,代碼來源:AttributeWiseMinMaxNormalization.java

示例3: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  DoubleListParameter meanP = new DoubleListParameter(MEAN_ID) //
      .setOptional(true);
  if(config.grab(meanP)) {
    mean = meanP.getValue().clone();
  }
  DoubleListParameter stddevP = new DoubleListParameter(STDDEV_ID) //
      .setOptional(!meanP.isDefined());
  if(config.grab(stddevP)) {
    stddev = stddevP.getValue().clone();

    for(double d : stddev) {
      if(d == 0.) {
        config.reportError(new WrongParameterValueException("Standard deviations must not be 0."));
      }
    }
  }
  // Non-formalized parameter constraint:
  if(mean != null && stddev != null && mean.length != stddev.length) {
    config.reportError(new WrongParameterValueException("Parameters " + meanP.getName() + " and " + stddevP.getName() + " must have the same number of values."));
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:25,代碼來源:AttributeWiseVarianceNormalization.java

示例4: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  DoubleParameter minP = new DoubleParameter(MIN_ID, 0.);
  if(config.grab(minP)) {
    min = minP.doubleValue();
  }
  DoubleParameter maxP = new DoubleParameter(MAX_ID, 1.);
  if(config.grab(maxP)) {
    max = maxP.doubleValue();
  }
  // Non-formalized parameter constraint: min < max
  if(min >= max) {
    config.reportError(new WrongParameterValueException("Parameter " + minP.getName() + " must be less than " + maxP.getName()));
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:17,代碼來源:InstanceMinMaxNormalization.java

示例5: instantiateClasses

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
public List<C> instantiateClasses(Parameterization config) {
  if(instances == null) {
    // instantiateClasses will descend itself.
    instances = super.instantiateClasses(config);
  }
  else {
    Parameterization cfg = null;
    for(int i = 0; i < instances.size(); i++) {
      if(instances.get(i) == null) {
        Class<? extends C> cls = getValue().get(i);
        try {
          // Descend at most once, and only when needed
          cfg = (cfg == null) ? config.descend(this) : null;
          C instance = ClassGenericsUtil.tryInstantiate(restrictionClass, cls, cfg);
          instances.set(i, instance);
        }
        catch(Exception e) {
          config.reportError(new WrongParameterValueException(this, cls.getName(), e.getMessage(), e));
        }
      }
    }
  }
  return new ArrayList<>(instances);
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:26,代碼來源:ObjectListParameter.java

示例6: instantiateClasses

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
/**
 * Returns a list of new instances for the value (i.e., the class name) of
 * this class list parameter. The instances have the type of the restriction
 * class of this class list parameter.
 * <p/>
 * If the Class for the class names is not found, the instantiation is tried
 * using the package of the restriction class as package of the class name.
 *
 * @param config Parameterization to use (if Parameterizable))
 * @return a list of new instances for the value of this class list parameter
 */
public List<C> instantiateClasses(Parameterization config) {
  config = config.descend(this);
  List<C> instances = new ArrayList<>();
  if(getValue() == null) {
    config.reportError(new UnspecifiedParameterException(this));
    return instances; // empty list.
  }

  for(Class<? extends C> cls : getValue()) {
    // NOTE: There is a duplication of this code in ObjectListParameter - keep
    // in sync!
    try {
      instances.add(ClassGenericsUtil.tryInstantiate(restrictionClass, cls, config));
    }
    catch(Exception e) {
      config.reportError(new WrongParameterValueException(this, cls.getName(), e.getMessage(), e));
    }
  }
  return instances;
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:32,代碼來源:ClassListParameter.java

示例7: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);

  DoubleParameter t1P = new DoubleParameter(T1_ID);
  if(config.grab(t1P)) {
    t1 = t1P.doubleValue();
  }

  DoubleParameter t2P = new DoubleParameter(T2_ID);
  if(config.grab(t2P)) {
    t2 = t2P.doubleValue();
  }
  // Non-formalized parameter constraint: t1 >= t2
  if(t1 < t2) {
    config.reportError(new WrongParameterValueException("Parameter " + t1P.getName() + " should be at least " + t2P.getName()));
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:19,代碼來源:CanopyPreClustering.java

示例8: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  IntParameter samplingP = new IntParameter(SAMPLING_ID, DEFAULT_SAMPLE_SIZE) //
  .addConstraint(CommonConstraints.GREATER_EQUAL_MINUSONE_INT);
  if(config.grab(samplingP)) {
    samplesize = samplingP.intValue();
  }
  StringParameter stylelibP = new StringParameter(STYLELIB_ID, PropertiesBasedStyleLibrary.DEFAULT_SCHEME_FILENAME);
  if(config.grab(stylelibP)) {
    String filename = stylelibP.getValue();
    try {
      stylelib = new PropertiesBasedStyleLibrary(filename, filename);
    }
    catch(AbortException e) {
      config.reportError(new WrongParameterValueException(stylelibP, filename, e.getMessage(), e));
    }
  }
  PatternParameter enablevisP = new PatternParameter(ENABLEVIS_ID) //
  .setOptional(true);
  if(config.grab(enablevisP) && !"all".equals(enablevisP.getValueAsString())) {
    enableVisualizers = enablevisP.getValue();
  }
  MergedParameterization merged = new MergedParameterization(config);
  factories = collectFactorys(merged, enableVisualizers);
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:27,代碼來源:VisualizerParameterizer.java

示例9: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  final FileParameter param = new FileParameter(MATRIX_ID, FileParameter.FileType.INPUT_FILE);
  if(config.grab(param)) {
    File matrixfile = param.getValue();
    try {
      cache = new OnDiskUpperTriangleMatrix(matrixfile, FLOAT_CACHE_MAGIC, 0, ByteArrayUtil.SIZE_FLOAT, false);
    }
    catch(IOException e) {
      config.reportError(new WrongParameterValueException(param, matrixfile.toString(), e.getMessage(), e));
    }
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:15,代碼來源:DiskCacheBasedFloatDistanceFunction.java

示例10: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  final FileParameter param = new FileParameter(MATRIX_ID, FileParameter.FileType.INPUT_FILE);
  if(config.grab(param)) {
    File matrixfile = param.getValue();
    try {
      cache = new OnDiskUpperTriangleMatrix(matrixfile, DOUBLE_CACHE_MAGIC, 0, ByteArrayUtil.SIZE_DOUBLE, false);
    }
    catch(IOException e) {
      config.reportError(new WrongParameterValueException(param, matrixfile.toString(), e.getMessage(), e));
    }
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:15,代碼來源:DiskCacheBasedDoubleDistanceFunction.java

示例11: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  EnumParameter<ScalingReference> scalingReferenceP = new EnumParameter<>(SCALINGREFERENCE_ID, ScalingReference.class, ScalingReference.UNITCUBE);
  if(config.grab(scalingReferenceP)) {
    scalingreference = scalingReferenceP.getValue();
  }
  EnumParameter<NoiseDistribution> noisedistributionP = new EnumParameter<>(NOISEDISTRIBUTION_ID, NoiseDistribution.class, NoiseDistribution.UNIFORM);
  if(config.grab(noisedistributionP)) {
    noisedistribution = noisedistributionP.getValue();
  }
  DoubleParameter percentageP = new DoubleParameter(PERCENTAGE_ID, .01) //
      .addConstraint(CommonConstraints.GREATER_THAN_ZERO_DOUBLE) //
      .addConstraint(CommonConstraints.LESS_EQUAL_ONE_DOUBLE);
  if(config.grab(percentageP)) {
    percentage = percentageP.getValue();
  }
  LongParameter seedP = new LongParameter(SEED_ID) //
      .setOptional(true);
  if(config.grab(seedP)) {
    seed = seedP.getValue();
  }
  DoubleListParameter minimaP = new DoubleListParameter(MINIMA_ID) //
      .setOptional(true);
  if(config.grab(minimaP)) {
    minima = minimaP.getValue().clone();
  }
  DoubleListParameter maximaP = new DoubleListParameter(MAXIMA_ID) //
      .setOptional(!minimaP.isDefined());
  if(config.grab(maximaP)) {
    maxima = maximaP.getValue().clone();
  }
  // Non-formalized parameter constraint:
  if(minima != null && maxima != null && minima.length != maxima.length) {
    config.reportError(new WrongParameterValueException("Parameters " + minimaP.getName() + " and " + maximaP.getName() + " must have the same number of values."));
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:38,代碼來源:PerturbationFilter.java

示例12: instantiateClass

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
/**
 * Returns a new instance for the value (i.e., the class name) of this class
 * parameter. The instance has the type of the restriction class of this class
 * parameter.
 * <p/>
 * If the Class for the class name is not found, the instantiation is tried
 * using the package of the restriction class as package of the class name.
 *
 * @param config Parameterization to use (if Parameterizable))
 * @return a new instance for the value of this class parameter
 */
public C instantiateClass(Parameterization config) {
  if(getValue() == null /* && !optionalParameter */) {
    config.reportError(new UnspecifiedParameterException(this));
    return null;
  }
  try {
    config = config.descend(this);
    return ClassGenericsUtil.tryInstantiate(restrictionClass, getValue(), config);
  }
  catch(ClassInstantiationException e) {
    config.reportError(new WrongParameterValueException(this, getValue().getCanonicalName(), "Error instantiating class.", e));
    return null;
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:26,代碼來源:ClassParameter.java

示例13: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  // Neighborhood predicate
  ObjectParameter<NeighborPredicate<?>> npredOpt = new ObjectParameter<>(NEIGHBORHOODPRED_ID, NeighborPredicate.class, EpsilonNeighborPredicate.class);
  if(config.grab(npredOpt)) {
    npred = npredOpt.instantiateClass(config);
  }

  // Core point predicate
  ObjectParameter<CorePredicate<?>> corepredOpt = new ObjectParameter<>(COREPRED_ID, CorePredicate.class, MinPtsCorePredicate.class);
  if(config.grab(corepredOpt)) {
    corepred = corepredOpt.instantiateClass(config);
  }

  if(npred != null && corepred != null) {
    // Ignore the generic, we do a run-time test below:
    @SuppressWarnings("unchecked")
    CorePredicate<Object> cp = (CorePredicate<Object>) corepred;
    if(!cp.acceptsType(npred.getOutputType())) {
      config.reportError(new WrongParameterValueException(corepredOpt, corepredOpt.getValueAsString(), "Neighbor predicate and core predicate are not compatible."));
    }
  }

  Flag coremodelOpt = new Flag(COREMODEL_ID);
  if(config.grab(coremodelOpt)) {
    coremodel = coremodelOpt.isTrue();
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:29,代碼來源:ParallelGeneralizedDBSCAN.java

示例14: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  // Neighborhood predicate
  ObjectParameter<NeighborPredicate<?>> npredOpt = new ObjectParameter<>(NEIGHBORHOODPRED_ID, NeighborPredicate.class, EpsilonNeighborPredicate.class);
  if(config.grab(npredOpt)) {
    npred = npredOpt.instantiateClass(config);
  }

  // Core point predicate
  ObjectParameter<CorePredicate<?>> corepredOpt = new ObjectParameter<>(COREPRED_ID, CorePredicate.class, MinPtsCorePredicate.class);
  if(config.grab(corepredOpt)) {
    corepred = corepredOpt.instantiateClass(config);
  }
  if(npred != null && corepred != null) {
    // Ignore the generic, we do a run-time test below:
    @SuppressWarnings("unchecked")
    CorePredicate<Object> cp = (CorePredicate<Object>) corepred;
    if(!cp.acceptsType(npred.getOutputType())) {
      config.reportError(new WrongParameterValueException(corepredOpt, corepredOpt.getValueAsString(), "Neighbor predicate and core predicate are not compatible."));
    }
  }

  Flag coremodelOpt = new Flag(COREMODEL_ID);
  if(config.grab(coremodelOpt)) {
    coremodel = coremodelOpt.isTrue();
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:28,代碼來源:GeneralizedDBSCAN.java

示例15: makeOptions

import de.lmu.ifi.dbs.elki.utilities.optionhandling.parameterization.Parameterization; //導入方法依賴的package包/類
@Override
protected void makeOptions(Parameterization config) {
  super.makeOptions(config);
  ObjectParameter<ClusteringAlgorithm<C>> palgorithm = new ObjectParameter<>(AbstractAlgorithm.ALGORITHM_ID, ClusteringAlgorithm.class);
  if(config.grab(palgorithm)) {
    inner = palgorithm.instantiateClass(config);
    if(inner != null && inner.getInputTypeRestriction().length > 0 && //
    !inner.getInputTypeRestriction()[0].isAssignableFromType(TypeUtil.NUMBER_VECTOR_FIELD)) {
      config.reportError(new WrongParameterValueException(palgorithm, palgorithm.getValueAsString(), "The inner clustering algorithm (as configured) does not accept numerical vectors: " + inner.getInputTypeRestriction()[0]));
    }
  }
}
 
開發者ID:elki-project,項目名稱:elki,代碼行數:13,代碼來源:CenterOfMassMetaClustering.java


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