summaryrefslogtreecommitdiffstats
path: root/tests/autodiff/reverse-nested-calls.slang
blob: 1b59cc75d205298025080271a9cd833a3b1b7eed (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
28
29
30
31
32
33
34
//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj -output-using-type
//TEST(compute, vulkan):COMPARE_COMPUTE_EX:-vk -compute -shaderobj -output-using-type
//TEST(compute):COMPARE_COMPUTE_EX:-cpu -compute -output-using-type -shaderobj
//DISABLE_TEST:SIMPLE(filecheck=CHK):-target glsl -stage compute -entry computeMain -report-checkpoint-intermediates

//TEST_INPUT:ubuffer(data=[0 0 0 0 0], stride=4):out,name=outputBuffer
RWStructuredBuffer<float> outputBuffer;

typedef DifferentialPair<float> dpfloat;
typedef float.Differential dfloat;

[BackwardDifferentiable]
float g(float y)
{
    float result = 2.0f * y;
    return result * result;
}

[BackwardDifferentiable]
float f(float x)
{
    return 3.0f * g(2.0f * x);
}

[numthreads(1, 1, 1)]
void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
{
    dpfloat dpa = dpfloat(1.0, 0.0);

    __bwd_diff(f)(dpa, 1.0f);
    outputBuffer[0] = dpa.d; // Expect: 96.0
}

//CHK-NOT: note