Support for the Ruby 2.4 series has ended. See here for reference.
Object
Iterates the given block over all prime numbers.
See Prime
#each for more details.
# File prime.rb, line 49 def Integer.each_prime(ubound, &block) # :yields: prime Prime.each(ubound, &block) end
Re-composes a prime factorization and returns the product.
See Prime#int_from_prime_division
for more details.
# File prime.rb, line 22 def Integer.from_prime_division(pd) Prime.int_from_prime_division(pd) end
Returns true if self
is a prime number, else returns false.
# File prime.rb, line 34 def prime? return self >= 2 if self <= 3 return true if self == 5 return false unless 30.gcd(self) == 1 (7..Math.sqrt(self).to_i).step(30) do |p| return false if self%(p) == 0 || self%(p+4) == 0 || self%(p+6) == 0 || self%(p+10) == 0 || self%(p+12) == 0 || self%(p+16) == 0 || self%(p+22) == 0 || self%(p+24) == 0 end true end
Returns the factorization of self
.
See Prime#prime_division
for more details.
# File prime.rb, line 29 def prime_division(generator = Prime::Generator23.new) Prime.prime_division(self, generator) end