mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
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.
24 lines
937 B
Swift
24 lines
937 B
Swift
// RUN: %target-swift-frontend -typecheck -verify %s
|
|
|
|
// TF-1167: `OverrideMatcher::match` crash due to meaningless assertion:
|
|
// `assert(false)`. The assertion was triggered when parameter indices
|
|
// could not be resolved for neither base nor derived declaration
|
|
// `@differentiable` attributes.
|
|
//
|
|
// `import _Differentiation` is intentionally omitted from this test case.
|
|
|
|
public protocol Base {
|
|
associatedtype Input
|
|
// expected-error @+1 {{cannot find type 'Differentiable' in scope}}
|
|
associatedtype Output: Differentiable
|
|
|
|
// expected-error @+1 {{@differentiable attribute used without importing module '_Differentiation'}}
|
|
@differentiable(reverse, wrt: self)
|
|
func callAsFunction(_ input: Input) -> Output
|
|
}
|
|
public protocol Derived: Base {
|
|
// expected-error @+1 {{@differentiable attribute used without importing module '_Differentiation'}}
|
|
@differentiable(reverse)
|
|
func callAsFunction(_ input: Input) -> Output
|
|
}
|