GRAYBYTE WORDPRESS FILE MANAGER4587

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//mathn.rb
#--
# $Release Version: 0.5 $
# $Revision: 1.1.1.1.4.1 $

##
# = mathn
#
# mathn is a library for changing the way Ruby does math.  If you need
# more precise rounding with multiple division or exponentiation
# operations, then mathn is the right tool.
#
# Without mathn:
#
#   3 / 2 => 1 # Integer
#
# With mathn:
#
#   3 / 2 => 3/2 # Rational
#
# mathn features late rounding and lacks truncation of intermediate results:
#
# Without mathn:
#
#   20 / 9 * 3 * 14 / 7 * 3 / 2 # => 18
#
# With mathn:
#
#   20 / 9 * 3 * 14 / 7 * 3 / 2 # => 20
#
#
# When you require 'mathn', the libraries for Prime, CMath, Matrix and Vector
# are also loaded.
#
# == Copyright
#
# Author: Keiju ISHITSUKA (SHL Japan Inc.)
#--
# class Numeric follows to make this documentation findable in a reasonable
# location

class Numeric; end

require "cmath.rb"
require "matrix.rb"
require "prime.rb"

require "mathn/rational"
require "mathn/complex"

unless defined?(Math.exp!)
  Object.instance_eval{remove_const :Math}
  Math = CMath # :nodoc:
end

##
# When mathn is required, Fixnum's division and exponentiation are enhanced to
# return more precise values from mathematical expressions.
#
#   2/3*3  # => 0
#   require 'mathn'
#   2/3*3  # => 2

class Fixnum
  remove_method :/

  ##
  # +/+ defines the Rational division for Fixnum.
  #
  #   1/3  # => (1/3)

  alias / quo

  alias power! ** unless method_defined? :power!

  ##
  # Exponentiate by +other+

  def ** (other)
    if self < 0 && other.round != other
      Complex(self, 0.0) ** other
    else
      power!(other)
    end
  end

end

##
# When mathn is required Bignum's division and exponentiation are enhanced to
# return more precise values from mathematical expressions.

class Bignum
  remove_method :/

  ##
  # +/+ defines the Rational division for Bignum.
  #
  #   (2**72) / ((2**70) * 3)  # => 4/3

  alias / quo

  alias power! ** unless method_defined? :power!

  ##
  # Exponentiate by +other+

  def ** (other)
    if self < 0 && other.round != other
      Complex(self, 0.0) ** other
    else
      power!(other)
    end
  end

end

##
# When mathn is required Rational is changed to simplify the use of Rational
# operations.
#
# Normal behaviour:
#
#   Rational.new!(1,3) ** 2 # => Rational(1, 9)
#   (1 / 3) ** 2            # => 0
#
# require 'mathn' behaviour:
#
#   (1 / 3) ** 2            # => 1/9

class Rational
  remove_method :**

  ##
  # Exponentiate by +other+
  #
  #   (1/3) ** 2 # => 1/9

  def ** (other)
    if other.kind_of?(Rational)
      other2 = other
      if self < 0
        return Complex(self, 0.0) ** other
      elsif other == 0
        return Rational(1,1)
      elsif self == 0
        return Rational(0,1)
      elsif self == 1
        return Rational(1,1)
      end

      npd = numerator.prime_division
      dpd = denominator.prime_division
      if other < 0
        other = -other
        npd, dpd = dpd, npd
      end

      for elm in npd
        elm[1] = elm[1] * other
        if !elm[1].kind_of?(Integer) and elm[1].denominator != 1
          return Float(self) ** other2
        end
        elm[1] = elm[1].to_i
      end

      for elm in dpd
        elm[1] = elm[1] * other
        if !elm[1].kind_of?(Integer) and elm[1].denominator != 1
          return Float(self) ** other2
        end
        elm[1] = elm[1].to_i
      end

      num = Integer.from_prime_division(npd)
      den = Integer.from_prime_division(dpd)

      Rational(num,den)

    elsif other.kind_of?(Integer)
      if other > 0
        num = numerator ** other
        den = denominator ** other
      elsif other < 0
        num = denominator ** -other
        den = numerator ** -other
      elsif other == 0
        num = 1
        den = 1
      end
      Rational(num, den)
    elsif other.kind_of?(Float)
      Float(self) ** other
    else
      x , y = other.coerce(self)
      x ** y
    end
  end
end

##
# When mathn is required, the Math module changes as follows:
#
# Standard Math module behaviour:
#   Math.sqrt(4/9)     # => 0.0
#   Math.sqrt(4.0/9.0) # => 0.666666666666667
#   Math.sqrt(- 4/9)   # => Errno::EDOM: Numerical argument out of domain - sqrt
#
# After require 'mathn', this is changed to:
#
#   require 'mathn'
#   Math.sqrt(4/9)      # => 2/3
#   Math.sqrt(4.0/9.0)  # => 0.666666666666667
#   Math.sqrt(- 4/9)    # => Complex(0, 2/3)

module Math
  remove_method(:sqrt)

  ##
  # Computes the square root of +a+.  It makes use of Complex and
  # Rational to have no rounding errors if possible.
  #
  #   Math.sqrt(4/9)      # => 2/3
  #   Math.sqrt(- 4/9)    # => Complex(0, 2/3)
  #   Math.sqrt(4.0/9.0)  # => 0.666666666666667

  def sqrt(a)
    if a.kind_of?(Complex)
      abs = sqrt(a.real*a.real + a.imag*a.imag)
#      if not abs.kind_of?(Rational)
#        return a**Rational(1,2)
#      end
      x = sqrt((a.real + abs)/Rational(2))
      y = sqrt((-a.real + abs)/Rational(2))
#      if !(x.kind_of?(Rational) and y.kind_of?(Rational))
#        return a**Rational(1,2)
#      end
      if a.imag >= 0
        Complex(x, y)
      else
        Complex(x, -y)
      end
    elsif a.respond_to?(:nan?) and a.nan?
      a
    elsif a >= 0
      rsqrt(a)
    else
      Complex(0,rsqrt(-a))
    end
  end

  ##
  # Compute square root of a non negative number. This method is
  # internally used by +Math.sqrt+.

  def rsqrt(a)
    if a.kind_of?(Float)
      sqrt!(a)
    elsif a.kind_of?(Rational)
      rsqrt(a.numerator)/rsqrt(a.denominator)
    else
      src = a
      max = 2 ** 32
      byte_a = [src & 0xffffffff]
      # ruby's bug
      while (src >= max) and (src >>= 32)
        byte_a.unshift src & 0xffffffff
      end

      answer = 0
      main = 0
      side = 0
      for elm in byte_a
        main = (main << 32) + elm
        side <<= 16
        if answer != 0
          if main * 4  < side * side
            applo = main.div(side)
          else
            applo = ((sqrt!(side * side + 4 * main) - side)/2.0).to_i + 1
          end
        else
          applo = sqrt!(main).to_i + 1
        end

        while (x = (side + applo) * applo) > main
          applo -= 1
        end
        main -= x
        answer = (answer << 16) + applo
        side += applo * 2
      end
      if main == 0
        answer
      else
        sqrt!(a)
      end
    end
  end

  class << self
    remove_method(:sqrt)
  end
  module_function :sqrt
  module_function :rsqrt
end

##
# When mathn is required, Float is changed to handle Complex numbers.

class Float
  alias power! **

  ##
  # Exponentiate by +other+

  def ** (other)
    if self < 0 && other.round != other
      Complex(self, 0.0) ** other
    else
      power!(other)
    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