conv padding
This commit is contained in:
parent
51f93d9f0e
commit
269d8f36b9
@ -2,15 +2,16 @@ struct Conv2D{F,A}
|
|||||||
σ::F
|
σ::F
|
||||||
weight::A
|
weight::A
|
||||||
stride::Int
|
stride::Int
|
||||||
|
pad::Int
|
||||||
end
|
end
|
||||||
|
|
||||||
Conv2D(k::NTuple{2,Integer}, ch::Pair{<:Integer,<:Integer}, σ = identity;
|
Conv2D(k::NTuple{2,Integer}, ch::Pair{<:Integer,<:Integer}, σ = identity;
|
||||||
init = initn, stride = 1) =
|
init = initn, stride = 1, pad = 0) =
|
||||||
Conv2D(σ, param(initn(k..., ch...)), stride)
|
Conv2D(σ, param(initn(k..., ch...)), stride, pad)
|
||||||
|
|
||||||
Flux.treelike(Conv2D)
|
Flux.treelike(Conv2D)
|
||||||
|
|
||||||
(c::Conv2D)(x) = c.σ.(conv2d(x, c.weight, stride = c.stride))
|
(c::Conv2D)(x) = c.σ.(conv2d(x, c.weight, stride = c.stride, padding = c.pad))
|
||||||
|
|
||||||
function Base.show(io::IO, l::Conv2D)
|
function Base.show(io::IO, l::Conv2D)
|
||||||
print(io, "Conv2D((", size(l.weight, 1), ", ", size(l.weight, 2), ")")
|
print(io, "Conv2D((", size(l.weight, 1), ", ", size(l.weight, 2), ")")
|
||||||
|
@ -136,18 +136,19 @@ softmax(xs::TrackedArray) = TrackedArray(Call(softmax, xs))
|
|||||||
|
|
||||||
back(::typeof(softmax), Δ, xs) = @back(xs, ∇softmax(Δ, data(xs)))
|
back(::typeof(softmax), Δ, xs) = @back(xs, ∇softmax(Δ, data(xs)))
|
||||||
|
|
||||||
_conv2d(x, w, stride) = conv2d(x, w, stride = stride)
|
# TODO: can store kwargs efficiently in namedtuples
|
||||||
|
_conv2d(x, w, stride, pad) = conv2d(x, w, stride = stride, padding = pad)
|
||||||
|
|
||||||
conv2d(x::TrackedArray{<:Any,4}, w::TrackedArray{<:Any,4}; stride = 1) =
|
conv2d(x::TrackedArray{<:Any,4}, w::TrackedArray{<:Any,4}; stride = 1, padding = 0) =
|
||||||
TrackedArray(Call(_conv2d, x, w, stride))
|
TrackedArray(Call(_conv2d, x, w, stride, padding))
|
||||||
conv2d(x::AbstractArray{<:Any,4}, w::TrackedArray{<:Any,4}; stride = 1) =
|
conv2d(x::AbstractArray{<:Any,4}, w::TrackedArray{<:Any,4}; stride = 1, padding = 0) =
|
||||||
TrackedArray(Call(_conv2d, x, w, stride))
|
TrackedArray(Call(_conv2d, x, w, stride, padding))
|
||||||
conv2d(x::TrackedArray{<:Any,4}, w::AbstractArray{<:Any,4}; stride = 1) =
|
conv2d(x::TrackedArray{<:Any,4}, w::AbstractArray{<:Any,4}; stride = 1, padding = 0) =
|
||||||
TrackedArray(Call(_conv2d, x, w, stride))
|
TrackedArray(Call(_conv2d, x, w, stride, padding))
|
||||||
|
|
||||||
function back(::typeof(_conv2d), Δ, x, w, stride)
|
function back(::typeof(_conv2d), Δ, x, w, stride, pad)
|
||||||
@back(x, NNlib.conv2d_grad_x(data(x), data(w), Δ; stride = stride))
|
@back(x, NNlib.conv2d_grad_x(data(x), data(w), Δ; stride = stride, padding = pad))
|
||||||
@back(w, NNlib.conv2d_grad_w(data(x), data(w), Δ; stride = stride))
|
@back(w, NNlib.conv2d_grad_w(data(x), data(w), Δ; stride = stride, padding = pad))
|
||||||
end
|
end
|
||||||
|
|
||||||
_pool(x, k, mode) = pool(x, window = k, mode = mode)
|
_pool(x, k, mode) = pool(x, window = k, mode = mode)
|
||||||
|
Loading…
Reference in New Issue
Block a user