|
| 1 | +import Base.Checked: checked_neg, checked_add, checked_sub, checked_mul |
| 2 | +if VERSION ≥ v"1.11-alpha" |
| 3 | + import Base.Checked: checked_pow |
| 4 | +end |
| 5 | +if VERSION ≥ v"1.2" |
| 6 | + using Base: broadcast_preserving_zero_d |
| 7 | +end |
| 8 | + |
| 9 | +checked_neg(A::AbstractArray) = broadcast_preserving_zero_d(checked_neg, A) |
| 10 | +for f in (:checked_add, :checked_sub) |
| 11 | + @eval function ($f)(A::AbstractArray, B::AbstractArray) |
| 12 | + promote_shape(A, B) # check size compatibility |
| 13 | + broadcast_preserving_zero_d($f, A, B) |
| 14 | + end |
| 15 | +end |
| 16 | +checked_mul(A::Number, B::AbstractArray) = broadcast_preserving_zero_d(checked_mul, B, A) |
| 17 | +checked_mul(A::AbstractArray, B::Number) = broadcast_preserving_zero_d(checked_mul, A, B) |
| 18 | +checked_mul(A::AbstractArray, B::AbstractArray) = error("Checked matrix multiplication is not available") |
| 19 | + |
| 20 | +checked_pow(A::AbstractArray, B::Number) = error("Checked matrix multiplication is not available") |
| 21 | + |
| 22 | +# Compatibility with Julia 1.0 and 1.1 |
| 23 | +if VERSION < v"1.2" |
| 24 | + if VERSION < v"1.1" |
| 25 | + @inline materialize(bc::Base.Broadcast.Broadcasted) = copy(Base.Broadcast.instantiate(bc)) |
| 26 | + else |
| 27 | + using Base.Broadcast: materialize |
| 28 | + end |
| 29 | + @inline function broadcast_preserving_zero_d(f, As...) |
| 30 | + bc = Base.Broadcast.broadcasted(f, As...) |
| 31 | + r = materialize(bc) |
| 32 | + return length(axes(bc)) == 0 ? fill!(similar(bc, typeof(r)), r) : r |
| 33 | + end |
| 34 | +end |
0 commit comments