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

Version Path
more_math-0.0.3 tests/test_newton_bisection.rb
more_math-0.0.2 tests/test_newton_bisection.rb
more_math-0.0.1 tests/test_newton_bisection.rb
more_math-0.0.0 tests/test_newton_bisection.rb