[Piglit] [PATCH v5 3/3] arb_shader_precision: add manually written tests for a*b+c and fma()

Micah Fedke micah.fedke at collabora.co.uk
Wed Apr 8 12:45:30 PDT 2015


Ian,

Thanks for taking a look at this.

The "draw arrays" was just something I had copied from a working test 
and never really asked myself if it was very readable.  The only issue I 
would have with your world coord solution is that some of these tests 
have more than four vectors.  I could use "ortho" to set individual 
pixels, however.

Would something like this make sense to you:

-[vertex data]
-piglit_vertex/float/2
--1.0 -1.0
- 1.0 -1.0
- 1.0  1.0
--1.0  1.0
-
  [test]
+ortho
  uniform float arg0  -2.99999993e-02
  uniform float arg1  -8.50000024e-01
  uniform float arg2  -2.54999995e-02
  uniform float expected_a  0.00000000e+00
  uniform float expected_b  6.22123464e-10
-draw arrays GL_TRIANGLE_FAN 0 4
-probe rgba 0 0 0.0 1.0 0.0 1.0
+draw rect 0 0 1 1
+probe rgba (0, 0) (0.0, 1.0, 0.0, 1.0)
  uniform float arg0  1.66999996e+00
  uniform float arg1  6.60000026e-01
  uniform float arg2  1.00000036e+00
  uniform float expected_a  2.10220027e+00
  uniform float expected_b  2.10220051e+00
-draw arrays GL_TRIANGLE_FAN 0 4
-probe rgba 1 0 0.0 1.0 0.0 1.0
+draw rect 1 1 1 1
+probe rgba (1, 1) (0.0, 1.0, 0.0, 1.0)
  uniform float arg0  -2.99999993e-02
  uniform float arg1  6.60000026e-01
  uniform float arg2  1.41949999e+00
  uniform float expected_a  1.39970005e+00
  uniform float expected_b  1.39970005e+00
-draw arrays GL_TRIANGLE_FAN 0 4
-probe rgba 2 0 0.0 1.0 0.0 1.0
+draw rect 2 2 1 1
+probe rgba (2, 2) (0.0, 1.0, 0.0, 1.0)
  uniform float arg0  1.87000000e+00
  uniform float arg1  -2.99999993e-02
  uniform float arg2  1.56979990e+00
  uniform float expected_a  1.51369989e+00
  uniform float expected_b  1.51369989e+00
-draw arrays GL_TRIANGLE_FAN 0 4
-probe rgba 3 0 0.0 1.0 0.0 1.0
+draw rect 3 3 1 1
+probe rgba (3, 3) (0.0, 1.0, 0.0, 1.0)


I will replace my scientific values with their binary counterparts for 
readability - Ilia recommended that very thing, now that I think about it.


-mf


