mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
![mrkn](/assets/img/avatar_default.png)
* Revert "Remove unnecessary linker flags" This reverts commit49efa01579
. * Revert "Move dependency on gemspec" This reverts commitbfb64d4765
. * Revert "Remove unnecessary directory listing" This reverts commit86661b5c60
. * Revert "* expand tabs." This reverts commit35ada33f83
. * Revert "Import bigdecimal-1.4.0.pre-20181204a" This reverts commit8891bb3bd6
. * Revert "ext/bigdecimal/bigdecimal.c: drop unused function" This reverts commit5ceeea4da1
. * Revert "* expand tabs." This reverts commite021386e90
. * Revert "Import bigdecimal-1.4.0.pre-20181130a" This reverts commita0e438cd3c
. * Revert "NEWS: write about bigdecimal updates" This reverts commit89455ff2ba
. * Revert "Fix rubyspec of bigdecimal for ruby <2.6" This reverts commit4bcdeeb65e
. * Revert "Fix rubyspec against bigdecimal updates" This reverts commitc8fb30fc9e
. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66210 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
40 lines
871 B
Ruby
40 lines
871 B
Ruby
#!/usr/local/bin/ruby
|
|
# frozen_string_literal: false
|
|
|
|
#
|
|
# nlsolve.rb
|
|
# An example for solving nonlinear algebraic equation system.
|
|
#
|
|
|
|
require "bigdecimal"
|
|
require "bigdecimal/newton"
|
|
include Newton
|
|
|
|
class Function # :nodoc: all
|
|
def initialize()
|
|
@zero = BigDecimal.new("0.0")
|
|
@one = BigDecimal.new("1.0")
|
|
@two = BigDecimal.new("2.0")
|
|
@ten = BigDecimal.new("10.0")
|
|
@eps = BigDecimal.new("1.0e-16")
|
|
end
|
|
def zero;@zero;end
|
|
def one ;@one ;end
|
|
def two ;@two ;end
|
|
def ten ;@ten ;end
|
|
def eps ;@eps ;end
|
|
def values(x) # <= defines functions solved
|
|
f = []
|
|
f1 = x[0]*x[0] + x[1]*x[1] - @two # f1 = x**2 + y**2 - 2 => 0
|
|
f2 = x[0] - x[1] # f2 = x - y => 0
|
|
f <<= f1
|
|
f <<= f2
|
|
f
|
|
end
|
|
end
|
|
|
|
f = BigDecimal.limit(100)
|
|
f = Function.new
|
|
x = [f.zero,f.zero] # Initial values
|
|
n = nlsolve(f,x)
|
|
p x
|