diff --git a/NEWS.md b/NEWS.md index 7dc672caa..66ae524cb 100644 --- a/NEWS.md +++ b/NEWS.md @@ -6,7 +6,7 @@ - The package now supports only Julia v1.3 and later. ### Breaking changes -- Changed from using `FastRounding.jl` to `RoundingEmulator.jl` for the defalt rounding mode. [#370](https://github.com/JuliaIntervals/IntervalArithmetic.jl/pull/370) +- Changed from using `FastRounding.jl` to `RoundingEmulator.jl` for the default rounding mode. [#370](https://github.com/JuliaIntervals/IntervalArithmetic.jl/pull/370) ## v0.15 @@ -293,7 +293,7 @@ v0.1 is the first public release of the package. ### Interval arithmetic - Two methods for interval rounding are available: - (i) narrow/slow (which uses hardward rounding mode changes for `Float64` intervals, and (ii) wide/fast (which does not change the rounding mode) + (i) narrow/slow (which uses hardware rounding mode changes for `Float64` intervals, and (ii) wide/fast (which does not change the rounding mode) - The current interval precision and rounding mode are stored in the `parameters` object - The macro `@interval` generates intervals based on the current interval precision - Trigonometric functions are "nearly" rigorous (for `Float64` intervals, correct rounding is not currently guaranteed) diff --git a/docs/src/input_output.md b/docs/src/input_output.md index 8ac10dc3b..bd7874e0d 100644 --- a/docs/src/input_output.md +++ b/docs/src/input_output.md @@ -73,7 +73,7 @@ 'u' Returns the interval with midpoint as lower bound and radius taken in upward direction. 'C' Returns upper case for Empty, Entire and Nai 'c' Returns lower case for Empty, Entire and Nai - '+' Returns postitve numbers with '+' sign before the number + '+' Returns positive numbers with '+' sign before the number '0' Left-pads the numbers with zeros instead of spaces within the field width - The field width specifies the length of midpoint string. diff --git a/examples/Range of 2-dimensional functions.ipynb b/examples/Range of 2-dimensional functions.ipynb index d1827efc9..6c5e83601 100644 --- a/examples/Range of 2-dimensional functions.ipynb +++ b/examples/Range of 2-dimensional functions.ipynb @@ -356,7 +356,7 @@ "\t\tconsole.log.apply(console, arguments);\n", "\t }\n", "\t},\n", - "\t// a central way to initalize communication\n", + "\t// a central way to initialize communication\n", "\t// for widgets.\n", "\tcommInitializer: function (widget) {\n", "\t widget.sendUpdate = function () {};\n", @@ -435,7 +435,7 @@ " });\n", "\t });\n", "\n", - "\t // coordingate with Comm and redraw Signals\n", + "\t // coordinate with Comm and redraw Signals\n", "\t // XXX: Test using Reactive here to improve performance\n", "\t $([IPython.events]).on(\n", "\t\t'output_appended.OutputArea', function (event, type, value, md, toinsert) {\n", diff --git a/src/multidim/intervalbox.jl b/src/multidim/intervalbox.jl index 48179e65e..05cfdbd26 100644 --- a/src/multidim/intervalbox.jl +++ b/src/multidim/intervalbox.jl @@ -61,7 +61,7 @@ length(::IntervalBox{N}) where {N} = N Return a vector of the `mid` of each interval composing the `IntervalBox`. -See `mid(X::Interval, α=0.5)` for more informations. +See `mid(X::Interval, α=0.5)` for more information. """ mid(X::IntervalBox) = mid.(X) scaled_mid(X::IntervalBox, α) = scaled_mid.(X, α) diff --git a/test/interval_tests/numeric.jl b/test/interval_tests/numeric.jl index bcb136075..b688d81f0 100644 --- a/test/interval_tests/numeric.jl +++ b/test/interval_tests/numeric.jl @@ -386,3 +386,44 @@ end @test nthroot(interval(BigFloat, -81, -16), -4) ≛ ∅ @test nthroot(interval(BigFloat, -81, -16), 1) ≛ interval(BigFloat, -81, -16) end + +# approximation used for testing (not to rely on ≈ for intervals) +# ⪆(x, y) = (x ≈ y) && (x ⊇ y) +⪆(x::Interval, y::Interval) = x.lo ≈ y.lo && x.hi ≈ y.hi && x ⊇ y + +@testset "`mod`" begin + r = 0.0625 + x = r..(1+r) + @test mod(x, 1) == mod(x, 1.0) == 0..1 + @test mod(x, 2) == mod(x, 2.0) ⪆ x + @test mod(x, 2.5) ⪆ x + @test mod(x, 0.5) == 0..0.5 + @test mod(x, -1) == mod(x, -1.0) == -1..0 + @test mod(x, -2) == mod(x, -2.0) ⪆ -2+x + @test mod(x, -2.5) ⪆ -2.5+x + @test mod(x, -0.5) == -0.5..0 + + x = (-1+r) .. -r + @test mod(x, 1) == mod(x, 1.0) ⪆ 1+x + @test mod(x, 2) == mod(x, 2.0) ⪆ 2+x + @test mod(x, 2.5) ⪆ 2.5+x + @test mod(x, 0.5) == 0..0.5 + @test mod(x, -1) == mod(x, -1.0) ⪆ x + @test mod(x, -2) == mod(x, -2.0) ⪆ x + @test mod(x, -2.5) ⪆ x + @test mod(x, -0.5) == -0.5..0 + + x = -r .. 1-r + @test mod(x, 1) == mod(x, 1.0) == 0..1 + @test mod(x, 2) == mod(x, 2.0) == 0..2 + @test mod(x, 2.5) == 0..2.5 + @test mod(x, 0.5) == 0..0.5 + @test mod(x, -1) == mod(x, -1.0) == -1..0 + @test mod(x, -2) == mod(x, -2.0) == -2..0 + @test mod(x, -2.5) == -2.5..0 + @test mod(x, -0.5) == -0.5..0 + + # TODO - implement mod for two intervals + @test_throws ArgumentError mod(1..2, 1.4..1.5) + @test_throws ArgumentError mod(1.0, 1.4..1.5) +end