update training process, mnist example
This commit is contained in:
parent
f6334e7e96
commit
42688f8aa8
@ -14,7 +14,7 @@ m = @Chain(
|
|||||||
model = mxnet(m)
|
model = mxnet(m)
|
||||||
|
|
||||||
# An example prediction pre-training
|
# An example prediction pre-training
|
||||||
model(data[1][1])
|
model(unsqueeze(data[1][1]))
|
||||||
|
|
||||||
Flux.train!(model, train, test, η = 1e-4)
|
Flux.train!(model, train, test, η = 1e-4)
|
||||||
|
|
||||||
|
@ -1,8 +1,5 @@
|
|||||||
export mse, mse!
|
export mse, mse!
|
||||||
|
|
||||||
function mse!(Δ, pred, target)
|
mse(ŷ, y) = sumabs2(ŷ .- y)/2
|
||||||
map!(-, Δ, pred, target)
|
|
||||||
sumabs2(Δ)/2
|
|
||||||
end
|
|
||||||
|
|
||||||
mse(pred, target) = mse!(similar(pred), pred, target)
|
back!(::typeof(mse), Δ, ŷ, y) = Δ*(ŷ .- y)
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
export onehot, onecold, chunk, partition, batches, sequences
|
export onehot, onecold, chunk, partition, batches, sequences
|
||||||
|
|
||||||
|
mapt(f, x) = f(x)
|
||||||
|
mapt(f, xs::Tuple) = map(x -> mapt(f, x), xs)
|
||||||
|
|
||||||
convertel(T::Type, xs::AbstractArray) = convert.(T, xs)
|
convertel(T::Type, xs::AbstractArray) = convert.(T, xs)
|
||||||
convertel{T}(::Type{T}, xs::AbstractArray{T}) = xs
|
convertel{T}(::Type{T}, xs::AbstractArray{T}) = xs
|
||||||
|
|
||||||
@ -21,7 +24,11 @@ onehot(label, labels) = onehot(Int, label, labels)
|
|||||||
The inverse of `onehot`; takes an output prediction vector and a list of
|
The inverse of `onehot`; takes an output prediction vector and a list of
|
||||||
possible values, and produces the appropriate value.
|
possible values, and produces the appropriate value.
|
||||||
"""
|
"""
|
||||||
onecold(pred, labels = 1:length(pred)) = labels[findfirst(pred, maximum(pred))]
|
onecold(y::AbstractVector, labels = 1:length(y)) =
|
||||||
|
labels[findfirst(y, maximum(y))]
|
||||||
|
|
||||||
|
onecold(y::AbstractMatrix, l...) =
|
||||||
|
squeeze(mapslices(y -> onecold(y, l...), y, 2), 2)
|
||||||
|
|
||||||
using Iterators
|
using Iterators
|
||||||
import Iterators: Partition, partition
|
import Iterators: Partition, partition
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
export unsqueeze
|
||||||
|
|
||||||
unsqueeze(xs, dim = 1) = reshape(xs, (size(xs)[1:dim-1]..., 1, size(xs)[dim:end]...))
|
unsqueeze(xs, dim = 1) = reshape(xs, (size(xs)[1:dim-1]..., 1, size(xs)[dim:end]...))
|
||||||
Base.squeeze(xs) = squeeze(xs, 1)
|
Base.squeeze(xs) = squeeze(xs, 1)
|
||||||
|
|
||||||
|
21
src/utils.jl
21
src/utils.jl
@ -2,22 +2,22 @@ export AArray
|
|||||||
|
|
||||||
const AArray = AbstractArray
|
const AArray = AbstractArray
|
||||||
|
|
||||||
mapt(f, x) = f(x)
|
|
||||||
mapt(f, xs::Tuple) = map(x -> mapt(f, x), xs)
|
|
||||||
|
|
||||||
initn(dims...) = randn(dims...)/100
|
initn(dims...) = randn(dims...)/100
|
||||||
|
|
||||||
function train!(m, train, test = []; epoch = 1, batch = 10, η = 0.1)
|
tobatch(xs::Batch) = rawbatch(xs)
|
||||||
|
tobatch(xs) = unsqueeze(xs)
|
||||||
|
|
||||||
|
function train!(m, train, test = []; epoch = 1, η = 0.1)
|
||||||
i = 0
|
i = 0
|
||||||
Δ = zeros(length(train[1][2]))
|
|
||||||
for _ in 1:epoch
|
for _ in 1:epoch
|
||||||
@progress for (x, y) in train
|
@progress for (x, y) in train
|
||||||
|
x, y = tobatch.((x, y))
|
||||||
i += 1
|
i += 1
|
||||||
pred = m(x)
|
ŷ = m(x)
|
||||||
any(isnan, pred) && error("NaN")
|
any(isnan, ŷ) && error("NaN")
|
||||||
err = mse!(Δ, pred, y)
|
Δ = back!(mse, 1, ŷ, y)
|
||||||
back!(m, Δ, x)
|
back!(m, Δ, x)
|
||||||
i % batch == 0 && update!(m, η)
|
update!(m, η)
|
||||||
i % 1000 == 0 && @show accuracy(m, test)
|
i % 1000 == 0 && @show accuracy(m, test)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -27,7 +27,8 @@ end
|
|||||||
function accuracy(m, data)
|
function accuracy(m, data)
|
||||||
correct = 0
|
correct = 0
|
||||||
for (x, y) in data
|
for (x, y) in data
|
||||||
onecold(m(x)) == onecold(y) && (correct += 1)
|
x, y = tobatch.((x, y))
|
||||||
|
correct += sum(onecold(m(x)) .== onecold(y))
|
||||||
end
|
end
|
||||||
return correct/length(data)
|
return correct/length(data)
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user