Sha256: 0a23b54ea38c109a24f14df216a5d86301b96e7672f3330058db2ad1d1512ce3
Contents?: true
Size: 1.49 KB
Versions: 3
Compression:
Stored size: 1.49 KB
Contents
module Picky module Query # Combinations represent an ordered list of Combination s. # # Combinations contain methods for calculating score (including # the boost) and ids for each of its Combination s. # # They are the core of an Allocation. # An Allocation consists of a number of Combinations. # class Combinations attr_reader :combinations forward :empty?, :inject, :to => :@combinations def initialize combinations = [] @combinations = combinations end # Sums up the weights of the combinations. # # Note: Optimized sum(&:weight) away – ~3% improvement. # def score @combinations.inject(0) { |total, combination| total + combination.weight } end def boost_for weights weights.boost_for @combinations end # Filters the tokens and categories such that categories # that are passed in, are removed. # # Note: This method is not totally independent of the calculate_ids one. # Since identifiers are only nullified, we need to not include the # ids that have an associated identifier that is nil. # def remove categories = [] @combinations.reject! { |combination| categories.include?(combination.category) } end # # def to_result @combinations.map &:to_result end # # def to_s @combinations.to_s end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
picky-4.12.4 | lib/picky/query/combinations.rb |
picky-4.12.3 | lib/picky/query/combinations.rb |
picky-4.12.2 | lib/picky/query/combinations.rb |