public protocol Differentiable
Un tipo que representa matemáticamente una variedad diferenciable cuyos espacios tangentes son de dimensión finita.
Un tipo que representa las derivadas de un valor diferenciable.
Matemáticamente, esto es equivalente al paquete tangente de la variedad diferenciable representada por el tipo diferenciable.
Declaración
associatedtype TangentVector: Differentiable & AdditiveArithmetic where TangentVector.TangentVector == TangentVector
Mueve
self
lo largo de la dirección dada. En la geometría de Riemann, esto es equivalente a mapa exponencial, que se mueveself
en la superficie geodésica lo largo del vector tangente dado.Declaración
mutating mutating func move(along direction: TangentVector)
Un cierre que produce un vector cero tangente, la captura de la información necesaria mínima por parte de
self
.move(along: zeroTangentVectorInitializer())
no debe modificarself
.En algunos casos, el vector cero tangente del
self
es igual aTangentVector.zero
. En otros casos, el vector cero tangente depende de la información enself
, tales como la forma de un tipo de matriz n-dimensional. Para la programación diferenciable, es más eficiente en la memoria para definir una costumbrezeroTangentVectorInitializer
propiedad que devuelve un cierre que capta y utiliza sólo la información necesaria para crear un vector tangente a cero. Por ejemplo:struct Vector { var scalars: [Float] var count: Int { scalars.count } init(scalars: [Float]) { ... } init(repeating repeatedElement: Float, count: Int) { ... } } extension Vector: AdditiveArithmetic { ... } extension Vector: Differentiable { typealias TangentVector = Vector @noDerivative var zeroTangentVectorInitializer: () -> TangentVector { let count = self.count return { TangentVector(repeating: 0, count: count) } } }
Declaración
var zeroTangentVectorInitializer: () -> TangentVector { get }
Un vector tangente inicializa utilizando
zeroTangentVectorInitializer
.move(along: zeroTangentVector)
no debe modificarself
.Declaración
var zeroTangentVector: TangentVector { get }
Declaración
@differentiable(wrt: self) func withRecomputationInPullbacks<Result : Differentiable>( _ body: @escaping @differentiable (Self) -> Result ) -> Result
Se aplica el cierre dado a la derivada de
self
.Las devoluciones
self
como una función de identidad. Cuando el valor de retorno se utiliza en un contexto en el que se diferencia con respecto a, se aplica el cierre dado a la derivada del valor de retorno.Declaración
@differentiable(wrt: self) func withDerivative(_ body: @escaping (inout TangentVector) -> Void) -> Self
Devuelve el resultado calculado mediante la aplicación de una secuencia de capas para la producción de la capa anterior, excepto que la entrada de la primera capa es
self
.Declaración
Parámetros
l1
La primera capa.
l2
La segunda capa.
Valor devuelto
Salida de la capa final después de la aplicación secuencial.
Devuelve el resultado calculado mediante la aplicación de una secuencia de capas para la producción de la capa anterior, excepto que la entrada de la primera capa es
self
.Declaración
Parámetros
l1
La primera capa.
l2
La segunda capa.
l3
La tercera capa.
Valor devuelto
Salida de la capa final después de la aplicación secuencial.
Devuelve el resultado calculado mediante la aplicación de una secuencia de capas para la producción de la capa anterior, excepto que la entrada de la primera capa es
self
.Declaración
Parámetros
l1
La primera capa.
l2
La segunda capa.
l3
La tercera capa.
l4
La cuarta capa.
Valor devuelto
Salida de la capa final después de la aplicación secuencial.
Devuelve el resultado calculado mediante la aplicación de una secuencia de capas para la producción de la capa anterior, excepto que la entrada de la primera capa es
self
.Declaración
Parámetros
l1
La primera capa.
l2
La segunda capa.
l3
La tercera capa.
l4
La tercera capa.
l5
La quinta capa.
Valor devuelto
Salida de la capa final después de la aplicación secuencial.
Devuelve el resultado calculado mediante la aplicación de una secuencia de capas para la producción de la capa anterior, excepto que la entrada de la primera capa es
self
.Declaración
@differentiable public func sequenced<L1: Layer, L2: Layer, L3: Layer, L4: Layer, L5: Layer, L6: Layer>( through l1: L1, _ l2: L2, _ l3: L3, _ l4: L4, _ l5: L5, _ l6: L6 ) -> L6.Output where L1.Input == Self, L1.Output == L2.Input, L2.Output == L3.Input, L3.Output == L4.Input, L4.Output == L5.Input, L5.Output == L6.Input
Parámetros
l1
La primera capa.
l2
La segunda capa.
l3
La tercera capa.
l4
La tercera capa.
l5
La quinta capa.
l6
La sexta capa.
Valor devuelto
Salida de la capa final después de la aplicación secuencial.