2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../../spec_helper'
|
|
|
|
require_relative 'fixtures/classes'
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
describe "Math.log2" do
|
|
|
|
it "returns a float" do
|
|
|
|
Math.log2(5.79).should be_close(2.53356334821451, TOLERANCE)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns the natural logarithm of the argument" do
|
|
|
|
Math.log2(1.1).should be_close(0.137503523749935, TOLERANCE)
|
|
|
|
Math.log2(3.14).should be_close(1.6507645591169, TOLERANCE)
|
|
|
|
Math.log2((2**101+45677544234809571)).should be_close(101.00000000000003, TOLERANCE)
|
|
|
|
|
|
|
|
Math.log2((2**10001+45677544234809571)).should == 10001.0
|
|
|
|
Math.log2((2**301+45677544234809571)).should == 301.0
|
|
|
|
end
|
|
|
|
|
2022-01-10 10:29:54 -05:00
|
|
|
it "raises Math::DomainError if the argument is less than 0" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> { Math.log2(-1e-15) }.should raise_error( Math::DomainError)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "raises a TypeError if the argument cannot be coerced with Float()" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> { Math.log2("test") }.should raise_error(TypeError)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "raises a TypeError if passed a numerical argument as a string" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> { Math.log2("1.0") }.should raise_error(TypeError)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns NaN given NaN" do
|
|
|
|
Math.log2(nan_value).nan?.should be_true
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises a TypeError if the argument is nil" do
|
2019-07-27 06:40:09 -04:00
|
|
|
-> { Math.log2(nil) }.should raise_error(TypeError)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "accepts any argument that can be coerced with Float()" do
|
|
|
|
Math.log2(MathSpecs::Float.new).should be_close(0.0, TOLERANCE)
|
|
|
|
end
|
|
|
|
end
|