org.apache.spark.ml.tuning.ParamGridBuilder.scala Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.spark.ml.tuning
import scala.annotation.varargs
import scala.collection.mutable
import org.apache.spark.annotation.{Experimental, Since}
import org.apache.spark.ml.param._
/**
* :: Experimental ::
* Builder for a param grid used in grid search-based model selection.
*/
@Since("1.2.0")
@Experimental
class ParamGridBuilder @Since("1.2.0") {
private val paramGrid = mutable.Map.empty[Param[_], Iterable[_]]
/**
* Sets the given parameters in this grid to fixed values.
*/
@Since("1.2.0")
def baseOn(paramMap: ParamMap): this.type = {
baseOn(paramMap.toSeq: _*)
this
}
/**
* Sets the given parameters in this grid to fixed values.
*/
@Since("1.2.0")
@varargs
def baseOn(paramPairs: ParamPair[_]*): this.type = {
paramPairs.foreach { p =>
addGrid(p.param.asInstanceOf[Param[Any]], Seq(p.value))
}
this
}
/**
* Adds a param with multiple values (overwrites if the input param exists).
*/
@Since("1.2.0")
def addGrid[T](param: Param[T], values: Iterable[T]): this.type = {
paramGrid.put(param, values)
this
}
// specialized versions of addGrid for Java.
/**
* Adds a double param with multiple values.
*/
@Since("1.2.0")
def addGrid(param: DoubleParam, values: Array[Double]): this.type = {
addGrid[Double](param, values)
}
/**
* Adds a int param with multiple values.
*/
@Since("1.2.0")
def addGrid(param: IntParam, values: Array[Int]): this.type = {
addGrid[Int](param, values)
}
/**
* Adds a float param with multiple values.
*/
@Since("1.2.0")
def addGrid(param: FloatParam, values: Array[Float]): this.type = {
addGrid[Float](param, values)
}
/**
* Adds a long param with multiple values.
*/
@Since("1.2.0")
def addGrid(param: LongParam, values: Array[Long]): this.type = {
addGrid[Long](param, values)
}
/**
* Adds a boolean param with true and false.
*/
@Since("1.2.0")
def addGrid(param: BooleanParam): this.type = {
addGrid[Boolean](param, Array(true, false))
}
/**
* Builds and returns all combinations of parameters specified by the param grid.
*/
@Since("1.2.0")
def build(): Array[ParamMap] = {
var paramMaps = Array(new ParamMap)
paramGrid.foreach { case (param, values) =>
val newParamMaps = values.flatMap { v =>
paramMaps.map(_.copy.put(param.asInstanceOf[Param[Any]], v))
}
paramMaps = newParamMaps.toArray
}
paramMaps
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy