All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.microsoft.ml.spark.core.metrics.MetricConstants.scala Maven / Gradle / Ivy

The newest version!
// Copyright (C) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License. See LICENSE in project root for information.

package com.microsoft.ml.spark.core.metrics

/** Contains constants used by modules for metrics. */
object MetricConstants {
  // Regression metrics
  val MseSparkMetric  = "mse"
  val RmseSparkMetric = "rmse"
  val R2SparkMetric   = "r2"
  val MaeSparkMetric  = "mae"
  val RegressionMetricsName = "regression"

  val RegressionMetrics = Set(MseSparkMetric, RmseSparkMetric, R2SparkMetric,
    MaeSparkMetric, RegressionMetricsName)

  // Binary Classification metrics
  val AreaUnderROCMetric   = "areaUnderROC"
  val AucSparkMetric       = "AUC"
  val AccuracySparkMetric  = "accuracy"
  val PrecisionSparkMetric = "precision"
  val RecallSparkMetric    = "recall"
  val ClassificationMetricsName = "classification"

  val ClassificationMetrics = Set(AreaUnderROCMetric, AucSparkMetric, AccuracySparkMetric,
    PrecisionSparkMetric, RecallSparkMetric, ClassificationMetricsName)

  val AllSparkMetrics      = "all"

  // Regression column names
  val MseColumnName  = "mean_squared_error"
  val RmseColumnName = "root_mean_squared_error"
  val R2ColumnName   = "R^2"
  val MaeColumnName  = "mean_absolute_error"

  // Binary Classification column names
  val AucColumnName = "AUC"

  // Binary and Multiclass (micro-averaged) column names
  val PrecisionColumnName = "precision"
  val RecallColumnName    = "recall"
  val AccuracyColumnName  = "accuracy"

  // Multiclass Classification column names
  val AverageAccuracy        = "average_accuracy"
  val MacroAveragedRecall    = "macro_averaged_recall"
  val MacroAveragedPrecision = "macro_averaged_precision"

  val ConfusionMatrix = "confusion_matrix"

  // Metric to column name
  val MetricToColumnName = Map(AccuracySparkMetric -> AccuracyColumnName,
    PrecisionSparkMetric -> PrecisionColumnName,
    RecallSparkMetric    -> RecallColumnName,
    MseSparkMetric       -> MseColumnName,
    RmseSparkMetric      -> RmseColumnName,
    R2SparkMetric        -> R2ColumnName,
    MaeSparkMetric       -> MaeColumnName)

  val ClassificationColumns = List(AccuracyColumnName, PrecisionColumnName, RecallColumnName)

  val RegressionColumns = List(MseColumnName, RmseColumnName, R2ColumnName, MaeColumnName)

  val ClassificationEvaluationType = "Classification"
  val EvaluationType = "evaluation_type"

  val FpRateROCColumnName = "false_positive_rate"
  val TpRateROCColumnName = "true_positive_rate"

  val FpRateROCLog = "fpr"
  val TpRateROCLog = "tpr"

  val BinningThreshold = 1000

  // Regression per instance metrics
  val L1LossMetric  = "L1_loss"
  val L2LossMetric  = "L2_loss"

  val RegressionPerInstanceMetrics = Set(RegressionMetricsName)

  // Classification per instance metrics
  val LogLossMetric = "log_loss"

  val ClassificationPerInstanceMetrics = Set(ClassificationMetricsName)

  val FindBestModelMetrics =
    Set(MetricConstants.MseSparkMetric,
        MetricConstants.RmseSparkMetric,
        MetricConstants.R2SparkMetric,
        MetricConstants.MaeSparkMetric,
        MetricConstants.AccuracySparkMetric,
        MetricConstants.PrecisionSparkMetric,
        MetricConstants.RecallSparkMetric,
        MetricConstants.AucSparkMetric)

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy