27af716c3a
This roughly matches their semantics in SPIR-V and MSL. For `FMin`, `FMax`, and `FClamp`, and the Metal functions `fast::min()`, `fast::max()`, and `fast::clamp()`, the result is undefined if any operand is NaN. For the 'N' operations and their corresponding MSL `precise::` functions, the result is consistent with IEEE 754 (first non-NaN wins; result is NaN if all operands are NaN). We can only do this with 32-bit floats, though, because Metal only provides these variants for `float`. `half` only has one variant of these functions that is presumably consistent with IEEE 754. I guess that's OK; the SPIR-V spec only says that `F{Min,Max,Clamp}` are undefined for NaNs. Performance might suffer, though.
41 lines
794 B
GLSL
41 lines
794 B
GLSL
#include <metal_stdlib>
|
|
#include <simd/simd.h>
|
|
|
|
using namespace metal;
|
|
|
|
struct Light
|
|
{
|
|
packed_float3 Position;
|
|
float Radius;
|
|
float4 Color;
|
|
};
|
|
|
|
struct UBO
|
|
{
|
|
float4x4 uMVP;
|
|
Light light;
|
|
};
|
|
|
|
struct main0_out
|
|
{
|
|
float4 vColor [[user(locn0)]];
|
|
float4 gl_Position [[position]];
|
|
};
|
|
|
|
struct main0_in
|
|
{
|
|
float4 aVertex [[attribute(0)]];
|
|
float3 aNormal [[attribute(1)]];
|
|
};
|
|
|
|
vertex main0_out main0(main0_in in [[stage_in]], constant UBO& _18 [[buffer(0)]])
|
|
{
|
|
main0_out out = {};
|
|
out.gl_Position = _18.uMVP * in.aVertex;
|
|
out.vColor = float4(0.0);
|
|
float3 L = in.aVertex.xyz - float3(_18.light.Position);
|
|
out.vColor += ((_18.light.Color * fast::clamp(1.0 - (length(L) / _18.light.Radius), 0.0, 1.0)) * dot(in.aNormal, normalize(L)));
|
|
return out;
|
|
}
|
|
|