Skip to content

Commit

Permalink
Deprecate vectorized ~ over AbstractArray and BitArray.
Browse files Browse the repository at this point in the history
  • Loading branch information
Sacha0 committed Feb 11, 2017
1 parent e0d4260 commit b6b08a9
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 19 deletions.
2 changes: 1 addition & 1 deletion base/arraymath.jl
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ julia> A
"""
conj!(A::AbstractArray{<:Number}) = (@inbounds broadcast!(conj, A, A); A)

for f in (:-, :~, :conj, :real, :imag)
for f in (:-, :conj, :real, :imag)
@eval ($f)(A::AbstractArray) = broadcast($f, A)
end

Expand Down
3 changes: 1 addition & 2 deletions base/bitarray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1195,7 +1195,6 @@ function (-)(B::BitArray)
end
broadcast(::typeof(sign), B::BitArray) = copy(B)

(~)(B::BitArray) = broadcast(~, B)
function broadcast(::typeof(~), B::BitArray)
C = similar(B)
Bc = B.chunks
Expand Down Expand Up @@ -1269,7 +1268,7 @@ broadcast(::typeof(&), B::BitArray, x::Bool) = x ? copy(B) : falses(size(B))
broadcast(::typeof(&), x::Bool, B::BitArray) = broadcast(&, B, x)
broadcast(::typeof(|), B::BitArray, x::Bool) = x ? trues(size(B)) : copy(B)
broadcast(::typeof(|), x::Bool, B::BitArray) = broadcast(|, B, x)
broadcast(::typeof(xor), B::BitArray, x::Bool) = x ? ~B : copy(B)
broadcast(::typeof(xor), B::BitArray, x::Bool) = x ? .~B : copy(B)
broadcast(::typeof(xor), x::Bool, B::BitArray) = broadcast(xor, B, x)
for f in (:&, :|, :xor)
@eval begin
Expand Down
4 changes: 4 additions & 0 deletions base/deprecated.jl
Original file line number Diff line number Diff line change
Expand Up @@ -827,6 +827,10 @@ end
@deprecate(!(A::AbstractArray{Bool}), .!A) # parens for #20541
@deprecate(!(B::BitArray), .!B) # parens for #20541

# Deprecate vectorized ~
@deprecate ~(A::AbstractArray) .~A
@deprecate ~(B::BitArray) .~B

function frexp(A::Array{<:AbstractFloat})
depwarn("`frexp(x::Array)` is discontinued.", :frexp)
F = similar(A)
Expand Down
4 changes: 2 additions & 2 deletions test/arrayops.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1863,8 +1863,8 @@ end
@test typeof(conj(B)) == Vector{Float64}
@test typeof(conj(C)) == Vector{Complex{Int}}

@test ~A == [9,-1,-4]
@test typeof(~A) == Vector{Int}
@test .~A == [9,-1,-4]
@test typeof(.~A) == Vector{Int}
end

@testset "issue #16247" begin
Expand Down
24 changes: 12 additions & 12 deletions test/bitarray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -721,7 +721,7 @@ timesofar("dequeue")

@testset "Unary operators" begin
b1 = bitrand(n1, n2)
@check_bit_operation (~)(b1) BitMatrix
@check_bit_operation broadcast(~, b1) BitMatrix
@check_bit_operation broadcast(!, b1) BitMatrix
@check_bit_operation (-)(b1) Matrix{Int}
@check_bit_operation broadcast(sign, b1) BitMatrix
Expand All @@ -730,15 +730,15 @@ timesofar("dequeue")
@check_bit_operation conj(b1) BitMatrix

b0 = falses(0)
@check_bit_operation (~)(b0) BitVector
@check_bit_operation broadcast(~, b0) BitVector
@check_bit_operation broadcast(!, b0) BitVector
@check_bit_operation (-)(b0) Vector{Int}
@check_bit_operation broadcast(sign, b0) BitVector

@testset "flipbits!" begin
b1 = bitrand(n1, n2)
i1 = Array(b1)
@test flipbits!(b1) == ~i1
@test flipbits!(b1) == .~i1
@test bitcheck(b1)
end
end
Expand Down Expand Up @@ -1072,13 +1072,13 @@ timesofar("datamove")
b1 = trues(v1)
for i = 0:(v1-1)
@test findfirst(b1 >> i) == i+1
@test Base.findfirstnot(~(b1 >> i)) == i+1
@test Base.findfirstnot(.~(b1 >> i)) == i+1
end

for i = 3:(v1-1), j = 2:i
submask = b1 << (v1-j+1)
@test findnext((b1 >> i) .| submask, j) == i+1
@test findnextnot((~(b1 >> i)) .⊻ submask, j) == i+1
@test findnextnot((.~(b1 >> i)) .⊻ submask, j) == i+1
end

b1 = bitrand(n1, n2)
Expand Down Expand Up @@ -1117,7 +1117,7 @@ timesofar("nnz&find")
for c = [falses, trues]
b1 = c(n)
b1[elts] = .!b1[elts]
b2 = ~b1
b2 = .~b1
i1 = Array(b1)
for i = 1:n
@test findprev(b1, i) == findprev(i1, i) == findprevnot(b2, i) == findprev(!, b2, i)
Expand All @@ -1128,7 +1128,7 @@ timesofar("nnz&find")
b1 = falses(1000)
b1[77] = true
b1[777] = true
b2 = ~b1
b2 = .~b1
@test_throws BoundsError findprev(b1, 1001)
@test_throws BoundsError findprevnot(b2, 1001)
@test_throws BoundsError findprev(!, b2, 1001)
Expand Down Expand Up @@ -1184,13 +1184,13 @@ timesofar("nnz&find")
@test findprev(t, l) == findprevnot(f, l) == l
b1 = falses(l)
b1[end] = true
b2 = ~b1
b2 = .~b1
@test findprev(b1, l) == findprevnot(b2, l) == l
@test findprevnot(b1, l) == findprev(b2, l) == l-1
if l > 1
b1 = falses(l)
b1[end-1] = true
b2 = ~b1
b2 = .~b1
@test findprev(b1, l) == findprevnot(b2, l) == l-1
@test findprevnot(b1, l) == findprev(b2, l) == l
end
Expand Down Expand Up @@ -1223,7 +1223,7 @@ timesofar("reductions")
for l = [0, 1, 63, 64, 65, 127, 128, 129, 255, 256, 257, 6399, 6400, 6401]
b1 = bitrand(l)
b2 = bitrand(l)
@test map(~, b1) == map(x->~x, b1) == ~b1
@test map(~, b1) == map(x->~x, b1) == broadcast(~, b1)
@test map(identity, b1) == map(x->x, b1) == b1

@test map(&, b1, b2) == map((x,y)->x&y, b1, b2) == broadcast(&, b1, b2)
Expand All @@ -1245,8 +1245,8 @@ timesofar("reductions")

@testset "map! for length $l" begin
b = BitArray(l)
@test map!(~, b, b1) == map!(x->~x, b, b1) == ~b1 == b
@test map!(!, b, b1) == map!(x->!x, b, b1) == ~b1 == b
@test map!(~, b, b1) == map!(x->~x, b, b1) == broadcast(~, b1) == b
@test map!(!, b, b1) == map!(x->!x, b, b1) == broadcast(~, b1) == b
@test map!(identity, b, b1) == map!(x->x, b, b1) == b1 == b
@test map!(zero, b, b1) == map!(x->false, b, b1) == falses(l) == b
@test map!(one, b, b1) == map!(x->true, b, b1) == trues(l) == b
Expand Down
4 changes: 2 additions & 2 deletions test/ranges.jl
Original file line number Diff line number Diff line change
Expand Up @@ -784,8 +784,8 @@ let A = -1:1, B = -1.0:1.0
@test conj(A) === A
@test conj(B) === B

@test ~A == [0,-1,-2]
@test typeof(~A) == Vector{Int}
@test .~A == [0,-1,-2]
@test typeof(.~A) == Vector{Int}
end

# conversion to Array
Expand Down

0 comments on commit b6b08a9

Please sign in to comment.