[英]calculating kurtosis array[Double] filed in spark scala
如何计算spark中数组场的峰度
spark 内置函数失败的数组字段。
due to data type mismatch: argument 1 requires double type, however, 'SERIES' is of array<double> type.;;
python中的示例
from scipy.stats import kurtosis
kurtosis([1, 2, 3, 4, 5])
-1.3
我使用了内置功能的火花
df.withColumn("newcolumn",when(col("SERIES").isNotNull,kurtosis(columnName))
使用 Twitter 代数包我可以获得峰度值。
import com.twitter.algebird._
val y = List(1, 2, 3, 4, 5)
def getMoments(xs: List[Int]): Moments =
xs.foldLeft(MomentsGroup.zero) { (m, x) =>
MomentsGroup.plus(m, Moments(x))
}
println(getMoments(y).kurtosis) // -1.3
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.