2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2013-07-07 10:01:40 -04:00
|
|
|
require 'test/unit'
|
|
|
|
require "-test-/bignum"
|
|
|
|
|
|
|
|
class TestBignum < Test::Unit::TestCase
|
|
|
|
class TestMul < Test::Unit::TestCase
|
|
|
|
|
Use Integer instead of Fixnum and Bignum.
* object.c, numeric.c, enum.c, ext/-test-/bignum/mul.c,
lib/rexml/quickpath.rb, lib/rexml/text.rb, lib/rexml/xpath_parser.rb,
lib/rubygems/specification.rb, lib/uri/generic.rb,
bootstraptest/test_eval.rb, basictest/test.rb,
test/-ext-/bignum/test_big2str.rb, test/-ext-/bignum/test_div.rb,
test/-ext-/bignum/test_mul.rb, test/-ext-/bignum/test_str2big.rb,
test/csv/test_data_converters.rb, test/date/test_date.rb,
test/json/test_json_generate.rb, test/minitest/test_minitest_mock.rb,
test/openssl/test_cipher.rb, test/rexml/test_jaxen.rb,
test/ruby/test_array.rb, test/ruby/test_basicinstructions.rb,
test/ruby/test_bignum.rb, test/ruby/test_case.rb,
test/ruby/test_class.rb, test/ruby/test_complex.rb,
test/ruby/test_enum.rb, test/ruby/test_eval.rb,
test/ruby/test_iseq.rb, test/ruby/test_literal.rb,
test/ruby/test_math.rb, test/ruby/test_module.rb,
test/ruby/test_numeric.rb, test/ruby/test_range.rb,
test/ruby/test_rational.rb, test/ruby/test_refinement.rb,
test/ruby/test_rubyvm.rb, test/ruby/test_struct.rb,
test/ruby/test_variable.rb, test/rubygems/test_gem_specification.rb,
test/thread/test_queue.rb: Use Integer instead of Fixnum and Bignum.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55029 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-05-17 09:15:57 -04:00
|
|
|
SIZEOF_BDIGIT = Integer::SIZEOF_BDIGIT
|
|
|
|
BITSPERDIG = Integer::BITSPERDIG
|
2013-07-07 11:21:26 -04:00
|
|
|
BDIGMAX = (1 << BITSPERDIG) - 1
|
2013-07-07 10:01:40 -04:00
|
|
|
|
|
|
|
def test_mul_normal
|
|
|
|
x = (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << BITSPERDIG) | 1
|
|
|
|
z = (1 << (BITSPERDIG*2)) | (2 << BITSPERDIG) | 1
|
|
|
|
assert_equal(z, x.big_mul_normal(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_normal_zero_in_x
|
|
|
|
x = (1 << (2*BITSPERDIG)) | 1
|
|
|
|
y = (1 << BITSPERDIG) | 1
|
|
|
|
z = (1 << (BITSPERDIG*3)) | (1 << (BITSPERDIG*2)) | (1 << BITSPERDIG) | 1
|
|
|
|
assert_equal(z, x.big_mul_normal(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_normal_zero_in_y
|
|
|
|
x = (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << (2*BITSPERDIG)) | 1
|
|
|
|
z = (1 << (BITSPERDIG*3)) | (1 << (BITSPERDIG*2)) | (1 << BITSPERDIG) | 1
|
|
|
|
assert_equal(z, x.big_mul_normal(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_normal_max_max
|
|
|
|
x = (1 << (2*BITSPERDIG)) - 1
|
|
|
|
y = (1 << (2*BITSPERDIG)) - 1
|
|
|
|
z = (1 << (4*BITSPERDIG)) - (1 << (2*BITSPERDIG+1)) + 1
|
|
|
|
assert_equal(z, x.big_mul_normal(y))
|
|
|
|
end
|
|
|
|
|
2013-07-08 09:05:57 -04:00
|
|
|
def test_sq_fast
|
|
|
|
x = (1 << BITSPERDIG) | 1
|
|
|
|
z = (1 << 2*BITSPERDIG) | (2 << BITSPERDIG) | 1
|
|
|
|
assert_equal(z, x.big_sq_fast)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_sq_fast_max2
|
|
|
|
x = (BDIGMAX << BITSPERDIG) | BDIGMAX
|
|
|
|
assert_equal(x.big_mul_normal(x), x.big_sq_fast)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_sq_fast_zero_in_middle
|
|
|
|
x = (BDIGMAX << 2*BITSPERDIG) | BDIGMAX
|
|
|
|
assert_equal(x.big_mul_normal(x), x.big_sq_fast)
|
|
|
|
end
|
|
|
|
|
2013-07-07 10:01:40 -04:00
|
|
|
def test_mul_balance
|
|
|
|
x = (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << BITSPERDIG) | 1
|
|
|
|
z = (1 << (BITSPERDIG*2)) | (2 << BITSPERDIG) | 1
|
|
|
|
assert_equal(z, x.big_mul_balance(y))
|
|
|
|
end
|
|
|
|
|
2013-07-08 07:56:55 -04:00
|
|
|
def test_mul_balance_2x16
|
Use Integer instead of Fixnum and Bignum.
* object.c, numeric.c, enum.c, ext/-test-/bignum/mul.c,
lib/rexml/quickpath.rb, lib/rexml/text.rb, lib/rexml/xpath_parser.rb,
lib/rubygems/specification.rb, lib/uri/generic.rb,
bootstraptest/test_eval.rb, basictest/test.rb,
test/-ext-/bignum/test_big2str.rb, test/-ext-/bignum/test_div.rb,
test/-ext-/bignum/test_mul.rb, test/-ext-/bignum/test_str2big.rb,
test/csv/test_data_converters.rb, test/date/test_date.rb,
test/json/test_json_generate.rb, test/minitest/test_minitest_mock.rb,
test/openssl/test_cipher.rb, test/rexml/test_jaxen.rb,
test/ruby/test_array.rb, test/ruby/test_basicinstructions.rb,
test/ruby/test_bignum.rb, test/ruby/test_case.rb,
test/ruby/test_class.rb, test/ruby/test_complex.rb,
test/ruby/test_enum.rb, test/ruby/test_eval.rb,
test/ruby/test_iseq.rb, test/ruby/test_literal.rb,
test/ruby/test_math.rb, test/ruby/test_module.rb,
test/ruby/test_numeric.rb, test/ruby/test_range.rb,
test/ruby/test_rational.rb, test/ruby/test_refinement.rb,
test/ruby/test_rubyvm.rb, test/ruby/test_struct.rb,
test/ruby/test_variable.rb, test/rubygems/test_gem_specification.rb,
test/thread/test_queue.rb: Use Integer instead of Fixnum and Bignum.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55029 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-05-17 09:15:57 -04:00
|
|
|
x = (1 << Integer::BITSPERDIG) | 1
|
|
|
|
y = (1 << Integer::BITSPERDIG*16) | 1
|
2013-07-08 07:56:55 -04:00
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_balance(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_balance_2x17
|
Use Integer instead of Fixnum and Bignum.
* object.c, numeric.c, enum.c, ext/-test-/bignum/mul.c,
lib/rexml/quickpath.rb, lib/rexml/text.rb, lib/rexml/xpath_parser.rb,
lib/rubygems/specification.rb, lib/uri/generic.rb,
bootstraptest/test_eval.rb, basictest/test.rb,
test/-ext-/bignum/test_big2str.rb, test/-ext-/bignum/test_div.rb,
test/-ext-/bignum/test_mul.rb, test/-ext-/bignum/test_str2big.rb,
test/csv/test_data_converters.rb, test/date/test_date.rb,
test/json/test_json_generate.rb, test/minitest/test_minitest_mock.rb,
test/openssl/test_cipher.rb, test/rexml/test_jaxen.rb,
test/ruby/test_array.rb, test/ruby/test_basicinstructions.rb,
test/ruby/test_bignum.rb, test/ruby/test_case.rb,
test/ruby/test_class.rb, test/ruby/test_complex.rb,
test/ruby/test_enum.rb, test/ruby/test_eval.rb,
test/ruby/test_iseq.rb, test/ruby/test_literal.rb,
test/ruby/test_math.rb, test/ruby/test_module.rb,
test/ruby/test_numeric.rb, test/ruby/test_range.rb,
test/ruby/test_rational.rb, test/ruby/test_refinement.rb,
test/ruby/test_rubyvm.rb, test/ruby/test_struct.rb,
test/ruby/test_variable.rb, test/rubygems/test_gem_specification.rb,
test/thread/test_queue.rb: Use Integer instead of Fixnum and Bignum.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55029 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2016-05-17 09:15:57 -04:00
|
|
|
x = (1 << Integer::BITSPERDIG) | 1
|
|
|
|
y = (1 << Integer::BITSPERDIG*17) | 1
|
2013-07-08 07:56:55 -04:00
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_balance(y))
|
|
|
|
end
|
|
|
|
|
2013-07-07 10:01:40 -04:00
|
|
|
def test_mul_karatsuba
|
|
|
|
x = (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << BITSPERDIG) | 1
|
|
|
|
z = (1 << (BITSPERDIG*2)) | (2 << BITSPERDIG) | 1
|
|
|
|
assert_equal(z, x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
2013-07-07 11:21:26 -04:00
|
|
|
def test_mul_karatsuba_odd_y
|
|
|
|
x = (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << (2*BITSPERDIG)) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_karatsuba_odd_xy
|
|
|
|
x = (1 << (2*BITSPERDIG)) | 1
|
|
|
|
y = (1 << (2*BITSPERDIG)) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_karatsuba_x1_gt_x0
|
|
|
|
x = (2 << BITSPERDIG) | 1
|
|
|
|
y = (1 << BITSPERDIG) | 2
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_karatsuba_y1_gt_y0
|
|
|
|
x = (1 << BITSPERDIG) | 2
|
|
|
|
y = (2 << BITSPERDIG) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_karatsuba_x1_gt_x0_and_y1_gt_y0
|
|
|
|
x = (2 << BITSPERDIG) | 1
|
|
|
|
y = (2 << BITSPERDIG) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_karatsuba_carry2
|
|
|
|
x = (1 << BITSPERDIG) | BDIGMAX
|
|
|
|
y = (1 << BITSPERDIG) | BDIGMAX
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_mul_karatsuba_borrow
|
|
|
|
x = (BDIGMAX << BITSPERDIG) | 1
|
|
|
|
y = (BDIGMAX << BITSPERDIG) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_karatsuba(y))
|
|
|
|
end
|
|
|
|
|
2013-07-08 09:05:57 -04:00
|
|
|
def test_mul_toom3
|
|
|
|
x = (1 << 2*BITSPERDIG) | (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << 2*BITSPERDIG) | (1 << BITSPERDIG) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_toom3(y))
|
|
|
|
end
|
|
|
|
|
2013-09-03 07:20:17 -04:00
|
|
|
def test_mul_gmp
|
|
|
|
x = (1 << 2*BITSPERDIG) | (1 << BITSPERDIG) | 1
|
|
|
|
y = (1 << 2*BITSPERDIG) | (1 << BITSPERDIG) | 1
|
|
|
|
assert_equal(x.big_mul_normal(y), x.big_mul_gmp(y))
|
|
|
|
rescue NotImplementedError
|
|
|
|
end
|
|
|
|
|
2013-07-07 10:01:40 -04:00
|
|
|
end
|
|
|
|
end
|