On this page
class Prime::PseudoPrimeGenerator
An abstract class for enumerating pseudo-prime numbers.
Concrete subclasses should override succ, next, rewind.
Public Class Methods
# File lib/prime.rb, line 237
def initialize(ubound = nil)
@ubound = ubound
end
Public Instance Methods
# File lib/prime.rb, line 269
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 257
def next
raise NotImplementedError, "need to define `next'"
end
alias of succ
.
# File lib/prime.rb, line 264
def rewind
raise NotImplementedError, "need to define `rewind'"
end
Rewinds the internal position for enumeration.
See Enumerator
#rewind.
# File lib/prime.rb, line 304
def size
Float::INFINITY
end
# File lib/prime.rb, line 252
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 244
def upper_bound
@ubound
end
# File lib/prime.rb, line 241
def upper_bound=(ubound)
@ubound = ubound
end
# File lib/prime.rb, line 286
def with_index(offset = 0)
return enum_for(:with_index, offset) { Float::INFINITY } unless block_given?
return each_with_index(&proc) if offset == 0
each do |prime|
yield prime, offset
offset += 1
end
end
see Enumerator
#with_index.
# File lib/prime.rb, line 297
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–2017 Yukihiro Matsumoto
Licensed under the Ruby License.
Ruby Standard Library © contributors
Licensed under their own licenses.