Sha256: b31387c5263b8b1c018806d8d4ede8096fff95896e07efb04a681f3221154fa8
Contents?: true
Size: 1.78 KB
Versions: 19
Compression:
Stored size: 1.78 KB
Contents
require 'epitools/basetypes' class Array alias_method :"original_*_for_cartesian_*", :* # # Overloaded * operator. # # Original behaviour: # array * number == <number> copies of array # Extra behaviour: # array * array = Cartesian product of the two arrays # def *(other) case other when Array # cross-product result = [] (0...self.size).each do |a| (0...other.size).each do |b| result << [self[a], other[b]] end end result else send(:"original_*_for_cartesian_*", other) end end # # Multiply the array by itself 'exponent'-times. # def **(exponent) ([self] * exponent).foldl(:*) end end # # Returns all the `size`-sized selections of the elements from an array. # # I can't remember why I wrote it like this, but the array you want to # permute is passed in as a block. For example: # # >> perms(1) { [1,2,3,4] } # => [[1], [2], [3], [4]] # >> perms(2) { [1,2,3,4] } # => [[1, 1], [1, 2], [1, 3], [1, 4], [2, 1], [2, 2], [2, 3], [2, 4], # [3, 1], [3, 2], [3, 3], [3, 4], [4, 1], [4, 2], [4, 3], [4, 4]] # # The block also gets passed a parameter: the depth of the recursion. # I can't remember why I did that either! :D # def perms(size, n=0, stack=[], &block) ps = yield(n) results = [] if n >= size results << stack else ps.each do |p| results += perms(size, n+1, stack + [p], &block) end end results end if $0 == __FILE__ puts "-------------- foldl ---" p [:sum, [1,1,1].foldl(:+)] p ["[[1,2],[3]].foldl(:+)", [[1,2],[3]].foldl(:+)] p [[0,1],[0,1]].foldl(:*) puts "-------------- cartesian product ---" p ["[0,1]*[2,3]",[0,1]*[2,3]] puts "-------------- cartesian exponent ---" p [0,1]**3 end
Version data entries
19 entries across 19 versions & 1 rubygems