blob: 2a9b9eab086d76c43d03cc02ea56071c7fee7976 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
//TEST:SIMPLE(filecheck=CHECK): -target hlsl -line-directive-mode none -stage compute -entry computeMain
//TEST:SIMPLE(filecheck=CHECK): -target cuda -line-directive-mode none
//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
RWStructuredBuffer<float> outputBuffer;
[BackwardDifferentiable]
[PreferRecompute]
float comp(float a, float b)
{
// CHECK: standard error = {
// CHECK-NEXT: }
return a * b;
}
[shader("compute")]
[numthreads(128, 1, 1)]
void computeMain(uint3 group_thread_id: SV_GroupThreadID, uint3 dispatch_thread_id: SV_DispatchThreadID)
{
DifferentialPair<float> value1 = diffPair(3.f, 0.f);
DifferentialPair<float> value2 = diffPair(3.f, 0.f);
bwd_diff(comp)(value1, value2, 1.f);
outputBuffer[dispatch_thread_id.x] = value1.d;
}
|