SPIRV-Cross/reference/shaders-msl/vert/read-from-row-major-array.vert

67 lines
1.7 KiB
GLSL
Raw Normal View History

#pragma clang diagnostic ignored "-Wmissing-prototypes"
#include <metal_stdlib>
#include <simd/simd.h>
using namespace metal;
struct Block
{
float2x3 var[3][4];
};
struct main0_out
{
float v_vtxResult [[user(locn0)]];
float4 gl_Position [[position]];
};
struct main0_in
{
float4 a_position [[attribute(0)]];
};
// Implementation of a conversion of matrix content from RowMajor to ColumnMajor organization.
float2x3 spvConvertFromRowMajor2x3(float2x3 m)
{
return float2x3(float3(m[0][0], m[0][2], m[1][1]), float3(m[0][1], m[1][0], m[1][2]));
}
float compare_float(thread const float& a, thread const float& b)
{
return float(abs(a - b) < 0.0500000007450580596923828125);
}
float compare_vec3(thread const float3& a, thread const float3& b)
{
float param = a.x;
float param_1 = b.x;
float param_2 = a.y;
float param_3 = b.y;
float param_4 = a.z;
float param_5 = b.z;
return (compare_float(param, param_1) * compare_float(param_2, param_3)) * compare_float(param_4, param_5);
}
float compare_mat2x3(thread const float2x3& a, thread const float2x3& b)
{
float3 param = a[0];
float3 param_1 = b[0];
float3 param_2 = a[1];
float3 param_3 = b[1];
return compare_vec3(param, param_1) * compare_vec3(param_2, param_3);
}
vertex main0_out main0(main0_in in [[stage_in]], constant Block& _104 [[buffer(0)]])
{
main0_out out = {};
out.gl_Position = in.a_position;
float result = 1.0;
float2x3 param = spvConvertFromRowMajor2x3(_104.var[0][0]);
float2x3 param_1 = float2x3(float3(2.0, 6.0, -6.0), float3(0.0, 5.0, 5.0));
result *= compare_mat2x3(param, param_1);
out.v_vtxResult = result;
return out;
}