| #include <metal_stdlib> |
| #include <simd/simd.h> |
| using namespace metal; |
| struct Inputs { |
| }; |
| struct Outputs { |
| float4 sk_FragColor [[color(0)]]; |
| }; |
| struct Globals { |
| float3x3 a; |
| float3x3 b; |
| float4x4 c; |
| float4x4 d; |
| }; |
| |
| template <int C, int R> |
| matrix<float, C, R> matrixCompMult(matrix<float, C, R> a, matrix<float, C, R> b) { |
| matrix<float, C, R> result; |
| for (int c = 0; c < C; ++c) { |
| result[c] = a[c] * b[c]; |
| } |
| return result; |
| } |
| fragment Outputs fragmentMain(Inputs _in [[stage_in]], bool _frontFacing [[front_facing]], float4 _fragCoord [[position]]) { |
| Globals _globals{{}, {}, {}, {}}; |
| (void)_globals; |
| Outputs _out; |
| (void)_out; |
| _out.sk_FragColor.xyz = matrixCompMult(_globals.a, _globals.b)[0]; |
| _out.sk_FragColor = matrixCompMult(_globals.c, _globals.d)[0]; |
| return _out; |
| } |