revive basic train code
This commit is contained in:
parent
6e5e532cc1
commit
5ea18ddffd
|
@ -0,0 +1,8 @@
|
|||
export mse, mse!
|
||||
|
||||
function mse!(∇, pred, target)
|
||||
map!(-, ∇, pred, target)
|
||||
sumabs2(∇)/2
|
||||
end
|
||||
|
||||
mse(pred, target) = mse(similar(pred), pred, target)
|
23
src/utils.jl
23
src/utils.jl
|
@ -4,3 +4,26 @@ const AArray = AbstractArray
|
|||
|
||||
onehot(label, labels) = [i == label for i in labels]
|
||||
onecold(pred, labels = 1:length(pred)) = labels[findfirst(pred, maximum(pred))]
|
||||
|
||||
function train!(m::Model, train, test = []; epoch = 1, batch = 10, η = 0.1)
|
||||
i = 0
|
||||
∇ = zeros(length(train[1][2]))
|
||||
for _ in 1:epoch
|
||||
for (x, y) in shuffle!(train)
|
||||
i += 1
|
||||
err = mse!(∇, m(x), y)
|
||||
back!(m, ∇)
|
||||
i % batch == 0 && update!(m, η/batch)
|
||||
end
|
||||
@show accuracy(m, test)
|
||||
end
|
||||
return m
|
||||
end
|
||||
|
||||
function accuracy(m::Model, data)
|
||||
correct = 0
|
||||
for (x, y) in data
|
||||
onecold(m(x)) == onecold(y) && (correct += 1)
|
||||
end
|
||||
return correct/length(data)
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue