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

Side by Side Diff: conformance/ogles/GL/atan/atan_float_frag_xvary_ref.frag

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 #ifdef GL_ES
27 precision mediump float;
28 #endif
29 varying vec4 color;
30
31 void main (void)
32 {
33 const float M_PI = 3.14159265358979323846;
34 float c = 4.0 * 2.0 * (color.r - 0.5);
35 float atan_c = 0.0;
36 float scale = 1.0;
37 float sign = 1.0;
38 vec4 result;
39
40 if(c < 0.0)
41 {
42 sign = -1.0;
43 c *= -1.0;
44 }
45
46 if(c <= 1.0)
47 {
48 // Taylors series expansion for atan
49 for(int i = 1; i < 12; i += 2)
50 {
51 atan_c += scale * pow(c, float(i)) / float(i);
52 scale *= -1.0;
53 }
54
55 result = vec4(sign * atan_c / M_PI + 0.5, 0.0, 0.0, 1.0);
56 }
57 else
58 {
59 c = 1.0 / c;
60
61 // Taylors series expansion for atan
62 for(int i = 1; i < 12; i += 2)
63 {
64 atan_c += scale * pow(c, float(i)) / float(i);
65 scale *= -1.0;
66 }
67
68 result = vec4(sign * (M_PI / 2.0 - atan_c) / M_PI + 0.5, 0.0, 0. 0, 1.0);
69 }
70
71 gl_FragColor = result;
72 }
OLDNEW
« no previous file with comments | « conformance/ogles/GL/atan/atan_float_frag_xvary.frag ('k') | conformance/ogles/GL/atan/atan_float_frag_xvaryyvary.frag » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698