https://github.com/shader-slang/slang
Raw File
Tip revision: 46529df2c4f73a4655bdd79d48004f29374a99a8 authored by Yong He on 06 November 2023, 22:40:38 UTC
Fix ICE when lowering an associatedtype declref from an derived interface. (#3312)
Tip revision: 46529df
raygen.slang.glsl
#version 460
#extension GL_EXT_ray_tracing : require
layout(row_major) uniform;
layout(row_major) buffer;
layout(binding = 0)
uniform texture2D samplerPosition_0;

layout(binding = 2)
uniform sampler sampler_0;

layout(binding = 1)
uniform texture2D samplerNormal_0;

struct Light_0
{
    vec4 position_0;
    vec4 color_0;
};

struct Uniforms_0
{
    Light_0 light_0;
    vec4 viewPos_0;
    mat4x4 view_0;
    mat4x4 model_0;
};

layout(binding = 3)
layout(std140) uniform _S1
{
    Light_0 light_0;
    vec4 viewPos_0;
    mat4x4 view_0;
    mat4x4 model_0;
}ubo_0;
layout(binding = 5)
uniform accelerationStructureEXT as_0;

layout(rgba32f)
layout(binding = 4)
uniform image2D outputImage_0;

struct ReflectionRay_0
{
    float color_1;
};

layout(location = 0)
rayPayloadEXT
ReflectionRay_0 p_0;

struct ShadowRay_0
{
    float hitDistance_0;
};

layout(location = 1)
rayPayloadEXT
ShadowRay_0 p_1;

struct RayDesc_0
{
    vec3 Origin_0;
    float TMin_0;
    vec3 Direction_0;
    float TMax_0;
};

void TraceRay_0(accelerationStructureEXT AccelerationStructure_0, uint RayFlags_0, uint InstanceInclusionMask_0, uint RayContributionToHitGroupIndex_0, uint MultiplierForGeometryContributionToHitGroupIndex_0, uint MissShaderIndex_0, RayDesc_0 Ray_0, inout ShadowRay_0 Payload_0)
{
    p_1 = Payload_0;
    traceRayEXT(AccelerationStructure_0, RayFlags_0, InstanceInclusionMask_0, RayContributionToHitGroupIndex_0, MultiplierForGeometryContributionToHitGroupIndex_0, MissShaderIndex_0, Ray_0.Origin_0, Ray_0.TMin_0, Ray_0.Direction_0, Ray_0.TMax_0, (1));
    Payload_0 = p_1;
    return;
}

void TraceRay_1(accelerationStructureEXT AccelerationStructure_1, uint RayFlags_1, uint InstanceInclusionMask_1, uint RayContributionToHitGroupIndex_1, uint MultiplierForGeometryContributionToHitGroupIndex_1, uint MissShaderIndex_1, RayDesc_0 Ray_1, inout ReflectionRay_0 Payload_1)
{
    p_0 = Payload_1;
    traceRayEXT(AccelerationStructure_1, RayFlags_1, InstanceInclusionMask_1, RayContributionToHitGroupIndex_1, MultiplierForGeometryContributionToHitGroupIndex_1, MissShaderIndex_1, Ray_1.Origin_0, Ray_1.TMin_0, Ray_1.Direction_0, Ray_1.TMax_0, (0));
    Payload_1 = p_0;
    return;
}

float saturate_0(float x_0)
{
    return clamp(x_0, 0.0, 1.0);
}

void main()
{
    uvec3 _S2 = ((gl_LaunchIDEXT));
    float _S3 = float(_S2.x) + 0.5;
    uvec3 _S4 = ((gl_LaunchSizeEXT));
    float _S5 = _S3 / float(_S4.x);
    uvec3 _S6 = ((gl_LaunchIDEXT));
    float _S7 = float(_S6.y) + 0.5;
    uvec3 _S8 = ((gl_LaunchSizeEXT));
    vec2 inUV_0 = vec2(_S5, _S7 / float(_S8.y));
    vec3 P_0 = (texture(sampler2D(samplerPosition_0,sampler_0), (inUV_0))).xyz;
    vec3 N_0 = (texture(sampler2D(samplerNormal_0,sampler_0), (inUV_0))).xyz * 2.0 - 1.0;
    vec3 lightDelta_0 = ubo_0.light_0.position_0.xyz - P_0;
    float lightDist_0 = length(lightDelta_0);
    vec3 L_0 = normalize(lightDelta_0);
    float _S9 = 1.0 / (lightDist_0 * lightDist_0);
    RayDesc_0 ray_0;
    ray_0.Origin_0 = P_0;
    ray_0.TMin_0 = 0.00000099999999747524;
    ray_0.Direction_0 = lightDelta_0;
    ray_0.TMax_0 = lightDist_0;
    ShadowRay_0 shadowRay_0;
    shadowRay_0.hitDistance_0 = 0.0;
    TraceRay_0(as_0, 1U, 255U, 0U, 0U, 2U, ray_0, shadowRay_0);
    float atten_0;
    if(shadowRay_0.hitDistance_0 < lightDist_0)
    {
        atten_0 = 0.0;
    }
    else
    {
        atten_0 = _S9;
    }
    vec3 color_2 = ubo_0.light_0.color_0.xyz * saturate_0(dot(N_0, L_0)) * atten_0;
    ReflectionRay_0 reflectionRay_0;
    TraceRay_1(as_0, 1U, 255U, 0U, 0U, 2U, ray_0, reflectionRay_0);
    vec3 color_3 = color_2 + reflectionRay_0.color_1;
    uvec3 _S10 = ((gl_LaunchIDEXT));
    imageStore((outputImage_0), ivec2((uvec2(ivec2(_S10.xy)))), vec4(color_3, 1.0));
    return;
}

back to top