[jvm-packages] Avoid loosing precision when computing probabilities by converting to Double early (#3576)
This commit is contained in:
parent
ce0f0568a6
commit
2b7a1c5780
@ -411,20 +411,15 @@ class XGBoostClassificationModel private[ml](
|
||||
}
|
||||
|
||||
val probabilityUDF = udf { probability: mutable.WrappedArray[Float] =>
|
||||
if (numClasses == 2) {
|
||||
Vectors.dense(Array(1 - probability(0), probability(0)).map(_.toDouble))
|
||||
} else {
|
||||
Vectors.dense(probability.map(_.toDouble).toArray)
|
||||
}
|
||||
val prob = probability.map(_.toDouble).toArray
|
||||
val probabilities = if (numClasses == 2) Array(1.0 - prob(0), prob(0)) else prob
|
||||
Vectors.dense(probabilities)
|
||||
}
|
||||
|
||||
val predictUDF = udf { probability: mutable.WrappedArray[Float] =>
|
||||
// From XGBoost probability to MLlib prediction
|
||||
val probabilities = if (numClasses == 2) {
|
||||
Array(1 - probability(0), probability(0)).map(_.toDouble)
|
||||
} else {
|
||||
probability.map(_.toDouble).toArray
|
||||
}
|
||||
val prob = probability.map(_.toDouble).toArray
|
||||
val probabilities = if (numClasses == 2) Array(1.0 - prob(0), prob(0)) else prob
|
||||
probability2prediction(Vectors.dense(probabilities))
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user