On 04/06/2015 09:16 PM, Ian Romanick wrote:
> On 04/03/2015 02:00 PM, Micah Fedke wrote:
>>
>> ---
>>   .../fs-fma-float-float-float.shader_test           | 56 +++++++++++++++
>>   .../fs-manual-fma-float-float-float.shader_test    | 56 +++++++++++++++
>>   .../gs-fma-float-float-float.shader_test           | 80 ++++++++++++++++++++++
>>   .../gs-manual-fma-float-float-float.shader_test    | 80 ++++++++++++++++++++++
>>   .../vs-fma-float-float-float.shader_test           | 65 ++++++++++++++++++
>>   .../vs-manual-fma-float-float-float.shader_test    | 65 ++++++++++++++++++
>>   6 files changed, 402 insertions(+)
>>   create mode 100644 tests/spec/arb_shader_precision/fs-fma-float-float-float.shader_test
>>   create mode 100644 tests/spec/arb_shader_precision/fs-manual-fma-float-float-float.shader_test
>>   create mode 100644 tests/spec/arb_shader_precision/gs-fma-float-float-float.shader_test
>>   create mode 100644 tests/spec/arb_shader_precision/gs-manual-fma-float-float-float.shader_test
>>   create mode 100644 tests/spec/arb_shader_precision/vs-fma-float-float-float.shader_test
>>   create mode 100644 tests/spec/arb_shader_precision/vs-manual-fma-float-float-float.shader_test
>>
>> diff --git a/tests/spec/arb_shader_precision/fs-fma-float-float-float.shader_test b/tests/spec/arb_shader_precision/fs-fma-float-float-float.shader_test
>> new file mode 100644
>> index 0000000..f8b186a
>> --- /dev/null
>> +++ b/tests/spec/arb_shader_precision/fs-fma-float-float-float.shader_test
>> @@ -0,0 +1,56 @@
>> +
>> +[require]
>> +GLSL >= 4.00
>> +
>> +[vertex shader passthrough]
>> +
>> +[fragment shader]
>> +#extension GL_ARB_shader_precision : require
>> +uniform float arg0;
>> +uniform float arg1;
>> +uniform float arg2;
>> +uniform float expected_a;
>> +uniform float expected_b;
>> +
>> +void main()
>> +{
>> +  float result = fma(arg0, arg1, arg2);
>> +  gl_FragColor = result == expected_a || result == expected_b ? vec4(0.0, 1.0, 0.0, 1.0) : vec4(1.0, 0.0, 0.0, 1.0);
>> +}
>> +
>> +[vertex data]
>> +piglit_vertex/float/2
>> +-1.0 -1.0
>> + 1.0 -1.0
>> + 1.0  1.0
>> +-1.0  1.0
>
> Why not just use 'draw rect -1 -1 2 2'?  I'm also not a fan of tests
> that redraw the whole window multiple times.  Debugging failures that
> aren't in the last subtest is very annoying.
>
> Since there are four subtests, it's better to have each draw to a
> specific region of the window.
>
> draw rect -1 -1 1 1
> ...
> draw rect  1 -1 1 1
> ...
> draw rect -1  1 1 1
> ...
> draw rect  1  1 1 1
>
>> +
>> +[test]
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  -8.50000024e-01
>> +uniform float arg2  -2.54999995e-02
>
> Trying to get bit-exact results using floating point notation always
> makes me nervous.  As of commit d859c94 you can specify float values
> using the raw, IEEE 754 hexadecimal notation.
>
>> +uniform float expected_a  0.00000000e+00
>> +uniform float expected_b  6.22123464e-10
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 0 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.66999996e+00
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.00000036e+00
>> +uniform float expected_a  2.10220027e+00
>> +uniform float expected_b  2.10220051e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 1 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.41949999e+00
>> +uniform float expected_a  1.39970005e+00
>> +uniform float expected_b  1.39970005e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 2 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.87000000e+00
>> +uniform float arg1  -2.99999993e-02
>> +uniform float arg2  1.56979990e+00
>> +uniform float expected_a  1.51369989e+00
>> +uniform float expected_b  1.51369989e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 3 0 0.0 1.0 0.0 1.0
>> diff --git a/tests/spec/arb_shader_precision/fs-manual-fma-float-float-float.shader_test b/tests/spec/arb_shader_precision/fs-manual-fma-float-float-float.shader_test
>> new file mode 100644
>> index 0000000..e8ade84
>> --- /dev/null
>> +++ b/tests/spec/arb_shader_precision/fs-manual-fma-float-float-float.shader_test
>> @@ -0,0 +1,56 @@
>> +
>> +[require]
>> +GLSL >= 4.00
>> +
>> +[vertex shader passthrough]
>> +
>> +[fragment shader]
>> +#extension GL_ARB_shader_precision : require
>> +uniform float arg0;
>> +uniform float arg1;
>> +uniform float arg2;
>> +uniform float expected_a;
>> +uniform float expected_b;
>> +
>> +void main()
>> +{
>> +  float result = arg0 * arg1 + arg2;
>> +  gl_FragColor = result == expected_a || result == expected_b ? vec4(0.0, 1.0, 0.0, 1.0) : vec4(1.0, 0.0, 0.0, 1.0);
>> +}
>> +
>> +[vertex data]
>> +piglit_vertex/float/2
>> +-1.0 -1.0
>> + 1.0 -1.0
>> + 1.0  1.0
>> +-1.0  1.0
>> +
>> +[test]
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  -8.50000024e-01
>> +uniform float arg2  -2.54999995e-02
>> +uniform float expected_a  0.00000000e+00
>> +uniform float expected_b  6.22123464e-10
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 0 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.66999996e+00
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.00000036e+00
>> +uniform float expected_a  2.10220027e+00
>> +uniform float expected_b  2.10220051e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 1 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.41949999e+00
>> +uniform float expected_a  1.39970005e+00
>> +uniform float expected_b  1.39970005e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 2 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.87000000e+00
>> +uniform float arg1  -2.99999993e-02
>> +uniform float arg2  1.56979990e+00
>> +uniform float expected_a  1.51369989e+00
>> +uniform float expected_b  1.51369989e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 3 0 0.0 1.0 0.0 1.0
>> diff --git a/tests/spec/arb_shader_precision/gs-fma-float-float-float.shader_test b/tests/spec/arb_shader_precision/gs-fma-float-float-float.shader_test
>> new file mode 100644
>> index 0000000..12fcb53
>> --- /dev/null
>> +++ b/tests/spec/arb_shader_precision/gs-fma-float-float-float.shader_test
>> @@ -0,0 +1,80 @@
>> +
>> +[require]
>> +GLSL >= 4.00
>> +
>> +[vertex shader]
>> +in vec4 piglit_vertex;
>> +flat out vec4 vertex_to_gs;
>> +void main()
>> +{
>> +     vertex_to_gs = piglit_vertex;
>> +}
>> +
>> +[geometry shader]
>> +#extension GL_ARB_shader_precision : require
>> +layout(triangles) in;
>> +layout(triangle_strip, max_vertices = 3) out;
>> +flat in vec4 vertex_to_gs[3];
>> +flat out vec4 color;
>> +uniform float arg0;
>> +uniform float arg1;
>> +uniform float arg2;
>> +uniform float expected_a;
>> +uniform float expected_b;
>> +
>> +void main()
>> +{
>> +  vec4 tmp_color;
>> +  float result = fma(arg0, arg1, arg2);
>> +  tmp_color = result == expected_a || result == expected_b ? vec4(0.0, 1.0, 0.0, 1.0) : vec4(1.0, 0.0, 0.0, 1.0);
>> +  for (int i = 0; i < 3; i++) {
>> +    gl_Position = vertex_to_gs[i];
>> +    color = tmp_color;
>> +    EmitVertex();
>> +  }
>> +}
>> +
>> +[fragment shader]
>> +flat in vec4 color;
>> +
>> +void main()
>> +{
>> +  gl_FragColor = color;
>> +}
>> +
>> +[vertex data]
>> +piglit_vertex/float/2
>> +-1.0 -1.0
>> + 1.0 -1.0
>> + 1.0  1.0
>> +-1.0  1.0
>> +
>> +[test]
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  -8.50000024e-01
>> +uniform float arg2  -2.54999995e-02
>> +uniform float expected_a  0.00000000e+00
>> +uniform float expected_b  6.22123464e-10
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 0 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.66999996e+00
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.00000036e+00
>> +uniform float expected_a  2.10220027e+00
>> +uniform float expected_b  2.10220051e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 1 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.41949999e+00
>> +uniform float expected_a  1.39970005e+00
>> +uniform float expected_b  1.39970005e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 2 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.87000000e+00
>> +uniform float arg1  -2.99999993e-02
>> +uniform float arg2  1.56979990e+00
>> +uniform float expected_a  1.51369989e+00
>> +uniform float expected_b  1.51369989e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 3 0 0.0 1.0 0.0 1.0
>> diff --git a/tests/spec/arb_shader_precision/gs-manual-fma-float-float-float.shader_test b/tests/spec/arb_shader_precision/gs-manual-fma-float-float-float.shader_test
>> new file mode 100644
>> index 0000000..eeebfc7
>> --- /dev/null
>> +++ b/tests/spec/arb_shader_precision/gs-manual-fma-float-float-float.shader_test
>> @@ -0,0 +1,80 @@
>> +
>> +[require]
>> +GLSL >= 4.00
>> +
>> +[vertex shader]
>> +in vec4 piglit_vertex;
>> +flat out vec4 vertex_to_gs;
>> +void main()
>> +{
>> +     vertex_to_gs = piglit_vertex;
>> +}
>> +
>> +[geometry shader]
>> +#extension GL_ARB_shader_precision : require
>> +layout(triangles) in;
>> +layout(triangle_strip, max_vertices = 3) out;
>> +flat in vec4 vertex_to_gs[3];
>> +flat out vec4 color;
>> +uniform float arg0;
>> +uniform float arg1;
>> +uniform float arg2;
>> +uniform float expected_a;
>> +uniform float expected_b;
>> +
>> +void main()
>> +{
>> +  vec4 tmp_color;
>> +  float result = arg0 * arg1 + arg2;
>> +  tmp_color = result == expected_a || result == expected_b ? vec4(0.0, 1.0, 0.0, 1.0) : vec4(1.0, 0.0, 0.0, 1.0);
>> +  for (int i = 0; i < 3; i++) {
>> +    gl_Position = vertex_to_gs[i];
>> +    color = tmp_color;
>> +    EmitVertex();
>> +  }
>> +}
>> +
>> +[fragment shader]
>> +flat in vec4 color;
>> +
>> +void main()
>> +{
>> +  gl_FragColor = color;
>> +}
>> +
>> +[vertex data]
>> +piglit_vertex/float/2
>> +-1.0 -1.0
>> + 1.0 -1.0
>> + 1.0  1.0
>> +-1.0  1.0
>> +
>> +[test]
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  -8.50000024e-01
>> +uniform float arg2  -2.54999995e-02
>> +uniform float expected_a  0.00000000e+00
>> +uniform float expected_b  6.22123464e-10
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 0 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.66999996e+00
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.00000036e+00
>> +uniform float expected_a  2.10220027e+00
>> +uniform float expected_b  2.10220051e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 1 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.41949999e+00
>> +uniform float expected_a  1.39970005e+00
>> +uniform float expected_b  1.39970005e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 2 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.87000000e+00
>> +uniform float arg1  -2.99999993e-02
>> +uniform float arg2  1.56979990e+00
>> +uniform float expected_a  1.51369989e+00
>> +uniform float expected_b  1.51369989e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 3 0 0.0 1.0 0.0 1.0
>> diff --git a/tests/spec/arb_shader_precision/vs-fma-float-float-float.shader_test b/tests/spec/arb_shader_precision/vs-fma-float-float-float.shader_test
>> new file mode 100644
>> index 0000000..6234ff4
>> --- /dev/null
>> +++ b/tests/spec/arb_shader_precision/vs-fma-float-float-float.shader_test
>> @@ -0,0 +1,65 @@
>> +
>> +[require]
>> +GLSL >= 4.00
>> +
>> +[vertex shader]
>> +#extension GL_ARB_shader_precision : require
>> +in vec4 piglit_vertex;
>> +flat out vec4 color;
>> +uniform float arg0;
>> +uniform float arg1;
>> +uniform float arg2;
>> +uniform float expected_a;
>> +uniform float expected_b;
>> +
>> +void main()
>> +{
>> +  gl_Position = piglit_vertex;
>> +  float result = fma(arg0, arg1, arg2);
>> +  color = result == expected_a || result == expected_b ? vec4(0.0, 1.0, 0.0, 1.0) : vec4(1.0, 0.0, 0.0, 1.0);
>> +}
>> +
>> +[fragment shader]
>> +flat in vec4 color;
>> +
>> +void main()
>> +{
>> +  gl_FragColor = color;
>> +}
>> +
>> +[vertex data]
>> +piglit_vertex/float/2
>> +-1.0 -1.0
>> + 1.0 -1.0
>> + 1.0  1.0
>> +-1.0  1.0
>> +
>> +[test]
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  -8.50000024e-01
>> +uniform float arg2  -2.54999995e-02
>> +uniform float expected_a  0.00000000e+00
>> +uniform float expected_b  6.22123464e-10
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 0 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.66999996e+00
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.00000036e+00
>> +uniform float expected_a  2.10220027e+00
>> +uniform float expected_b  2.10220051e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 1 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.41949999e+00
>> +uniform float expected_a  1.39970005e+00
>> +uniform float expected_b  1.39970005e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 2 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.87000000e+00
>> +uniform float arg1  -2.99999993e-02
>> +uniform float arg2  1.56979990e+00
>> +uniform float expected_a  1.51369989e+00
>> +uniform float expected_b  1.51369989e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 3 0 0.0 1.0 0.0 1.0
>> diff --git a/tests/spec/arb_shader_precision/vs-manual-fma-float-float-float.shader_test b/tests/spec/arb_shader_precision/vs-manual-fma-float-float-float.shader_test
>> new file mode 100644
>> index 0000000..4ba2d02
>> --- /dev/null
>> +++ b/tests/spec/arb_shader_precision/vs-manual-fma-float-float-float.shader_test
>> @@ -0,0 +1,65 @@
>> +
>> +[require]
>> +GLSL >= 4.00
>> +
>> +[vertex shader]
>> +#extension GL_ARB_shader_precision : require
>> +in vec4 piglit_vertex;
>> +flat out vec4 color;
>> +uniform float arg0;
>> +uniform float arg1;
>> +uniform float arg2;
>> +uniform float expected_a;
>> +uniform float expected_b;
>> +
>> +void main()
>> +{
>> +  gl_Position = piglit_vertex;
>> +  float result = arg0 * arg1 + arg2;
>> +  color = result == expected_a || result == expected_b ? vec4(0.0, 1.0, 0.0, 1.0) : vec4(1.0, 0.0, 0.0, 1.0);
>> +}
>> +
>> +[fragment shader]
>> +flat in vec4 color;
>> +
>> +void main()
>> +{
>> +  gl_FragColor = color;
>> +}
>> +
>> +[vertex data]
>> +piglit_vertex/float/2
>> +-1.0 -1.0
>> + 1.0 -1.0
>> + 1.0  1.0
>> +-1.0  1.0
>> +
>> +[test]
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  -8.50000024e-01
>> +uniform float arg2  -2.54999995e-02
>> +uniform float expected_a  0.00000000e+00
>> +uniform float expected_b  6.22123464e-10
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 0 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.66999996e+00
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.00000036e+00
>> +uniform float expected_a  2.10220027e+00
>> +uniform float expected_b  2.10220051e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 1 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  -2.99999993e-02
>> +uniform float arg1  6.60000026e-01
>> +uniform float arg2  1.41949999e+00
>> +uniform float expected_a  1.39970005e+00
>> +uniform float expected_b  1.39970005e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 2 0 0.0 1.0 0.0 1.0
>> +uniform float arg0  1.87000000e+00
>> +uniform float arg1  -2.99999993e-02
>> +uniform float arg2  1.56979990e+00
>> +uniform float expected_a  1.51369989e+00
>> +uniform float expected_b  1.51369989e+00
>> +draw arrays GL_TRIANGLE_FAN 0 4
>> +probe rgba 3 0 0.0 1.0 0.0 1.0
>>
>

-- 

Micah Fedke
Collabora Ltd.
+44 1223 362967
https://www.collabora.com/
https://twitter.com/collaboraltd


More information about the Piglit mailing list