From a3651d99fb8f3a046365d60751d1f3f806e48f7a Mon Sep 17 00:00:00 2001 From: jsmall-nvidia Date: Mon, 2 Dec 2019 11:14:28 -0500 Subject: Fix bug in calcSafeRadians. (#1138) --- tests/compute/transcendental.slang | 31 +++++++++++++++++++++++++ tests/compute/transcendental.slang.expected.txt | 16 +++++++++++++ 2 files changed, 47 insertions(+) create mode 100644 tests/compute/transcendental.slang create mode 100644 tests/compute/transcendental.slang.expected.txt (limited to 'tests') diff --git a/tests/compute/transcendental.slang b/tests/compute/transcendental.slang new file mode 100644 index 000000000..aa40da752 --- /dev/null +++ b/tests/compute/transcendental.slang @@ -0,0 +1,31 @@ +//TEST(compute):COMPARE_COMPUTE:-cpu +//TEST(compute):COMPARE_COMPUTE: +//TEST(compute,vulcan):COMPARE_COMPUTE:-vk + +//TEST_INPUT:ubuffer(data=[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer : register(u0); + +int quantize(double value) +{ + return int(value * 256); +} + +int quantize(float value) +{ + return int(value * 256); +} + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + float values[] = { -9, 9, -3, 3 }; + + int tid = int(dispatchThreadID.x); + float value = values[tid]; + + outputBuffer[tid * 4] = quantize(sin(value)); + outputBuffer[tid * 4 + 1] = quantize(cos(value)); + + outputBuffer[tid * 4 + 2] = quantize(sin(double(value))); + outputBuffer[tid * 4 + 3] = quantize(cos(double(value))); +} \ No newline at end of file diff --git a/tests/compute/transcendental.slang.expected.txt b/tests/compute/transcendental.slang.expected.txt new file mode 100644 index 000000000..4a525cc7c --- /dev/null +++ b/tests/compute/transcendental.slang.expected.txt @@ -0,0 +1,16 @@ +FFFFFF97 +FFFFFF17 +FFFFFF97 +FFFFFF17 +69 +FFFFFF17 +69 +FFFFFF17 +FFFFFFDC +FFFFFF03 +FFFFFFDC +FFFFFF03 +24 +FFFFFF03 +24 +FFFFFF03 -- cgit v1.2.3