| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- // RUN: %dxc -E main -T ps_6_0 -O0 %s | FileCheck %s
- // CHECK: Frc
- // CHECK: IMax
- // CHECK: UMin
- // CHECK: textureLoad
- // CHECK: Log
- // CHECK: Exp
- //
- // Copyright (c) Microsoft. All rights reserved.
- // This code is licensed under the MIT License (MIT).
- // THIS CODE IS PROVIDED *AS IS* WITHOUT WARRANTY OF
- // ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY
- // IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR
- // PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.
- //
- // Developed by Minigraph
- //
- // Author: James Stanard
- //
- //--------------------------------------------------------------------------------------
- // Simple bicubic filter
- //
- // http://en.wikipedia.org/wiki/Bicubic_interpolation
- // http://http.developer.nvidia.com/GPUGems/gpugems_ch24.html
- //
- //--------------------------------------------------------------------------------------
- #include "ShaderUtility.hlsli"
- #include "PresentRS.hlsli"
- Texture2D<float3> ColorTex : register(t0);
- SamplerState BilinearClamp : register(s0);
- cbuffer Constants : register(b0)
- {
- uint2 TextureSize;
- float A;
- }
- float W1(float x)
- {
- return x * x * ((A + 2) * x - (A + 3)) + 1.0;
- }
- float W2(float x)
- {
- return A * (x * (x * (x - 5) + 8) - 4);
- }
- float4 GetWeights(float d1)
- {
- return float4(W2(1.0 + d1), W1(d1), W1(1.0 - d1), W2(2.0 - d1));
- }
- float3 Cubic(float4 w, float3 c0, float3 c1, float3 c2, float3 c3)
- {
- return c0 * w.x + c1 * w.y + c2 * w.z + c3 * w.w;
- }
- float3 GetColor(uint s, uint t)
- {
- #ifdef GAMMA_SPACE
- return ApplyColorProfile(ColorTex[uint2(s, t)], DISPLAY_PLANE_FORMAT);
- #else
- return ColorTex[uint2(s, t)];
- #endif
- }
- [RootSignature(Present_RootSig)]
- float3 main(float4 position : SV_Position, float2 uv : TexCoord0) : SV_Target0
- {
- float2 t = uv * TextureSize + 0.5;
- float2 f = frac(t);
- int2 st = int2(t);
- uint MaxWidth = TextureSize.x - 1;
- uint MaxHeight = TextureSize.y - 1;
- uint s0 = max(st.x - 2, 0);
- uint s1 = max(st.x - 1, 0);
- uint s2 = min(st.x + 0, MaxWidth);
- uint s3 = min(st.x + 1, MaxWidth);
- uint t0 = max(st.y - 2, 0);
- uint t1 = max(st.y - 1, 0);
- uint t2 = min(st.y + 0, MaxHeight);
- uint t3 = min(st.y + 1, MaxHeight);
- float4 Weights = GetWeights(f.x);
- float3 c0 = Cubic(Weights, GetColor(s0, t0), GetColor(s1, t0), GetColor(s2, t0), GetColor(s3, t0));
- float3 c1 = Cubic(Weights, GetColor(s0, t1), GetColor(s1, t1), GetColor(s2, t1), GetColor(s3, t1));
- float3 c2 = Cubic(Weights, GetColor(s0, t2), GetColor(s1, t2), GetColor(s2, t2), GetColor(s3, t2));
- float3 c3 = Cubic(Weights, GetColor(s0, t3), GetColor(s1, t3), GetColor(s2, t3), GetColor(s3, t3));
- float3 Color = Cubic(GetWeights(f.y), c0, c1, c2, c3);
- #ifdef GAMMA_SPACE
- return Color;
- #else
- return ApplyColorProfile(Color, DISPLAY_PLANE_FORMAT);
- #endif
- }
|