GRAYBYTE WORDPRESS FILE MANAGER9704

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/ruby20/lib64/ruby/2.0.0/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/ruby20/lib64/ruby/2.0.0//prime.rb
#
# = prime.rb
#
# Prime numbers and factorization library.
#
# Copyright::
#   Copyright (c) 1998-2008 Keiju ISHITSUKA(SHL Japan Inc.)
#   Copyright (c) 2008 Yuki Sonoda (Yugui) <yugui@yugui.jp>
#
# Documentation::
#   Yuki Sonoda
#

require "singleton"
require "forwardable"

class Integer
  # Re-composes a prime factorization and returns the product.
  #
  # See Prime#int_from_prime_division for more details.
  def Integer.from_prime_division(pd)
    Prime.int_from_prime_division(pd)
  end

  # Returns the factorization of +self+.
  #
  # See Prime#prime_division for more details.
  def prime_division(generator = Prime::Generator23.new)
    Prime.prime_division(self, generator)
  end

  # Returns true if +self+ is a prime number, false for a composite.
  def prime?
    Prime.prime?(self)
  end

  # Iterates the given block over all prime numbers.
  #
  # See +Prime+#each for more details.
  def Integer.each_prime(ubound, &block) # :yields: prime
    Prime.each(ubound, &block)
  end
end

#
# The set of all prime numbers.
#
# == Example
#
#   Prime.each(100) do |prime|
#     p prime  #=> 2, 3, 5, 7, 11, ...., 97
#   end
#
# Prime is Enumerable:
#
#   Prime.first 5 # => [2, 3, 5, 7, 11]
#
# == Retrieving the instance
#
# +Prime+.new is obsolete. Now +Prime+ has the default instance and you can
# access it as +Prime+.instance.
#
# For convenience, each instance method of +Prime+.instance can be accessed
# as a class method of +Prime+.
#
# e.g.
#   Prime.instance.prime?(2)  #=> true
#   Prime.prime?(2)           #=> true
#
# == Generators
#
# A "generator" provides an implementation of enumerating pseudo-prime
# numbers and it remembers the position of enumeration and upper bound.
# Furthermore, it is a external iterator of prime enumeration which is
# compatible to an Enumerator.
#
# +Prime+::+PseudoPrimeGenerator+ is the base class for generators.
# There are few implementations of generator.
#
# [+Prime+::+EratosthenesGenerator+]
#   Uses eratosthenes's sieve.
# [+Prime+::+TrialDivisionGenerator+]
#   Uses the trial division method.
# [+Prime+::+Generator23+]
#   Generates all positive integers which is not divided by 2 nor 3.
#   This sequence is very bad as a pseudo-prime sequence. But this
#   is faster and uses much less memory than other generators. So,
#   it is suitable for factorizing an integer which is not large but
#   has many prime factors. e.g. for Prime#prime? .

