the-algorithm/home-mixer/server/src/main/scala/com/twitter/home_mixer/functional_component/filter/DropMaxCandidatesFilter.scala

28 lines
1.1 KiB
Scala
Raw Normal View History

package com.twitter.home_mixer.functional_component.filter
import com.twitter.product_mixer.core.functional_component.filter.Filter
import com.twitter.product_mixer.core.functional_component.filter.FilterResult
import com.twitter.product_mixer.core.model.common.CandidateWithFeatures
import com.twitter.product_mixer.core.model.common.UniversalNoun
import com.twitter.product_mixer.core.model.common.identifier.FilterIdentifier
import com.twitter.product_mixer.core.pipeline.PipelineQuery
import com.twitter.stitch.Stitch
import com.twitter.timelines.configapi.FSBoundedParam
case class DropMaxCandidatesFilter[Candidate <: UniversalNoun[Any]](
maxCandidatesParam: FSBoundedParam[Int])
extends Filter[PipelineQuery, Candidate] {
override val identifier: FilterIdentifier = FilterIdentifier("DropMaxCandidates")
override def apply(
query: PipelineQuery,
candidates: Seq[CandidateWithFeatures[Candidate]]
): Stitch[FilterResult[Candidate]] = {
val maxCandidates = query.params(maxCandidatesParam)
val (kept, removed) = candidates.map(_.candidate).splitAt(maxCandidates)
Stitch.value(FilterResult(kept, removed))
}
}