Module: Peach
- Defined in:
- lib/peach.rb
Instance Method Summary collapse
Instance Method Details
#peach(n = nil, &b) ⇒ Object
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 |
# File 'lib/peach.rb', line 26 def peach(n = nil, &b) return [] if n == 0 or size == 0 result = Array.new(size) n ||= $peach_default_threads || size div = (size.to_f/n).ceil return [] if div == 0 threads = [] max = size - 1 offset = 0 for i in (0..n-1) threads << Thread.new(offset - div, offset > max ? max : offset) do |lower, upper| for j in lower..upper yield(slice(j)) end end offset += div end threads.each { |t| t.join } self end |
#pmap(n = nil, &b) ⇒ Object
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'lib/peach.rb', line 51 def pmap(n = nil, &b) return [] if n == 0 n ||= $peach_default_threads || size div = (size.to_f/n).ceil return [] if div == 0 result = Array.new(size) threads = [] max = size - 1 offset = div for i in (0..n-1) threads << Thread.new(offset - div, offset > max ? max : offset) do |lower, upper| for j in lower..upper result[j] = yield(slice(j)) end end offset += div end threads.each { |t| t.join } result end |
#pselect(n = nil, &b) ⇒ Object
77 78 79 |
# File 'lib/peach.rb', line 77 def pselect(n = nil, &b) peach_run(:select, b, n) end |