class Prime
  include Enumerable
  @the_instance = Prime.new

  # obsolete. Use +Prime+::+instance+ or class methods of +Prime+.
  def initialize
    @generator = EratosthenesGenerator.new
    extend OldCompatibility
    warn "Prime::new is obsolete. use Prime::instance or class methods of Prime."
  end

  class << self
    extend Forwardable
    include Enumerable
    # Returns the default instance of Prime.
    def instance; @the_instance end

    def method_added(method) # :nodoc:
      (class<< self;self;end).def_delegator :instance, method
    end
  end

  # Iterates the given block over all prime numbers.
  #
  # == Parameters
  #
  # +ubound+::
  #   Optional. An arbitrary positive number.
  #   The upper bound of enumeration. The method enumerates
  #   prime numbers infinitely if +ubound+ is nil.
  # +generator+::
  #   Optional. An implementation of pseudo-prime generator.
  #
  # == Return value
  #
  # An evaluated value of the given block at the last time.
  # Or an enumerator which is compatible to an +Enumerator+
  # if no block given.
  #
  # == Description
  #
  # Calls +block+ once for each prime number, passing the prime as
  # a parameter.
  #
  # +ubound+::
  #   Upper bound of prime numbers. The iterator stops after
  #   yields all prime numbers p <= +ubound+.
  #
  # == Note
  #
  # +Prime+.+new+ returns a object extended by +Prime+::+OldCompatibility+
  # in order to compatibility to Ruby 1.8, and +Prime+#each is overwritten
  # by +Prime+::+OldCompatibility+#+each+.
  #
  # +Prime+.+new+ is now obsolete. Use +Prime+.+instance+.+each+ or simply
  # +Prime+.+each+.
  def each(ubound = nil, generator = EratosthenesGenerator.new, &block)
    generator.upper_bound = ubound
    generator.each(&block)
  end


  # Returns true if +value+ is prime, false for a composite.
  #
  # == Parameters
  #
  # +value+:: an arbitrary integer to be checked.
  # +generator+:: optional. A pseudo-prime generator.
  def prime?(value, generator = Prime::Generator23.new)
    value = -value if value < 0
    return false if value < 2
    for num in generator
      q,r = value.divmod num
      return true if q < num
      return false if r == 0
    end
  end

  # Re-composes a prime factorization and returns the product.
  #
  # == Parameters
  # +pd+:: Array of pairs of integers. The each internal
  #        pair consists of a prime number -- a prime factor --
  #        and a natural number -- an exponent.
  #
  # == Example
  # For <tt>[[p_1, e_1], [p_2, e_2], ...., [p_n, e_n]]</tt>, it returns:
  #
  #   p_1**e_1 * p_2**e_2 * .... * p_n**e_n.
  #
  #   Prime.int_from_prime_division([[2,2], [3,1]])  #=> 12
  def int_from_prime_division(pd)
    pd.inject(1){|value, (prime, index)|
      value *= prime**index
    }
  end

  # Returns the factorization of +value+.
  #
  # == Parameters
  # +value+:: An arbitrary integer.
  # +generator+:: Optional. A pseudo-prime generator.
  #               +generator+.succ must return the next
  #               pseudo-prime number in the ascendent
  #               order. It must generate all prime numbers,
  #               but may generate non prime numbers.
  #
  # === Exceptions
  # +ZeroDivisionError+:: when +value+ is zero.
  #
  # == Example
  # For an arbitrary integer:
  #
  #   n = p_1**e_1 * p_2**e_2 * .... * p_n**e_n,
  #
  # prime_division(n) returns:
  #
  #   [[p_1, e_1], [p_2, e_2], ...., [p_n, e_n]].
  #
  #   Prime.prime_division(12) #=> [[2,2], [3,1]]
  #
  def prime_division(value, generator= Prime::Generator23.new)
    raise ZeroDivisionError if value == 0
    if value < 0
      value = -value
      pv = [[-1, 1]]
    else
      pv = []
    end
    for prime in generator
      count = 0
      while (value1, mod = value.divmod(prime)
             mod) == 0
        value = value1
        count += 1
      end
      if count != 0
        pv.push [prime, count]
      end
      break if value1 <= prime
    end
    if value > 1
      pv.push [value, 1]
    end
    return pv
  end

  # An abstract class for enumerating pseudo-prime numbers.
  #
  # Concrete subclasses should override succ, next, rewind.
  class PseudoPrimeGenerator
    include Enumerable

    def initialize(ubound = nil)
      @ubound = ubound
    end

    def upper_bound=(ubound)
      @ubound = ubound
    end
    def upper_bound
      @ubound
    end

    # returns the next pseudo-prime number, and move the internal
    # position forward.
    #
    # +PseudoPrimeGenerator+#succ raises +NotImplementedError+.
    def succ
      raise NotImplementedError, "need to define `succ'"
    end

    # alias of +succ+.
    def next
      raise NotImplementedError, "need to define `next'"
    end

    # Rewinds the internal position for enumeration.
    #
    # See +Enumerator+#rewind.
    def rewind
      raise NotImplementedError, "need to define `rewind'"
    end

    # Iterates the given block for each prime numbers.
    def each(&block)
      return self.dup unless block
      if @ubound
        last_value = nil
        loop do
          prime = succ
          break last_value if prime > @ubound
          last_value = block.call(prime)
        end
      else
        loop do
          block.call(succ)
        end
      end
    end

    # see +Enumerator+#with_index.
    alias with_index each_with_index

    # see +Enumerator+#with_object.
    def with_object(obj)
      return enum_for(:with_object) unless block_given?
      each do |prime|
        yield prime, obj
      end
    end
  end

  # An implementation of +PseudoPrimeGenerator+.
  #
  # Uses +EratosthenesSieve+.
  class EratosthenesGenerator < PseudoPrimeGenerator
    def initialize
      @last_prime = nil
      super
    end

    def succ
      @last_prime = @last_prime ? EratosthenesSieve.instance.next_to(@last_prime) : 2
    end
    def rewind
      initialize
    end
    alias next succ
  end

  # An implementation of +PseudoPrimeGenerator+ which uses
  # a prime table generated by trial division.
  class TrialDivisionGenerator<PseudoPrimeGenerator
    def initialize
      @index = -1
      super
    end

    def succ
      TrialDivision.instance[@index += 1]
    end
    def rewind
      initialize
    end
    alias next succ
  end

  # Generates all integer which are greater than 2 and
  # are not divided by 2 nor 3.
  #
  # This is a pseudo-prime generator, suitable on
  # checking primality of a integer by brute force
  # method.
  class Generator23<PseudoPrimeGenerator
    def initialize
      @prime = 1
      @step = nil
      super
    end

    def succ
      loop do
        if (@step)
          @prime += @step
          @step = 6 - @step
        else
          case @prime
          when 1; @prime = 2
          when 2; @prime = 3
          when 3; @prime = 5; @step = 2
          end
        end
        return @prime
      end
    end
    alias next succ
    def rewind
      initialize
    end
  end

  # Internal use. An implementation of prime table by trial division method.
  class TrialDivision
    include Singleton

    def initialize # :nodoc:
      # These are included as class variables to cache them for later uses.  If memory
      #   usage is a problem, they can be put in Prime#initialize as instance variables.

      # There must be no primes between @primes[-1] and @next_to_check.
      @primes = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101]
      # @next_to_check % 6 must be 1.
      @next_to_check = 103            # @primes[-1] - @primes[-1] % 6 + 7
      @ulticheck_index = 3            # @primes.index(@primes.reverse.find {|n|
      #   n < Math.sqrt(@@next_to_check) })
      @ulticheck_next_squared = 121   # @primes[@ulticheck_index + 1] ** 2
    end

    # Returns the cached prime numbers.
    def cache
      return @primes
    end
    alias primes cache
    alias primes_so_far cache

    # Returns the +index+th prime number.
    #
    # +index+ is a 0-based index.
    def [](index)
      while index >= @primes.length
        # Only check for prime factors up to the square root of the potential primes,
        #   but without the performance hit of an actual square root calculation.
        if @next_to_check + 4 > @ulticheck_next_squared
          @ulticheck_index += 1
          @ulticheck_next_squared = @primes.at(@ulticheck_index + 1) ** 2
        end
        # Only check numbers congruent to one and five, modulo six. All others

        #   are divisible by two or three.  This also allows us to skip checking against
        #   two and three.
        @primes.push @next_to_check if @primes[2..@ulticheck_index].find {|prime| @next_to_check % prime == 0 }.nil?
        @next_to_check += 4
        @primes.push @next_to_check if @primes[2..@ulticheck_index].find {|prime| @next_to_check % prime == 0 }.nil?
        @next_to_check += 2
      end
      return @primes[index]
    end
  end

  # Internal use. An implementation of eratosthenes's sieve
  class EratosthenesSieve
    include Singleton

    BITS_PER_ENTRY = 16  # each entry is a set of 16-bits in a Fixnum
    NUMS_PER_ENTRY = BITS_PER_ENTRY * 2 # twiced because even numbers are omitted
    ENTRIES_PER_TABLE = 8
    NUMS_PER_TABLE = NUMS_PER_ENTRY * ENTRIES_PER_TABLE
    FILLED_ENTRY = (1 << NUMS_PER_ENTRY) - 1

    def initialize # :nodoc:
      # bitmap for odd prime numbers less than 256.
      # For an arbitrary odd number n, @tables[i][j][k] is
      # * 1 if n is prime,
      # * 0 if n is composite,
      # where i,j,k = indices(n)
      @tables = [[0xcb6e, 0x64b4, 0x129a, 0x816d, 0x4c32, 0x864a, 0x820d, 0x2196].freeze]
    end

    # returns the least odd prime number which is greater than +n+.
    def next_to(n)
      n = (n-1).div(2)*2+3 # the next odd number to given n
      table_index, integer_index, bit_index = indices(n)
      loop do
        extend_table until @tables.length > table_index
        for j in integer_index...ENTRIES_PER_TABLE
          if !@tables[table_index][j].zero?
            for k in bit_index...BITS_PER_ENTRY
              return NUMS_PER_TABLE*table_index + NUMS_PER_ENTRY*j + 2*k+1 if !@tables[table_index][j][k].zero?
            end
          end
          bit_index = 0
        end
        table_index += 1; integer_index = 0
      end
    end

    private
    # for an odd number +n+, returns (i, j, k) such that @tables[i][j][k] represents primarity of the number
    def indices(n)
      #   binary digits of n: |0|1|2|3|4|5|6|7|8|9|10|11|....
      #   indices:            |-|    k  |  j  |     i
      # because of NUMS_PER_ENTRY, NUMS_PER_TABLE

      k = (n & 0b00011111) >> 1
      j = (n & 0b11100000) >> 5
      i = n >> 8
      return i, j, k
    end

    def extend_table
      lbound = NUMS_PER_TABLE * @tables.length
      ubound = lbound + NUMS_PER_TABLE
      new_table = [FILLED_ENTRY] * ENTRIES_PER_TABLE # which represents primarity in lbound...ubound
      (3..Integer(Math.sqrt(ubound))).step(2) do |p|
        i, j, k = indices(p)
        next if @tables[i][j][k].zero?

        start = (lbound.div(p)+1)*p  # least multiple of p which is >= lbound
        start += p if start.even?
        (start...ubound).step(2*p) do |n|
          _, j, k = indices(n)
          new_table[j] &= FILLED_ENTRY^(1<<k)
        end
      end
      @tables << new_table.freeze
    end
  end

  # Provides a +Prime+ object with compatibility to Ruby 1.8 when instantiated via +Prime+.+new+.
  module OldCompatibility
    # Returns the next prime number and forwards internal pointer.
    def succ
      @generator.succ
    end
    alias next succ

    # Overwrites Prime#each.
    #
    # Iterates the given block over all prime numbers. Note that enumeration
    # starts from the current position of internal pointer, not rewound.
    def each(&block)
      return @generator.dup unless block_given?
      loop do
        yield succ
      end
    end
  end
