From d8f4c9424c69a3d406fabf56a25dd3eda4bc7d51 Mon Sep 17 00:00:00 2001 From: Sai Praveen Bangaru <31557731+saipraveenb25@users.noreply.github.com> Date: Fri, 20 Oct 2023 21:21:30 -0400 Subject: Fix issue with transposing `IRMakeVector` with non-singleton operands (#3280) --- tests/autodiff/make-array-non-uniform.slang | 39 ++++++++++++++++++++++ .../make-array-non-uniform.slang.expected.txt | 6 ++++ 2 files changed, 45 insertions(+) create mode 100644 tests/autodiff/make-array-non-uniform.slang create mode 100644 tests/autodiff/make-array-non-uniform.slang.expected.txt (limited to 'tests') diff --git a/tests/autodiff/make-array-non-uniform.slang b/tests/autodiff/make-array-non-uniform.slang new file mode 100644 index 000000000..2cdedb864 --- /dev/null +++ b/tests/autodiff/make-array-non-uniform.slang @@ -0,0 +1,39 @@ +//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj -output-using-type +//TEST(compute, vulkan):COMPARE_COMPUTE_EX:-vk -compute -shaderobj -output-using-type + +//TEST_INPUT:ubuffer(data=[0 0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +typedef DifferentialPair dpfloat2; +typedef DifferentialPair dpfloat3; +typedef DifferentialPair dpfloat4; + +[Differentiable] +float4 f(float4 x) +{ + return float4(x.rgb, x.a * x.a); +} + +[numthreads(1, 1, 1)] +void computeMain(uint3 dispatchThreadID: SV_DispatchThreadID) +{ + { + float4 a = float4(1.0, 2.0, 3.0, 4.0); + float4 da = float4(1.0, 0.5, 1.5, 2.5); + + outputBuffer[0] = fwd_diff(f)(dpfloat4(a, da)).d.x; + } + + { + float4 a = float4(1.0, 2.0, 3.0, 4.0); + + var dpa = diffPair(a); + + bwd_diff(f)(dpa, float4(1.0, 0.5, 1.5, 2.5)); + + outputBuffer[1] = dpa.d.x; // 1.0 + outputBuffer[2] = dpa.d.y; // 0.5 + outputBuffer[3] = dpa.d.z; // 0.0 + outputBuffer[4] = dpa.d.a; // 0.0 + } +} diff --git a/tests/autodiff/make-array-non-uniform.slang.expected.txt b/tests/autodiff/make-array-non-uniform.slang.expected.txt new file mode 100644 index 000000000..ba5428fd7 --- /dev/null +++ b/tests/autodiff/make-array-non-uniform.slang.expected.txt @@ -0,0 +1,6 @@ +type: float +1.000000 +1.000000 +0.500000 +1.500000 +20.000000 -- cgit v1.2.3