Issue/Bug 在 Spark 版本 3.0.0 中加载和应用 MultilayerPerceptronClassifier 时

Issue/Bug when loading and applying MultilayerPerceptronClassifier in Spark Version 3.0.0

IllegalArgumentException: MultilayerPerceptronClassifier_... 给定无效值的参数求解器 auto

我相信我在 spark 3.0.0、scala 2.1.2 中加载 MultilayerPerceptronClassificationModel 时发现了一个错误,我已经测试过并且可以看到至少在 Spark 2.4.3、Scala 2.11 中不存在。 .

我在数据块集群上使用 pyspark 并导入库“from pyspark.ml.classification import MultilayerPerceptronClassificationModel”

当运行 model=MultilayerPerceptronClassificationModel.(“load”) 然后建模。 transform (df) 我收到以下错误:IllegalArgumentException: MultilayerPerceptronClassifier_8055d1368e78 parameter solver given invalid value auto.

这个问题可以通过 运行 spark 文档中给出的示例轻松复制:http://spark.apache.org/docs/latest/ml-classification-regression.html#multilayer-perceptron-classifier

然后添加保存模型、加载模型和转换语句:

from pyspark.ml.classification import MultilayerPerceptronClassifier
from pyspark.ml.evaluation import MulticlassClassificationEvaluator

# Load training data
data = spark.read.format("libsvm")\
    .load("data/mllib/sample_multiclass_classification_data.txt")

# Split the data into train and test
splits = data.randomSplit([0.6, 0.4], 1234)
train = splits[0]
test = splits[1]

# specify layers for the neural network:
# input layer of size 4 (features), two intermediate of size 5 and 4
# and output of size 3 (classes)
layers = [4, 5, 4, 3]

# create the trainer and set its parameters
trainer = MultilayerPerceptronClassifier(maxIter=100, layers=layers, blockSize=128, seed=1234)

# train the model
model = trainer.fit(train)

# compute accuracy on the test set
result = model.transform(test)
predictionAndLabels = result.select("prediction", "label")
evaluator = MulticlassClassificationEvaluator(metricName="accuracy")
print("Test set accuracy = " + str(evaluator.evaluate(predictionAndLabels)))

from pyspark.ml.classification import MultilayerPerceptronClassifier, MultilayerPerceptronClassificationModel
model.save(Save_location)
model2. MultilayerPerceptronClassificationModel.load(Save_location)

result_from_loaded = model2.transform(test)

Bug 已确认 Jira 打开::https://issues.apache.org/jira/browse/SPARK-32232