Sha256: d5e136156ada0ec0384de46edaaf48d517f5bb82d568fe1395cb4fc00aad2628

Contents?: true

Size: 1.46 KB

Versions: 9

Compression:

Stored size: 1.46 KB

Contents

require 'test/unit'
require 'gsl'

GSL::IEEE.env_setup
GSL::Rng.env_setup

class GSL::TestCase < Test::Unit::TestCase

  def assert_factor(result, expected, factor, desc)
    refute result == expected ? false : expected.zero? ? result != expected :
      (u = result / expected; u > factor || u < 1.0 / factor),
      '%s (%.18g observed vs %.18g expected)' % [desc, result, expected]
  end

  def assert_rel(result, expected, relerr, desc)
    refute((GSL.isnan?(result) || GSL.isnan?(expected)) ?
       GSL.isnan?(result) != GSL.isnan?(expected) :
      (GSL.isinf?(result) || GSL.isinf?(expected)) ?
       GSL.isinf?(result) != GSL.isinf?(expected) :
      expected.zero? ? result.abs > relerr :
      (result - expected).abs / expected.abs > relerr,
      '%s (%.18g observed vs %.18g expected)' % [desc, result, expected])
  end

  def assert_abs(result, expected, abserr, desc)
    refute((GSL.isnan?(result) || GSL.isnan?(expected)) ?
       GSL.isnan?(result) != GSL.isnan?(expected) :
      (GSL.isinf?(result) || GSL.isinf?(expected)) ?
       GSL.isinf?(result) != GSL.isinf?(expected) :
      (result - expected).abs > abserr,
      '%s (%.18g observed vs %.18g expected)' % [desc, result, expected])
  end

  def assert_int(result, expected, desc)
    assert(result == expected, '%s (%d observed vs %d expected)' % [desc, result, expected])
  end

  def assert_tol(a, b, msg)
    assert((a - b).abs < (self.class::EPSREL * GSL.MIN(a.abs, b.abs) + self.class::EPSABS), msg)
  end

end

Version data entries

9 entries across 9 versions & 2 rubygems

Version Path
gsl-1.16.0.6 test/test_helper.rb
rb-gsl-1.16.0.5 test/test_helper.rb
rb-gsl-1.16.0.4 test/test_helper.rb
rb-gsl-1.16.0.3 test/test_helper.rb
rb-gsl-1.16.0.3.rc1 test/test_helper.rb
rb-gsl-1.16.0.2 test/test_helper.rb
rb-gsl-1.16.0.1 test/test_helper.rb
rb-gsl-1.16.0 test/test_helper.rb
rb-gsl-1.15.3.2 test/test_helper.rb