mirror of
https://github.com/twitter/the-algorithm.git
synced 2024-06-27 21:46:04 +02:00
28 lines
1.1 KiB
Scala
28 lines
1.1 KiB
Scala
![]() |
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))
|
||
|
}
|
||
|
}
|