Skip to content

Commit

Permalink
Fix sum(::AbstractArray{<:AbstractMutable}; dims) (#310)
Browse files Browse the repository at this point in the history
  • Loading branch information
odow authored Oct 16, 2024
1 parent 3f811de commit 5705dc3
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 2 deletions.
14 changes: 12 additions & 2 deletions src/dispatch.jl
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,18 @@

abstract type AbstractMutable end

function Base.sum(a::AbstractArray{<:AbstractMutable}; kwargs...)
return operate(sum, a; kwargs...)
function Base.sum(
a::AbstractArray{T};
dims = :,
init = zero(promote_operation(+, T, T)),
) where {T<:AbstractMutable}
if dims !== Colon()
# We cannot use `mapreduce` with `add!!` instead of `Base.add_mul` like
# `operate(sum, ...)` because the same instance given at `init` is used
# at several places.
return mapreduce(identity, Base.add_sum, a; dims, init)
end
return operate(sum, a; init)
end

# When doing `x'y` where the elements of `x` and/or `y` are arrays, redirecting
Expand Down
12 changes: 12 additions & 0 deletions test/dispatch.jl
Original file line number Diff line number Diff line change
Expand Up @@ -131,3 +131,15 @@ end
# MA is at least 10-times better than no MA for this example
@test 10 * with_init < no_ma
end

@testset "sum_with_init_and_dims" begin
x = reshape(convert(Vector{DummyBigInt}, 1:12), 3, 4)
X = reshape(1:12, 3, 4)
for dims in (1, 2, :, 1:2, (1, 2))
# Without (; init)
@test MA.isequal_canonical(sum(x; dims), DummyBigInt.(sum(X; dims)))
# With (; init)
y = sum(x; init = DummyBigInt(0), dims)
@test MA.isequal_canonical(y, DummyBigInt.(sum(X; dims)))
end
end

0 comments on commit 5705dc3

Please sign in to comment.