Sha256: dc04adb9e43ffd084f43b1a0ef42ba65832c6a476823d39205576ebe387657ed
Contents?: true
Size: 889 Bytes
Versions: 4
Compression:
Stored size: 889 Bytes
Contents
#!/usr/bin/env ruby require 'test/unit' require 'more_math' class TestNewtonBisection < Test::Unit::TestCase include MoreMath def test_bracket solver = NewtonBisection.new { |x| x ** 2 - 3 } assert_raises(ArgumentError) { solver.bracket(1..1) } assert_raises(ArgumentError) { solver.bracket(1..-1) } range = solver.bracket(0..0.1) assert_in_delta range.first, 0, 1E-6 assert_in_delta range.last, 1.7576, 1E-6 range = solver.bracket(2..3) assert_in_delta range.first, 0.4, 1E-6 assert_in_delta range.last, 3, 1E-6 end def test_zero solver = NewtonBisection.new { |x| x ** 2 - 3 } assert_in_delta 1.73205, solver.solve, 1E-6 assert_in_delta(-1.73205, solver.solve(-5..-1), 1E-6) assert_in_delta 1.73205, solver.solve(solver.bracket(0..0.1)), 1E-6 assert_in_delta 1.73205, solver.solve(solver.bracket(2..3)), 1E-6 end end
Version data entries
4 entries across 4 versions & 1 rubygems