Sha256: 1e3035ccf3c5011b586f65ebbd425436c4cc90aaa5382fb6dab2d6b3b1d9a84d
Contents?: true
Size: 1.44 KB
Versions: 1
Compression:
Stored size: 1.44 KB
Contents
module Picky module Backends class Memory < Backend def create_inverted bundle File::JSON.new bundle.index_path(:inverted) end def create_weights bundle File::JSON.new bundle.index_path(:weights) end def create_similarity bundle File::Marshal.new bundle.index_path(:similarity) end def create_configuration bundle File::JSON.new bundle.index_path(:configuration) end # Returns the result ids for the allocation. # # Sorts the ids by size and & through them in the following order (sizes): # 0. [100_000, 400, 30, 2] # 1. [2, 30, 400, 100_000] # 2. (100_000 & (400 & (30 & 2))) # => result # # Note: Uses a C-optimized intersection routine (in performant.c) # for speed and memory efficiency. # # Note: In the memory based version we ignore the amount and offset hints. # We cannot use the information to speed up the algorithm, unfortunately. # def ids combinations, _, _ return [] if combinations.empty? # Get the ids for each combination. # id_arrays = combinations.inject([]) do |total, combination| total << combination.ids end # Call the optimized C algorithm. # # Note: It orders the passed arrays by size. # Performant::Array.memory_efficient_intersect id_arrays end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
picky-3.1.0 | lib/picky/backends/memory.rb |