Flux.jl/src/utils.jl
2017-04-19 14:23:48 +01:00

35 lines
722 B
Julia

export AArray
const AArray = AbstractArray
initn(dims...) = randn(dims...)/100
tobatch(xs::Batch) = rawbatch(xs)
tobatch(xs) = unsqueeze(xs)
function train!(m, train, test = []; epoch = 1, η = 0.1)
i = 0
for _ in 1:epoch
@progress for (x, y) in train
x, y = tobatch.((x, y))
i += 1
= m(x)
any(isnan, ) && error("NaN")
Δ = back!(mse, 1, , y)
back!(m, Δ, x)
update!(m, η)
i % 1000 == 0 && @show accuracy(m, test)
end
end
return m
end
function accuracy(m, data)
correct = 0
for (x, y) in data
x, y = tobatch.((x, y))
correct += sum(onecold(m(x)) .== onecold(y))
end
return correct/length(data)
end