Sha256: 2588910b835be23668908d1e0b35cb233a1fef3ec47f743c9b41351df508e5d9

Contents?: true

Size: 1.84 KB

Versions: 62

Compression:

Stored size: 1.84 KB

Contents

# frozen_string_literal: false
require "bigdecimal/ludcmp"
require "bigdecimal/jacobian"

#
# newton.rb
#
# Solves the nonlinear algebraic equation system f = 0 by Newton's method.
# This program is not dependent on BigDecimal.
#
# To call:
#    n = nlsolve(f,x)
#  where n is the number of iterations required,
#        x is the initial value vector
#        f is an Object which is used to compute the values of the equations to be solved.
# It must provide the following methods:
#
# f.values(x):: returns the values of all functions at x
#
# f.zero:: returns 0.0
# f.one:: returns 1.0
# f.two:: returns 2.0
# f.ten:: returns 10.0
#
# f.eps:: returns the convergence criterion (epsilon value) used to determine whether two values are considered equal. If |a-b| < epsilon, the two values are considered equal.
#
# On exit, x is the solution vector.
#
module Newton
  include LUSolve
  include Jacobian
  module_function

  def norm(fv,zero=0.0) # :nodoc:
    s = zero
    n = fv.size
    for i in 0...n do
      s += fv[i]*fv[i]
    end
    s
  end

  # See also Newton
  def nlsolve(f,x)
    nRetry = 0
    n = x.size

    f0 = f.values(x)
    zero = f.zero
    one  = f.one
    two  = f.two
    p5 = one/two
    d  = norm(f0,zero)
    minfact = f.ten*f.ten*f.ten
    minfact = one/minfact
    e = f.eps
    while d >= e do
      nRetry += 1
      # Not yet converged. => Compute Jacobian matrix
      dfdx = jacobian(f,f0,x)
      # Solve dfdx*dx = -f0 to estimate dx
      dx = lusolve(dfdx,f0,ludecomp(dfdx,n,zero,one),zero)
      fact = two
      xs = x.dup
      begin
        fact *= p5
        if fact < minfact then
          raise "Failed to reduce function values."
        end
        for i in 0...n do
          x[i] = xs[i] - dx[i]*fact
        end
        f0 = f.values(x)
        dn = norm(f0,zero)
      end while(dn>=d)
      d = dn
    end
    nRetry
  end
end

Version data entries

62 entries across 62 versions & 10 rubygems

Version Path
minato_ruby_api_client-0.2.2 vendor/bundle/ruby/3.2.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
bigdecimal-3.1.9-java lib/bigdecimal/newton.rb
bigdecimal-3.1.9 lib/bigdecimal/newton.rb
cloudsmith-api-2.0.16 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
cloudsmith-api-2.0.15 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
cloudsmith-api-2.0.14 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
blacklight-spotlight-3.6.0.beta8 vendor/bundle/ruby/3.2.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
katalyst-govuk-formbuilder-1.9.2 vendor/bundle/ruby/3.3.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
tinymce-rails-7.1.2 vendor/bundle/ruby/3.3.0/gems/bigdecimal-3.1.8/lib/bigdecimal/newton.rb
cloudsmith-api-2.0.13 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.7/lib/bigdecimal/newton.rb
cloudsmith-api-2.0.12 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.7/lib/bigdecimal/newton.rb
bigdecimal-3.1.7-java lib/bigdecimal/newton.rb
bigdecimal-3.1.7 lib/bigdecimal/newton.rb
cloudsmith-api-2.0.11 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.6/lib/bigdecimal/newton.rb
cloudsmith-api-2.0.10 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.6/lib/bigdecimal/newton.rb
cloudsmith-api-2.0.9 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.6/lib/bigdecimal/newton.rb
rhodes-7.6.0 lib/extensions/bigdecimal/bigdecimal/newton.rb
cloudsmith-api-2.0.8 vendor/bundle/ruby/2.6.0/gems/bigdecimal-3.1.6/lib/bigdecimal/newton.rb
mlh-rubocop-config-1.0.3 vendor/bundle/ruby/3.2.0/gems/bigdecimal-3.1.6/lib/bigdecimal/newton.rb
bigdecimal-3.1.6-java lib/bigdecimal/newton.rb