From 6c747f304c4c4f0514fcce01ad67132bbcbaa78a Mon Sep 17 00:00:00 2001 From: Michael Abbott <32575566+mcabbott@users.noreply.github.com> Date: Sat, 27 Aug 2022 19:55:18 -0400 Subject: [PATCH] mark `stop`, `skip`, `@epochs` as deprecated (#2027) * mark stop, skip, at-epochs as deprecated * remove at-epochs from testing * add removal notes * typo * Apply suggestions from code review Co-authored-by: Brian Chen Co-authored-by: Brian Chen --- src/optimise/train.jl | 17 ++++++++++++++++- src/utils.jl | 9 ++++++--- 2 files changed, 22 insertions(+), 4 deletions(-) diff --git a/src/optimise/train.jl b/src/optimise/train.jl index dac294cb19..b6d6986285 100644 --- a/src/optimise/train.jl +++ b/src/optimise/train.jl @@ -38,6 +38,9 @@ struct SkipException <: Exception end Call `Flux.skip()` in a callback to indicate when a callback condition is met. This will trigger the train loop to skip the current data point and not update with the calculated gradient. +!!! note + `Flux.skip()` will be removed from Flux 0.14 + # Examples ```julia cb = function () @@ -46,6 +49,8 @@ end ``` """ function skip() + Base.depwarn("""Flux.skip() will be removed from Flux 0.14. + and should be replaced with `continue` in an ordinary `for` loop.""", :skip) throw(SkipException()) end @@ -58,6 +63,9 @@ struct StopException <: Exception end Call `Flux.stop()` in a callback to indicate when a callback condition is met. This will trigger the train loop to stop and exit. +!!! note + `Flux.stop()` will be removed from Flux 0.14. It should be replaced with `break` in an ordinary `for` loop. + # Examples ```julia cb = function () @@ -66,6 +74,8 @@ end ``` """ function stop() + Base.depwarn("""Flux.stop() will be removed from Flux 0.14. + It should be replaced with `break` in an ordinary `for` loop.""", :stop) throw(StopException()) end @@ -140,8 +150,11 @@ end Run `body` `N` times. Mainly useful for quickly doing multiple epochs of training in a REPL. +!!! note + The macro `@epochs` will be removed from Flux 0.14. Please just write an ordinary `for` loop. + # Examples -```jldoctest +```julia julia> Flux.@epochs 2 println("hello") [ Info: Epoch 1 hello @@ -150,6 +163,8 @@ hello ``` """ macro epochs(n, ex) + Base.depwarn("""The macro `@epochs` will be removed from Flux 0.14. + As an alternative, you can write a simple `for i in 1:epochs` loop.""", Symbol("@epochs"), force=true) :(@progress for i = 1:$(esc(n)) @info "Epoch $i" $(esc(ex)) diff --git a/src/utils.jl b/src/utils.jl index ad963d5ed6..83ae222aa5 100644 --- a/src/utils.jl +++ b/src/utils.jl @@ -648,7 +648,8 @@ julia> loss() = rand(); julia> trigger = Flux.patience(() -> loss() < 1, 3); -julia> Flux.@epochs 10 begin +julia> for i in 1:10 + @info "Epoch \$i" trigger() && break end [ Info: Epoch 1 @@ -685,7 +686,8 @@ julia> loss = let l = 0 julia> es = Flux.early_stopping(loss, 3); -julia> Flux.@epochs 10 begin +julia> for i in 1:10 + @info "Epoch \$i" es() && break end [ Info: Epoch 1 @@ -726,7 +728,8 @@ julia> f = let v = 10 julia> trigger = Flux.plateau(f, 3; init_score=10, min_dist=18); -julia> Flux.@epochs 10 begin +julia> for i in 1:10 + @info "Epoch \$i" trigger() && break end [ Info: Epoch 1