An abstract class for enumerating pseudo-prime numbers.
Concrete subclasses should override succ, next, rewind.
# File lib/prime.rb, line 335 def initialize(ubound = nil) @ubound = ubound end
# File lib/prime.rb, line 367 def each return self.dup unless block_given? if @ubound last_value = nil loop do prime = succ break last_value if prime > @ubound last_value = yield prime end else loop do yield succ end end end
Iterates the given block for each prime number.
# File lib/prime.rb, line 355 def next raise NotImplementedError, "need to define `next'" end
alias of succ
.
# File lib/prime.rb, line 362 def rewind raise NotImplementedError, "need to define `rewind'" end
Rewinds the internal position for enumeration.
See Enumerator
#rewind.
# File lib/prime.rb, line 402 def size Float::INFINITY end
# File lib/prime.rb, line 350 def succ raise NotImplementedError, "need to define `succ'" end
returns the next pseudo-prime number, and move the internal position forward.
PseudoPrimeGenerator
#succ raises NotImplementedError
.
# File lib/prime.rb, line 342 def upper_bound @ubound end
# File lib/prime.rb, line 339 def upper_bound=(ubound) @ubound = ubound end
# File lib/prime.rb, line 384 def with_index(offset = 0, &block) return enum_for(:with_index, offset) { Float::INFINITY } unless block return each_with_index(&block) if offset == 0 each do |prime| yield prime, offset offset += 1 end end
see Enumerator
#with_index.
# File lib/prime.rb, line 395 def with_object(obj) return enum_for(:with_object, obj) { Float::INFINITY } unless block_given? each do |prime| yield prime, obj end end
see Enumerator
#with_object.
Ruby Core © 1993–2020 Yukihiro Matsumoto
Licensed under the Ruby License.
Ruby Standard Library © contributors
Licensed under their own licenses.