Files
swift-mirror/test/AutoDiff/Syntax/round_trip_parse_gen.swift
Richard Wei af8942d940 [AutoDiff] Rename '@differentiable' to '@differentiable(reverse)'.
Compiler:
- Add `Forward` and `Reverse` to `DifferentiabilityKind`.
- Expand `DifferentiabilityMask` in `ExtInfo` to 3 bits so that it now holds all 4 cases of `DifferentiabilityKind`.
- Parse `@differentiable(reverse)` and `@differentiable(_forward)` declaration attributes and type attributes.
- Emit a warning for `@differentiable` without `reverse`.
- Emit an error for `@differentiable(_forward)`.
- Rename `@differentiable(linear)` to `@differentiable(_linear)`.
- Make `@differentiable(reverse)` type lowering go through today's `@differentiable` code path. We will specialize it to reverse-mode in a follow-up patch.

ABI:
- Add `Forward` and `Reverse` to `FunctionMetadataDifferentiabilityKind`.
- Extend `TargetFunctionTypeFlags` by 1 bit to store the highest bit of differentiability kind (linear). Note that there is a 2-bit gap in `DifferentiabilityMask` which is reserved for `AsyncMask` and `ConcurrentMask`; `AsyncMask` is ABI-stable so we cannot change that.

_Differentiation module:
- Replace all occurrences of `@differentiable` with `@differentiable(reverse)`.
- Delete `_transpose(of:)`.

Resolves rdar://69980056.
2021-02-07 14:09:46 -08:00

123 lines
3.5 KiB
Swift

// RUN: rm -rf %t
// RUN: %swift-syntax-test -input-source-filename %s -parse-gen > %t
// RUN: diff -u %s %t
// RUN: %swift-syntax-test -input-source-filename %s -parse-gen -print-node-kind > %t.withkinds
// RUN: diff -u %S/Outputs/round_trip_parse_gen.swift.withkinds %t.withkinds
// RUN: %swift-syntax-test -input-source-filename %s -eof > %t
// RUN: diff -u %s %t
// RUN: %swift-syntax-test -serialize-raw-tree -input-source-filename %s > %t.dump
// RUN: %swift-syntax-test -deserialize-raw-tree -input-source-filename %t.dump -output-filename %t
// RUN: diff -u %s %t
// Note: RUN lines copied from test/Syntax/round_trip_parse_gen.swift.
@differentiable(reverse)
func bar(_ x: Float, _: Float) -> Float { return 1 }
@differentiable(reverse where T : FloatingPoint)
func bar<T : Numeric>(_ x: T, _: T) -> T { return 1 }
@differentiable(reverse, wrt: x)
func bar(_ x: Float, _: Float) -> Float { return 1 }
@differentiable(reverse, wrt: (self, x, y))
func bar(_ x: Float, y: Float) -> Float { return 1 }
@differentiable(reverse, wrt: (self, x, y) where T : FloatingPoint)
func bar<T : Numeric>(_ x: T, y: T) -> T { return 1 }
@derivative(of: -)
func negateDerivative(_ x: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (-x, { v in -v })
}
@derivative(of: baz(label:_:), wrt: (x))
func bazDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@derivative(of: baz(label:_:).set, wrt: (x))
func bazSetDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@derivative(of: baz(label:_:).get, wrt: (x))
func bazGetDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@transpose(of: -)
func negateDerivative(_ x: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (-x, { v in -v })
}
@derivative(of: baz(label:_:), wrt: (x))
func bazDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@derivative(of: A<T>.B<U, V>.C.foo(label:_:), wrt: x)
func qualifiedDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@derivative(of: A<T>.B<U, V>.C.foo(label:_:).get, wrt: x)
func qualifiedGetDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@derivative(of: A<T>.B<U, V>.C.foo(label:_:).set, wrt: x)
func qualifiedSetDerivative(_ x: Float, y: Float)
-> (value: Float, pullback: (Float) -> Float) {
return (x, { v in v })
}
@transpose(of: +)
func addTranspose(_ v: Float) -> (Float, Float) {
return (v, v)
}
@transpose(of: -, wrt: (0, 1))
func subtractTranspose(_ v: Float) -> (Float, Float) {
return (v, -v)
}
@transpose(of: Float.-, wrt: (0, 1))
func subtractTranspose(_ v: Float) -> (Float, Float) {
return (v, -v)
}
@transpose(of: Float.-.get, wrt: (0, 1))
func subtractGetTranspose(_ v: Float) -> (Float, Float) {
return (v, -v)
}
@transpose(of: Float.-.set, wrt: (0, 1))
func subtractSetTranspose(_ v: Float) -> (Float, Float) {
return (v, -v)
}
@derivative(of: A<T>.B<U, V>.C.foo(label:_:), wrt: 0)
func qualifiedTranspose(_ v: Float) -> (Float, Float) {
return (v, -v)
}
@transpose(of: A<T>.B<U, V>.C.foo(label:_:).get, wrt: 0)
func qualifiedGetTranspose(_ v: Float) -> (Float, Float) {
return (v, -v)
}
@derivative(of: subscript(_:).set, wrt: (self, newValue))
func subscriptSetterDerivative() {}
@transpose(of: subscript(_:).set, wrt: (self, 0)
func subscriptSetterTranspose() {}