end

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
March 03 2024 22:43:32
root / root
0755
cgi
--
March 03 2024 22:43:33
root / linksafe
0755
date
--
March 03 2024 22:43:33
root / linksafe
0755
digest
--
March 03 2024 22:43:33
root / linksafe
0755
dl
--
March 03 2024 22:43:33
root / linksafe
0755
drb
--
March 03 2024 22:43:33
root / linksafe
0755
fiddle
--
March 03 2024 22:43:33
root / linksafe
0755
irb
--
March 03 2024 22:43:33
root / linksafe
0755
json
--
March 03 2024 22:43:37
root / linksafe
0755
matrix
--
March 03 2024 22:43:33
root / linksafe
0755
net
--
March 03 2024 22:43:33
root / linksafe
0755
openssl
--
March 03 2024 22:43:33
root / linksafe
0755
optparse
--
March 03 2024 22:43:33
root / linksafe
0755
psych
--
March 03 2024 22:43:38
root / linksafe
0755
racc
--
March 03 2024 22:43:33
root / linksafe
0755
rake
--
March 03 2024 22:53:08
root / linksafe
0755
rbconfig
--
March 03 2024 22:43:42
root / linksafe
0755
rdoc
--
March 03 2024 22:43:41
root / linksafe
0755
rexml
--
March 03 2024 22:43:33
root / linksafe
0755
rinda
--
March 03 2024 22:43:33
root / linksafe
0755
ripper
--
March 03 2024 22:43:33
root / linksafe
0755
rss
--
March 03 2024 22:43:33
root / linksafe
0755
rubygems
--
March 03 2024 22:43:42
root / linksafe
0755
shell
--
March 03 2024 22:43:33
root / linksafe
0755
syslog
--
March 03 2024 22:43:33
root / root
0755
test
--
March 03 2024 22:43:33
root / linksafe
0755
uri
--
March 03 2024 22:43:33
root / linksafe
0755
webrick
--
March 03 2024 22:43:33
root / linksafe
0755
x86_64-linux
--
March 03 2024 22:43:38
root / root
0755
xmlrpc
--
March 03 2024 22:43:33
root / linksafe
0755
yaml
--
March 03 2024 22:43:33
root / linksafe
0755
English.rb
6.443 KB
February 04 2013 02:50:20
root / linksafe
0644
abbrev.rb
3.313 KB
February 24 2013 05:06:42
root / linksafe
0644
base64.rb
2.631 KB
October 02 2009 10:45:39
root / linksafe
0644
benchmark.rb
17.939 KB
July 18 2012 03:56:58
root / linksafe
0644
cgi.rb
9.391 KB
November 30 2012 05:06:45
root / linksafe
0644
cmath.rb
7.223 KB
July 23 2011 12:14:43
root / linksafe
0644
complex.rb
0.371 KB
August 16 2009 15:34:35
root / linksafe
0644
csv.rb
81.322 KB
September 17 2014 05:56:35
root / linksafe
0644
date.rb
0.924 KB
July 26 2023 14:09:00
root / linksafe
0644
debug.rb
28.898 KB
February 02 2013 05:04:54
root / linksafe
0644
delegate.rb
9.783 KB
April 30 2014 07:45:49
root / linksafe
0644
digest.rb
2.244 KB
July 26 2023 14:09:00
root / linksafe
0644
dl.rb
0.273 KB
July 26 2023 14:09:00
root / linksafe
0644
drb.rb
0.019 KB
October 02 2009 10:45:39
root / linksafe
0644
e2mmap.rb
3.805 KB
May 19 2011 00:07:25
root / linksafe
0644
erb.rb
26.084 KB
September 03 2014 04:42:39
root / linksafe
0644
expect.rb
2.144 KB
July 26 2023 14:09:00
root / linksafe
0644
fiddle.rb
1.252 KB
July 26 2023 14:09:00
root / linksafe
0644
fileutils.rb
46.353 KB
October 16 2014 07:23:46
root / linksafe
0644
find.rb
2.082 KB
September 20 2012 07:14:54
root / linksafe
0644
forwardable.rb
7.562 KB
January 04 2013 02:52:54
root / linksafe
0644
getoptlong.rb
15.381 KB
December 24 2013 15:46:01
root / linksafe
0644
gserver.rb
8.856 KB
July 07 2014 03:55:25
root / linksafe
0644
ipaddr.rb
26.17 KB
February 23 2013 04:03:59
root / linksafe
0644
irb.rb
20.029 KB
February 05 2013 15:57:19
root / linksafe
0644
json.rb
1.737 KB
July 26 2023 14:09:00
root / linksafe
0644
kconv.rb
5.737 KB
July 26 2023 14:09:00
root / linksafe
0644
logger.rb
20.96 KB
July 13 2013 15:16:09
root / linksafe
0644
mathn.rb
6.524 KB
August 26 2011 22:22:37
root / linksafe
0644
matrix.rb
45.019 KB
February 05 2013 05:43:36
root / linksafe
0644
mkmf.rb
78.186 KB
July 26 2023 14:06:15
root / linksafe
0644
monitor.rb
6.935 KB
November 16 2012 16:55:29
root / linksafe
0644
mutex_m.rb
2.002 KB
February 24 2013 04:49:04
root / linksafe
0644
observer.rb
5.705 KB
August 21 2012 13:03:30
root / linksafe
0644
open-uri.rb
23.656 KB
February 16 2014 17:02:51
root / linksafe
0644
open3.rb
21.172 KB
January 13 2013 04:40:15
root / linksafe
0644
openssl.rb
0.516 KB
July 26 2023 14:09:00
root / linksafe
0644
optparse.rb
51.267 KB
February 19 2014 16:38:03
root / linksafe
0644
ostruct.rb
7.636 KB
October 28 2012 21:20:10
root / linksafe
0644
pathname.rb
15.297 KB
July 26 2023 14:09:00
root / linksafe
0644
pp.rb
13.136 KB
August 15 2012 11:50:01
root / linksafe
0644
prettyprint.rb
9.628 KB
August 02 2011 15:25:59
root / linksafe
0644
prime.rb
13.978 KB
January 13 2013 05:07:08
root / linksafe
0644
profile.rb
0.2 KB
October 02 2009 10:45:39
root / linksafe
0644
profiler.rb
4.287 KB
February 03 2013 00:38:46
root / linksafe
0644
pstore.rb
14.849 KB
November 11 2012 04:23:04
root / linksafe
0644
psych.rb
9.896 KB
July 26 2023 14:09:00
root / linksafe
0644
rake.rb
2.069 KB
November 29 2012 19:16:46
root / linksafe
0644
rational.rb
0.301 KB
September 24 2009 00:42:23
root / linksafe
0644
rdoc.rb
4.877 KB
February 19 2013 05:06:36
root / linksafe
0644
resolv-replace.rb
1.732 KB
April 03 2013 17:27:19
root / linksafe
0644
resolv.rb
61.449 KB
June 01 2015 15:13:01
root / linksafe
0644
ripper.rb
2.525 KB
July 26 2023 14:09:00
root / linksafe
0644
rss.rb
2.841 KB
May 11 2011 10:22:16
root / linksafe
0644
rubygems.rb
27.534 KB
July 26 2023 14:06:15
root / linksafe
0644
scanf.rb
23.517 KB
November 05 2011 07:37:47
root / linksafe
0644
securerandom.rb
8.563 KB
September 13 2012 13:01:23
root / linksafe
0644
set.rb
17.316 KB
November 24 2012 18:51:45
root / linksafe
0644
shell.rb
10.3 KB
December 05 2012 02:55:07
root / linksafe
0644
shellwords.rb
5.94 KB
November 09 2012 06:28:00
root / linksafe
0644
singleton.rb
4.018 KB
May 18 2011 14:09:38
root / linksafe
0644
socket.rb
25.758 KB
July 26 2023 14:09:00
root / linksafe
0644
sync.rb
7.256 KB
December 23 2012 10:18:58
root / linksafe
0644
tempfile.rb
10.153 KB
October 09 2013 16:11:16
root / linksafe
0644
thread.rb
6.944 KB
February 09 2014 16:07:41
root / linksafe
0644
thwait.rb
3.376 KB
June 29 2011 03:09:34
root / linksafe
0644
time.rb
21.091 KB
October 09 2013 15:07:45
root / linksafe
0644
timeout.rb
3.163 KB
April 14 2013 15:20:33
root / linksafe
0644
tmpdir.rb
4.148 KB
December 12 2012 12:40:51
root / linksafe
0644
tracer.rb
6.537 KB
February 04 2013 17:59:52
root / linksafe
0644
tsort.rb
6.795 KB
March 06 2009 04:23:05
root / linksafe
0644
ubygems.rb
0.262 KB
October 02 2009 10:45:39
root / linksafe
0644
un.rb
8.337 KB
August 03 2012 08:23:18
root / linksafe
0644
uri.rb
3.07 KB
May 13 2011 20:03:21
root / linksafe
0644
weakref.rb
3.229 KB
December 02 2012 07:57:45
root / linksafe
0644
webrick.rb
6.695 KB
November 07 2012 06:49:57
root / linksafe
0644
xmlrpc.rb
8.493 KB
September 13 2012 02:24:08
root / linksafe
0644
yaml.rb
2.303 KB
May 19 2013 19:01:43
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF