Saves the optimizer and network states during training. The final network and optimizer are always stored.
Details
Saving the learner itself in the callback with a trained model is impossible, as the model slot is set after the last callback step is executed.
Super class
mlr3torch::CallbackSet -> CallbackSetCheckpoint
Methods
Method new()
Creates a new instance of this R6 class.
Usage
CallbackSetCheckpoint$new(path, freq, freq_type = "epoch")Arguments
- path
- ( - character(1))
 The path to a folder where the models are saved.
- freq
- ( - integer(1))
 The frequency how often the model is saved. Frequency is either per step or epoch, which can be configured through the- freq_typeparameter.
- freq_type
- ( - character(1))
 Can be be either- "epoch"(default) or- "step".
Method on_epoch_end()
Saves the network and optimizer state dict.
Does nothing if freq_type or freq are not met.
Method on_batch_end()
Saves the selected objects defined in save.
Does nothing if freq_type or freq are not met.
Examples
cb = t_clbk("checkpoint", freq = 1)
task = tsk("iris")
pth = tempfile()
learner = lrn("classif.mlp", epochs = 3, batch_size = 1, callbacks = cb)
learner$param_set$set_values(cb.checkpoint.path = pth)
learner$train(task)
list.files(pth)
#> [1] "network1.pt"   "network2.pt"   "network3.pt"   "optimizer1.pt"
#> [5] "optimizer2.pt" "optimizer3.pt"