blob: 9281435d3af7d9cdce622d754acfea079539d1c2 (
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
|
//TEST(compute):COMPARE_COMPUTE:-cuda -output-using-type -shaderobj
//TEST(compute):COMPARE_COMPUTE:-cpu -output-using-type -shaderobj
//TEST(compute):COMPARE_COMPUTE: -output-using-type -shaderobj
//TEST(compute,vulkan):COMPARE_COMPUTE:-vk -output-using-type -shaderobj
//TEST_INPUT:ubuffer(data=[0 0 0 0 0 0 0 0], stride=4):out,name=outputBuffer
RWStructuredBuffer<float> outputBuffer;
float quantize(float value)
{
return int(value * 256) * 1.0f / 256.0f;
}
[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 * 2] = quantize(sin(value));
outputBuffer[tid * 2 + 1] = quantize(cos(value));
}
|