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

Side by Side Diff: conformance/ogles/GL/atan/atan_float_vert_xvaryyvary_ref.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 attribute vec4 gtf_Color;
28 uniform mat4 gtf_ModelViewProjectionMatrix;
29 varying vec4 color;
30
31 void main (void)
32 {
33 const float M_PI = 3.14159265358979323846;
34 float x = 2.0 * (gtf_Color.g - 0.5);
35 float y = 2.0 * (gtf_Color.b - 0.5);
36 float atan_c = 0.0;
37 float scale = 1.0;
38 float sign = 1.0;
39 vec4 result = vec4(0.0, 0.0, 0.0, 1.0);
40 const float epsilon = 1.0e-4;
41
42 // Avoid evaluating atan(0, x) for x < epsilon because it's implementati on-dependent
43 if(x > epsilon || abs(y) > epsilon)
44 {
45 if(x < 0.0 ^^ y < 0.0)
46 {
47 sign = -1.0;
48 }
49
50 if(abs(y) <= abs(x))
51 {
52 float c = abs(y / x);
53
54 // Taylors series expansion for atan
55 for(int i = 1; i < 12; i += 2)
56 {
57 atan_c += scale * pow(c, float(i)) / float(i);
58 scale *= -1.0;
59 }
60
61 result = vec4(sign * atan_c / (2.0 * M_PI) + 0.5, 0.0, 0 .0, 1.0);
62 }
63 else
64 {
65 float c = abs(x / y);
66
67 // Taylors series expansion for atan
68 for(int i = 1; i < 12; i += 2)
69 {
70 atan_c += scale * pow(c, float(i)) / float(i);
71 scale *= -1.0;
72 }
73
74 result = vec4(sign * (M_PI / 2.0 - atan_c) / (2.0 * M_PI ) + 0.5, 0.0, 0.0, 1.0);
75 }
76
77 if(x < 0.0)
78 if(y < 0.0) result.r -= 0.5;
79 else if(y > 0.0) result.r += 0.5;
80 }
81
82 color = result;
83 gl_Position = gtf_ModelViewProjectionMatrix * gtf_Vertex;
84 }
85
OLDNEW
« no previous file with comments | « conformance/ogles/GL/atan/atan_float_vert_xvaryyvary.vert ('k') | conformance/ogles/GL/atan/atan_vec2_frag_xvary.frag » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698