Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(145)

Side by Side Diff: conformance/ogles/GL/mat/const_mat4_copy_vert.vert

Issue 41993002: Add ToT WebGL conformance tests : part 9 (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/deps/third_party/webgl/sdk/tests/
Patch Set: Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1
2 /*
3 ** Copyright (c) 2012 The Khronos Group Inc.
4 **
5 ** Permission is hereby granted, free of charge, to any person obtaining a
6 ** copy of this software and/or associated documentation files (the
7 ** "Materials"), to deal in the Materials without restriction, including
8 ** without limitation the rights to use, copy, modify, merge, publish,
9 ** distribute, sublicense, and/or sell copies of the Materials, and to
10 ** permit persons to whom the Materials are furnished to do so, subject to
11 ** the following conditions:
12 **
13 ** The above copyright notice and this permission notice shall be included
14 ** in all copies or substantial portions of the Materials.
15 **
16 ** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 ** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 ** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19 ** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20 ** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21 ** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22 ** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
23 */
24
25
26 attribute vec4 gtf_Vertex;
27 uniform mat4 gtf_ModelViewProjectionMatrix;
28 varying vec4 color;
29
30 #define ERROR_EPSILON 0.1
31
32 void main (void)
33 {
34 float x;
35 // Declare a constant 4 by 4 matrix with unique elements.
36 const mat4 a = mat4( 1.0, 2.0, 4.0, 8.0, // 1.0 16.0 25 6.0 4096.0
37 16.0, 32.0, 64.0, 128.0, // 2.0 32.0 51 2.0 8192.0
38 256.0, 512.0, 1024.0, 2048.0, // 4.0 64.0 102 4.0 16384.0
39 4096.0, 8192.0, 16384.0, 32768.0); // 8.0 128.0 204 8.0 32768.0
40
41 // Copy the constant matrix to another non-const matrix.
42 mat4 b = a;
43
44 // Check each element of the copy.
45 bool elms = true;
46 if(b[0][0] != 1.0) elms = false;
47 if(b[0][1] != 2.0) elms = false;
48 if(b[0][2] != 4.0) elms = false;
49 if(b[0][3] != 8.0) elms = false;
50 if(b[1][0] != 16.0) elms = false;
51 if(b[1][1] != 32.0) elms = false;
52 if(b[1][2] != 64.0) elms = false;
53 if(b[1][3] != 128.0) elms = false;
54 if(b[2][0] != 256.0) elms = false;
55 if(b[2][1] != 512.0) elms = false;
56 if(b[2][2] != 1024.0) elms = false;
57 if(b[2][3] != 2048.0) elms = false;
58 if(b[3][0] != 4096.0) elms = false;
59 if(b[3][1] != 8192.0) elms = false;
60 if(b[3][2] != 16384.0) elms = false;
61 if(b[3][3] != 32768.0) elms = false;
62
63 // Add up each row of the copy.
64 bool rows = true;
65 x = b[0][0] + b[1][0] + b[2][0] + b[3][0];
66 if(x < 4369.0-ERROR_EPSILON || x > 4369.0+ERROR_EPSILON) rows = false;
67 x = b[0][1] + b[1][1] + b[2][1] + b[3][1];
68 if(x < 8738.0-ERROR_EPSILON || x > 8738.0+ERROR_EPSILON) rows = false;
69 x = b[0][2] + b[1][2] + b[2][2] + b[3][2];
70 if(x < 17476.0-ERROR_EPSILON || x > 17476.0+ERROR_EPSILON) rows = false;
71 x = b[0][3] + b[1][3] + b[2][3] + b[3][3];
72 if(x < 34952.0-ERROR_EPSILON || x > 34952.0+ERROR_EPSILON) rows = false;
73
74 // Add up each column of the copy.
75 bool cols = true;
76 x = b[0][0] + b[0][1] + b[0][2] + b[0][3];
77 if(x < 15.0-ERROR_EPSILON || x > 15.0+ERROR_EPSILON) cols = false;
78 x = b[1][0] + b[1][1] + b[1][2] + b[1][3];
79 if(x < 240.0-ERROR_EPSILON || x > 240.0+ERROR_EPSILON) cols = false;
80 x = b[2][0] + b[2][1] + b[2][2] + b[2][3];
81 if(x < 3840.0-ERROR_EPSILON || x > 3840.0+ERROR_EPSILON) cols = false;
82 x = b[3][0] + b[3][1] + b[3][2] + b[3][3];
83 if(x < 61440.0-ERROR_EPSILON || x > 61440.0+ERROR_EPSILON) cols = false;
84
85 // Check if all of the operations were successful.
86 float gray = elms && rows && cols ? 1.0 : 0.0;
87
88 // Assign the varying variable color.
89 color = vec4(gray, gray, gray, 1.0);
90
91 // Transform the vertex position.
92 gl_Position = gtf_ModelViewProjectionMatrix * gtf_Vertex;
93 }
94
OLDNEW
« no previous file with comments | « conformance/ogles/GL/mat/const_mat4_copy_frag.frag ('k') | conformance/ogles/GL/mat/const_mat4_frag.frag » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698