public class Adam<Model: Differentiable>: Optimizer
where
Model.TangentVector: VectorProtocol & PointwiseMultiplicative
& ElementaryFunctions & KeyPathIterable,
Model.TangentVector.VectorSpaceScalar == Float
Ottimizzatore di Adam.
Implementa l'algoritmo di ottimizzazione di Adam. Adam è un metodo stocastico di discesa del gradiente che calcola i tassi di apprendimento adattivo individuali per diversi parametri dalle stime dei momenti di primo e secondo ordine dei gradienti.
Riferimento: "Adam: un metodo per l'ottimizzazione stocastica" (Kingma e Ba, 2014).
Esempi:
- Formare un semplice agente di apprendimento per rinforzo:
...
// Instantiate an agent's policy - approximated by the neural network (`net`) after defining it
in advance.
var net = Net(observationSize: Int(observationSize), hiddenSize: hiddenSize, actionCount: actionCount)
// Define the Adam optimizer for the network with a learning rate set to 0.01.
let optimizer = Adam(for: net, learningRate: 0.01)
...
// Begin training the agent (over a certain number of episodes).
while true {
...
// Implementing the gradient descent with the Adam optimizer:
// Define the gradients (use withLearningPhase to call a closure under a learning phase).
let gradients = withLearningPhase(.training) {
TensorFlow.gradient(at: net) { net -> Tensor<Float> in
// Return a softmax (loss) function
return loss = softmaxCrossEntropy(logits: net(input), probabilities: target)
}
}
// Update the differentiable variables of the network (`net`) along the gradients with the Adam
optimizer.
optimizer.update(&net, along: gradients)
...
}
}
- Formare una rete avversaria generativa (GAN):
...
// Instantiate the generator and the discriminator networks after defining them.
var generator = Generator()
var discriminator = Discriminator()
// Define the Adam optimizers for each network with a learning rate set to 2e-4 and beta1 - to 0.5.
let adamOptimizerG = Adam(for: generator, learningRate: 2e-4, beta1: 0.5)
let adamOptimizerD = Adam(for: discriminator, learningRate: 2e-4, beta1: 0.5)
...
Start the training loop over a certain number of epochs (`epochCount`).
for epoch in 1...epochCount {
// Start the training phase.
...
for batch in trainingShuffled.batched(batchSize) {
// Implementing the gradient descent with the Adam optimizer:
// 1) Update the generator.
...
let 𝛁generator = TensorFlow.gradient(at: generator) { generator -> Tensor<Float> in
...
return loss
}
// Update the differentiable variables of the generator along the gradients (`𝛁generator`)
// with the Adam optimizer.
adamOptimizerG.update(&generator, along: 𝛁generator)
// 2) Update the discriminator.
...
let 𝛁discriminator = TensorFlow.gradient(at: discriminator) { discriminator -> Tensor<Float> in
...
return loss
}
// Update the differentiable variables of the discriminator along the gradients (`𝛁discriminator`)
// with the Adam optimizer.
adamOptimizerD.update(&discriminator, along: 𝛁discriminator)
}
}
Dichiarazione
public typealias Model = Model
Il tasso di apprendimento.
Dichiarazione
public var learningRate: Float
Un coefficiente utilizzato per calcolare i primi momenti dei gradienti.
Dichiarazione
public var beta1: Float
Un coefficiente utilizzato per calcolare i momenti secondi dei gradienti.
Dichiarazione
public var beta2: Float
Un piccolo scalare aggiunto al denominatore per migliorare la stabilità numerica.
Dichiarazione
public var epsilon: Float
Il decadimento del tasso di apprendimento.
Dichiarazione
public var decay: Float
Il passo attuale.
Dichiarazione
public var step: Int
I primi momenti dei pesi.
Dichiarazione
public var firstMoments: Model.TangentVector
I momenti secondi dei pesi.
Dichiarazione
public var secondMoments: Model.TangentVector
Dichiarazione
public init( for model: __shared Model, learningRate: Float = 1e-3, beta1: Float = 0.9, beta2: Float = 0.999, epsilon: Float = 1e-8, decay: Float = 0 )
Parametri
learningRate
Il tasso di apprendimento. Il valore predefinito è
1e-3
.beta1
Il tasso di decadimento esponenziale per le stime del primo momento. Il valore predefinito è
0.9
.beta2
Il tasso di decadimento esponenziale per le stime del 2° momento. Il valore predefinito è
0.999
.epsilon
Un piccolo scalare aggiunto al denominatore per migliorare la stabilità numerica. Il valore predefinito è
1e-8
.decay
Il decadimento del tasso di apprendimento. Il valore predefinito è
0
.Dichiarazione
public required init(copying other: Adam, to device: Device)