Skip to content

Commit

Permalink
Fixes and more tests for indexing with non-1 logical arrays
Browse files Browse the repository at this point in the history
(cherry picked from commit c491473)
ref #18040
  • Loading branch information
timholy authored and tkelman committed Aug 20, 2016
1 parent 0136e4f commit 18aa36e
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 5 deletions.
2 changes: 1 addition & 1 deletion base/multidimensional.jl
Original file line number Diff line number Diff line change
Expand Up @@ -318,7 +318,7 @@ function _unsafe_getindex(::LinearFast, src::AbstractArray, I::AbstractArray{Boo

D = eachindex(dest)
Ds = start(D)
s = 0
s = first(linearindices(src))-1
for i in eachindex(I)
s += 1
@inbounds if I[i]
Expand Down
15 changes: 11 additions & 4 deletions test/offsetarray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ let
# Basics
v0 = rand(4)
v = OffsetArray(v0, (-3,))
h = OffsetArray([-1,1,-2,2,0], (-3,))
@test indices(v) == (-2:1,)
@test_throws ErrorException size(v)
@test_throws ErrorException size(v, 1)
Expand Down Expand Up @@ -48,6 +49,16 @@ S = OffsetArray(view(A0, 1:2, 1:2), (-1,2)) # LinearSlow
@test eachindex(A) == 1:4
@test eachindex(S) == CartesianRange((0:1,3:4))

# logical indexing
@test A[A .> 2] == [3,4]
@test_throws BoundsError h[trues(2)]
@test_throws BoundsError h[trues(5)]
@test h[OffsetArray(trues(5), (-3,))] == parent(h)
@test h[OffsetArray([true,false,false,true,true], (-3,))] == parent(h)[[1,4,5]]
@test A[OffsetArray([true false; false true], A.offsets)] == [1,4]
@test A[OffsetArray([true true; false true], A.offsets)] == [1,3,4]
@test_throws BoundsError A[[true true; false true]]

# view
S = view(A, :, 3)
@test S == OffsetArray([1,2], (A.offsets[1],))
Expand Down Expand Up @@ -172,9 +183,6 @@ v = view(A0, i1, 1)
v = view(A0, 1:1, i1)
@test indices(v) === (Base.OneTo(1), -4:-3)

# logical indexing
@test A[A .> 2] == [3,4]

# copy! and fill!
a = OffsetArray{Int}((-3:-1,))
fill!(a, -1)
Expand Down Expand Up @@ -281,7 +289,6 @@ I,J,N = findnz(z)
@test I == [-1]
@test J == [0]
@test N == [2]
h = OffsetArray([-1,1,-2,2,0], (-3,))
@test find(h) == [-2:1;]
@test find(x->x>0, h) == [-1,1]
@test find(x->x<0, h) == [-2,0]
Expand Down

1 comment on commit 18aa36e

@tkelman
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@nanosoldier runbenchmarks(ALL, vs = "@0350e5769b43f56c4c570741b0f5b2edf9399dc7")
18aa36e vs rc2

Please sign in to comment.