From 6edfce9d1e8322a53a5f42e4bf527aa8a42307f6 Mon Sep 17 00:00:00 2001 From: Brian Chen Date: Sun, 14 May 2023 17:37:57 -0700 Subject: [PATCH] Excise getindex adjoint We have a better rule in Chainrules now --- src/lib/array.jl | 18 ------------------ 1 file changed, 18 deletions(-) diff --git a/src/lib/array.jl b/src/lib/array.jl index 37884cded..a182c037d 100644 --- a/src/lib/array.jl +++ b/src/lib/array.jl @@ -41,24 +41,6 @@ end @adjoint (::Type{T})(sz) where {T<:Zeros} = T(sz), Δ->(nothing,) @adjoint (::Type{T})(sz) where {T<:Ones} = T(sz), Δ->(nothing,) -@adjoint getindex(x::AbstractArray, inds...) = x[inds...], ∇getindex(x, inds) - -@adjoint view(x::AbstractArray, inds...) = view(x, inds...), ∇getindex(x, inds) - -∇getindex(x::AbstractArray{T,N}, inds) where {T,N} = dy -> begin - if inds isa NTuple{N,Int} && T <: Number - dx = OneElement(dy, inds, axes(x)) - elseif inds isa NTuple{<:Any, Integer} - dx = _zero(x, typeof(dy)) - dx[inds...] = dy - else - dx = _zero(x, eltype(dy)) - dxv = view(dx, inds...) - dxv .= accum.(dxv, _droplike(dy, dxv)) - end - return (_project(x, dx), map(_->nothing, inds)...) -end - """ OneElement(val, ind, axes) <: AbstractArray