From: universato@... Date: 2020-10-11T05:54:57+00:00 Subject: [ruby-core:100367] [Ruby master Bug#17257] Integer#pow(0, 1) returns 1, which is incorrect Issue #17257 has been updated by universato (Yoshimine Sato). `x.pow(y, m)` doesn't equal multiplying `x % m` to 1 `y` times. ```ruby p 1 * (3 % 4) * (3 % 4) #=> 9 p 3.pow(2, 4) #=> 1 ``` it is the last to mod. Method `pow` should be simply defined as `(x**y) % m`. And, `0.pow(0)` is not necessarily undefined. Many programming languages define `0 ** 0` returns 1 because it is useful. For example, Python, R, C++, C#, Java, JavaScript, PHP, Perl, MATLAB, Octave, Haskell, Julia, Crystal and Ruby e.t.c. For reference, Python has pow function like ruby's pow. Python define pow as `(x**y) % m`, and Python's pow return 0. ```python print((12 ** 0) % 1) # 0 print(pow(12, 0, 1)) # 0 ``` ---------------------------------------- Bug #17257: Integer#pow(0, 1) returns 1, which is incorrect https://bugs.ruby-lang.org/issues/17257#change-87978 * Author: universato (Yoshimine Sato) * Status: Assigned * Priority: Normal * Assignee: mrkn (Kenta Murata) * Backport: 2.5: UNKNOWN, 2.6: UNKNOWN, 2.7: UNKNOWN ---------------------------------------- Ruby 2.5.8, 2.6.6, 2.7.1 ```ruby p -1.pow(0, 1) #=> 1 p 0.pow(0, 1) #=> 1 p 1.pow(0, 1) #=> 1 p 1234567890.pow(0, 1) #=> 1 ``` These return values should be 0. Patch for test: Let's add some boundary value tests to `test_pow` of [test_numeric.rb](https://github.com/ruby/ruby/blob/e014e6bf6685f681998238ff005f6d161d43ce51/test/ruby/test_numeric.rb). ```ruby integers = [-2, -1, 0, 1, 2, 3, 6, 1234567890123456789] integers.each do |i| assert_equal(0, i.pow(0, 1), '[Bug #17257]') assert_equal(1, i.pow(0, 2)) assert_equal(1, i.pow(0, 3)) assert_equal(1, i.pow(0, 6)) assert_equal(1, i.pow(0, 1234567890123456789)) assert_equal(0, i.pow(0, -1)) assert_equal(-1, i.pow(0, -2)) assert_equal(-2, i.pow(0, -3)) assert_equal(-5, i.pow(0, -6)) assert_equal(-1234567890123456788, i.pow(0, -1234567890123456789)) end assert_equal(0, 0.pow(2, 1)) assert_equal(0, 0.pow(3, 1)) assert_equal(0, 2.pow(3, 1)) assert_equal(0, -2.pow(3, 1)) -- https://bugs.ruby-lang.org/ Unsubscribe: