1 /* polytopes --- Shows one of the six regular polytopes rotating in 4d */
4 static const char sccsid[] = "@(#)polytopes.c 1.2 05/09/28 xlockmore";
7 /* Copyright (c) 2003-2007 Carsten Steger <carsten@mirsanmir.org>. */
10 * Permission to use, copy, modify, and distribute this software and its
11 * documentation for any purpose and without fee is hereby granted,
12 * provided that the above copyright notice appear in all copies and that
13 * both that copyright notice and this permission notice appear in
14 * supporting documentation.
16 * This file is provided AS IS with no warranties of any kind. The author
17 * shall have no liability with respect to the infringement of copyrights,
18 * trade secrets or any patents by this file or any part thereof. In no
19 * event will the author be liable for any lost revenue or profits or
20 * other special, indirect and consequential damages.
23 * C. Steger - 03/08/10: Initial version
24 * C. Steger - 05/09/28: Added trackball support
25 * C. Steger - 07/01/23: Improved 4d trackball support
29 * This program shows one of the six regular 4D polytopes rotating in 4D.
30 * Written by Carsten Steger, inspired by H.S.M Coxeter's book "Regular
31 * Polytopes", 3rd Edition, Dover Publications, Inc., 1973, and Thomas
32 * Banchoff's book "Beyond the Third Dimension: Geometry, Computer
33 * Graphics, and Higher Dimensions", Scientific American Library, 1990.
37 #define M_PI 3.14159265358979323846
40 #define SQRT15OVER4 1.93649167310370844259 /* sqrt(15/4) */
41 #define SQRT10OVER3 1.82574185835055371152 /* sqrt(10/3) */
42 #define SQRT5OVER2 1.58113883008418966600 /* sqrt(5/2) */
43 #define SQRT5OVER6 0.91287092917527685576 /* sqrt(5/6) */
44 #define SQRT5OVER12 0.64549722436790281420 /* sqrt(5/12) */
45 #define SQRT2 1.41421356237309504880 /* sqrt(2) */
46 #define GOLDEN 1.61803398874989484820 /* (sqrt(5)+1)/2 */
47 #define GOLDENINV 0.61803398874989484820 /* (sqrt(5)-1)/2 */
48 #define SQRT2INV 0.70710678118654752440 /* sqrt(1/2) */
49 #define GOLDEN2 1.14412280563536859520 /* ((sqrt(5)+1)/2)/sqrt(2) */
50 #define GOLDENINV2 0.43701602444882107080 /* ((sqrt(5)-1)/2)/sqrt(2) */
51 #define GOLDEN22 1.85122958682191611960 /* (((sqrt(5)+1)/2)^2)/sqrt(2) */
52 #define GOLDENINV22 0.27009075673772645360 /* (((sqrt(5)-1)/2)^2)/sqrt(2) */
54 #define DISP_WIREFRAME 0
55 #define DISP_WIREFRAME_STR "0"
56 #define DISP_SURFACE 1
57 #define DISP_SURFACE_STR "1"
58 #define DISP_TRANSPARENT 2
59 #define DISP_TRANSPARENT_STR "2"
61 #define POLYTOPE_RANDOM -1
62 #define POLYTOPE_RANDOM_STR "-1"
63 #define POLYTOPE_5_CELL 0
64 #define POLYTOPE_5_CELL_STR "0"
65 #define POLYTOPE_8_CELL 1
66 #define POLYTOPE_8_CELL_STR "1"
67 #define POLYTOPE_16_CELL 2
68 #define POLYTOPE_16_CELL_STR "2"
69 #define POLYTOPE_24_CELL 3
70 #define POLYTOPE_24_CELL_STR "3"
71 #define POLYTOPE_120_CELL 4
72 #define POLYTOPE_120_CELL_STR "4"
73 #define POLYTOPE_600_CELL 5
74 #define POLYTOPE_600_CELL_STR "5"
75 #define POLYTOPE_LAST_CELL POLYTOPE_600_CELL
77 #define COLORS_SINGLE 0
78 #define COLORS_SINGLE_STR "0"
79 #define COLORS_DEPTH 1
80 #define COLORS_DEPTH_STR "1"
82 #define DISP_3D_PERSPECTIVE 0
83 #define DISP_3D_PERSPECTIVE_STR "0"
84 #define DISP_3D_ORTHOGRAPHIC 1
85 #define DISP_3D_ORTHOGRAPHIC_STR "1"
87 #define DISP_4D_PERSPECTIVE 0
88 #define DISP_4D_PERSPECTIVE_STR "0"
89 #define DISP_4D_ORTHOGRAPHIC 1
90 #define DISP_4D_ORTHOGRAPHIC_STR "1"
93 #define DALPHA_STR "1.1"
95 #define DBETA_STR "1.3"
97 #define DDELTA_STR "1.5"
99 #define DZETA_STR "1.7"
101 #define DETA_STR "1.9"
103 #define DTHETA_STR "2.1"
105 #define DEF_DISPLAY_MODE DISP_TRANSPARENT_STR
106 #define DEF_POLYTOPE POLYTOPE_RANDOM_STR
107 #define DEF_COLORS COLORS_DEPTH_STR
108 #define DEF_3D_PROJECTION DISP_3D_PERSPECTIVE_STR
109 #define DEF_4D_PROJECTION DISP_4D_PERSPECTIVE_STR
110 #define DEF_DALPHA DALPHA_STR
111 #define DEF_DBETA DBETA_STR
112 #define DEF_DDELTA DDELTA_STR
113 #define DEF_DZETA DZETA_STR
114 #define DEF_DETA DETA_STR
115 #define DEF_DTHETA DTHETA_STR
118 # define DEFAULTS "*delay: 25000 \n" \
121 # define refresh_polytopes 0
122 # include "xlockmore.h" /* from the xscreensaver distribution */
123 #else /* !STANDALONE */
124 # include "xlock.h" /* from the xlockmore distribution */
125 #endif /* !STANDALONE */
129 #include <X11/keysym.h>
130 #include "gltrackball.h"
134 ModStruct polytopes_description =
135 {"polytopes", "init_polytopes", "draw_polytopes", "release_polytopes",
136 "draw_polytopes", "change_polytopes", NULL, &polytopes_opts,
137 25000, 1, 1, 1, 1.0, 4, "",
138 "Shows one of the six regular 4d polytopes rotating in 4d", 0, NULL};
143 static int display_mode;
145 static int color_mode;
146 static int projection_3d;
147 static int projection_4d;
148 static float speed_wx;
149 static float speed_wy;
150 static float speed_wz;
151 static float speed_xy;
152 static float speed_xz;
153 static float speed_yz;
155 static const float offset4d[4] = { 0.0, 0.0, 0.0, 3.0 };
156 static const float offset3d[4] = { 0.0, 0.0, -2.0, 0.0 };
159 static XrmOptionDescRec opts[] =
161 {"-mode", ".polytopes.displayMode", XrmoptionSepArg, 0 },
162 {"-wireframe", ".polytopes.displayMode", XrmoptionNoArg,
163 DISP_WIREFRAME_STR },
164 {"-surface", ".polytopes.displayMode", XrmoptionNoArg,
166 {"-transparent", ".polytopes.displayMode", XrmoptionNoArg,
167 DISP_TRANSPARENT_STR },
168 {"-random", ".polytopes.polytope", XrmoptionNoArg,
169 POLYTOPE_RANDOM_STR },
171 {"-polytope", ".polytopes.polytope", XrmoptionSepArg, 0 },
172 {"-5-cell", ".polytopes.polytope", XrmoptionNoArg,
173 POLYTOPE_5_CELL_STR },
174 {"-8-cell", ".polytopes.polytope", XrmoptionNoArg,
175 POLYTOPE_8_CELL_STR },
176 {"-16-cell", ".polytopes.polytope", XrmoptionNoArg,
177 POLYTOPE_16_CELL_STR },
178 {"-24-cell", ".polytopes.polytope", XrmoptionNoArg,
179 POLYTOPE_24_CELL_STR },
180 {"-120-cell", ".polytopes.polytope", XrmoptionNoArg,
181 POLYTOPE_120_CELL_STR },
182 {"-600-cell", ".polytopes.polytope", XrmoptionNoArg,
183 POLYTOPE_600_CELL_STR },
184 {"-single-color", ".polytopes.colors", XrmoptionNoArg,
186 {"-depth-colors", ".polytopes.colors", XrmoptionNoArg,
188 {"-perspective-3d", ".polytopes.projection3d", XrmoptionNoArg,
189 DISP_3D_PERSPECTIVE_STR },
190 {"-orthographic-3d", ".polytopes.projection3d", XrmoptionNoArg,
191 DISP_3D_ORTHOGRAPHIC_STR },
192 {"-perspective-4d", ".polytopes.projection4d", XrmoptionNoArg,
193 DISP_4D_PERSPECTIVE_STR },
194 {"-orthographic-4d", ".polytopes.projection4d", XrmoptionNoArg,
195 DISP_4D_ORTHOGRAPHIC_STR },
196 {"-speed-wx", ".polytopes.speedwx", XrmoptionSepArg, 0 },
197 {"-speed-wy", ".polytopes.speedwy", XrmoptionSepArg, 0 },
198 {"-speed-wz", ".polytopes.speedwz", XrmoptionSepArg, 0 },
199 {"-speed-xy", ".polytopes.speedxy", XrmoptionSepArg, 0 },
200 {"-speed-xz", ".polytopes.speedxz", XrmoptionSepArg, 0 },
201 {"-speed-yz", ".polytopes.speedyz", XrmoptionSepArg, 0 }
204 static argtype vars[] =
206 { &display_mode, "displayMode", "DisplayMode", DEF_DISPLAY_MODE, t_Int },
207 { &polytope, "polytope", "Polytope", DEF_POLYTOPE, t_Int },
208 { &color_mode, "colors", "Colors", DEF_COLORS, t_Int },
209 { &projection_3d, "projection3d", "Projection3d",DEF_3D_PROJECTION, t_Int },
210 { &projection_4d, "projection4d", "Projection4d",DEF_4D_PROJECTION, t_Int },
211 { &speed_wx, "speedwx", "Speedwx", DEF_DALPHA, t_Float},
212 { &speed_wy, "speedwy", "Speedwy", DEF_DBETA, t_Float},
213 { &speed_wz, "speedwz", "Speedwz", DEF_DDELTA, t_Float},
214 { &speed_xy, "speedxy", "Speedxy", DEF_DZETA, t_Float},
215 { &speed_xz, "speedxz", "Speedxz", DEF_DETA, t_Float},
216 { &speed_yz, "speedyz", "Speedyz", DEF_DTHETA, t_Float}
219 static OptionStruct desc[] =
221 { "-wireframe", "display the polytope as a wireframe mesh" },
222 { "-surface", "display the polytope as a solid surface" },
223 { "-transparent", "display the polytope as a transparent surface" },
224 { "-solid", "display the polytope as a solid object" },
225 { "-bands", "display the polytope as see-through bands" },
226 { "-twosided", "display the polytope with two colors" },
227 { "-colorwheel", "display the polytope with a smooth color wheel" },
228 { "-perspective-3d", "project the polytope perspectively from 3d to 2d" },
229 { "-orthographic-3d", "project the polytope orthographically from 3d to 2d"},
230 { "-perspective-4d", "project the polytope perspectively from 4d to 3d" },
231 { "-orthographic-4d", "project the polytope orthographically from 4d to 3d"},
232 { "-speed-wx <arg>", "rotation speed around the wx plane" },
233 { "-speed-wy <arg>", "rotation speed around the wy plane" },
234 { "-speed-wz <arg>", "rotation speed around the wz plane" },
235 { "-speed-xy <arg>", "rotation speed around the xy plane" },
236 { "-speed-xz <arg>", "rotation speed around the xz plane" },
237 { "-speed-yz <arg>", "rotation speed around the yz plane" }
240 ENTRYPOINT ModeSpecOpt polytopes_opts =
241 {sizeof opts / sizeof opts[0], opts, sizeof vars / sizeof vars[0], vars, desc};
246 #define NUM_EDGE_5 10
247 #define NUM_FACE_5 10
248 #define VERT_PER_FACE_5 3
250 #define MIN_EDGE_DEPTH_5 (-0.5)
251 #define MAX_EDGE_DEPTH_5 0.75
252 #define MIN_FACE_DEPTH_5 (-0.5)
253 #define MAX_FACE_DEPTH_5 (1.0/3.0)
257 #define NUM_VERT_8 16
258 #define NUM_EDGE_8 32
259 #define NUM_FACE_8 24
260 #define VERT_PER_FACE_8 4
262 #define MIN_EDGE_DEPTH_8 (-1.0)
263 #define MAX_EDGE_DEPTH_8 1.0
264 #define MIN_FACE_DEPTH_8 (-1.0)
265 #define MAX_FACE_DEPTH_8 1.0
267 /* 16-cell {3,3,4} */
268 #define NUM_VERT_16 8
269 #define NUM_EDGE_16 24
270 #define NUM_FACE_16 32
271 #define VERT_PER_FACE_16 3
273 #define MIN_EDGE_DEPTH_16 (-1.0)
274 #define MAX_EDGE_DEPTH_16 1.0
275 #define MIN_FACE_DEPTH_16 (-2.0/3.0)
276 #define MAX_FACE_DEPTH_16 (2.0/3.0)
279 /* 24-cell {3,4,3} */
280 #define NUM_VERT_24 24
281 #define NUM_EDGE_24 96
282 #define NUM_FACE_24 96
283 #define VERT_PER_FACE_24 3
285 #define MIN_EDGE_DEPTH_24 (-SQRT2)
286 #define MAX_EDGE_DEPTH_24 SQRT2
287 #define MIN_FACE_DEPTH_24 (-SQRT2)
288 #define MAX_FACE_DEPTH_24 SQRT2
291 /* 120-cell {5,3,3} */
292 #define NUM_VERT_120 600
293 #define NUM_EDGE_120 1200
294 #define NUM_FACE_120 720
295 #define VERT_PER_FACE_120 5
297 #define MIN_EDGE_DEPTH_120 (-GOLDEN22)
298 #define MAX_EDGE_DEPTH_120 GOLDEN22
299 #define MIN_FACE_DEPTH_120 (-GOLDEN22)
300 #define MAX_FACE_DEPTH_120 GOLDEN22
303 /* 600-cell {3,3,5} */
304 #define NUM_VERT_600 120
305 #define NUM_EDGE_600 720
306 #define NUM_FACE_600 1200
307 #define VERT_PER_FACE_600 3
309 #define MIN_EDGE_DEPTH_600 (-GOLDEN/2.0-1)
310 #define MAX_EDGE_DEPTH_600 (GOLDEN/2.0+1)
311 #define MIN_FACE_DEPTH_600 ((-2*GOLDEN-2)/3.0)
312 #define MAX_FACE_DEPTH_600 ((2*GOLDEN+2)/3.0)
317 GLXContext *glx_context;
318 /* 4D rotation angles */
319 float alpha, beta, delta, zeta, eta, theta;
320 /* Aspect ratio of the current window */
324 /* Trackball states */
325 trackball_state *trackballs[2];
326 int current_trackball;
329 float edge_color_5[NUM_EDGE_5][4];
330 float face_color_5[NUM_FACE_5][4];
331 float face_color_trans_5[NUM_FACE_5][4];
333 float edge_color_8[NUM_EDGE_8][4];
334 float face_color_8[NUM_FACE_8][4];
335 float face_color_trans_8[NUM_FACE_8][4];
337 float edge_color_16[NUM_EDGE_16][4];
338 float face_color_16[NUM_FACE_16][4];
339 float face_color_trans_16[NUM_FACE_16][4];
341 float edge_color_24[NUM_EDGE_24][4];
342 float face_color_24[NUM_FACE_24][4];
343 float face_color_trans_24[NUM_FACE_24][4];
345 float edge_color_120[NUM_EDGE_120][4];
346 float face_color_120[NUM_FACE_120][4];
347 float face_color_trans_120[NUM_FACE_120][4];
349 float edge_color_600[NUM_EDGE_600][4];
350 float face_color_600[NUM_FACE_600][4];
351 float face_color_trans_600[NUM_FACE_600][4];
357 static polytopesstruct *poly = (polytopesstruct *) NULL;
360 /* Vertex, edge, and face data for the six regular polytopes. All the
361 polytopes are constructed with coordinates chosen such that their 4d
362 circumsphere has a radius of 2. */
364 static const float vert_5[NUM_VERT_5][4] = {
365 { -SQRT5OVER2, -SQRT5OVER6, -SQRT5OVER12, -0.5 },
366 { SQRT5OVER2, -SQRT5OVER6, -SQRT5OVER12, -0.5 },
367 { 0.0, SQRT10OVER3, -SQRT5OVER12, -0.5 },
368 { 0.0, 0.0, SQRT15OVER4, -0.5 },
369 { 0.0, 0.0, 0.0, 2.0 }
372 static const int edge_5[NUM_EDGE_5][2] = {
373 { 0, 1 }, { 0, 2 }, { 0, 3 }, { 0, 4 }, { 1, 2 }, { 1, 3 }, { 1, 4 },
374 { 2, 3 }, { 2, 4 }, { 3, 4 }
377 static const int face_5[NUM_FACE_5][VERT_PER_FACE_5] = {
378 { 0, 1, 2 }, { 0, 1, 3 }, { 0, 1, 4 }, { 0, 2, 3 }, { 0, 2, 4 }, { 0, 3, 4 },
379 { 1, 2, 3 }, { 1, 2, 4 }, { 1, 3, 4 }, { 2, 3, 4 }
383 static const float vert_8[NUM_VERT_8][4] = {
384 { -1.0, -1.0, -1.0, -1.0 }, { 1.0, -1.0, -1.0, -1.0 },
385 { -1.0, 1.0, -1.0, -1.0 }, { 1.0, 1.0, -1.0, -1.0 },
386 { -1.0, -1.0, 1.0, -1.0 }, { 1.0, -1.0, 1.0, -1.0 },
387 { -1.0, 1.0, 1.0, -1.0 }, { 1.0, 1.0, 1.0, -1.0 },
388 { -1.0, -1.0, -1.0, 1.0 }, { 1.0, -1.0, -1.0, 1.0 },
389 { -1.0, 1.0, -1.0, 1.0 }, { 1.0, 1.0, -1.0, 1.0 },
390 { -1.0, -1.0, 1.0, 1.0 }, { 1.0, -1.0, 1.0, 1.0 },
391 { -1.0, 1.0, 1.0, 1.0 }, { 1.0, 1.0, 1.0, 1.0 }
394 static const int edge_8[NUM_EDGE_8][2] = {
395 { 0, 1 }, { 0, 2 }, { 0, 4 }, { 0, 8 }, { 1, 3 }, { 1, 5 },
396 { 1, 9 }, { 2, 3 }, { 2, 6 }, { 2, 10 }, { 3, 7 }, { 3, 11 },
397 { 4, 5 }, { 4, 6 }, { 4, 12 }, { 5, 7 }, { 5, 13 }, { 6, 7 },
398 { 6, 14 }, { 7, 15 }, { 8, 9 }, { 8, 10 }, { 8, 12 }, { 9, 11 },
399 { 9, 13 }, { 10, 11 }, { 10, 14 }, { 11, 15 }, { 12, 13 }, { 12, 14 },
400 { 13, 15 }, { 14, 15 }
403 static const int face_8[NUM_FACE_8][VERT_PER_FACE_8] = {
404 { 0, 1, 3, 2 }, { 0, 1, 5, 4 }, { 0, 1, 9, 8 },
405 { 0, 2, 6, 4 }, { 0, 2, 10, 8 }, { 0, 4, 12, 8 },
406 { 1, 3, 7, 5 }, { 1, 3, 11, 9 }, { 1, 5, 13, 9 },
407 { 2, 3, 7, 6 }, { 2, 3, 11, 10 }, { 2, 6, 14, 10 },
408 { 3, 7, 15, 11 }, { 4, 5, 7, 6 }, { 4, 5, 13, 12 },
409 { 4, 6, 14, 12 }, { 5, 7, 15, 13 }, { 6, 7, 15, 14 },
410 { 8, 9, 11, 10 }, { 8, 9, 13, 12 }, { 8, 10, 14, 12 },
411 { 9, 11, 15, 13 }, { 10, 11, 15, 14 }, { 12, 13, 15, 14 }
416 static const float vert_16[NUM_VERT_16][4] = {
417 { 0.0, 0.0, 0.0, -2.0 }, { 0.0, 0.0, -2.0, 0.0 },
418 { 0.0, -2.0, 0.0, 0.0 }, { -2.0, 0.0, 0.0, 0.0 },
419 { 2.0, 0.0, 0.0, 0.0 }, { 0.0, 2.0, 0.0, 0.0 },
420 { 0.0, 0.0, 2.0, 0.0 }, { 0.0, 0.0, 0.0, 2.0 }
423 static const int edge_16[NUM_EDGE_16][2] = {
424 { 0, 1 }, { 0, 2 }, { 0, 3 }, { 0, 4 }, { 0, 5 }, { 0, 6 }, { 1, 2 },
425 { 1, 3 }, { 1, 4 }, { 1, 5 }, { 1, 7 }, { 2, 3 }, { 2, 4 }, { 2, 6 },
426 { 2, 7 }, { 3, 5 }, { 3, 6 }, { 3, 7 }, { 4, 5 }, { 4, 6 }, { 4, 7 },
427 { 5, 6 }, { 5, 7 }, { 6, 7 }
430 static const int face_16[NUM_FACE_16][VERT_PER_FACE_16] = {
431 { 0, 1, 2 }, { 0, 1, 3 }, { 0, 1, 4 }, { 0, 1, 5 }, { 0, 2, 3 }, { 0, 2, 4 },
432 { 0, 2, 6 }, { 0, 3, 5 }, { 0, 3, 6 }, { 0, 4, 5 }, { 0, 4, 6 }, { 0, 5, 6 },
433 { 1, 2, 3 }, { 1, 2, 4 }, { 1, 2, 7 }, { 1, 3, 5 }, { 1, 3, 7 }, { 1, 4, 5 },
434 { 1, 4, 7 }, { 1, 5, 7 }, { 2, 3, 6 }, { 2, 3, 7 }, { 2, 4, 6 }, { 2, 4, 7 },
435 { 2, 6, 7 }, { 3, 5, 6 }, { 3, 5, 7 }, { 3, 6, 7 }, { 4, 5, 6 }, { 4, 5, 7 },
436 { 4, 6, 7 }, { 5, 6, 7 }
441 static const float vert_24[NUM_VERT_24][4] = {
442 { 0.0, 0.0, -SQRT2, -SQRT2 }, { 0.0, -SQRT2, 0.0, -SQRT2 },
443 { -SQRT2, 0.0, 0.0, -SQRT2 }, { SQRT2, 0.0, 0.0, -SQRT2 },
444 { 0.0, SQRT2, 0.0, -SQRT2 }, { 0.0, 0.0, SQRT2, -SQRT2 },
445 { 0.0, -SQRT2, -SQRT2, 0.0 }, { -SQRT2, 0.0, -SQRT2, 0.0 },
446 { SQRT2, 0.0, -SQRT2, 0.0 }, { 0.0, SQRT2, -SQRT2, 0.0 },
447 { -SQRT2, -SQRT2, 0.0, 0.0 }, { SQRT2, -SQRT2, 0.0, 0.0 },
448 { -SQRT2, SQRT2, 0.0, 0.0 }, { SQRT2, SQRT2, 0.0, 0.0 },
449 { 0.0, -SQRT2, SQRT2, 0.0 }, { -SQRT2, 0.0, SQRT2, 0.0 },
450 { SQRT2, 0.0, SQRT2, 0.0 }, { 0.0, SQRT2, SQRT2, 0.0 },
451 { 0.0, 0.0, -SQRT2, SQRT2 }, { 0.0, -SQRT2, 0.0, SQRT2 },
452 { -SQRT2, 0.0, 0.0, SQRT2 }, { SQRT2, 0.0, 0.0, SQRT2 },
453 { 0.0, SQRT2, 0.0, SQRT2 }, { 0.0, 0.0, SQRT2, SQRT2 }
456 static const int edge_24[NUM_EDGE_24][2] = {
457 { 0, 1 }, { 0, 2 }, { 0, 3 }, { 0, 4 }, { 0, 6 }, { 0, 7 },
458 { 0, 8 }, { 0, 9 }, { 1, 2 }, { 1, 3 }, { 1, 5 }, { 1, 6 },
459 { 1, 10 }, { 1, 11 }, { 1, 14 }, { 2, 4 }, { 2, 5 }, { 2, 7 },
460 { 2, 10 }, { 2, 12 }, { 2, 15 }, { 3, 4 }, { 3, 5 }, { 3, 8 },
461 { 3, 11 }, { 3, 13 }, { 3, 16 }, { 4, 5 }, { 4, 9 }, { 4, 12 },
462 { 4, 13 }, { 4, 17 }, { 5, 14 }, { 5, 15 }, { 5, 16 }, { 5, 17 },
463 { 6, 7 }, { 6, 8 }, { 6, 10 }, { 6, 11 }, { 6, 18 }, { 6, 19 },
464 { 7, 9 }, { 7, 10 }, { 7, 12 }, { 7, 18 }, { 7, 20 }, { 8, 9 },
465 { 8, 11 }, { 8, 13 }, { 8, 18 }, { 8, 21 }, { 9, 12 }, { 9, 13 },
466 { 9, 18 }, { 9, 22 }, { 10, 14 }, { 10, 15 }, { 10, 19 }, { 10, 20 },
467 { 11, 14 }, { 11, 16 }, { 11, 19 }, { 11, 21 }, { 12, 15 }, { 12, 17 },
468 { 12, 20 }, { 12, 22 }, { 13, 16 }, { 13, 17 }, { 13, 21 }, { 13, 22 },
469 { 14, 15 }, { 14, 16 }, { 14, 19 }, { 14, 23 }, { 15, 17 }, { 15, 20 },
470 { 15, 23 }, { 16, 17 }, { 16, 21 }, { 16, 23 }, { 17, 22 }, { 17, 23 },
471 { 18, 19 }, { 18, 20 }, { 18, 21 }, { 18, 22 }, { 19, 20 }, { 19, 21 },
472 { 19, 23 }, { 20, 22 }, { 20, 23 }, { 21, 22 }, { 21, 23 }, { 22, 23 }
475 static const int face_24[NUM_FACE_24][VERT_PER_FACE_24] = {
476 { 0, 1, 2 }, { 0, 1, 3 }, { 0, 1, 6 }, { 0, 2, 4 },
477 { 0, 2, 7 }, { 0, 3, 4 }, { 0, 3, 8 }, { 0, 4, 9 },
478 { 0, 6, 7 }, { 0, 6, 8 }, { 0, 7, 9 }, { 0, 8, 9 },
479 { 1, 2, 5 }, { 1, 2, 10 }, { 1, 3, 5 }, { 1, 3, 11 },
480 { 1, 5, 14 }, { 1, 6, 10 }, { 1, 6, 11 }, { 1, 10, 14 },
481 { 1, 11, 14 }, { 2, 4, 5 }, { 2, 4, 12 }, { 2, 5, 15 },
482 { 2, 7, 10 }, { 2, 7, 12 }, { 2, 10, 15 }, { 2, 12, 15 },
483 { 3, 4, 5 }, { 3, 4, 13 }, { 3, 5, 16 }, { 3, 8, 11 },
484 { 3, 8, 13 }, { 3, 11, 16 }, { 3, 13, 16 }, { 4, 5, 17 },
485 { 4, 9, 12 }, { 4, 9, 13 }, { 4, 12, 17 }, { 4, 13, 17 },
486 { 5, 14, 15 }, { 5, 14, 16 }, { 5, 15, 17 }, { 5, 16, 17 },
487 { 6, 7, 10 }, { 6, 7, 18 }, { 6, 8, 11 }, { 6, 8, 18 },
488 { 6, 10, 19 }, { 6, 11, 19 }, { 6, 18, 19 }, { 7, 9, 12 },
489 { 7, 9, 18 }, { 7, 10, 20 }, { 7, 12, 20 }, { 7, 18, 20 },
490 { 8, 9, 13 }, { 8, 9, 18 }, { 8, 11, 21 }, { 8, 13, 21 },
491 { 8, 18, 21 }, { 9, 12, 22 }, { 9, 13, 22 }, { 9, 18, 22 },
492 { 10, 14, 15 }, { 10, 14, 19 }, { 10, 15, 20 }, { 10, 19, 20 },
493 { 11, 14, 16 }, { 11, 14, 19 }, { 11, 16, 21 }, { 11, 19, 21 },
494 { 12, 15, 17 }, { 12, 15, 20 }, { 12, 17, 22 }, { 12, 20, 22 },
495 { 13, 16, 17 }, { 13, 16, 21 }, { 13, 17, 22 }, { 13, 21, 22 },
496 { 14, 15, 23 }, { 14, 16, 23 }, { 14, 19, 23 }, { 15, 17, 23 },
497 { 15, 20, 23 }, { 16, 17, 23 }, { 16, 21, 23 }, { 17, 22, 23 },
498 { 18, 19, 20 }, { 18, 19, 21 }, { 18, 20, 22 }, { 18, 21, 22 },
499 { 19, 20, 23 }, { 19, 21, 23 }, { 20, 22, 23 }, { 21, 22, 23 }
505 static const float vert_120[NUM_VERT_120][4] = {
506 { -GOLDENINV22, 0.0, -SQRT2INV, -GOLDEN22 },
507 { GOLDENINV22, 0.0, -SQRT2INV, -GOLDEN22 },
508 { -GOLDENINV2, -GOLDENINV2, -GOLDENINV2, -GOLDEN22 },
509 { GOLDENINV2, -GOLDENINV2, -GOLDENINV2, -GOLDEN22 },
510 { -GOLDENINV2, GOLDENINV2, -GOLDENINV2, -GOLDEN22 },
511 { GOLDENINV2, GOLDENINV2, -GOLDENINV2, -GOLDEN22 },
512 { 0.0, -SQRT2INV, -GOLDENINV22, -GOLDEN22 },
513 { 0.0, SQRT2INV, -GOLDENINV22, -GOLDEN22 },
514 { -SQRT2INV, -GOLDENINV22, 0.0, -GOLDEN22 },
515 { SQRT2INV, -GOLDENINV22, 0.0, -GOLDEN22 },
516 { -SQRT2INV, GOLDENINV22, 0.0, -GOLDEN22 },
517 { SQRT2INV, GOLDENINV22, 0.0, -GOLDEN22 },
518 { 0.0, -SQRT2INV, GOLDENINV22, -GOLDEN22 },
519 { 0.0, SQRT2INV, GOLDENINV22, -GOLDEN22 },
520 { -GOLDENINV2, -GOLDENINV2, GOLDENINV2, -GOLDEN22 },
521 { GOLDENINV2, -GOLDENINV2, GOLDENINV2, -GOLDEN22 },
522 { -GOLDENINV2, GOLDENINV2, GOLDENINV2, -GOLDEN22 },
523 { GOLDENINV2, GOLDENINV2, GOLDENINV2, -GOLDEN22 },
524 { -GOLDENINV22, 0.0, SQRT2INV, -GOLDEN22 },
525 { GOLDENINV22, 0.0, SQRT2INV, -GOLDEN22 },
526 { -GOLDENINV2, 0.0, -GOLDEN2, -SQRT5OVER2 },
527 { GOLDENINV2, 0.0, -GOLDEN2, -SQRT5OVER2 },
528 { -SQRT2INV, -SQRT2INV, -SQRT2INV, -SQRT5OVER2 },
529 { SQRT2INV, -SQRT2INV, -SQRT2INV, -SQRT5OVER2 },
530 { -SQRT2INV, SQRT2INV, -SQRT2INV, -SQRT5OVER2 },
531 { SQRT2INV, SQRT2INV, -SQRT2INV, -SQRT5OVER2 },
532 { 0.0, -GOLDEN2, -GOLDENINV2, -SQRT5OVER2 },
533 { 0.0, GOLDEN2, -GOLDENINV2, -SQRT5OVER2 },
534 { -GOLDEN2, -GOLDENINV2, 0.0, -SQRT5OVER2 },
535 { GOLDEN2, -GOLDENINV2, 0.0, -SQRT5OVER2 },
536 { -GOLDEN2, GOLDENINV2, 0.0, -SQRT5OVER2 },
537 { GOLDEN2, GOLDENINV2, 0.0, -SQRT5OVER2 },
538 { 0.0, -GOLDEN2, GOLDENINV2, -SQRT5OVER2 },
539 { 0.0, GOLDEN2, GOLDENINV2, -SQRT5OVER2 },
540 { -SQRT2INV, -SQRT2INV, SQRT2INV, -SQRT5OVER2 },
541 { SQRT2INV, -SQRT2INV, SQRT2INV, -SQRT5OVER2 },
542 { -SQRT2INV, SQRT2INV, SQRT2INV, -SQRT5OVER2 },
543 { SQRT2INV, SQRT2INV, SQRT2INV, -SQRT5OVER2 },
544 { -GOLDENINV2, 0.0, GOLDEN2, -SQRT5OVER2 },
545 { GOLDENINV2, 0.0, GOLDEN2, -SQRT5OVER2 },
546 { 0.0, 0.0, -SQRT2, -SQRT2 },
547 { -SQRT2INV, -GOLDENINV2, -GOLDEN2, -SQRT2 },
548 { SQRT2INV, -GOLDENINV2, -GOLDEN2, -SQRT2 },
549 { -SQRT2INV, GOLDENINV2, -GOLDEN2, -SQRT2 },
550 { SQRT2INV, GOLDENINV2, -GOLDEN2, -SQRT2 },
551 { -GOLDENINV2, -GOLDEN2, -SQRT2INV, -SQRT2 },
552 { GOLDENINV2, -GOLDEN2, -SQRT2INV, -SQRT2 },
553 { -GOLDENINV2, GOLDEN2, -SQRT2INV, -SQRT2 },
554 { GOLDENINV2, GOLDEN2, -SQRT2INV, -SQRT2 },
555 { -GOLDEN2, -SQRT2INV, -GOLDENINV2, -SQRT2 },
556 { GOLDEN2, -SQRT2INV, -GOLDENINV2, -SQRT2 },
557 { -GOLDEN2, SQRT2INV, -GOLDENINV2, -SQRT2 },
558 { GOLDEN2, SQRT2INV, -GOLDENINV2, -SQRT2 },
559 { 0.0, -SQRT2, 0.0, -SQRT2 },
560 { -SQRT2, 0.0, 0.0, -SQRT2 },
561 { SQRT2, 0.0, 0.0, -SQRT2 },
562 { 0.0, SQRT2, 0.0, -SQRT2 },
563 { -GOLDEN2, -SQRT2INV, GOLDENINV2, -SQRT2 },
564 { GOLDEN2, -SQRT2INV, GOLDENINV2, -SQRT2 },
565 { -GOLDEN2, SQRT2INV, GOLDENINV2, -SQRT2 },
566 { GOLDEN2, SQRT2INV, GOLDENINV2, -SQRT2 },
567 { -GOLDENINV2, -GOLDEN2, SQRT2INV, -SQRT2 },
568 { GOLDENINV2, -GOLDEN2, SQRT2INV, -SQRT2 },
569 { -GOLDENINV2, GOLDEN2, SQRT2INV, -SQRT2 },
570 { GOLDENINV2, GOLDEN2, SQRT2INV, -SQRT2 },
571 { -SQRT2INV, -GOLDENINV2, GOLDEN2, -SQRT2 },
572 { SQRT2INV, -GOLDENINV2, GOLDEN2, -SQRT2 },
573 { -SQRT2INV, GOLDENINV2, GOLDEN2, -SQRT2 },
574 { SQRT2INV, GOLDENINV2, GOLDEN2, -SQRT2 },
575 { 0.0, 0.0, SQRT2, -SQRT2 },
576 { 0.0, -GOLDENINV2, -SQRT5OVER2, -GOLDEN2 },
577 { 0.0, GOLDENINV2, -SQRT5OVER2, -GOLDEN2 },
578 { -GOLDENINV2, -SQRT2INV, -SQRT2, -GOLDEN2 },
579 { GOLDENINV2, -SQRT2INV, -SQRT2, -GOLDEN2 },
580 { -GOLDENINV2, SQRT2INV, -SQRT2, -GOLDEN2 },
581 { GOLDENINV2, SQRT2INV, -SQRT2, -GOLDEN2 },
582 { -GOLDENINV22, -GOLDEN2, -GOLDEN2, -GOLDEN2 },
583 { GOLDENINV22, -GOLDEN2, -GOLDEN2, -GOLDEN2 },
584 { -GOLDEN2, -GOLDENINV22, -GOLDEN2, -GOLDEN2 },
585 { GOLDEN2, -GOLDENINV22, -GOLDEN2, -GOLDEN2 },
586 { -GOLDEN2, GOLDENINV22, -GOLDEN2, -GOLDEN2 },
587 { GOLDEN2, GOLDENINV22, -GOLDEN2, -GOLDEN2 },
588 { -GOLDENINV22, GOLDEN2, -GOLDEN2, -GOLDEN2 },
589 { GOLDENINV22, GOLDEN2, -GOLDEN2, -GOLDEN2 },
590 { -SQRT2, -GOLDENINV2, -SQRT2INV, -GOLDEN2 },
591 { SQRT2, -GOLDENINV2, -SQRT2INV, -GOLDEN2 },
592 { -SQRT2, GOLDENINV2, -SQRT2INV, -GOLDEN2 },
593 { SQRT2, GOLDENINV2, -SQRT2INV, -GOLDEN2 },
594 { -SQRT2INV, -SQRT2, -GOLDENINV2, -GOLDEN2 },
595 { SQRT2INV, -SQRT2, -GOLDENINV2, -GOLDEN2 },
596 { -SQRT5OVER2, 0.0, -GOLDENINV2, -GOLDEN2 },
597 { SQRT5OVER2, 0.0, -GOLDENINV2, -GOLDEN2 },
598 { -SQRT2INV, SQRT2, -GOLDENINV2, -GOLDEN2 },
599 { SQRT2INV, SQRT2, -GOLDENINV2, -GOLDEN2 },
600 { -GOLDEN2, -GOLDEN2, -GOLDENINV22, -GOLDEN2 },
601 { GOLDEN2, -GOLDEN2, -GOLDENINV22, -GOLDEN2 },
602 { -GOLDEN2, GOLDEN2, -GOLDENINV22, -GOLDEN2 },
603 { GOLDEN2, GOLDEN2, -GOLDENINV22, -GOLDEN2 },
604 { -GOLDENINV2, -SQRT5OVER2, 0.0, -GOLDEN2 },
605 { GOLDENINV2, -SQRT5OVER2, 0.0, -GOLDEN2 },
606 { -GOLDENINV2, SQRT5OVER2, 0.0, -GOLDEN2 },
607 { GOLDENINV2, SQRT5OVER2, 0.0, -GOLDEN2 },
608 { -GOLDEN2, -GOLDEN2, GOLDENINV22, -GOLDEN2 },
609 { GOLDEN2, -GOLDEN2, GOLDENINV22, -GOLDEN2 },
610 { -GOLDEN2, GOLDEN2, GOLDENINV22, -GOLDEN2 },
611 { GOLDEN2, GOLDEN2, GOLDENINV22, -GOLDEN2 },
612 { -SQRT2INV, -SQRT2, GOLDENINV2, -GOLDEN2 },
613 { SQRT2INV, -SQRT2, GOLDENINV2, -GOLDEN2 },
614 { -SQRT5OVER2, 0.0, GOLDENINV2, -GOLDEN2 },
615 { SQRT5OVER2, 0.0, GOLDENINV2, -GOLDEN2 },
616 { -SQRT2INV, SQRT2, GOLDENINV2, -GOLDEN2 },
617 { SQRT2INV, SQRT2, GOLDENINV2, -GOLDEN2 },
618 { -SQRT2, -GOLDENINV2, SQRT2INV, -GOLDEN2 },
619 { SQRT2, -GOLDENINV2, SQRT2INV, -GOLDEN2 },
620 { -SQRT2, GOLDENINV2, SQRT2INV, -GOLDEN2 },
621 { SQRT2, GOLDENINV2, SQRT2INV, -GOLDEN2 },
622 { -GOLDENINV22, -GOLDEN2, GOLDEN2, -GOLDEN2 },
623 { GOLDENINV22, -GOLDEN2, GOLDEN2, -GOLDEN2 },
624 { -GOLDEN2, -GOLDENINV22, GOLDEN2, -GOLDEN2 },
625 { GOLDEN2, -GOLDENINV22, GOLDEN2, -GOLDEN2 },
626 { -GOLDEN2, GOLDENINV22, GOLDEN2, -GOLDEN2 },
627 { GOLDEN2, GOLDENINV22, GOLDEN2, -GOLDEN2 },
628 { -GOLDENINV22, GOLDEN2, GOLDEN2, -GOLDEN2 },
629 { GOLDENINV22, GOLDEN2, GOLDEN2, -GOLDEN2 },
630 { -GOLDENINV2, -SQRT2INV, SQRT2, -GOLDEN2 },
631 { GOLDENINV2, -SQRT2INV, SQRT2, -GOLDEN2 },
632 { -GOLDENINV2, SQRT2INV, SQRT2, -GOLDEN2 },
633 { GOLDENINV2, SQRT2INV, SQRT2, -GOLDEN2 },
634 { 0.0, -GOLDENINV2, SQRT5OVER2, -GOLDEN2 },
635 { 0.0, GOLDENINV2, SQRT5OVER2, -GOLDEN2 },
636 { 0.0, -GOLDENINV22, -GOLDEN22, -SQRT2INV },
637 { 0.0, GOLDENINV22, -GOLDEN22, -SQRT2INV },
638 { -SQRT2INV, -SQRT2INV, -SQRT5OVER2, -SQRT2INV },
639 { SQRT2INV, -SQRT2INV, -SQRT5OVER2, -SQRT2INV },
640 { -SQRT2INV, SQRT2INV, -SQRT5OVER2, -SQRT2INV },
641 { SQRT2INV, SQRT2INV, -SQRT5OVER2, -SQRT2INV },
642 { -GOLDEN2, -GOLDENINV2, -SQRT2, -SQRT2INV },
643 { GOLDEN2, -GOLDENINV2, -SQRT2, -SQRT2INV },
644 { -GOLDEN2, GOLDENINV2, -SQRT2, -SQRT2INV },
645 { GOLDEN2, GOLDENINV2, -SQRT2, -SQRT2INV },
646 { -GOLDENINV2, -SQRT2, -GOLDEN2, -SQRT2INV },
647 { GOLDENINV2, -SQRT2, -GOLDEN2, -SQRT2INV },
648 { -GOLDENINV2, SQRT2, -GOLDEN2, -SQRT2INV },
649 { GOLDENINV2, SQRT2, -GOLDEN2, -SQRT2INV },
650 { -SQRT2INV, -SQRT5OVER2, -SQRT2INV, -SQRT2INV },
651 { SQRT2INV, -SQRT5OVER2, -SQRT2INV, -SQRT2INV },
652 { -SQRT5OVER2, -SQRT2INV, -SQRT2INV, -SQRT2INV },
653 { SQRT5OVER2, -SQRT2INV, -SQRT2INV, -SQRT2INV },
654 { -SQRT5OVER2, SQRT2INV, -SQRT2INV, -SQRT2INV },
655 { SQRT5OVER2, SQRT2INV, -SQRT2INV, -SQRT2INV },
656 { -SQRT2INV, SQRT5OVER2, -SQRT2INV, -SQRT2INV },
657 { SQRT2INV, SQRT5OVER2, -SQRT2INV, -SQRT2INV },
658 { -SQRT2, -GOLDEN2, -GOLDENINV2, -SQRT2INV },
659 { SQRT2, -GOLDEN2, -GOLDENINV2, -SQRT2INV },
660 { -SQRT2, GOLDEN2, -GOLDENINV2, -SQRT2INV },
661 { SQRT2, GOLDEN2, -GOLDENINV2, -SQRT2INV },
662 { -GOLDEN22, 0.0, -GOLDENINV22, -SQRT2INV },
663 { GOLDEN22, 0.0, -GOLDENINV22, -SQRT2INV },
664 { -GOLDENINV22, -GOLDEN22, 0.0, -SQRT2INV },
665 { GOLDENINV22, -GOLDEN22, 0.0, -SQRT2INV },
666 { -GOLDENINV22, GOLDEN22, 0.0, -SQRT2INV },
667 { GOLDENINV22, GOLDEN22, 0.0, -SQRT2INV },
668 { -GOLDEN22, 0.0, GOLDENINV22, -SQRT2INV },
669 { GOLDEN22, 0.0, GOLDENINV22, -SQRT2INV },
670 { -SQRT2, -GOLDEN2, GOLDENINV2, -SQRT2INV },
671 { SQRT2, -GOLDEN2, GOLDENINV2, -SQRT2INV },
672 { -SQRT2, GOLDEN2, GOLDENINV2, -SQRT2INV },
673 { SQRT2, GOLDEN2, GOLDENINV2, -SQRT2INV },
674 { -SQRT2INV, -SQRT5OVER2, SQRT2INV, -SQRT2INV },
675 { SQRT2INV, -SQRT5OVER2, SQRT2INV, -SQRT2INV },
676 { -SQRT5OVER2, -SQRT2INV, SQRT2INV, -SQRT2INV },
677 { SQRT5OVER2, -SQRT2INV, SQRT2INV, -SQRT2INV },
678 { -SQRT5OVER2, SQRT2INV, SQRT2INV, -SQRT2INV },
679 { SQRT5OVER2, SQRT2INV, SQRT2INV, -SQRT2INV },
680 { -SQRT2INV, SQRT5OVER2, SQRT2INV, -SQRT2INV },
681 { SQRT2INV, SQRT5OVER2, SQRT2INV, -SQRT2INV },
682 { -GOLDENINV2, -SQRT2, GOLDEN2, -SQRT2INV },
683 { GOLDENINV2, -SQRT2, GOLDEN2, -SQRT2INV },
684 { -GOLDENINV2, SQRT2, GOLDEN2, -SQRT2INV },
685 { GOLDENINV2, SQRT2, GOLDEN2, -SQRT2INV },
686 { -GOLDEN2, -GOLDENINV2, SQRT2, -SQRT2INV },
687 { GOLDEN2, -GOLDENINV2, SQRT2, -SQRT2INV },
688 { -GOLDEN2, GOLDENINV2, SQRT2, -SQRT2INV },
689 { GOLDEN2, GOLDENINV2, SQRT2, -SQRT2INV },
690 { -SQRT2INV, -SQRT2INV, SQRT5OVER2, -SQRT2INV },
691 { SQRT2INV, -SQRT2INV, SQRT5OVER2, -SQRT2INV },
692 { -SQRT2INV, SQRT2INV, SQRT5OVER2, -SQRT2INV },
693 { SQRT2INV, SQRT2INV, SQRT5OVER2, -SQRT2INV },
694 { 0.0, -GOLDENINV22, GOLDEN22, -SQRT2INV },
695 { 0.0, GOLDENINV22, GOLDEN22, -SQRT2INV },
696 { -GOLDENINV2, -GOLDENINV2, -GOLDEN22, -GOLDENINV2 },
697 { GOLDENINV2, -GOLDENINV2, -GOLDEN22, -GOLDENINV2 },
698 { -GOLDENINV2, GOLDENINV2, -GOLDEN22, -GOLDENINV2 },
699 { GOLDENINV2, GOLDENINV2, -GOLDEN22, -GOLDENINV2 },
700 { -GOLDEN2, 0.0, -SQRT5OVER2, -GOLDENINV2 },
701 { GOLDEN2, 0.0, -SQRT5OVER2, -GOLDENINV2 },
702 { -SQRT2INV, -GOLDEN2, -SQRT2, -GOLDENINV2 },
703 { SQRT2INV, -GOLDEN2, -SQRT2, -GOLDENINV2 },
704 { -SQRT2INV, GOLDEN2, -SQRT2, -GOLDENINV2 },
705 { SQRT2INV, GOLDEN2, -SQRT2, -GOLDENINV2 },
706 { 0.0, -SQRT5OVER2, -GOLDEN2, -GOLDENINV2 },
707 { -SQRT2, -SQRT2INV, -GOLDEN2, -GOLDENINV2 },
708 { SQRT2, -SQRT2INV, -GOLDEN2, -GOLDENINV2 },
709 { -SQRT2, SQRT2INV, -GOLDEN2, -GOLDENINV2 },
710 { SQRT2, SQRT2INV, -GOLDEN2, -GOLDENINV2 },
711 { 0.0, SQRT5OVER2, -GOLDEN2, -GOLDENINV2 },
712 { -GOLDEN2, -SQRT2, -SQRT2INV, -GOLDENINV2 },
713 { GOLDEN2, -SQRT2, -SQRT2INV, -GOLDENINV2 },
714 { -GOLDEN2, SQRT2, -SQRT2INV, -GOLDENINV2 },
715 { GOLDEN2, SQRT2, -SQRT2INV, -GOLDENINV2 },
716 { -GOLDENINV2, -GOLDEN22, -GOLDENINV2, -GOLDENINV2 },
717 { GOLDENINV2, -GOLDEN22, -GOLDENINV2, -GOLDENINV2 },
718 { -GOLDEN22, -GOLDENINV2, -GOLDENINV2, -GOLDENINV2 },
719 { GOLDEN22, -GOLDENINV2, -GOLDENINV2, -GOLDENINV2 },
720 { -GOLDEN22, GOLDENINV2, -GOLDENINV2, -GOLDENINV2 },
721 { GOLDEN22, GOLDENINV2, -GOLDENINV2, -GOLDENINV2 },
722 { -GOLDENINV2, GOLDEN22, -GOLDENINV2, -GOLDENINV2 },
723 { GOLDENINV2, GOLDEN22, -GOLDENINV2, -GOLDENINV2 },
724 { -SQRT5OVER2, -GOLDEN2, 0.0, -GOLDENINV2 },
725 { SQRT5OVER2, -GOLDEN2, 0.0, -GOLDENINV2 },
726 { -SQRT5OVER2, GOLDEN2, 0.0, -GOLDENINV2 },
727 { SQRT5OVER2, GOLDEN2, 0.0, -GOLDENINV2 },
728 { -GOLDENINV2, -GOLDEN22, GOLDENINV2, -GOLDENINV2 },
729 { GOLDENINV2, -GOLDEN22, GOLDENINV2, -GOLDENINV2 },
730 { -GOLDEN22, -GOLDENINV2, GOLDENINV2, -GOLDENINV2 },
731 { GOLDEN22, -GOLDENINV2, GOLDENINV2, -GOLDENINV2 },
732 { -GOLDEN22, GOLDENINV2, GOLDENINV2, -GOLDENINV2 },
733 { GOLDEN22, GOLDENINV2, GOLDENINV2, -GOLDENINV2 },
734 { -GOLDENINV2, GOLDEN22, GOLDENINV2, -GOLDENINV2 },
735 { GOLDENINV2, GOLDEN22, GOLDENINV2, -GOLDENINV2 },
736 { -GOLDEN2, -SQRT2, SQRT2INV, -GOLDENINV2 },
737 { GOLDEN2, -SQRT2, SQRT2INV, -GOLDENINV2 },
738 { -GOLDEN2, SQRT2, SQRT2INV, -GOLDENINV2 },
739 { GOLDEN2, SQRT2, SQRT2INV, -GOLDENINV2 },
740 { 0.0, -SQRT5OVER2, GOLDEN2, -GOLDENINV2 },
741 { -SQRT2, -SQRT2INV, GOLDEN2, -GOLDENINV2 },
742 { SQRT2, -SQRT2INV, GOLDEN2, -GOLDENINV2 },
743 { -SQRT2, SQRT2INV, GOLDEN2, -GOLDENINV2 },
744 { SQRT2, SQRT2INV, GOLDEN2, -GOLDENINV2 },
745 { 0.0, SQRT5OVER2, GOLDEN2, -GOLDENINV2 },
746 { -SQRT2INV, -GOLDEN2, SQRT2, -GOLDENINV2 },
747 { SQRT2INV, -GOLDEN2, SQRT2, -GOLDENINV2 },
748 { -SQRT2INV, GOLDEN2, SQRT2, -GOLDENINV2 },
749 { SQRT2INV, GOLDEN2, SQRT2, -GOLDENINV2 },
750 { -GOLDEN2, 0.0, SQRT5OVER2, -GOLDENINV2 },
751 { GOLDEN2, 0.0, SQRT5OVER2, -GOLDENINV2 },
752 { -GOLDENINV2, -GOLDENINV2, GOLDEN22, -GOLDENINV2 },
753 { GOLDENINV2, -GOLDENINV2, GOLDEN22, -GOLDENINV2 },
754 { -GOLDENINV2, GOLDENINV2, GOLDEN22, -GOLDENINV2 },
755 { GOLDENINV2, GOLDENINV2, GOLDEN22, -GOLDENINV2 },
756 { -SQRT2INV, 0.0, -GOLDEN22, -GOLDENINV22 },
757 { SQRT2INV, 0.0, -GOLDEN22, -GOLDENINV22 },
758 { -GOLDEN2, -GOLDEN2, -GOLDEN2, -GOLDENINV22 },
759 { GOLDEN2, -GOLDEN2, -GOLDEN2, -GOLDENINV22 },
760 { -GOLDEN2, GOLDEN2, -GOLDEN2, -GOLDENINV22 },
761 { GOLDEN2, GOLDEN2, -GOLDEN2, -GOLDENINV22 },
762 { 0.0, -GOLDEN22, -SQRT2INV, -GOLDENINV22 },
763 { 0.0, GOLDEN22, -SQRT2INV, -GOLDENINV22 },
764 { -GOLDEN22, -SQRT2INV, 0.0, -GOLDENINV22 },
765 { GOLDEN22, -SQRT2INV, 0.0, -GOLDENINV22 },
766 { -GOLDEN22, SQRT2INV, 0.0, -GOLDENINV22 },
767 { GOLDEN22, SQRT2INV, 0.0, -GOLDENINV22 },
768 { 0.0, -GOLDEN22, SQRT2INV, -GOLDENINV22 },
769 { 0.0, GOLDEN22, SQRT2INV, -GOLDENINV22 },
770 { -GOLDEN2, -GOLDEN2, GOLDEN2, -GOLDENINV22 },
771 { GOLDEN2, -GOLDEN2, GOLDEN2, -GOLDENINV22 },
772 { -GOLDEN2, GOLDEN2, GOLDEN2, -GOLDENINV22 },
773 { GOLDEN2, GOLDEN2, GOLDEN2, -GOLDENINV22 },
774 { -SQRT2INV, 0.0, GOLDEN22, -GOLDENINV22 },
775 { SQRT2INV, 0.0, GOLDEN22, -GOLDENINV22 },
776 { -GOLDENINV22, -SQRT2INV, -GOLDEN22, 0.0 },
777 { GOLDENINV22, -SQRT2INV, -GOLDEN22, 0.0 },
778 { -GOLDENINV22, SQRT2INV, -GOLDEN22, 0.0 },
779 { GOLDENINV22, SQRT2INV, -GOLDEN22, 0.0 },
780 { -GOLDENINV2, -GOLDEN2, -SQRT5OVER2, 0.0 },
781 { GOLDENINV2, -GOLDEN2, -SQRT5OVER2, 0.0 },
782 { -GOLDENINV2, GOLDEN2, -SQRT5OVER2, 0.0 },
783 { GOLDENINV2, GOLDEN2, -SQRT5OVER2, 0.0 },
784 { 0.0, -SQRT2, -SQRT2, 0.0 },
785 { -SQRT2, 0.0, -SQRT2, 0.0 },
786 { SQRT2, 0.0, -SQRT2, 0.0 },
787 { 0.0, SQRT2, -SQRT2, 0.0 },
788 { -SQRT5OVER2, -GOLDENINV2, -GOLDEN2, 0.0 },
789 { SQRT5OVER2, -GOLDENINV2, -GOLDEN2, 0.0 },
790 { -SQRT5OVER2, GOLDENINV2, -GOLDEN2, 0.0 },
791 { SQRT5OVER2, GOLDENINV2, -GOLDEN2, 0.0 },
792 { -GOLDEN22, -GOLDENINV22, -SQRT2INV, 0.0 },
793 { GOLDEN22, -GOLDENINV22, -SQRT2INV, 0.0 },
794 { -GOLDEN22, GOLDENINV22, -SQRT2INV, 0.0 },
795 { GOLDEN22, GOLDENINV22, -SQRT2INV, 0.0 },
796 { -GOLDEN2, -SQRT5OVER2, -GOLDENINV2, 0.0 },
797 { GOLDEN2, -SQRT5OVER2, -GOLDENINV2, 0.0 },
798 { -GOLDEN2, SQRT5OVER2, -GOLDENINV2, 0.0 },
799 { GOLDEN2, SQRT5OVER2, -GOLDENINV2, 0.0 },
800 { -SQRT2INV, -GOLDEN22, -GOLDENINV22, 0.0 },
801 { SQRT2INV, -GOLDEN22, -GOLDENINV22, 0.0 },
802 { -SQRT2INV, GOLDEN22, -GOLDENINV22, 0.0 },
803 { SQRT2INV, GOLDEN22, -GOLDENINV22, 0.0 },
804 { -SQRT2, -SQRT2, 0.0, 0.0 },
805 { SQRT2, -SQRT2, 0.0, 0.0 },
806 { -SQRT2, SQRT2, 0.0, 0.0 },
807 { SQRT2, SQRT2, 0.0, 0.0 },
808 { -SQRT2INV, -GOLDEN22, GOLDENINV22, 0.0 },
809 { SQRT2INV, -GOLDEN22, GOLDENINV22, 0.0 },
810 { -SQRT2INV, GOLDEN22, GOLDENINV22, 0.0 },
811 { SQRT2INV, GOLDEN22, GOLDENINV22, 0.0 },
812 { -GOLDEN2, -SQRT5OVER2, GOLDENINV2, 0.0 },
813 { GOLDEN2, -SQRT5OVER2, GOLDENINV2, 0.0 },
814 { -GOLDEN2, SQRT5OVER2, GOLDENINV2, 0.0 },
815 { GOLDEN2, SQRT5OVER2, GOLDENINV2, 0.0 },
816 { -GOLDEN22, -GOLDENINV22, SQRT2INV, 0.0 },
817 { GOLDEN22, -GOLDENINV22, SQRT2INV, 0.0 },
818 { -GOLDEN22, GOLDENINV22, SQRT2INV, 0.0 },
819 { GOLDEN22, GOLDENINV22, SQRT2INV, 0.0 },
820 { -SQRT5OVER2, -GOLDENINV2, GOLDEN2, 0.0 },
821 { SQRT5OVER2, -GOLDENINV2, GOLDEN2, 0.0 },
822 { -SQRT5OVER2, GOLDENINV2, GOLDEN2, 0.0 },
823 { SQRT5OVER2, GOLDENINV2, GOLDEN2, 0.0 },
824 { 0.0, -SQRT2, SQRT2, 0.0 },
825 { -SQRT2, 0.0, SQRT2, 0.0 },
826 { SQRT2, 0.0, SQRT2, 0.0 },
827 { 0.0, SQRT2, SQRT2, 0.0 },
828 { -GOLDENINV2, -GOLDEN2, SQRT5OVER2, 0.0 },
829 { GOLDENINV2, -GOLDEN2, SQRT5OVER2, 0.0 },
830 { -GOLDENINV2, GOLDEN2, SQRT5OVER2, 0.0 },
831 { GOLDENINV2, GOLDEN2, SQRT5OVER2, 0.0 },
832 { -GOLDENINV22, -SQRT2INV, GOLDEN22, 0.0 },
833 { GOLDENINV22, -SQRT2INV, GOLDEN22, 0.0 },
834 { -GOLDENINV22, SQRT2INV, GOLDEN22, 0.0 },
835 { GOLDENINV22, SQRT2INV, GOLDEN22, 0.0 },
836 { -SQRT2INV, 0.0, -GOLDEN22, GOLDENINV22 },
837 { SQRT2INV, 0.0, -GOLDEN22, GOLDENINV22 },
838 { -GOLDEN2, -GOLDEN2, -GOLDEN2, GOLDENINV22 },
839 { GOLDEN2, -GOLDEN2, -GOLDEN2, GOLDENINV22 },
840 { -GOLDEN2, GOLDEN2, -GOLDEN2, GOLDENINV22 },
841 { GOLDEN2, GOLDEN2, -GOLDEN2, GOLDENINV22 },
842 { 0.0, -GOLDEN22, -SQRT2INV, GOLDENINV22 },
843 { 0.0, GOLDEN22, -SQRT2INV, GOLDENINV22 },
844 { -GOLDEN22, -SQRT2INV, 0.0, GOLDENINV22 },
845 { GOLDEN22, -SQRT2INV, 0.0, GOLDENINV22 },
846 { -GOLDEN22, SQRT2INV, 0.0, GOLDENINV22 },
847 { GOLDEN22, SQRT2INV, 0.0, GOLDENINV22 },
848 { 0.0, -GOLDEN22, SQRT2INV, GOLDENINV22 },
849 { 0.0, GOLDEN22, SQRT2INV, GOLDENINV22 },
850 { -GOLDEN2, -GOLDEN2, GOLDEN2, GOLDENINV22 },
851 { GOLDEN2, -GOLDEN2, GOLDEN2, GOLDENINV22 },
852 { -GOLDEN2, GOLDEN2, GOLDEN2, GOLDENINV22 },
853 { GOLDEN2, GOLDEN2, GOLDEN2, GOLDENINV22 },
854 { -SQRT2INV, 0.0, GOLDEN22, GOLDENINV22 },
855 { SQRT2INV, 0.0, GOLDEN22, GOLDENINV22 },
856 { -GOLDENINV2, -GOLDENINV2, -GOLDEN22, GOLDENINV2 },
857 { GOLDENINV2, -GOLDENINV2, -GOLDEN22, GOLDENINV2 },
858 { -GOLDENINV2, GOLDENINV2, -GOLDEN22, GOLDENINV2 },
859 { GOLDENINV2, GOLDENINV2, -GOLDEN22, GOLDENINV2 },
860 { -GOLDEN2, 0.0, -SQRT5OVER2, GOLDENINV2 },
861 { GOLDEN2, 0.0, -SQRT5OVER2, GOLDENINV2 },
862 { -SQRT2INV, -GOLDEN2, -SQRT2, GOLDENINV2 },
863 { SQRT2INV, -GOLDEN2, -SQRT2, GOLDENINV2 },
864 { -SQRT2INV, GOLDEN2, -SQRT2, GOLDENINV2 },
865 { SQRT2INV, GOLDEN2, -SQRT2, GOLDENINV2 },
866 { 0.0, -SQRT5OVER2, -GOLDEN2, GOLDENINV2 },
867 { -SQRT2, -SQRT2INV, -GOLDEN2, GOLDENINV2 },
868 { SQRT2, -SQRT2INV, -GOLDEN2, GOLDENINV2 },
869 { -SQRT2, SQRT2INV, -GOLDEN2, GOLDENINV2 },
870 { SQRT2, SQRT2INV, -GOLDEN2, GOLDENINV2 },
871 { 0.0, SQRT5OVER2, -GOLDEN2, GOLDENINV2 },
872 { -GOLDEN2, -SQRT2, -SQRT2INV, GOLDENINV2 },
873 { GOLDEN2, -SQRT2, -SQRT2INV, GOLDENINV2 },
874 { -GOLDEN2, SQRT2, -SQRT2INV, GOLDENINV2 },
875 { GOLDEN2, SQRT2, -SQRT2INV, GOLDENINV2 },
876 { -GOLDENINV2, -GOLDEN22, -GOLDENINV2, GOLDENINV2 },
877 { GOLDENINV2, -GOLDEN22, -GOLDENINV2, GOLDENINV2 },
878 { -GOLDEN22, -GOLDENINV2, -GOLDENINV2, GOLDENINV2 },
879 { GOLDEN22, -GOLDENINV2, -GOLDENINV2, GOLDENINV2 },
880 { -GOLDEN22, GOLDENINV2, -GOLDENINV2, GOLDENINV2 },
881 { GOLDEN22, GOLDENINV2, -GOLDENINV2, GOLDENINV2 },
882 { -GOLDENINV2, GOLDEN22, -GOLDENINV2, GOLDENINV2 },
883 { GOLDENINV2, GOLDEN22, -GOLDENINV2, GOLDENINV2 },
884 { -SQRT5OVER2, -GOLDEN2, 0.0, GOLDENINV2 },
885 { SQRT5OVER2, -GOLDEN2, 0.0, GOLDENINV2 },
886 { -SQRT5OVER2, GOLDEN2, 0.0, GOLDENINV2 },
887 { SQRT5OVER2, GOLDEN2, 0.0, GOLDENINV2 },
888 { -GOLDENINV2, -GOLDEN22, GOLDENINV2, GOLDENINV2 },
889 { GOLDENINV2, -GOLDEN22, GOLDENINV2, GOLDENINV2 },
890 { -GOLDEN22, -GOLDENINV2, GOLDENINV2, GOLDENINV2 },
891 { GOLDEN22, -GOLDENINV2, GOLDENINV2, GOLDENINV2 },
892 { -GOLDEN22, GOLDENINV2, GOLDENINV2, GOLDENINV2 },
893 { GOLDEN22, GOLDENINV2, GOLDENINV2, GOLDENINV2 },
894 { -GOLDENINV2, GOLDEN22, GOLDENINV2, GOLDENINV2 },
895 { GOLDENINV2, GOLDEN22, GOLDENINV2, GOLDENINV2 },
896 { -GOLDEN2, -SQRT2, SQRT2INV, GOLDENINV2 },
897 { GOLDEN2, -SQRT2, SQRT2INV, GOLDENINV2 },
898 { -GOLDEN2, SQRT2, SQRT2INV, GOLDENINV2 },
899 { GOLDEN2, SQRT2, SQRT2INV, GOLDENINV2 },
900 { 0.0, -SQRT5OVER2, GOLDEN2, GOLDENINV2 },
901 { -SQRT2, -SQRT2INV, GOLDEN2, GOLDENINV2 },
902 { SQRT2, -SQRT2INV, GOLDEN2, GOLDENINV2 },
903 { -SQRT2, SQRT2INV, GOLDEN2, GOLDENINV2 },
904 { SQRT2, SQRT2INV, GOLDEN2, GOLDENINV2 },
905 { 0.0, SQRT5OVER2, GOLDEN2, GOLDENINV2 },
906 { -SQRT2INV, -GOLDEN2, SQRT2, GOLDENINV2 },
907 { SQRT2INV, -GOLDEN2, SQRT2, GOLDENINV2 },
908 { -SQRT2INV, GOLDEN2, SQRT2, GOLDENINV2 },
909 { SQRT2INV, GOLDEN2, SQRT2, GOLDENINV2 },
910 { -GOLDEN2, 0.0, SQRT5OVER2, GOLDENINV2 },
911 { GOLDEN2, 0.0, SQRT5OVER2, GOLDENINV2 },
912 { -GOLDENINV2, -GOLDENINV2, GOLDEN22, GOLDENINV2 },
913 { GOLDENINV2, -GOLDENINV2, GOLDEN22, GOLDENINV2 },
914 { -GOLDENINV2, GOLDENINV2, GOLDEN22, GOLDENINV2 },
915 { GOLDENINV2, GOLDENINV2, GOLDEN22, GOLDENINV2 },
916 { 0.0, -GOLDENINV22, -GOLDEN22, SQRT2INV },
917 { 0.0, GOLDENINV22, -GOLDEN22, SQRT2INV },
918 { -SQRT2INV, -SQRT2INV, -SQRT5OVER2, SQRT2INV },
919 { SQRT2INV, -SQRT2INV, -SQRT5OVER2, SQRT2INV },
920 { -SQRT2INV, SQRT2INV, -SQRT5OVER2, SQRT2INV },
921 { SQRT2INV, SQRT2INV, -SQRT5OVER2, SQRT2INV },
922 { -GOLDEN2, -GOLDENINV2, -SQRT2, SQRT2INV },
923 { GOLDEN2, -GOLDENINV2, -SQRT2, SQRT2INV },
924 { -GOLDEN2, GOLDENINV2, -SQRT2, SQRT2INV },
925 { GOLDEN2, GOLDENINV2, -SQRT2, SQRT2INV },
926 { -GOLDENINV2, -SQRT2, -GOLDEN2, SQRT2INV },
927 { GOLDENINV2, -SQRT2, -GOLDEN2, SQRT2INV },
928 { -GOLDENINV2, SQRT2, -GOLDEN2, SQRT2INV },
929 { GOLDENINV2, SQRT2, -GOLDEN2, SQRT2INV },
930 { -SQRT2INV, -SQRT5OVER2, -SQRT2INV, SQRT2INV },
931 { SQRT2INV, -SQRT5OVER2, -SQRT2INV, SQRT2INV },
932 { -SQRT5OVER2, -SQRT2INV, -SQRT2INV, SQRT2INV },
933 { SQRT5OVER2, -SQRT2INV, -SQRT2INV, SQRT2INV },
934 { -SQRT5OVER2, SQRT2INV, -SQRT2INV, SQRT2INV },
935 { SQRT5OVER2, SQRT2INV, -SQRT2INV, SQRT2INV },
936 { -SQRT2INV, SQRT5OVER2, -SQRT2INV, SQRT2INV },
937 { SQRT2INV, SQRT5OVER2, -SQRT2INV, SQRT2INV },
938 { -SQRT2, -GOLDEN2, -GOLDENINV2, SQRT2INV },
939 { SQRT2, -GOLDEN2, -GOLDENINV2, SQRT2INV },
940 { -SQRT2, GOLDEN2, -GOLDENINV2, SQRT2INV },
941 { SQRT2, GOLDEN2, -GOLDENINV2, SQRT2INV },
942 { -GOLDEN22, 0.0, -GOLDENINV22, SQRT2INV },
943 { GOLDEN22, 0.0, -GOLDENINV22, SQRT2INV },
944 { -GOLDENINV22, -GOLDEN22, 0.0, SQRT2INV },
945 { GOLDENINV22, -GOLDEN22, 0.0, SQRT2INV },
946 { -GOLDENINV22, GOLDEN22, 0.0, SQRT2INV },
947 { GOLDENINV22, GOLDEN22, 0.0, SQRT2INV },
948 { -GOLDEN22, 0.0, GOLDENINV22, SQRT2INV },
949 { GOLDEN22, 0.0, GOLDENINV22, SQRT2INV },
950 { -SQRT2, -GOLDEN2, GOLDENINV2, SQRT2INV },
951 { SQRT2, -GOLDEN2, GOLDENINV2, SQRT2INV },
952 { -SQRT2, GOLDEN2, GOLDENINV2, SQRT2INV },
953 { SQRT2, GOLDEN2, GOLDENINV2, SQRT2INV },
954 { -SQRT2INV, -SQRT5OVER2, SQRT2INV, SQRT2INV },
955 { SQRT2INV, -SQRT5OVER2, SQRT2INV, SQRT2INV },
956 { -SQRT5OVER2, -SQRT2INV, SQRT2INV, SQRT2INV },
957 { SQRT5OVER2, -SQRT2INV, SQRT2INV, SQRT2INV },
958 { -SQRT5OVER2, SQRT2INV, SQRT2INV, SQRT2INV },
959 { SQRT5OVER2, SQRT2INV, SQRT2INV, SQRT2INV },
960 { -SQRT2INV, SQRT5OVER2, SQRT2INV, SQRT2INV },
961 { SQRT2INV, SQRT5OVER2, SQRT2INV, SQRT2INV },
962 { -GOLDENINV2, -SQRT2, GOLDEN2, SQRT2INV },
963 { GOLDENINV2, -SQRT2, GOLDEN2, SQRT2INV },
964 { -GOLDENINV2, SQRT2, GOLDEN2, SQRT2INV },
965 { GOLDENINV2, SQRT2, GOLDEN2, SQRT2INV },
966 { -GOLDEN2, -GOLDENINV2, SQRT2, SQRT2INV },
967 { GOLDEN2, -GOLDENINV2, SQRT2, SQRT2INV },
968 { -GOLDEN2, GOLDENINV2, SQRT2, SQRT2INV },
969 { GOLDEN2, GOLDENINV2, SQRT2, SQRT2INV },
970 { -SQRT2INV, -SQRT2INV, SQRT5OVER2, SQRT2INV },
971 { SQRT2INV, -SQRT2INV, SQRT5OVER2, SQRT2INV },
972 { -SQRT2INV, SQRT2INV, SQRT5OVER2, SQRT2INV },
973 { SQRT2INV, SQRT2INV, SQRT5OVER2, SQRT2INV },
974 { 0.0, -GOLDENINV22, GOLDEN22, SQRT2INV },
975 { 0.0, GOLDENINV22, GOLDEN22, SQRT2INV },
976 { 0.0, -GOLDENINV2, -SQRT5OVER2, GOLDEN2 },
977 { 0.0, GOLDENINV2, -SQRT5OVER2, GOLDEN2 },
978 { -GOLDENINV2, -SQRT2INV, -SQRT2, GOLDEN2 },
979 { GOLDENINV2, -SQRT2INV, -SQRT2, GOLDEN2 },
980 { -GOLDENINV2, SQRT2INV, -SQRT2, GOLDEN2 },
981 { GOLDENINV2, SQRT2INV, -SQRT2, GOLDEN2 },
982 { -GOLDENINV22, -GOLDEN2, -GOLDEN2, GOLDEN2 },
983 { GOLDENINV22, -GOLDEN2, -GOLDEN2, GOLDEN2 },
984 { -GOLDEN2, -GOLDENINV22, -GOLDEN2, GOLDEN2 },
985 { GOLDEN2, -GOLDENINV22, -GOLDEN2, GOLDEN2 },
986 { -GOLDEN2, GOLDENINV22, -GOLDEN2, GOLDEN2 },
987 { GOLDEN2, GOLDENINV22, -GOLDEN2, GOLDEN2 },
988 { -GOLDENINV22, GOLDEN2, -GOLDEN2, GOLDEN2 },
989 { GOLDENINV22, GOLDEN2, -GOLDEN2, GOLDEN2 },
990 { -SQRT2, -GOLDENINV2, -SQRT2INV, GOLDEN2 },
991 { SQRT2, -GOLDENINV2, -SQRT2INV, GOLDEN2 },
992 { -SQRT2, GOLDENINV2, -SQRT2INV, GOLDEN2 },
993 { SQRT2, GOLDENINV2, -SQRT2INV, GOLDEN2 },
994 { -SQRT2INV, -SQRT2, -GOLDENINV2, GOLDEN2 },
995 { SQRT2INV, -SQRT2, -GOLDENINV2, GOLDEN2 },
996 { -SQRT5OVER2, 0.0, -GOLDENINV2, GOLDEN2 },
997 { SQRT5OVER2, 0.0, -GOLDENINV2, GOLDEN2 },
998 { -SQRT2INV, SQRT2, -GOLDENINV2, GOLDEN2 },
999 { SQRT2INV, SQRT2, -GOLDENINV2, GOLDEN2 },
1000 { -GOLDEN2, -GOLDEN2, -GOLDENINV22, GOLDEN2 },
1001 { GOLDEN2, -GOLDEN2, -GOLDENINV22, GOLDEN2 },
1002 { -GOLDEN2, GOLDEN2, -GOLDENINV22, GOLDEN2 },
1003 { GOLDEN2, GOLDEN2, -GOLDENINV22, GOLDEN2 },
1004 { -GOLDENINV2, -SQRT5OVER2, 0.0, GOLDEN2 },
1005 { GOLDENINV2, -SQRT5OVER2, 0.0, GOLDEN2 },
1006 { -GOLDENINV2, SQRT5OVER2, 0.0, GOLDEN2 },
1007 { GOLDENINV2, SQRT5OVER2, 0.0, GOLDEN2 },
1008 { -GOLDEN2, -GOLDEN2, GOLDENINV22, GOLDEN2 },
1009 { GOLDEN2, -GOLDEN2, GOLDENINV22, GOLDEN2 },
1010 { -GOLDEN2, GOLDEN2, GOLDENINV22, GOLDEN2 },
1011 { GOLDEN2, GOLDEN2, GOLDENINV22, GOLDEN2 },
1012 { -SQRT2INV, -SQRT2, GOLDENINV2, GOLDEN2 },
1013 { SQRT2INV, -SQRT2, GOLDENINV2, GOLDEN2 },
1014 { -SQRT5OVER2, 0.0, GOLDENINV2, GOLDEN2 },
1015 { SQRT5OVER2, 0.0, GOLDENINV2, GOLDEN2 },
1016 { -SQRT2INV, SQRT2, GOLDENINV2, GOLDEN2 },
1017 { SQRT2INV, SQRT2, GOLDENINV2, GOLDEN2 },
1018 { -SQRT2, -GOLDENINV2, SQRT2INV, GOLDEN2 },
1019 { SQRT2, -GOLDENINV2, SQRT2INV, GOLDEN2 },
1020 { -SQRT2, GOLDENINV2, SQRT2INV, GOLDEN2 },
1021 { SQRT2, GOLDENINV2, SQRT2INV, GOLDEN2 },
1022 { -GOLDENINV22, -GOLDEN2, GOLDEN2, GOLDEN2 },
1023 { GOLDENINV22, -GOLDEN2, GOLDEN2, GOLDEN2 },
1024 { -GOLDEN2, -GOLDENINV22, GOLDEN2, GOLDEN2 },
1025 { GOLDEN2, -GOLDENINV22, GOLDEN2, GOLDEN2 },
1026 { -GOLDEN2, GOLDENINV22, GOLDEN2, GOLDEN2 },
1027 { GOLDEN2, GOLDENINV22, GOLDEN2, GOLDEN2 },
1028 { -GOLDENINV22, GOLDEN2, GOLDEN2, GOLDEN2 },
1029 { GOLDENINV22, GOLDEN2, GOLDEN2, GOLDEN2 },
1030 { -GOLDENINV2, -SQRT2INV, SQRT2, GOLDEN2 },
1031 { GOLDENINV2, -SQRT2INV, SQRT2, GOLDEN2 },
1032 { -GOLDENINV2, SQRT2INV, SQRT2, GOLDEN2 },
1033 { GOLDENINV2, SQRT2INV, SQRT2, GOLDEN2 },
1034 { 0.0, -GOLDENINV2, SQRT5OVER2, GOLDEN2 },
1035 { 0.0, GOLDENINV2, SQRT5OVER2, GOLDEN2 },
1036 { 0.0, 0.0, -SQRT2, SQRT2 },
1037 { -SQRT2INV, -GOLDENINV2, -GOLDEN2, SQRT2 },
1038 { SQRT2INV, -GOLDENINV2, -GOLDEN2, SQRT2 },
1039 { -SQRT2INV, GOLDENINV2, -GOLDEN2, SQRT2 },
1040 { SQRT2INV, GOLDENINV2, -GOLDEN2, SQRT2 },
1041 { -GOLDENINV2, -GOLDEN2, -SQRT2INV, SQRT2 },
1042 { GOLDENINV2, -GOLDEN2, -SQRT2INV, SQRT2 },
1043 { -GOLDENINV2, GOLDEN2, -SQRT2INV, SQRT2 },
1044 { GOLDENINV2, GOLDEN2, -SQRT2INV, SQRT2 },
1045 { -GOLDEN2, -SQRT2INV, -GOLDENINV2, SQRT2 },
1046 { GOLDEN2, -SQRT2INV, -GOLDENINV2, SQRT2 },
1047 { -GOLDEN2, SQRT2INV, -GOLDENINV2, SQRT2 },
1048 { GOLDEN2, SQRT2INV, -GOLDENINV2, SQRT2 },
1049 { 0.0, -SQRT2, 0.0, SQRT2 },
1050 { -SQRT2, 0.0, 0.0, SQRT2 },
1051 { SQRT2, 0.0, 0.0, SQRT2 },
1052 { 0.0, SQRT2, 0.0, SQRT2 },
1053 { -GOLDEN2, -SQRT2INV, GOLDENINV2, SQRT2 },
1054 { GOLDEN2, -SQRT2INV, GOLDENINV2, SQRT2 },
1055 { -GOLDEN2, SQRT2INV, GOLDENINV2, SQRT2 },
1056 { GOLDEN2, SQRT2INV, GOLDENINV2, SQRT2 },
1057 { -GOLDENINV2, -GOLDEN2, SQRT2INV, SQRT2 },
1058 { GOLDENINV2, -GOLDEN2, SQRT2INV, SQRT2 },
1059 { -GOLDENINV2, GOLDEN2, SQRT2INV, SQRT2 },
1060 { GOLDENINV2, GOLDEN2, SQRT2INV, SQRT2 },
1061 { -SQRT2INV, -GOLDENINV2, GOLDEN2, SQRT2 },
1062 { SQRT2INV, -GOLDENINV2, GOLDEN2, SQRT2 },
1063 { -SQRT2INV, GOLDENINV2, GOLDEN2, SQRT2 },
1064 { SQRT2INV, GOLDENINV2, GOLDEN2, SQRT2 },
1065 { 0.0, 0.0, SQRT2, SQRT2 },
1066 { -GOLDENINV2, 0.0, -GOLDEN2, SQRT5OVER2 },
1067 { GOLDENINV2, 0.0, -GOLDEN2, SQRT5OVER2 },
1068 { -SQRT2INV, -SQRT2INV, -SQRT2INV, SQRT5OVER2 },
1069 { SQRT2INV, -SQRT2INV, -SQRT2INV, SQRT5OVER2 },
1070 { -SQRT2INV, SQRT2INV, -SQRT2INV, SQRT5OVER2 },
1071 { SQRT2INV, SQRT2INV, -SQRT2INV, SQRT5OVER2 },
1072 { 0.0, -GOLDEN2, -GOLDENINV2, SQRT5OVER2 },
1073 { 0.0, GOLDEN2, -GOLDENINV2, SQRT5OVER2 },
1074 { -GOLDEN2, -GOLDENINV2, 0.0, SQRT5OVER2 },
1075 { GOLDEN2, -GOLDENINV2, 0.0, SQRT5OVER2 },
1076 { -GOLDEN2, GOLDENINV2, 0.0, SQRT5OVER2 },
1077 { GOLDEN2, GOLDENINV2, 0.0, SQRT5OVER2 },
1078 { 0.0, -GOLDEN2, GOLDENINV2, SQRT5OVER2 },
1079 { 0.0, GOLDEN2, GOLDENINV2, SQRT5OVER2 },
1080 { -SQRT2INV, -SQRT2INV, SQRT2INV, SQRT5OVER2 },
1081 { SQRT2INV, -SQRT2INV, SQRT2INV, SQRT5OVER2 },
1082 { -SQRT2INV, SQRT2INV, SQRT2INV, SQRT5OVER2 },
1083 { SQRT2INV, SQRT2INV, SQRT2INV, SQRT5OVER2 },
1084 { -GOLDENINV2, 0.0, GOLDEN2, SQRT5OVER2 },
1085 { GOLDENINV2, 0.0, GOLDEN2, SQRT5OVER2 },
1086 { -GOLDENINV22, 0.0, -SQRT2INV, GOLDEN22 },
1087 { GOLDENINV22, 0.0, -SQRT2INV, GOLDEN22 },
1088 { -GOLDENINV2, -GOLDENINV2, -GOLDENINV2, GOLDEN22 },
1089 { GOLDENINV2, -GOLDENINV2, -GOLDENINV2, GOLDEN22 },
1090 { -GOLDENINV2, GOLDENINV2, -GOLDENINV2, GOLDEN22 },
1091 { GOLDENINV2, GOLDENINV2, -GOLDENINV2, GOLDEN22 },
1092 { 0.0, -SQRT2INV, -GOLDENINV22, GOLDEN22 },
1093 { 0.0, SQRT2INV, -GOLDENINV22, GOLDEN22 },
1094 { -SQRT2INV, -GOLDENINV22, 0.0, GOLDEN22 },
1095 { SQRT2INV, -GOLDENINV22, 0.0, GOLDEN22 },
1096 { -SQRT2INV, GOLDENINV22, 0.0, GOLDEN22 },
1097 { SQRT2INV, GOLDENINV22, 0.0, GOLDEN22 },
1098 { 0.0, -SQRT2INV, GOLDENINV22, GOLDEN22 },
1099 { 0.0, SQRT2INV, GOLDENINV22, GOLDEN22 },
1100 { -GOLDENINV2, -GOLDENINV2, GOLDENINV2, GOLDEN22 },
1101 { GOLDENINV2, -GOLDENINV2, GOLDENINV2, GOLDEN22 },
1102 { -GOLDENINV2, GOLDENINV2, GOLDENINV2, GOLDEN22 },
1103 { GOLDENINV2, GOLDENINV2, GOLDENINV2, GOLDEN22 },
1104 { -GOLDENINV22, 0.0, SQRT2INV, GOLDEN22 },
1105 { GOLDENINV22, 0.0, SQRT2INV, GOLDEN22 }
1108 static const int edge_120[NUM_EDGE_120][2] = {
1109 { 0, 1 }, { 0, 2 }, { 0, 4 }, { 0, 20 }, { 1, 3 },
1110 { 1, 5 }, { 1, 21 }, { 2, 6 }, { 2, 8 }, { 2, 22 },
1111 { 3, 6 }, { 3, 9 }, { 3, 23 }, { 4, 7 }, { 4, 10 },
1112 { 4, 24 }, { 5, 7 }, { 5, 11 }, { 5, 25 }, { 6, 12 },
1113 { 6, 26 }, { 7, 13 }, { 7, 27 }, { 8, 10 }, { 8, 14 },
1114 { 8, 28 }, { 9, 11 }, { 9, 15 }, { 9, 29 }, { 10, 16 },
1115 { 10, 30 }, { 11, 17 }, { 11, 31 }, { 12, 14 }, { 12, 15 },
1116 { 12, 32 }, { 13, 16 }, { 13, 17 }, { 13, 33 }, { 14, 18 },
1117 { 14, 34 }, { 15, 19 }, { 15, 35 }, { 16, 18 }, { 16, 36 },
1118 { 17, 19 }, { 17, 37 }, { 18, 19 }, { 18, 38 }, { 19, 39 },
1119 { 20, 40 }, { 20, 41 }, { 20, 43 }, { 21, 40 }, { 21, 42 },
1120 { 21, 44 }, { 22, 41 }, { 22, 45 }, { 22, 49 }, { 23, 42 },
1121 { 23, 46 }, { 23, 50 }, { 24, 43 }, { 24, 47 }, { 24, 51 },
1122 { 25, 44 }, { 25, 48 }, { 25, 52 }, { 26, 45 }, { 26, 46 },
1123 { 26, 53 }, { 27, 47 }, { 27, 48 }, { 27, 56 }, { 28, 49 },
1124 { 28, 54 }, { 28, 57 }, { 29, 50 }, { 29, 55 }, { 29, 58 },
1125 { 30, 51 }, { 30, 54 }, { 30, 59 }, { 31, 52 }, { 31, 55 },
1126 { 31, 60 }, { 32, 53 }, { 32, 61 }, { 32, 62 }, { 33, 56 },
1127 { 33, 63 }, { 33, 64 }, { 34, 57 }, { 34, 61 }, { 34, 65 },
1128 { 35, 58 }, { 35, 62 }, { 35, 66 }, { 36, 59 }, { 36, 63 },
1129 { 36, 67 }, { 37, 60 }, { 37, 64 }, { 37, 68 }, { 38, 65 },
1130 { 38, 67 }, { 38, 69 }, { 39, 66 }, { 39, 68 }, { 39, 69 },
1131 { 40, 70 }, { 40, 71 }, { 41, 72 }, { 41, 78 }, { 42, 73 },
1132 { 42, 79 }, { 43, 74 }, { 43, 80 }, { 44, 75 }, { 44, 81 },
1133 { 45, 76 }, { 45, 88 }, { 46, 77 }, { 46, 89 }, { 47, 82 },
1134 { 47, 92 }, { 48, 83 }, { 48, 93 }, { 49, 84 }, { 49, 94 },
1135 { 50, 85 }, { 50, 95 }, { 51, 86 }, { 51, 96 }, { 52, 87 },
1136 { 52, 97 }, { 53, 98 }, { 53, 99 }, { 54, 90 }, { 54, 108 },
1137 { 55, 91 }, { 55, 109 }, { 56, 100 }, { 56, 101 }, { 57, 102 },
1138 { 57, 112 }, { 58, 103 }, { 58, 113 }, { 59, 104 }, { 59, 114 },
1139 { 60, 105 }, { 60, 115 }, { 61, 106 }, { 61, 116 }, { 62, 107 },
1140 { 62, 117 }, { 63, 110 }, { 63, 122 }, { 64, 111 }, { 64, 123 },
1141 { 65, 118 }, { 65, 124 }, { 66, 119 }, { 66, 125 }, { 67, 120 },
1142 { 67, 126 }, { 68, 121 }, { 68, 127 }, { 69, 128 }, { 69, 129 },
1143 { 70, 72 }, { 70, 73 }, { 70, 130 }, { 71, 74 }, { 71, 75 },
1144 { 71, 131 }, { 72, 76 }, { 72, 132 }, { 73, 77 }, { 73, 133 },
1145 { 74, 82 }, { 74, 134 }, { 75, 83 }, { 75, 135 }, { 76, 77 },
1146 { 76, 140 }, { 77, 141 }, { 78, 80 }, { 78, 84 }, { 78, 136 },
1147 { 79, 81 }, { 79, 85 }, { 79, 137 }, { 80, 86 }, { 80, 138 },
1148 { 81, 87 }, { 81, 139 }, { 82, 83 }, { 82, 142 }, { 83, 143 },
1149 { 84, 90 }, { 84, 146 }, { 85, 91 }, { 85, 147 }, { 86, 90 },
1150 { 86, 148 }, { 87, 91 }, { 87, 149 }, { 88, 94 }, { 88, 98 },
1151 { 88, 144 }, { 89, 95 }, { 89, 99 }, { 89, 145 }, { 90, 156 },
1152 { 91, 157 }, { 92, 96 }, { 92, 100 }, { 92, 150 }, { 93, 97 },
1153 { 93, 101 }, { 93, 151 }, { 94, 102 }, { 94, 152 }, { 95, 103 },
1154 { 95, 153 }, { 96, 104 }, { 96, 154 }, { 97, 105 }, { 97, 155 },
1155 { 98, 106 }, { 98, 158 }, { 99, 107 }, { 99, 159 }, { 100, 110 },
1156 { 100, 160 }, { 101, 111 }, { 101, 161 }, { 102, 106 }, { 102, 164 },
1157 { 103, 107 }, { 103, 165 }, { 104, 110 }, { 104, 166 }, { 105, 111 },
1158 { 105, 167 }, { 106, 168 }, { 107, 169 }, { 108, 112 }, { 108, 114 },
1159 { 108, 162 }, { 109, 113 }, { 109, 115 }, { 109, 163 }, { 110, 174 },
1160 { 111, 175 }, { 112, 118 }, { 112, 170 }, { 113, 119 }, { 113, 171 },
1161 { 114, 120 }, { 114, 172 }, { 115, 121 }, { 115, 173 }, { 116, 117 },
1162 { 116, 124 }, { 116, 176 }, { 117, 125 }, { 117, 177 }, { 118, 120 },
1163 { 118, 180 }, { 119, 121 }, { 119, 181 }, { 120, 182 }, { 121, 183 },
1164 { 122, 123 }, { 122, 126 }, { 122, 178 }, { 123, 127 }, { 123, 179 },
1165 { 124, 128 }, { 124, 184 }, { 125, 128 }, { 125, 185 }, { 126, 129 },
1166 { 126, 186 }, { 127, 129 }, { 127, 187 }, { 128, 188 }, { 129, 189 },
1167 { 130, 131 }, { 130, 190 }, { 130, 191 }, { 131, 192 }, { 131, 193 },
1168 { 132, 136 }, { 132, 190 }, { 132, 196 }, { 133, 137 }, { 133, 191 },
1169 { 133, 197 }, { 134, 138 }, { 134, 192 }, { 134, 198 }, { 135, 139 },
1170 { 135, 193 }, { 135, 199 }, { 136, 194 }, { 136, 201 }, { 137, 195 },
1171 { 137, 202 }, { 138, 194 }, { 138, 203 }, { 139, 195 }, { 139, 204 },
1172 { 140, 144 }, { 140, 196 }, { 140, 200 }, { 141, 145 }, { 141, 197 },
1173 { 141, 200 }, { 142, 150 }, { 142, 198 }, { 142, 205 }, { 143, 151 },
1174 { 143, 199 }, { 143, 205 }, { 144, 206 }, { 144, 210 }, { 145, 207 },
1175 { 145, 211 }, { 146, 152 }, { 146, 201 }, { 146, 212 }, { 147, 153 },
1176 { 147, 202 }, { 147, 213 }, { 148, 154 }, { 148, 203 }, { 148, 214 },
1177 { 149, 155 }, { 149, 204 }, { 149, 215 }, { 150, 208 }, { 150, 216 },
1178 { 151, 209 }, { 151, 217 }, { 152, 206 }, { 152, 218 }, { 153, 207 },
1179 { 153, 219 }, { 154, 208 }, { 154, 220 }, { 155, 209 }, { 155, 221 },
1180 { 156, 162 }, { 156, 212 }, { 156, 214 }, { 157, 163 }, { 157, 213 },
1181 { 157, 215 }, { 158, 159 }, { 158, 210 }, { 158, 222 }, { 159, 211 },
1182 { 159, 223 }, { 160, 161 }, { 160, 216 }, { 160, 228 }, { 161, 217 },
1183 { 161, 229 }, { 162, 224 }, { 162, 226 }, { 163, 225 }, { 163, 227 },
1184 { 164, 170 }, { 164, 218 }, { 164, 230 }, { 165, 171 }, { 165, 219 },
1185 { 165, 231 }, { 166, 172 }, { 166, 220 }, { 166, 232 }, { 167, 173 },
1186 { 167, 221 }, { 167, 233 }, { 168, 176 }, { 168, 222 }, { 168, 230 },
1187 { 169, 177 }, { 169, 223 }, { 169, 231 }, { 170, 224 }, { 170, 235 },
1188 { 171, 225 }, { 171, 236 }, { 172, 226 }, { 172, 237 }, { 173, 227 },
1189 { 173, 238 }, { 174, 178 }, { 174, 228 }, { 174, 232 }, { 175, 179 },
1190 { 175, 229 }, { 175, 233 }, { 176, 234 }, { 176, 240 }, { 177, 234 },
1191 { 177, 241 }, { 178, 239 }, { 178, 242 }, { 179, 239 }, { 179, 243 },
1192 { 180, 184 }, { 180, 235 }, { 180, 244 }, { 181, 185 }, { 181, 236 },
1193 { 181, 245 }, { 182, 186 }, { 182, 237 }, { 182, 244 }, { 183, 187 },
1194 { 183, 238 }, { 183, 245 }, { 184, 240 }, { 184, 246 }, { 185, 241 },
1195 { 185, 247 }, { 186, 242 }, { 186, 248 }, { 187, 243 }, { 187, 249 },
1196 { 188, 189 }, { 188, 246 }, { 188, 247 }, { 189, 248 }, { 189, 249 },
1197 { 190, 250 }, { 190, 270 }, { 191, 251 }, { 191, 271 }, { 192, 250 },
1198 { 192, 272 }, { 193, 251 }, { 193, 273 }, { 194, 250 }, { 194, 279 },
1199 { 195, 251 }, { 195, 280 }, { 196, 252 }, { 196, 274 }, { 197, 253 },
1200 { 197, 275 }, { 198, 254 }, { 198, 276 }, { 199, 255 }, { 199, 277 },
1201 { 200, 256 }, { 200, 278 }, { 201, 252 }, { 201, 282 }, { 202, 253 },
1202 { 202, 283 }, { 203, 254 }, { 203, 284 }, { 204, 255 }, { 204, 285 },
1203 { 205, 257 }, { 205, 281 }, { 206, 252 }, { 206, 290 }, { 207, 253 },
1204 { 207, 291 }, { 208, 254 }, { 208, 292 }, { 209, 255 }, { 209, 293 },
1205 { 210, 256 }, { 210, 294 }, { 211, 256 }, { 211, 295 }, { 212, 258 },
1206 { 212, 286 }, { 213, 259 }, { 213, 287 }, { 214, 260 }, { 214, 288 },
1207 { 215, 261 }, { 215, 289 }, { 216, 257 }, { 216, 296 }, { 217, 257 },
1208 { 217, 297 }, { 218, 258 }, { 218, 298 }, { 219, 259 }, { 219, 299 },
1209 { 220, 260 }, { 220, 300 }, { 221, 261 }, { 221, 301 }, { 222, 262 },
1210 { 222, 302 }, { 223, 262 }, { 223, 303 }, { 224, 258 }, { 224, 310 },
1211 { 225, 259 }, { 225, 311 }, { 226, 260 }, { 226, 312 }, { 227, 261 },
1212 { 227, 313 }, { 228, 263 }, { 228, 304 }, { 229, 263 }, { 229, 305 },
1213 { 230, 264 }, { 230, 306 }, { 231, 265 }, { 231, 307 }, { 232, 266 },
1214 { 232, 308 }, { 233, 267 }, { 233, 309 }, { 234, 262 }, { 234, 318 },
1215 { 235, 264 }, { 235, 314 }, { 236, 265 }, { 236, 315 }, { 237, 266 },
1216 { 237, 316 }, { 238, 267 }, { 238, 317 }, { 239, 263 }, { 239, 321 },
1217 { 240, 264 }, { 240, 322 }, { 241, 265 }, { 241, 323 }, { 242, 266 },
1218 { 242, 324 }, { 243, 267 }, { 243, 325 }, { 244, 268 }, { 244, 319 },
1219 { 245, 269 }, { 245, 320 }, { 246, 268 }, { 246, 326 }, { 247, 269 },
1220 { 247, 327 }, { 248, 268 }, { 248, 328 }, { 249, 269 }, { 249, 329 },
1221 { 250, 330 }, { 251, 331 }, { 252, 332 }, { 253, 333 }, { 254, 334 },
1222 { 255, 335 }, { 256, 336 }, { 257, 337 }, { 258, 338 }, { 259, 339 },
1223 { 260, 340 }, { 261, 341 }, { 262, 342 }, { 263, 343 }, { 264, 344 },
1224 { 265, 345 }, { 266, 346 }, { 267, 347 }, { 268, 348 }, { 269, 349 },
1225 { 270, 271 }, { 270, 274 }, { 270, 350 }, { 271, 275 }, { 271, 351 },
1226 { 272, 273 }, { 272, 276 }, { 272, 352 }, { 273, 277 }, { 273, 353 },
1227 { 274, 278 }, { 274, 356 }, { 275, 278 }, { 275, 357 }, { 276, 281 },
1228 { 276, 358 }, { 277, 281 }, { 277, 359 }, { 278, 360 }, { 279, 282 },
1229 { 279, 284 }, { 279, 354 }, { 280, 283 }, { 280, 285 }, { 280, 355 },
1230 { 281, 365 }, { 282, 286 }, { 282, 361 }, { 283, 287 }, { 283, 362 },
1231 { 284, 288 }, { 284, 363 }, { 285, 289 }, { 285, 364 }, { 286, 288 },
1232 { 286, 372 }, { 287, 289 }, { 287, 373 }, { 288, 374 }, { 289, 375 },
1233 { 290, 294 }, { 290, 298 }, { 290, 366 }, { 291, 295 }, { 291, 299 },
1234 { 291, 367 }, { 292, 296 }, { 292, 300 }, { 292, 368 }, { 293, 297 },
1235 { 293, 301 }, { 293, 369 }, { 294, 302 }, { 294, 370 }, { 295, 303 },
1236 { 295, 371 }, { 296, 304 }, { 296, 376 }, { 297, 305 }, { 297, 377 },
1237 { 298, 306 }, { 298, 378 }, { 299, 307 }, { 299, 379 }, { 300, 308 },
1238 { 300, 380 }, { 301, 309 }, { 301, 381 }, { 302, 306 }, { 302, 382 },
1239 { 303, 307 }, { 303, 383 }, { 304, 308 }, { 304, 388 }, { 305, 309 },
1240 { 305, 389 }, { 306, 390 }, { 307, 391 }, { 308, 392 }, { 309, 393 },
1241 { 310, 312 }, { 310, 314 }, { 310, 384 }, { 311, 313 }, { 311, 315 },
1242 { 311, 385 }, { 312, 316 }, { 312, 386 }, { 313, 317 }, { 313, 387 },
1243 { 314, 319 }, { 314, 395 }, { 315, 320 }, { 315, 396 }, { 316, 319 },
1244 { 316, 397 }, { 317, 320 }, { 317, 398 }, { 318, 322 }, { 318, 323 },
1245 { 318, 394 }, { 319, 404 }, { 320, 405 }, { 321, 324 }, { 321, 325 },
1246 { 321, 399 }, { 322, 326 }, { 322, 400 }, { 323, 327 }, { 323, 401 },
1247 { 324, 328 }, { 324, 402 }, { 325, 329 }, { 325, 403 }, { 326, 327 },
1248 { 326, 406 }, { 327, 407 }, { 328, 329 }, { 328, 408 }, { 329, 409 },
1249 { 330, 350 }, { 330, 352 }, { 330, 354 }, { 331, 351 }, { 331, 353 },
1250 { 331, 355 }, { 332, 356 }, { 332, 361 }, { 332, 366 }, { 333, 357 },
1251 { 333, 362 }, { 333, 367 }, { 334, 358 }, { 334, 363 }, { 334, 368 },
1252 { 335, 359 }, { 335, 364 }, { 335, 369 }, { 336, 360 }, { 336, 370 },
1253 { 336, 371 }, { 337, 365 }, { 337, 376 }, { 337, 377 }, { 338, 372 },
1254 { 338, 378 }, { 338, 384 }, { 339, 373 }, { 339, 379 }, { 339, 385 },
1255 { 340, 374 }, { 340, 380 }, { 340, 386 }, { 341, 375 }, { 341, 381 },
1256 { 341, 387 }, { 342, 382 }, { 342, 383 }, { 342, 394 }, { 343, 388 },
1257 { 343, 389 }, { 343, 399 }, { 344, 390 }, { 344, 395 }, { 344, 400 },
1258 { 345, 391 }, { 345, 396 }, { 345, 401 }, { 346, 392 }, { 346, 397 },
1259 { 346, 402 }, { 347, 393 }, { 347, 398 }, { 347, 403 }, { 348, 404 },
1260 { 348, 406 }, { 348, 408 }, { 349, 405 }, { 349, 407 }, { 349, 409 },
1261 { 350, 410 }, { 350, 412 }, { 351, 410 }, { 351, 413 }, { 352, 411 },
1262 { 352, 414 }, { 353, 411 }, { 353, 415 }, { 354, 416 }, { 354, 418 },
1263 { 355, 417 }, { 355, 419 }, { 356, 412 }, { 356, 420 }, { 357, 413 },
1264 { 357, 421 }, { 358, 414 }, { 358, 422 }, { 359, 415 }, { 359, 423 },
1265 { 360, 420 }, { 360, 421 }, { 361, 416 }, { 361, 426 }, { 362, 417 },
1266 { 362, 427 }, { 363, 418 }, { 363, 428 }, { 364, 419 }, { 364, 429 },
1267 { 365, 422 }, { 365, 423 }, { 366, 424 }, { 366, 432 }, { 367, 425 },
1268 { 367, 433 }, { 368, 430 }, { 368, 434 }, { 369, 431 }, { 369, 435 },
1269 { 370, 424 }, { 370, 438 }, { 371, 425 }, { 371, 439 }, { 372, 426 },
1270 { 372, 436 }, { 373, 427 }, { 373, 437 }, { 374, 428 }, { 374, 436 },
1271 { 375, 429 }, { 375, 437 }, { 376, 430 }, { 376, 440 }, { 377, 431 },
1272 { 377, 441 }, { 378, 432 }, { 378, 444 }, { 379, 433 }, { 379, 445 },
1273 { 380, 434 }, { 380, 446 }, { 381, 435 }, { 381, 447 }, { 382, 438 },
1274 { 382, 448 }, { 383, 439 }, { 383, 449 }, { 384, 442 }, { 384, 450 },
1275 { 385, 443 }, { 385, 451 }, { 386, 442 }, { 386, 452 }, { 387, 443 },
1276 { 387, 453 }, { 388, 440 }, { 388, 454 }, { 389, 441 }, { 389, 455 },
1277 { 390, 444 }, { 390, 448 }, { 391, 445 }, { 391, 449 }, { 392, 446 },
1278 { 392, 454 }, { 393, 447 }, { 393, 455 }, { 394, 456 }, { 394, 457 },
1279 { 395, 450 }, { 395, 460 }, { 396, 451 }, { 396, 461 }, { 397, 452 },
1280 { 397, 462 }, { 398, 453 }, { 398, 463 }, { 399, 458 }, { 399, 459 },
1281 { 400, 456 }, { 400, 464 }, { 401, 457 }, { 401, 465 }, { 402, 458 },
1282 { 402, 466 }, { 403, 459 }, { 403, 467 }, { 404, 460 }, { 404, 462 },
1283 { 405, 461 }, { 405, 463 }, { 406, 464 }, { 406, 468 }, { 407, 465 },
1284 { 407, 468 }, { 408, 466 }, { 408, 469 }, { 409, 467 }, { 409, 469 },
1285 { 410, 411 }, { 410, 470 }, { 411, 471 }, { 412, 416 }, { 412, 472 },
1286 { 413, 417 }, { 413, 473 }, { 414, 418 }, { 414, 474 }, { 415, 419 },
1287 { 415, 475 }, { 416, 478 }, { 417, 479 }, { 418, 480 }, { 419, 481 },
1288 { 420, 424 }, { 420, 476 }, { 421, 425 }, { 421, 477 }, { 422, 430 },
1289 { 422, 482 }, { 423, 431 }, { 423, 483 }, { 424, 488 }, { 425, 489 },
1290 { 426, 432 }, { 426, 484 }, { 427, 433 }, { 427, 485 }, { 428, 434 },
1291 { 428, 486 }, { 429, 435 }, { 429, 487 }, { 430, 492 }, { 431, 493 },
1292 { 432, 494 }, { 433, 495 }, { 434, 496 }, { 435, 497 }, { 436, 442 },
1293 { 436, 490 }, { 437, 443 }, { 437, 491 }, { 438, 439 }, { 438, 498 },
1294 { 439, 499 }, { 440, 441 }, { 440, 500 }, { 441, 501 }, { 442, 508 },
1295 { 443, 509 }, { 444, 450 }, { 444, 502 }, { 445, 451 }, { 445, 503 },
1296 { 446, 452 }, { 446, 504 }, { 447, 453 }, { 447, 505 }, { 448, 456 },
1297 { 448, 506 }, { 449, 457 }, { 449, 507 }, { 450, 512 }, { 451, 513 },
1298 { 452, 514 }, { 453, 515 }, { 454, 458 }, { 454, 510 }, { 455, 459 },
1299 { 455, 511 }, { 456, 516 }, { 457, 517 }, { 458, 522 }, { 459, 523 },
1300 { 460, 464 }, { 460, 518 }, { 461, 465 }, { 461, 519 }, { 462, 466 },
1301 { 462, 520 }, { 463, 467 }, { 463, 521 }, { 464, 524 }, { 465, 525 },
1302 { 466, 526 }, { 467, 527 }, { 468, 469 }, { 468, 528 }, { 469, 529 },
1303 { 470, 472 }, { 470, 473 }, { 470, 530 }, { 471, 474 }, { 471, 475 },
1304 { 471, 530 }, { 472, 476 }, { 472, 531 }, { 473, 477 }, { 473, 532 },
1305 { 474, 482 }, { 474, 533 }, { 475, 483 }, { 475, 534 }, { 476, 477 },
1306 { 476, 535 }, { 477, 536 }, { 478, 480 }, { 478, 484 }, { 478, 531 },
1307 { 479, 481 }, { 479, 485 }, { 479, 532 }, { 480, 486 }, { 480, 533 },
1308 { 481, 487 }, { 481, 534 }, { 482, 483 }, { 482, 537 }, { 483, 538 },
1309 { 484, 490 }, { 484, 539 }, { 485, 491 }, { 485, 540 }, { 486, 490 },
1310 { 486, 541 }, { 487, 491 }, { 487, 542 }, { 488, 494 }, { 488, 498 },
1311 { 488, 535 }, { 489, 495 }, { 489, 499 }, { 489, 536 }, { 490, 544 },
1312 { 491, 545 }, { 492, 496 }, { 492, 500 }, { 492, 537 }, { 493, 497 },
1313 { 493, 501 }, { 493, 538 }, { 494, 502 }, { 494, 539 }, { 495, 503 },
1314 { 495, 540 }, { 496, 504 }, { 496, 541 }, { 497, 505 }, { 497, 542 },
1315 { 498, 506 }, { 498, 543 }, { 499, 507 }, { 499, 543 }, { 500, 510 },
1316 { 500, 546 }, { 501, 511 }, { 501, 546 }, { 502, 506 }, { 502, 547 },
1317 { 503, 507 }, { 503, 548 }, { 504, 510 }, { 504, 549 }, { 505, 511 },
1318 { 505, 550 }, { 506, 551 }, { 507, 552 }, { 508, 512 }, { 508, 514 },
1319 { 508, 544 }, { 509, 513 }, { 509, 515 }, { 509, 545 }, { 510, 553 },
1320 { 511, 554 }, { 512, 518 }, { 512, 547 }, { 513, 519 }, { 513, 548 },
1321 { 514, 520 }, { 514, 549 }, { 515, 521 }, { 515, 550 }, { 516, 517 },
1322 { 516, 524 }, { 516, 551 }, { 517, 525 }, { 517, 552 }, { 518, 520 },
1323 { 518, 555 }, { 519, 521 }, { 519, 556 }, { 520, 557 }, { 521, 558 },
1324 { 522, 523 }, { 522, 526 }, { 522, 553 }, { 523, 527 }, { 523, 554 },
1325 { 524, 528 }, { 524, 555 }, { 525, 528 }, { 525, 556 }, { 526, 529 },
1326 { 526, 557 }, { 527, 529 }, { 527, 558 }, { 528, 559 }, { 529, 559 },
1327 { 530, 560 }, { 530, 561 }, { 531, 560 }, { 531, 562 }, { 532, 561 },
1328 { 532, 563 }, { 533, 560 }, { 533, 564 }, { 534, 561 }, { 534, 565 },
1329 { 535, 562 }, { 535, 566 }, { 536, 563 }, { 536, 566 }, { 537, 564 },
1330 { 537, 567 }, { 538, 565 }, { 538, 567 }, { 539, 562 }, { 539, 568 },
1331 { 540, 563 }, { 540, 569 }, { 541, 564 }, { 541, 570 }, { 542, 565 },
1332 { 542, 571 }, { 543, 566 }, { 543, 572 }, { 544, 568 }, { 544, 570 },
1333 { 545, 569 }, { 545, 571 }, { 546, 567 }, { 546, 573 }, { 547, 568 },
1334 { 547, 574 }, { 548, 569 }, { 548, 575 }, { 549, 570 }, { 549, 576 },
1335 { 550, 571 }, { 550, 577 }, { 551, 572 }, { 551, 574 }, { 552, 572 },
1336 { 552, 575 }, { 553, 573 }, { 553, 576 }, { 554, 573 }, { 554, 577 },
1337 { 555, 574 }, { 555, 578 }, { 556, 575 }, { 556, 579 }, { 557, 576 },
1338 { 557, 578 }, { 558, 577 }, { 558, 579 }, { 559, 578 }, { 559, 579 },
1339 { 560, 580 }, { 561, 581 }, { 562, 582 }, { 563, 583 }, { 564, 584 },
1340 { 565, 585 }, { 566, 586 }, { 567, 587 }, { 568, 588 }, { 569, 589 },
1341 { 570, 590 }, { 571, 591 }, { 572, 592 }, { 573, 593 }, { 574, 594 },
1342 { 575, 595 }, { 576, 596 }, { 577, 597 }, { 578, 598 }, { 579, 599 },
1343 { 580, 581 }, { 580, 582 }, { 580, 584 }, { 581, 583 }, { 581, 585 },
1344 { 582, 586 }, { 582, 588 }, { 583, 586 }, { 583, 589 }, { 584, 587 },
1345 { 584, 590 }, { 585, 587 }, { 585, 591 }, { 586, 592 }, { 587, 593 },
1346 { 588, 590 }, { 588, 594 }, { 589, 591 }, { 589, 595 }, { 590, 596 },
1347 { 591, 597 }, { 592, 594 }, { 592, 595 }, { 593, 596 }, { 593, 597 },
1348 { 594, 598 }, { 595, 599 }, { 596, 598 }, { 597, 599 }, { 598, 599 }
1351 static const int face_120[NUM_FACE_120][VERT_PER_FACE_120] = {
1352 { 0, 1, 3, 6, 2 }, { 0, 1, 5, 7, 4 },
1353 { 0, 1, 21, 40, 20 }, { 0, 2, 8, 10, 4 },
1354 { 0, 2, 22, 41, 20 }, { 0, 4, 24, 43, 20 },
1355 { 1, 3, 9, 11, 5 }, { 1, 3, 23, 42, 21 },
1356 { 1, 5, 25, 44, 21 }, { 2, 6, 12, 14, 8 },
1357 { 2, 6, 26, 45, 22 }, { 2, 8, 28, 49, 22 },
1358 { 3, 6, 12, 15, 9 }, { 3, 6, 26, 46, 23 },
1359 { 3, 9, 29, 50, 23 }, { 4, 7, 13, 16, 10 },
1360 { 4, 7, 27, 47, 24 }, { 4, 10, 30, 51, 24 },
1361 { 5, 7, 13, 17, 11 }, { 5, 7, 27, 48, 25 },
1362 { 5, 11, 31, 52, 25 }, { 6, 12, 32, 53, 26 },
1363 { 7, 13, 33, 56, 27 }, { 8, 10, 16, 18, 14 },
1364 { 8, 10, 30, 54, 28 }, { 8, 14, 34, 57, 28 },
1365 { 9, 11, 17, 19, 15 }, { 9, 11, 31, 55, 29 },
1366 { 9, 15, 35, 58, 29 }, { 10, 16, 36, 59, 30 },
1367 { 11, 17, 37, 60, 31 }, { 12, 14, 18, 19, 15 },
1368 { 12, 14, 34, 61, 32 }, { 12, 15, 35, 62, 32 },
1369 { 13, 16, 18, 19, 17 }, { 13, 16, 36, 63, 33 },
1370 { 13, 17, 37, 64, 33 }, { 14, 18, 38, 65, 34 },
1371 { 15, 19, 39, 66, 35 }, { 16, 18, 38, 67, 36 },
1372 { 17, 19, 39, 68, 37 }, { 18, 19, 39, 69, 38 },
1373 { 20, 40, 70, 72, 41 }, { 20, 40, 71, 74, 43 },
1374 { 20, 41, 78, 80, 43 }, { 21, 40, 70, 73, 42 },
1375 { 21, 40, 71, 75, 44 }, { 21, 42, 79, 81, 44 },
1376 { 22, 41, 72, 76, 45 }, { 22, 41, 78, 84, 49 },
1377 { 22, 45, 88, 94, 49 }, { 23, 42, 73, 77, 46 },
1378 { 23, 42, 79, 85, 50 }, { 23, 46, 89, 95, 50 },
1379 { 24, 43, 74, 82, 47 }, { 24, 43, 80, 86, 51 },
1380 { 24, 47, 92, 96, 51 }, { 25, 44, 75, 83, 48 },
1381 { 25, 44, 81, 87, 52 }, { 25, 48, 93, 97, 52 },
1382 { 26, 45, 76, 77, 46 }, { 26, 45, 88, 98, 53 },
1383 { 26, 46, 89, 99, 53 }, { 27, 47, 82, 83, 48 },
1384 { 27, 47, 92, 100, 56 }, { 27, 48, 93, 101, 56 },
1385 { 28, 49, 84, 90, 54 }, { 28, 49, 94, 102, 57 },
1386 { 28, 54, 108, 112, 57 }, { 29, 50, 85, 91, 55 },
1387 { 29, 50, 95, 103, 58 }, { 29, 55, 109, 113, 58 },
1388 { 30, 51, 86, 90, 54 }, { 30, 51, 96, 104, 59 },
1389 { 30, 54, 108, 114, 59 }, { 31, 52, 87, 91, 55 },
1390 { 31, 52, 97, 105, 60 }, { 31, 55, 109, 115, 60 },
1391 { 32, 53, 98, 106, 61 }, { 32, 53, 99, 107, 62 },
1392 { 32, 61, 116, 117, 62 }, { 33, 56, 100, 110, 63 },
1393 { 33, 56, 101, 111, 64 }, { 33, 63, 122, 123, 64 },
1394 { 34, 57, 102, 106, 61 }, { 34, 57, 112, 118, 65 },
1395 { 34, 61, 116, 124, 65 }, { 35, 58, 103, 107, 62 },
1396 { 35, 58, 113, 119, 66 }, { 35, 62, 117, 125, 66 },
1397 { 36, 59, 104, 110, 63 }, { 36, 59, 114, 120, 67 },
1398 { 36, 63, 122, 126, 67 }, { 37, 60, 105, 111, 64 },
1399 { 37, 60, 115, 121, 68 }, { 37, 64, 123, 127, 68 },
1400 { 38, 65, 118, 120, 67 }, { 38, 65, 124, 128, 69 },
1401 { 38, 67, 126, 129, 69 }, { 39, 66, 119, 121, 68 },
1402 { 39, 66, 125, 128, 69 }, { 39, 68, 127, 129, 69 },
1403 { 40, 70, 130, 131, 71 }, { 41, 72, 132, 136, 78 },
1404 { 42, 73, 133, 137, 79 }, { 43, 74, 134, 138, 80 },
1405 { 44, 75, 135, 139, 81 }, { 45, 76, 140, 144, 88 },
1406 { 46, 77, 141, 145, 89 }, { 47, 82, 142, 150, 92 },
1407 { 48, 83, 143, 151, 93 }, { 49, 84, 146, 152, 94 },
1408 { 50, 85, 147, 153, 95 }, { 51, 86, 148, 154, 96 },
1409 { 52, 87, 149, 155, 97 }, { 53, 98, 158, 159, 99 },
1410 { 54, 90, 156, 162, 108 }, { 55, 91, 157, 163, 109 },
1411 { 56, 100, 160, 161, 101 }, { 57, 102, 164, 170, 112 },
1412 { 58, 103, 165, 171, 113 }, { 59, 104, 166, 172, 114 },
1413 { 60, 105, 167, 173, 115 }, { 61, 106, 168, 176, 116 },
1414 { 62, 107, 169, 177, 117 }, { 63, 110, 174, 178, 122 },
1415 { 64, 111, 175, 179, 123 }, { 65, 118, 180, 184, 124 },
1416 { 66, 119, 181, 185, 125 }, { 67, 120, 182, 186, 126 },
1417 { 68, 121, 183, 187, 127 }, { 69, 128, 188, 189, 129 },
1418 { 70, 72, 76, 77, 73 }, { 70, 72, 132, 190, 130 },
1419 { 70, 73, 133, 191, 130 }, { 71, 74, 82, 83, 75 },
1420 { 71, 74, 134, 192, 131 }, { 71, 75, 135, 193, 131 },
1421 { 72, 76, 140, 196, 132 }, { 73, 77, 141, 197, 133 },
1422 { 74, 82, 142, 198, 134 }, { 75, 83, 143, 199, 135 },
1423 { 76, 77, 141, 200, 140 }, { 78, 80, 86, 90, 84 },
1424 { 78, 80, 138, 194, 136 }, { 78, 84, 146, 201, 136 },
1425 { 79, 81, 87, 91, 85 }, { 79, 81, 139, 195, 137 },
1426 { 79, 85, 147, 202, 137 }, { 80, 86, 148, 203, 138 },
1427 { 81, 87, 149, 204, 139 }, { 82, 83, 143, 205, 142 },
1428 { 84, 90, 156, 212, 146 }, { 85, 91, 157, 213, 147 },
1429 { 86, 90, 156, 214, 148 }, { 87, 91, 157, 215, 149 },
1430 { 88, 94, 102, 106, 98 }, { 88, 94, 152, 206, 144 },
1431 { 88, 98, 158, 210, 144 }, { 89, 95, 103, 107, 99 },
1432 { 89, 95, 153, 207, 145 }, { 89, 99, 159, 211, 145 },
1433 { 92, 96, 104, 110, 100 }, { 92, 96, 154, 208, 150 },
1434 { 92, 100, 160, 216, 150 }, { 93, 97, 105, 111, 101 },
1435 { 93, 97, 155, 209, 151 }, { 93, 101, 161, 217, 151 },
1436 { 94, 102, 164, 218, 152 }, { 95, 103, 165, 219, 153 },
1437 { 96, 104, 166, 220, 154 }, { 97, 105, 167, 221, 155 },
1438 { 98, 106, 168, 222, 158 }, { 99, 107, 169, 223, 159 },
1439 { 100, 110, 174, 228, 160 }, { 101, 111, 175, 229, 161 },
1440 { 102, 106, 168, 230, 164 }, { 103, 107, 169, 231, 165 },
1441 { 104, 110, 174, 232, 166 }, { 105, 111, 175, 233, 167 },
1442 { 108, 112, 118, 120, 114 }, { 108, 112, 170, 224, 162 },
1443 { 108, 114, 172, 226, 162 }, { 109, 113, 119, 121, 115 },
1444 { 109, 113, 171, 225, 163 }, { 109, 115, 173, 227, 163 },
1445 { 112, 118, 180, 235, 170 }, { 113, 119, 181, 236, 171 },
1446 { 114, 120, 182, 237, 172 }, { 115, 121, 183, 238, 173 },
1447 { 116, 117, 125, 128, 124 }, { 116, 117, 177, 234, 176 },
1448 { 116, 124, 184, 240, 176 }, { 117, 125, 185, 241, 177 },
1449 { 118, 120, 182, 244, 180 }, { 119, 121, 183, 245, 181 },
1450 { 122, 123, 127, 129, 126 }, { 122, 123, 179, 239, 178 },
1451 { 122, 126, 186, 242, 178 }, { 123, 127, 187, 243, 179 },
1452 { 124, 128, 188, 246, 184 }, { 125, 128, 188, 247, 185 },
1453 { 126, 129, 189, 248, 186 }, { 127, 129, 189, 249, 187 },
1454 { 130, 131, 192, 250, 190 }, { 130, 131, 193, 251, 191 },
1455 { 130, 190, 270, 271, 191 }, { 131, 192, 272, 273, 193 },
1456 { 132, 136, 194, 250, 190 }, { 132, 136, 201, 252, 196 },
1457 { 132, 190, 270, 274, 196 }, { 133, 137, 195, 251, 191 },
1458 { 133, 137, 202, 253, 197 }, { 133, 191, 271, 275, 197 },
1459 { 134, 138, 194, 250, 192 }, { 134, 138, 203, 254, 198 },
1460 { 134, 192, 272, 276, 198 }, { 135, 139, 195, 251, 193 },
1461 { 135, 139, 204, 255, 199 }, { 135, 193, 273, 277, 199 },
1462 { 136, 194, 279, 282, 201 }, { 137, 195, 280, 283, 202 },
1463 { 138, 194, 279, 284, 203 }, { 139, 195, 280, 285, 204 },
1464 { 140, 144, 206, 252, 196 }, { 140, 144, 210, 256, 200 },
1465 { 140, 196, 274, 278, 200 }, { 141, 145, 207, 253, 197 },
1466 { 141, 145, 211, 256, 200 }, { 141, 197, 275, 278, 200 },
1467 { 142, 150, 208, 254, 198 }, { 142, 150, 216, 257, 205 },
1468 { 142, 198, 276, 281, 205 }, { 143, 151, 209, 255, 199 },
1469 { 143, 151, 217, 257, 205 }, { 143, 199, 277, 281, 205 },
1470 { 144, 206, 290, 294, 210 }, { 145, 207, 291, 295, 211 },
1471 { 146, 152, 206, 252, 201 }, { 146, 152, 218, 258, 212 },
1472 { 146, 201, 282, 286, 212 }, { 147, 153, 207, 253, 202 },
1473 { 147, 153, 219, 259, 213 }, { 147, 202, 283, 287, 213 },
1474 { 148, 154, 208, 254, 203 }, { 148, 154, 220, 260, 214 },
1475 { 148, 203, 284, 288, 214 }, { 149, 155, 209, 255, 204 },
1476 { 149, 155, 221, 261, 215 }, { 149, 204, 285, 289, 215 },
1477 { 150, 208, 292, 296, 216 }, { 151, 209, 293, 297, 217 },
1478 { 152, 206, 290, 298, 218 }, { 153, 207, 291, 299, 219 },
1479 { 154, 208, 292, 300, 220 }, { 155, 209, 293, 301, 221 },
1480 { 156, 162, 224, 258, 212 }, { 156, 162, 226, 260, 214 },
1481 { 156, 212, 286, 288, 214 }, { 157, 163, 225, 259, 213 },
1482 { 157, 163, 227, 261, 215 }, { 157, 213, 287, 289, 215 },
1483 { 158, 159, 211, 256, 210 }, { 158, 159, 223, 262, 222 },
1484 { 158, 210, 294, 302, 222 }, { 159, 211, 295, 303, 223 },
1485 { 160, 161, 217, 257, 216 }, { 160, 161, 229, 263, 228 },
1486 { 160, 216, 296, 304, 228 }, { 161, 217, 297, 305, 229 },
1487 { 162, 224, 310, 312, 226 }, { 163, 225, 311, 313, 227 },
1488 { 164, 170, 224, 258, 218 }, { 164, 170, 235, 264, 230 },
1489 { 164, 218, 298, 306, 230 }, { 165, 171, 225, 259, 219 },
1490 { 165, 171, 236, 265, 231 }, { 165, 219, 299, 307, 231 },
1491 { 166, 172, 226, 260, 220 }, { 166, 172, 237, 266, 232 },
1492 { 166, 220, 300, 308, 232 }, { 167, 173, 227, 261, 221 },
1493 { 167, 173, 238, 267, 233 }, { 167, 221, 301, 309, 233 },
1494 { 168, 176, 234, 262, 222 }, { 168, 176, 240, 264, 230 },
1495 { 168, 222, 302, 306, 230 }, { 169, 177, 234, 262, 223 },
1496 { 169, 177, 241, 265, 231 }, { 169, 223, 303, 307, 231 },
1497 { 170, 224, 310, 314, 235 }, { 171, 225, 311, 315, 236 },
1498 { 172, 226, 312, 316, 237 }, { 173, 227, 313, 317, 238 },
1499 { 174, 178, 239, 263, 228 }, { 174, 178, 242, 266, 232 },
1500 { 174, 228, 304, 308, 232 }, { 175, 179, 239, 263, 229 },
1501 { 175, 179, 243, 267, 233 }, { 175, 229, 305, 309, 233 },
1502 { 176, 234, 318, 322, 240 }, { 177, 234, 318, 323, 241 },
1503 { 178, 239, 321, 324, 242 }, { 179, 239, 321, 325, 243 },
1504 { 180, 184, 240, 264, 235 }, { 180, 184, 246, 268, 244 },
1505 { 180, 235, 314, 319, 244 }, { 181, 185, 241, 265, 236 },
1506 { 181, 185, 247, 269, 245 }, { 181, 236, 315, 320, 245 },
1507 { 182, 186, 242, 266, 237 }, { 182, 186, 248, 268, 244 },
1508 { 182, 237, 316, 319, 244 }, { 183, 187, 243, 267, 238 },
1509 { 183, 187, 249, 269, 245 }, { 183, 238, 317, 320, 245 },
1510 { 184, 240, 322, 326, 246 }, { 185, 241, 323, 327, 247 },
1511 { 186, 242, 324, 328, 248 }, { 187, 243, 325, 329, 249 },
1512 { 188, 189, 248, 268, 246 }, { 188, 189, 249, 269, 247 },
1513 { 188, 246, 326, 327, 247 }, { 189, 248, 328, 329, 249 },
1514 { 190, 250, 330, 350, 270 }, { 191, 251, 331, 351, 271 },
1515 { 192, 250, 330, 352, 272 }, { 193, 251, 331, 353, 273 },
1516 { 194, 250, 330, 354, 279 }, { 195, 251, 331, 355, 280 },
1517 { 196, 252, 332, 356, 274 }, { 197, 253, 333, 357, 275 },
1518 { 198, 254, 334, 358, 276 }, { 199, 255, 335, 359, 277 },
1519 { 200, 256, 336, 360, 278 }, { 201, 252, 332, 361, 282 },
1520 { 202, 253, 333, 362, 283 }, { 203, 254, 334, 363, 284 },
1521 { 204, 255, 335, 364, 285 }, { 205, 257, 337, 365, 281 },
1522 { 206, 252, 332, 366, 290 }, { 207, 253, 333, 367, 291 },
1523 { 208, 254, 334, 368, 292 }, { 209, 255, 335, 369, 293 },
1524 { 210, 256, 336, 370, 294 }, { 211, 256, 336, 371, 295 },
1525 { 212, 258, 338, 372, 286 }, { 213, 259, 339, 373, 287 },
1526 { 214, 260, 340, 374, 288 }, { 215, 261, 341, 375, 289 },
1527 { 216, 257, 337, 376, 296 }, { 217, 257, 337, 377, 297 },
1528 { 218, 258, 338, 378, 298 }, { 219, 259, 339, 379, 299 },
1529 { 220, 260, 340, 380, 300 }, { 221, 261, 341, 381, 301 },
1530 { 222, 262, 342, 382, 302 }, { 223, 262, 342, 383, 303 },
1531 { 224, 258, 338, 384, 310 }, { 225, 259, 339, 385, 311 },
1532 { 226, 260, 340, 386, 312 }, { 227, 261, 341, 387, 313 },
1533 { 228, 263, 343, 388, 304 }, { 229, 263, 343, 389, 305 },
1534 { 230, 264, 344, 390, 306 }, { 231, 265, 345, 391, 307 },
1535 { 232, 266, 346, 392, 308 }, { 233, 267, 347, 393, 309 },
1536 { 234, 262, 342, 394, 318 }, { 235, 264, 344, 395, 314 },
1537 { 236, 265, 345, 396, 315 }, { 237, 266, 346, 397, 316 },
1538 { 238, 267, 347, 398, 317 }, { 239, 263, 343, 399, 321 },
1539 { 240, 264, 344, 400, 322 }, { 241, 265, 345, 401, 323 },
1540 { 242, 266, 346, 402, 324 }, { 243, 267, 347, 403, 325 },
1541 { 244, 268, 348, 404, 319 }, { 245, 269, 349, 405, 320 },
1542 { 246, 268, 348, 406, 326 }, { 247, 269, 349, 407, 327 },
1543 { 248, 268, 348, 408, 328 }, { 249, 269, 349, 409, 329 },
1544 { 270, 271, 275, 278, 274 }, { 270, 271, 351, 410, 350 },
1545 { 270, 274, 356, 412, 350 }, { 271, 275, 357, 413, 351 },
1546 { 272, 273, 277, 281, 276 }, { 272, 273, 353, 411, 352 },
1547 { 272, 276, 358, 414, 352 }, { 273, 277, 359, 415, 353 },
1548 { 274, 278, 360, 420, 356 }, { 275, 278, 360, 421, 357 },
1549 { 276, 281, 365, 422, 358 }, { 277, 281, 365, 423, 359 },
1550 { 279, 282, 286, 288, 284 }, { 279, 282, 361, 416, 354 },
1551 { 279, 284, 363, 418, 354 }, { 280, 283, 287, 289, 285 },
1552 { 280, 283, 362, 417, 355 }, { 280, 285, 364, 419, 355 },
1553 { 282, 286, 372, 426, 361 }, { 283, 287, 373, 427, 362 },
1554 { 284, 288, 374, 428, 363 }, { 285, 289, 375, 429, 364 },
1555 { 286, 288, 374, 436, 372 }, { 287, 289, 375, 437, 373 },
1556 { 290, 294, 302, 306, 298 }, { 290, 294, 370, 424, 366 },
1557 { 290, 298, 378, 432, 366 }, { 291, 295, 303, 307, 299 },
1558 { 291, 295, 371, 425, 367 }, { 291, 299, 379, 433, 367 },
1559 { 292, 296, 304, 308, 300 }, { 292, 296, 376, 430, 368 },
1560 { 292, 300, 380, 434, 368 }, { 293, 297, 305, 309, 301 },
1561 { 293, 297, 377, 431, 369 }, { 293, 301, 381, 435, 369 },
1562 { 294, 302, 382, 438, 370 }, { 295, 303, 383, 439, 371 },
1563 { 296, 304, 388, 440, 376 }, { 297, 305, 389, 441, 377 },
1564 { 298, 306, 390, 444, 378 }, { 299, 307, 391, 445, 379 },
1565 { 300, 308, 392, 446, 380 }, { 301, 309, 393, 447, 381 },
1566 { 302, 306, 390, 448, 382 }, { 303, 307, 391, 449, 383 },
1567 { 304, 308, 392, 454, 388 }, { 305, 309, 393, 455, 389 },
1568 { 310, 312, 316, 319, 314 }, { 310, 312, 386, 442, 384 },
1569 { 310, 314, 395, 450, 384 }, { 311, 313, 317, 320, 315 },
1570 { 311, 313, 387, 443, 385 }, { 311, 315, 396, 451, 385 },
1571 { 312, 316, 397, 452, 386 }, { 313, 317, 398, 453, 387 },
1572 { 314, 319, 404, 460, 395 }, { 315, 320, 405, 461, 396 },
1573 { 316, 319, 404, 462, 397 }, { 317, 320, 405, 463, 398 },
1574 { 318, 322, 326, 327, 323 }, { 318, 322, 400, 456, 394 },
1575 { 318, 323, 401, 457, 394 }, { 321, 324, 328, 329, 325 },
1576 { 321, 324, 402, 458, 399 }, { 321, 325, 403, 459, 399 },
1577 { 322, 326, 406, 464, 400 }, { 323, 327, 407, 465, 401 },
1578 { 324, 328, 408, 466, 402 }, { 325, 329, 409, 467, 403 },
1579 { 326, 327, 407, 468, 406 }, { 328, 329, 409, 469, 408 },
1580 { 330, 350, 410, 411, 352 }, { 330, 350, 412, 416, 354 },
1581 { 330, 352, 414, 418, 354 }, { 331, 351, 410, 411, 353 },
1582 { 331, 351, 413, 417, 355 }, { 331, 353, 415, 419, 355 },
1583 { 332, 356, 412, 416, 361 }, { 332, 356, 420, 424, 366 },
1584 { 332, 361, 426, 432, 366 }, { 333, 357, 413, 417, 362 },
1585 { 333, 357, 421, 425, 367 }, { 333, 362, 427, 433, 367 },
1586 { 334, 358, 414, 418, 363 }, { 334, 358, 422, 430, 368 },
1587 { 334, 363, 428, 434, 368 }, { 335, 359, 415, 419, 364 },
1588 { 335, 359, 423, 431, 369 }, { 335, 364, 429, 435, 369 },
1589 { 336, 360, 420, 424, 370 }, { 336, 360, 421, 425, 371 },
1590 { 336, 370, 438, 439, 371 }, { 337, 365, 422, 430, 376 },
1591 { 337, 365, 423, 431, 377 }, { 337, 376, 440, 441, 377 },
1592 { 338, 372, 426, 432, 378 }, { 338, 372, 436, 442, 384 },
1593 { 338, 378, 444, 450, 384 }, { 339, 373, 427, 433, 379 },
1594 { 339, 373, 437, 443, 385 }, { 339, 379, 445, 451, 385 },
1595 { 340, 374, 428, 434, 380 }, { 340, 374, 436, 442, 386 },
1596 { 340, 380, 446, 452, 386 }, { 341, 375, 429, 435, 381 },
1597 { 341, 375, 437, 443, 387 }, { 341, 381, 447, 453, 387 },
1598 { 342, 382, 438, 439, 383 }, { 342, 382, 448, 456, 394 },
1599 { 342, 383, 449, 457, 394 }, { 343, 388, 440, 441, 389 },
1600 { 343, 388, 454, 458, 399 }, { 343, 389, 455, 459, 399 },
1601 { 344, 390, 444, 450, 395 }, { 344, 390, 448, 456, 400 },
1602 { 344, 395, 460, 464, 400 }, { 345, 391, 445, 451, 396 },
1603 { 345, 391, 449, 457, 401 }, { 345, 396, 461, 465, 401 },
1604 { 346, 392, 446, 452, 397 }, { 346, 392, 454, 458, 402 },
1605 { 346, 397, 462, 466, 402 }, { 347, 393, 447, 453, 398 },
1606 { 347, 393, 455, 459, 403 }, { 347, 398, 463, 467, 403 },
1607 { 348, 404, 460, 464, 406 }, { 348, 404, 462, 466, 408 },
1608 { 348, 406, 468, 469, 408 }, { 349, 405, 461, 465, 407 },
1609 { 349, 405, 463, 467, 409 }, { 349, 407, 468, 469, 409 },
1610 { 350, 410, 470, 472, 412 }, { 351, 410, 470, 473, 413 },
1611 { 352, 411, 471, 474, 414 }, { 353, 411, 471, 475, 415 },
1612 { 354, 416, 478, 480, 418 }, { 355, 417, 479, 481, 419 },
1613 { 356, 412, 472, 476, 420 }, { 357, 413, 473, 477, 421 },
1614 { 358, 414, 474, 482, 422 }, { 359, 415, 475, 483, 423 },
1615 { 360, 420, 476, 477, 421 }, { 361, 416, 478, 484, 426 },
1616 { 362, 417, 479, 485, 427 }, { 363, 418, 480, 486, 428 },
1617 { 364, 419, 481, 487, 429 }, { 365, 422, 482, 483, 423 },
1618 { 366, 424, 488, 494, 432 }, { 367, 425, 489, 495, 433 },
1619 { 368, 430, 492, 496, 434 }, { 369, 431, 493, 497, 435 },
1620 { 370, 424, 488, 498, 438 }, { 371, 425, 489, 499, 439 },
1621 { 372, 426, 484, 490, 436 }, { 373, 427, 485, 491, 437 },
1622 { 374, 428, 486, 490, 436 }, { 375, 429, 487, 491, 437 },
1623 { 376, 430, 492, 500, 440 }, { 377, 431, 493, 501, 441 },
1624 { 378, 432, 494, 502, 444 }, { 379, 433, 495, 503, 445 },
1625 { 380, 434, 496, 504, 446 }, { 381, 435, 497, 505, 447 },
1626 { 382, 438, 498, 506, 448 }, { 383, 439, 499, 507, 449 },
1627 { 384, 442, 508, 512, 450 }, { 385, 443, 509, 513, 451 },
1628 { 386, 442, 508, 514, 452 }, { 387, 443, 509, 515, 453 },
1629 { 388, 440, 500, 510, 454 }, { 389, 441, 501, 511, 455 },
1630 { 390, 444, 502, 506, 448 }, { 391, 445, 503, 507, 449 },
1631 { 392, 446, 504, 510, 454 }, { 393, 447, 505, 511, 455 },
1632 { 394, 456, 516, 517, 457 }, { 395, 450, 512, 518, 460 },
1633 { 396, 451, 513, 519, 461 }, { 397, 452, 514, 520, 462 },
1634 { 398, 453, 515, 521, 463 }, { 399, 458, 522, 523, 459 },
1635 { 400, 456, 516, 524, 464 }, { 401, 457, 517, 525, 465 },
1636 { 402, 458, 522, 526, 466 }, { 403, 459, 523, 527, 467 },
1637 { 404, 460, 518, 520, 462 }, { 405, 461, 519, 521, 463 },
1638 { 406, 464, 524, 528, 468 }, { 407, 465, 525, 528, 468 },
1639 { 408, 466, 526, 529, 469 }, { 409, 467, 527, 529, 469 },
1640 { 410, 411, 471, 530, 470 }, { 412, 416, 478, 531, 472 },
1641 { 413, 417, 479, 532, 473 }, { 414, 418, 480, 533, 474 },
1642 { 415, 419, 481, 534, 475 }, { 420, 424, 488, 535, 476 },
1643 { 421, 425, 489, 536, 477 }, { 422, 430, 492, 537, 482 },
1644 { 423, 431, 493, 538, 483 }, { 426, 432, 494, 539, 484 },
1645 { 427, 433, 495, 540, 485 }, { 428, 434, 496, 541, 486 },
1646 { 429, 435, 497, 542, 487 }, { 436, 442, 508, 544, 490 },
1647 { 437, 443, 509, 545, 491 }, { 438, 439, 499, 543, 498 },
1648 { 440, 441, 501, 546, 500 }, { 444, 450, 512, 547, 502 },
1649 { 445, 451, 513, 548, 503 }, { 446, 452, 514, 549, 504 },
1650 { 447, 453, 515, 550, 505 }, { 448, 456, 516, 551, 506 },
1651 { 449, 457, 517, 552, 507 }, { 454, 458, 522, 553, 510 },
1652 { 455, 459, 523, 554, 511 }, { 460, 464, 524, 555, 518 },
1653 { 461, 465, 525, 556, 519 }, { 462, 466, 526, 557, 520 },
1654 { 463, 467, 527, 558, 521 }, { 468, 469, 529, 559, 528 },
1655 { 470, 472, 476, 477, 473 }, { 470, 472, 531, 560, 530 },
1656 { 470, 473, 532, 561, 530 }, { 471, 474, 482, 483, 475 },
1657 { 471, 474, 533, 560, 530 }, { 471, 475, 534, 561, 530 },
1658 { 472, 476, 535, 562, 531 }, { 473, 477, 536, 563, 532 },
1659 { 474, 482, 537, 564, 533 }, { 475, 483, 538, 565, 534 },
1660 { 476, 477, 536, 566, 535 }, { 478, 480, 486, 490, 484 },
1661 { 478, 480, 533, 560, 531 }, { 478, 484, 539, 562, 531 },
1662 { 479, 481, 487, 491, 485 }, { 479, 481, 534, 561, 532 },
1663 { 479, 485, 540, 563, 532 }, { 480, 486, 541, 564, 533 },
1664 { 481, 487, 542, 565, 534 }, { 482, 483, 538, 567, 537 },
1665 { 484, 490, 544, 568, 539 }, { 485, 491, 545, 569, 540 },
1666 { 486, 490, 544, 570, 541 }, { 487, 491, 545, 571, 542 },
1667 { 488, 494, 502, 506, 498 }, { 488, 494, 539, 562, 535 },
1668 { 488, 498, 543, 566, 535 }, { 489, 495, 503, 507, 499 },
1669 { 489, 495, 540, 563, 536 }, { 489, 499, 543, 566, 536 },
1670 { 492, 496, 504, 510, 500 }, { 492, 496, 541, 564, 537 },
1671 { 492, 500, 546, 567, 537 }, { 493, 497, 505, 511, 501 },
1672 { 493, 497, 542, 565, 538 }, { 493, 501, 546, 567, 538 },
1673 { 494, 502, 547, 568, 539 }, { 495, 503, 548, 569, 540 },
1674 { 496, 504, 549, 570, 541 }, { 497, 505, 550, 571, 542 },
1675 { 498, 506, 551, 572, 543 }, { 499, 507, 552, 572, 543 },
1676 { 500, 510, 553, 573, 546 }, { 501, 511, 554, 573, 546 },
1677 { 502, 506, 551, 574, 547 }, { 503, 507, 552, 575, 548 },
1678 { 504, 510, 553, 576, 549 }, { 505, 511, 554, 577, 550 },
1679 { 508, 512, 518, 520, 514 }, { 508, 512, 547, 568, 544 },
1680 { 508, 514, 549, 570, 544 }, { 509, 513, 519, 521, 515 },
1681 { 509, 513, 548, 569, 545 }, { 509, 515, 550, 571, 545 },
1682 { 512, 518, 555, 574, 547 }, { 513, 519, 556, 575, 548 },
1683 { 514, 520, 557, 576, 549 }, { 515, 521, 558, 577, 550 },
1684 { 516, 517, 525, 528, 524 }, { 516, 517, 552, 572, 551 },
1685 { 516, 524, 555, 574, 551 }, { 517, 525, 556, 575, 552 },
1686 { 518, 520, 557, 578, 555 }, { 519, 521, 558, 579, 556 },
1687 { 522, 523, 527, 529, 526 }, { 522, 523, 554, 573, 553 },
1688 { 522, 526, 557, 576, 553 }, { 523, 527, 558, 577, 554 },
1689 { 524, 528, 559, 578, 555 }, { 525, 528, 559, 579, 556 },
1690 { 526, 529, 559, 578, 557 }, { 527, 529, 559, 579, 558 },
1691 { 530, 560, 580, 581, 561 }, { 531, 560, 580, 582, 562 },
1692 { 532, 561, 581, 583, 563 }, { 533, 560, 580, 584, 564 },
1693 { 534, 561, 581, 585, 565 }, { 535, 562, 582, 586, 566 },
1694 { 536, 563, 583, 586, 566 }, { 537, 564, 584, 587, 567 },
1695 { 538, 565, 585, 587, 567 }, { 539, 562, 582, 588, 568 },
1696 { 540, 563, 583, 589, 569 }, { 541, 564, 584, 590, 570 },
1697 { 542, 565, 585, 591, 571 }, { 543, 566, 586, 592, 572 },
1698 { 544, 568, 588, 590, 570 }, { 545, 569, 589, 591, 571 },
1699 { 546, 567, 587, 593, 573 }, { 547, 568, 588, 594, 574 },
1700 { 548, 569, 589, 595, 575 }, { 549, 570, 590, 596, 576 },
1701 { 550, 571, 591, 597, 577 }, { 551, 572, 592, 594, 574 },
1702 { 552, 572, 592, 595, 575 }, { 553, 573, 593, 596, 576 },
1703 { 554, 573, 593, 597, 577 }, { 555, 574, 594, 598, 578 },
1704 { 556, 575, 595, 599, 579 }, { 557, 576, 596, 598, 578 },
1705 { 558, 577, 597, 599, 579 }, { 559, 578, 598, 599, 579 },
1706 { 580, 581, 583, 586, 582 }, { 580, 581, 585, 587, 584 },
1707 { 580, 582, 588, 590, 584 }, { 581, 583, 589, 591, 585 },
1708 { 582, 586, 592, 594, 588 }, { 583, 586, 592, 595, 589 },
1709 { 584, 587, 593, 596, 590 }, { 585, 587, 593, 597, 591 },
1710 { 588, 590, 596, 598, 594 }, { 589, 591, 597, 599, 595 },
1711 { 592, 594, 598, 599, 595 }, { 593, 596, 598, 599, 597 }
1716 static const float vert_600[NUM_VERT_600][4] = {
1717 { 0.0, 0.0, 0.0, -2.0 },
1718 { 0.0, -GOLDENINV, -1.0, -GOLDEN },
1719 { 0.0, GOLDENINV, -1.0, -GOLDEN },
1720 { -1.0, 0.0, -GOLDENINV, -GOLDEN },
1721 { 1.0, 0.0, -GOLDENINV, -GOLDEN },
1722 { -GOLDENINV, -1.0, 0.0, -GOLDEN },
1723 { GOLDENINV, -1.0, 0.0, -GOLDEN },
1724 { -GOLDENINV, 1.0, 0.0, -GOLDEN },
1725 { GOLDENINV, 1.0, 0.0, -GOLDEN },
1726 { -1.0, 0.0, GOLDENINV, -GOLDEN },
1727 { 1.0, 0.0, GOLDENINV, -GOLDEN },
1728 { 0.0, -GOLDENINV, 1.0, -GOLDEN },
1729 { 0.0, GOLDENINV, 1.0, -GOLDEN },
1730 { -GOLDENINV, 0.0, -GOLDEN, -1.0 },
1731 { GOLDENINV, 0.0, -GOLDEN, -1.0 },
1732 { -1.0, -1.0, -1.0, -1.0 },
1733 { 1.0, -1.0, -1.0, -1.0 },
1734 { -1.0, 1.0, -1.0, -1.0 },
1735 { 1.0, 1.0, -1.0, -1.0 },
1736 { 0.0, -GOLDEN, -GOLDENINV, -1.0 },
1737 { 0.0, GOLDEN, -GOLDENINV, -1.0 },
1738 { -GOLDEN, -GOLDENINV, 0.0, -1.0 },
1739 { GOLDEN, -GOLDENINV, 0.0, -1.0 },
1740 { -GOLDEN, GOLDENINV, 0.0, -1.0 },
1741 { GOLDEN, GOLDENINV, 0.0, -1.0 },
1742 { 0.0, -GOLDEN, GOLDENINV, -1.0 },
1743 { 0.0, GOLDEN, GOLDENINV, -1.0 },
1744 { -1.0, -1.0, 1.0, -1.0 },
1745 { 1.0, -1.0, 1.0, -1.0 },
1746 { -1.0, 1.0, 1.0, -1.0 },
1747 { 1.0, 1.0, 1.0, -1.0 },
1748 { -GOLDENINV, 0.0, GOLDEN, -1.0 },
1749 { GOLDENINV, 0.0, GOLDEN, -1.0 },
1750 { 0.0, -1.0, -GOLDEN, -GOLDENINV },
1751 { 0.0, 1.0, -GOLDEN, -GOLDENINV },
1752 { -GOLDEN, 0.0, -1.0, -GOLDENINV },
1753 { GOLDEN, 0.0, -1.0, -GOLDENINV },
1754 { -1.0, -GOLDEN, 0.0, -GOLDENINV },
1755 { 1.0, -GOLDEN, 0.0, -GOLDENINV },
1756 { -1.0, GOLDEN, 0.0, -GOLDENINV },
1757 { 1.0, GOLDEN, 0.0, -GOLDENINV },
1758 { -GOLDEN, 0.0, 1.0, -GOLDENINV },
1759 { GOLDEN, 0.0, 1.0, -GOLDENINV },
1760 { 0.0, -1.0, GOLDEN, -GOLDENINV },
1761 { 0.0, 1.0, GOLDEN, -GOLDENINV },
1762 { 0.0, 0.0, -2.0, 0.0 },
1763 { -1.0, -GOLDENINV, -GOLDEN, 0.0 },
1764 { 1.0, -GOLDENINV, -GOLDEN, 0.0 },
1765 { -1.0, GOLDENINV, -GOLDEN, 0.0 },
1766 { 1.0, GOLDENINV, -GOLDEN, 0.0 },
1767 { -GOLDENINV, -GOLDEN, -1.0, 0.0 },
1768 { GOLDENINV, -GOLDEN, -1.0, 0.0 },
1769 { -GOLDENINV, GOLDEN, -1.0, 0.0 },
1770 { GOLDENINV, GOLDEN, -1.0, 0.0 },
1771 { -GOLDEN, -1.0, -GOLDENINV, 0.0 },
1772 { GOLDEN, -1.0, -GOLDENINV, 0.0 },
1773 { -GOLDEN, 1.0, -GOLDENINV, 0.0 },
1774 { GOLDEN, 1.0, -GOLDENINV, 0.0 },
1775 { 0.0, -2.0, 0.0, 0.0 },
1776 { -2.0, 0.0, 0.0, 0.0 },
1777 { 2.0, 0.0, 0.0, 0.0 },
1778 { 0.0, 2.0, 0.0, 0.0 },
1779 { -GOLDEN, -1.0, GOLDENINV, 0.0 },
1780 { GOLDEN, -1.0, GOLDENINV, 0.0 },
1781 { -GOLDEN, 1.0, GOLDENINV, 0.0 },
1782 { GOLDEN, 1.0, GOLDENINV, 0.0 },
1783 { -GOLDENINV, -GOLDEN, 1.0, 0.0 },
1784 { GOLDENINV, -GOLDEN, 1.0, 0.0 },
1785 { -GOLDENINV, GOLDEN, 1.0, 0.0 },
1786 { GOLDENINV, GOLDEN, 1.0, 0.0 },
1787 { -1.0, -GOLDENINV, GOLDEN, 0.0 },
1788 { 1.0, -GOLDENINV, GOLDEN, 0.0 },
1789 { -1.0, GOLDENINV, GOLDEN, 0.0 },
1790 { 1.0, GOLDENINV, GOLDEN, 0.0 },
1791 { 0.0, 0.0, 2.0, 0.0 },
1792 { 0.0, -1.0, -GOLDEN, GOLDENINV },
1793 { 0.0, 1.0, -GOLDEN, GOLDENINV },
1794 { -GOLDEN, 0.0, -1.0, GOLDENINV },
1795 { GOLDEN, 0.0, -1.0, GOLDENINV },
1796 { -1.0, -GOLDEN, 0.0, GOLDENINV },
1797 { 1.0, -GOLDEN, 0.0, GOLDENINV },
1798 { -1.0, GOLDEN, 0.0, GOLDENINV },
1799 { 1.0, GOLDEN, 0.0, GOLDENINV },
1800 { -GOLDEN, 0.0, 1.0, GOLDENINV },
1801 { GOLDEN, 0.0, 1.0, GOLDENINV },
1802 { 0.0, -1.0, GOLDEN, GOLDENINV },
1803 { 0.0, 1.0, GOLDEN, GOLDENINV },
1804 { -GOLDENINV, 0.0, -GOLDEN, 1.0 },
1805 { GOLDENINV, 0.0, -GOLDEN, 1.0 },
1806 { -1.0, -1.0, -1.0, 1.0 },
1807 { 1.0, -1.0, -1.0, 1.0 },
1808 { -1.0, 1.0, -1.0, 1.0 },
1809 { 1.0, 1.0, -1.0, 1.0 },
1810 { 0.0, -GOLDEN, -GOLDENINV, 1.0 },
1811 { 0.0, GOLDEN, -GOLDENINV, 1.0 },
1812 { -GOLDEN, -GOLDENINV, 0.0, 1.0 },
1813 { GOLDEN, -GOLDENINV, 0.0, 1.0 },
1814 { -GOLDEN, GOLDENINV, 0.0, 1.0 },
1815 { GOLDEN, GOLDENINV, 0.0, 1.0 },
1816 { 0.0, -GOLDEN, GOLDENINV, 1.0 },
1817 { 0.0, GOLDEN, GOLDENINV, 1.0 },
1818 { -1.0, -1.0, 1.0, 1.0 },
1819 { 1.0, -1.0, 1.0, 1.0 },
1820 { -1.0, 1.0, 1.0, 1.0 },
1821 { 1.0, 1.0, 1.0, 1.0 },
1822 { -GOLDENINV, 0.0, GOLDEN, 1.0 },
1823 { GOLDENINV, 0.0, GOLDEN, 1.0 },
1824 { 0.0, -GOLDENINV, -1.0, GOLDEN },
1825 { 0.0, GOLDENINV, -1.0, GOLDEN },
1826 { -1.0, 0.0, -GOLDENINV, GOLDEN },
1827 { 1.0, 0.0, -GOLDENINV, GOLDEN },
1828 { -GOLDENINV, -1.0, 0.0, GOLDEN },
1829 { GOLDENINV, -1.0, 0.0, GOLDEN },
1830 { -GOLDENINV, 1.0, 0.0, GOLDEN },
1831 { GOLDENINV, 1.0, 0.0, GOLDEN },
1832 { -1.0, 0.0, GOLDENINV, GOLDEN },
1833 { 1.0, 0.0, GOLDENINV, GOLDEN },
1834 { 0.0, -GOLDENINV, 1.0, GOLDEN },
1835 { 0.0, GOLDENINV, 1.0, GOLDEN },
1836 { 0.0, 0.0, 0.0, 2.0 }
1839 static const int edge_600[NUM_EDGE_600][2] = {
1840 { 0, 1 }, { 0, 2 }, { 0, 3 }, { 0, 4 }, { 0, 5 },
1841 { 0, 6 }, { 0, 7 }, { 0, 8 }, { 0, 9 }, { 0, 10 },
1842 { 0, 11 }, { 0, 12 }, { 1, 2 }, { 1, 3 }, { 1, 4 },
1843 { 1, 5 }, { 1, 6 }, { 1, 13 }, { 1, 14 }, { 1, 15 },
1844 { 1, 16 }, { 1, 19 }, { 1, 33 }, { 2, 3 }, { 2, 4 },
1845 { 2, 7 }, { 2, 8 }, { 2, 13 }, { 2, 14 }, { 2, 17 },
1846 { 2, 18 }, { 2, 20 }, { 2, 34 }, { 3, 5 }, { 3, 7 },
1847 { 3, 9 }, { 3, 13 }, { 3, 15 }, { 3, 17 }, { 3, 21 },
1848 { 3, 23 }, { 3, 35 }, { 4, 6 }, { 4, 8 }, { 4, 10 },
1849 { 4, 14 }, { 4, 16 }, { 4, 18 }, { 4, 22 }, { 4, 24 },
1850 { 4, 36 }, { 5, 6 }, { 5, 9 }, { 5, 11 }, { 5, 15 },
1851 { 5, 19 }, { 5, 21 }, { 5, 25 }, { 5, 27 }, { 5, 37 },
1852 { 6, 10 }, { 6, 11 }, { 6, 16 }, { 6, 19 }, { 6, 22 },
1853 { 6, 25 }, { 6, 28 }, { 6, 38 }, { 7, 8 }, { 7, 9 },
1854 { 7, 12 }, { 7, 17 }, { 7, 20 }, { 7, 23 }, { 7, 26 },
1855 { 7, 29 }, { 7, 39 }, { 8, 10 }, { 8, 12 }, { 8, 18 },
1856 { 8, 20 }, { 8, 24 }, { 8, 26 }, { 8, 30 }, { 8, 40 },
1857 { 9, 11 }, { 9, 12 }, { 9, 21 }, { 9, 23 }, { 9, 27 },
1858 { 9, 29 }, { 9, 31 }, { 9, 41 }, { 10, 11 }, { 10, 12 },
1859 { 10, 22 }, { 10, 24 }, { 10, 28 }, { 10, 30 }, { 10, 32 },
1860 { 10, 42 }, { 11, 12 }, { 11, 25 }, { 11, 27 }, { 11, 28 },
1861 { 11, 31 }, { 11, 32 }, { 11, 43 }, { 12, 26 }, { 12, 29 },
1862 { 12, 30 }, { 12, 31 }, { 12, 32 }, { 12, 44 }, { 13, 14 },
1863 { 13, 15 }, { 13, 17 }, { 13, 33 }, { 13, 34 }, { 13, 35 },
1864 { 13, 45 }, { 13, 46 }, { 13, 48 }, { 14, 16 }, { 14, 18 },
1865 { 14, 33 }, { 14, 34 }, { 14, 36 }, { 14, 45 }, { 14, 47 },
1866 { 14, 49 }, { 15, 19 }, { 15, 21 }, { 15, 33 }, { 15, 35 },
1867 { 15, 37 }, { 15, 46 }, { 15, 50 }, { 15, 54 }, { 16, 19 },
1868 { 16, 22 }, { 16, 33 }, { 16, 36 }, { 16, 38 }, { 16, 47 },
1869 { 16, 51 }, { 16, 55 }, { 17, 20 }, { 17, 23 }, { 17, 34 },
1870 { 17, 35 }, { 17, 39 }, { 17, 48 }, { 17, 52 }, { 17, 56 },
1871 { 18, 20 }, { 18, 24 }, { 18, 34 }, { 18, 36 }, { 18, 40 },
1872 { 18, 49 }, { 18, 53 }, { 18, 57 }, { 19, 25 }, { 19, 33 },
1873 { 19, 37 }, { 19, 38 }, { 19, 50 }, { 19, 51 }, { 19, 58 },
1874 { 20, 26 }, { 20, 34 }, { 20, 39 }, { 20, 40 }, { 20, 52 },
1875 { 20, 53 }, { 20, 61 }, { 21, 23 }, { 21, 27 }, { 21, 35 },
1876 { 21, 37 }, { 21, 41 }, { 21, 54 }, { 21, 59 }, { 21, 62 },
1877 { 22, 24 }, { 22, 28 }, { 22, 36 }, { 22, 38 }, { 22, 42 },
1878 { 22, 55 }, { 22, 60 }, { 22, 63 }, { 23, 29 }, { 23, 35 },
1879 { 23, 39 }, { 23, 41 }, { 23, 56 }, { 23, 59 }, { 23, 64 },
1880 { 24, 30 }, { 24, 36 }, { 24, 40 }, { 24, 42 }, { 24, 57 },
1881 { 24, 60 }, { 24, 65 }, { 25, 27 }, { 25, 28 }, { 25, 37 },
1882 { 25, 38 }, { 25, 43 }, { 25, 58 }, { 25, 66 }, { 25, 67 },
1883 { 26, 29 }, { 26, 30 }, { 26, 39 }, { 26, 40 }, { 26, 44 },
1884 { 26, 61 }, { 26, 68 }, { 26, 69 }, { 27, 31 }, { 27, 37 },
1885 { 27, 41 }, { 27, 43 }, { 27, 62 }, { 27, 66 }, { 27, 70 },
1886 { 28, 32 }, { 28, 38 }, { 28, 42 }, { 28, 43 }, { 28, 63 },
1887 { 28, 67 }, { 28, 71 }, { 29, 31 }, { 29, 39 }, { 29, 41 },
1888 { 29, 44 }, { 29, 64 }, { 29, 68 }, { 29, 72 }, { 30, 32 },
1889 { 30, 40 }, { 30, 42 }, { 30, 44 }, { 30, 65 }, { 30, 69 },
1890 { 30, 73 }, { 31, 32 }, { 31, 41 }, { 31, 43 }, { 31, 44 },
1891 { 31, 70 }, { 31, 72 }, { 31, 74 }, { 32, 42 }, { 32, 43 },
1892 { 32, 44 }, { 32, 71 }, { 32, 73 }, { 32, 74 }, { 33, 45 },
1893 { 33, 46 }, { 33, 47 }, { 33, 50 }, { 33, 51 }, { 33, 75 },
1894 { 34, 45 }, { 34, 48 }, { 34, 49 }, { 34, 52 }, { 34, 53 },
1895 { 34, 76 }, { 35, 46 }, { 35, 48 }, { 35, 54 }, { 35, 56 },
1896 { 35, 59 }, { 35, 77 }, { 36, 47 }, { 36, 49 }, { 36, 55 },
1897 { 36, 57 }, { 36, 60 }, { 36, 78 }, { 37, 50 }, { 37, 54 },
1898 { 37, 58 }, { 37, 62 }, { 37, 66 }, { 37, 79 }, { 38, 51 },
1899 { 38, 55 }, { 38, 58 }, { 38, 63 }, { 38, 67 }, { 38, 80 },
1900 { 39, 52 }, { 39, 56 }, { 39, 61 }, { 39, 64 }, { 39, 68 },
1901 { 39, 81 }, { 40, 53 }, { 40, 57 }, { 40, 61 }, { 40, 65 },
1902 { 40, 69 }, { 40, 82 }, { 41, 59 }, { 41, 62 }, { 41, 64 },
1903 { 41, 70 }, { 41, 72 }, { 41, 83 }, { 42, 60 }, { 42, 63 },
1904 { 42, 65 }, { 42, 71 }, { 42, 73 }, { 42, 84 }, { 43, 66 },
1905 { 43, 67 }, { 43, 70 }, { 43, 71 }, { 43, 74 }, { 43, 85 },
1906 { 44, 68 }, { 44, 69 }, { 44, 72 }, { 44, 73 }, { 44, 74 },
1907 { 44, 86 }, { 45, 46 }, { 45, 47 }, { 45, 48 }, { 45, 49 },
1908 { 45, 75 }, { 45, 76 }, { 45, 87 }, { 45, 88 }, { 46, 48 },
1909 { 46, 50 }, { 46, 54 }, { 46, 75 }, { 46, 77 }, { 46, 87 },
1910 { 46, 89 }, { 47, 49 }, { 47, 51 }, { 47, 55 }, { 47, 75 },
1911 { 47, 78 }, { 47, 88 }, { 47, 90 }, { 48, 52 }, { 48, 56 },
1912 { 48, 76 }, { 48, 77 }, { 48, 87 }, { 48, 91 }, { 49, 53 },
1913 { 49, 57 }, { 49, 76 }, { 49, 78 }, { 49, 88 }, { 49, 92 },
1914 { 50, 51 }, { 50, 54 }, { 50, 58 }, { 50, 75 }, { 50, 79 },
1915 { 50, 89 }, { 50, 93 }, { 51, 55 }, { 51, 58 }, { 51, 75 },
1916 { 51, 80 }, { 51, 90 }, { 51, 93 }, { 52, 53 }, { 52, 56 },
1917 { 52, 61 }, { 52, 76 }, { 52, 81 }, { 52, 91 }, { 52, 94 },
1918 { 53, 57 }, { 53, 61 }, { 53, 76 }, { 53, 82 }, { 53, 92 },
1919 { 53, 94 }, { 54, 59 }, { 54, 62 }, { 54, 77 }, { 54, 79 },
1920 { 54, 89 }, { 54, 95 }, { 55, 60 }, { 55, 63 }, { 55, 78 },
1921 { 55, 80 }, { 55, 90 }, { 55, 96 }, { 56, 59 }, { 56, 64 },
1922 { 56, 77 }, { 56, 81 }, { 56, 91 }, { 56, 97 }, { 57, 60 },
1923 { 57, 65 }, { 57, 78 }, { 57, 82 }, { 57, 92 }, { 57, 98 },
1924 { 58, 66 }, { 58, 67 }, { 58, 79 }, { 58, 80 }, { 58, 93 },
1925 { 58, 99 }, { 59, 62 }, { 59, 64 }, { 59, 77 }, { 59, 83 },
1926 { 59, 95 }, { 59, 97 }, { 60, 63 }, { 60, 65 }, { 60, 78 },
1927 { 60, 84 }, { 60, 96 }, { 60, 98 }, { 61, 68 }, { 61, 69 },
1928 { 61, 81 }, { 61, 82 }, { 61, 94 }, { 61, 100 }, { 62, 66 },
1929 { 62, 70 }, { 62, 79 }, { 62, 83 }, { 62, 95 }, { 62, 101 },
1930 { 63, 67 }, { 63, 71 }, { 63, 80 }, { 63, 84 }, { 63, 96 },
1931 { 63, 102 }, { 64, 68 }, { 64, 72 }, { 64, 81 }, { 64, 83 },
1932 { 64, 97 }, { 64, 103 }, { 65, 69 }, { 65, 73 }, { 65, 82 },
1933 { 65, 84 }, { 65, 98 }, { 65, 104 }, { 66, 67 }, { 66, 70 },
1934 { 66, 79 }, { 66, 85 }, { 66, 99 }, { 66, 101 }, { 67, 71 },
1935 { 67, 80 }, { 67, 85 }, { 67, 99 }, { 67, 102 }, { 68, 69 },
1936 { 68, 72 }, { 68, 81 }, { 68, 86 }, { 68, 100 }, { 68, 103 },
1937 { 69, 73 }, { 69, 82 }, { 69, 86 }, { 69, 100 }, { 69, 104 },
1938 { 70, 72 }, { 70, 74 }, { 70, 83 }, { 70, 85 }, { 70, 101 },
1939 { 70, 105 }, { 71, 73 }, { 71, 74 }, { 71, 84 }, { 71, 85 },
1940 { 71, 102 }, { 71, 106 }, { 72, 74 }, { 72, 83 }, { 72, 86 },
1941 { 72, 103 }, { 72, 105 }, { 73, 74 }, { 73, 84 }, { 73, 86 },
1942 { 73, 104 }, { 73, 106 }, { 74, 85 }, { 74, 86 }, { 74, 105 },
1943 { 74, 106 }, { 75, 87 }, { 75, 88 }, { 75, 89 }, { 75, 90 },
1944 { 75, 93 }, { 75, 107 }, { 76, 87 }, { 76, 88 }, { 76, 91 },
1945 { 76, 92 }, { 76, 94 }, { 76, 108 }, { 77, 87 }, { 77, 89 },
1946 { 77, 91 }, { 77, 95 }, { 77, 97 }, { 77, 109 }, { 78, 88 },
1947 { 78, 90 }, { 78, 92 }, { 78, 96 }, { 78, 98 }, { 78, 110 },
1948 { 79, 89 }, { 79, 93 }, { 79, 95 }, { 79, 99 }, { 79, 101 },
1949 { 79, 111 }, { 80, 90 }, { 80, 93 }, { 80, 96 }, { 80, 99 },
1950 { 80, 102 }, { 80, 112 }, { 81, 91 }, { 81, 94 }, { 81, 97 },
1951 { 81, 100 }, { 81, 103 }, { 81, 113 }, { 82, 92 }, { 82, 94 },
1952 { 82, 98 }, { 82, 100 }, { 82, 104 }, { 82, 114 }, { 83, 95 },
1953 { 83, 97 }, { 83, 101 }, { 83, 103 }, { 83, 105 }, { 83, 115 },
1954 { 84, 96 }, { 84, 98 }, { 84, 102 }, { 84, 104 }, { 84, 106 },
1955 { 84, 116 }, { 85, 99 }, { 85, 101 }, { 85, 102 }, { 85, 105 },
1956 { 85, 106 }, { 85, 117 }, { 86, 100 }, { 86, 103 }, { 86, 104 },
1957 { 86, 105 }, { 86, 106 }, { 86, 118 }, { 87, 88 }, { 87, 89 },
1958 { 87, 91 }, { 87, 107 }, { 87, 108 }, { 87, 109 }, { 88, 90 },
1959 { 88, 92 }, { 88, 107 }, { 88, 108 }, { 88, 110 }, { 89, 93 },
1960 { 89, 95 }, { 89, 107 }, { 89, 109 }, { 89, 111 }, { 90, 93 },
1961 { 90, 96 }, { 90, 107 }, { 90, 110 }, { 90, 112 }, { 91, 94 },
1962 { 91, 97 }, { 91, 108 }, { 91, 109 }, { 91, 113 }, { 92, 94 },
1963 { 92, 98 }, { 92, 108 }, { 92, 110 }, { 92, 114 }, { 93, 99 },
1964 { 93, 107 }, { 93, 111 }, { 93, 112 }, { 94, 100 }, { 94, 108 },
1965 { 94, 113 }, { 94, 114 }, { 95, 97 }, { 95, 101 }, { 95, 109 },
1966 { 95, 111 }, { 95, 115 }, { 96, 98 }, { 96, 102 }, { 96, 110 },
1967 { 96, 112 }, { 96, 116 }, { 97, 103 }, { 97, 109 }, { 97, 113 },
1968 { 97, 115 }, { 98, 104 }, { 98, 110 }, { 98, 114 }, { 98, 116 },
1969 { 99, 101 }, { 99, 102 }, { 99, 111 }, { 99, 112 }, { 99, 117 },
1970 { 100, 103 }, { 100, 104 }, { 100, 113 }, { 100, 114 }, { 100, 118 },
1971 { 101, 105 }, { 101, 111 }, { 101, 115 }, { 101, 117 }, { 102, 106 },
1972 { 102, 112 }, { 102, 116 }, { 102, 117 }, { 103, 105 }, { 103, 113 },
1973 { 103, 115 }, { 103, 118 }, { 104, 106 }, { 104, 114 }, { 104, 116 },
1974 { 104, 118 }, { 105, 106 }, { 105, 115 }, { 105, 117 }, { 105, 118 },
1975 { 106, 116 }, { 106, 117 }, { 106, 118 }, { 107, 108 }, { 107, 109 },
1976 { 107, 110 }, { 107, 111 }, { 107, 112 }, { 107, 119 }, { 108, 109 },
1977 { 108, 110 }, { 108, 113 }, { 108, 114 }, { 108, 119 }, { 109, 111 },
1978 { 109, 113 }, { 109, 115 }, { 109, 119 }, { 110, 112 }, { 110, 114 },
1979 { 110, 116 }, { 110, 119 }, { 111, 112 }, { 111, 115 }, { 111, 117 },
1980 { 111, 119 }, { 112, 116 }, { 112, 117 }, { 112, 119 }, { 113, 114 },
1981 { 113, 115 }, { 113, 118 }, { 113, 119 }, { 114, 116 }, { 114, 118 },
1982 { 114, 119 }, { 115, 117 }, { 115, 118 }, { 115, 119 }, { 116, 117 },
1983 { 116, 118 }, { 116, 119 }, { 117, 118 }, { 117, 119 }, { 118, 119 }
1986 static const int face_600[NUM_FACE_600][VERT_PER_FACE_600] = {
1987 { 0, 1, 2 }, { 0, 1, 3 }, { 0, 1, 4 }, { 0, 1, 5 },
1988 { 0, 1, 6 }, { 0, 2, 3 }, { 0, 2, 4 }, { 0, 2, 7 },
1989 { 0, 2, 8 }, { 0, 3, 5 }, { 0, 3, 7 }, { 0, 3, 9 },
1990 { 0, 4, 6 }, { 0, 4, 8 }, { 0, 4, 10 }, { 0, 5, 6 },
1991 { 0, 5, 9 }, { 0, 5, 11 }, { 0, 6, 10 }, { 0, 6, 11 },
1992 { 0, 7, 8 }, { 0, 7, 9 }, { 0, 7, 12 }, { 0, 8, 10 },
1993 { 0, 8, 12 }, { 0, 9, 11 }, { 0, 9, 12 }, { 0, 10, 11 },
1994 { 0, 10, 12 }, { 0, 11, 12 }, { 1, 2, 3 }, { 1, 2, 4 },
1995 { 1, 2, 13 }, { 1, 2, 14 }, { 1, 3, 5 }, { 1, 3, 13 },
1996 { 1, 3, 15 }, { 1, 4, 6 }, { 1, 4, 14 }, { 1, 4, 16 },
1997 { 1, 5, 6 }, { 1, 5, 15 }, { 1, 5, 19 }, { 1, 6, 16 },
1998 { 1, 6, 19 }, { 1, 13, 14 }, { 1, 13, 15 }, { 1, 13, 33 },
1999 { 1, 14, 16 }, { 1, 14, 33 }, { 1, 15, 19 }, { 1, 15, 33 },
2000 { 1, 16, 19 }, { 1, 16, 33 }, { 1, 19, 33 }, { 2, 3, 7 },
2001 { 2, 3, 13 }, { 2, 3, 17 }, { 2, 4, 8 }, { 2, 4, 14 },
2002 { 2, 4, 18 }, { 2, 7, 8 }, { 2, 7, 17 }, { 2, 7, 20 },
2003 { 2, 8, 18 }, { 2, 8, 20 }, { 2, 13, 14 }, { 2, 13, 17 },
2004 { 2, 13, 34 }, { 2, 14, 18 }, { 2, 14, 34 }, { 2, 17, 20 },
2005 { 2, 17, 34 }, { 2, 18, 20 }, { 2, 18, 34 }, { 2, 20, 34 },
2006 { 3, 5, 9 }, { 3, 5, 15 }, { 3, 5, 21 }, { 3, 7, 9 },
2007 { 3, 7, 17 }, { 3, 7, 23 }, { 3, 9, 21 }, { 3, 9, 23 },
2008 { 3, 13, 15 }, { 3, 13, 17 }, { 3, 13, 35 }, { 3, 15, 21 },
2009 { 3, 15, 35 }, { 3, 17, 23 }, { 3, 17, 35 }, { 3, 21, 23 },
2010 { 3, 21, 35 }, { 3, 23, 35 }, { 4, 6, 10 }, { 4, 6, 16 },
2011 { 4, 6, 22 }, { 4, 8, 10 }, { 4, 8, 18 }, { 4, 8, 24 },
2012 { 4, 10, 22 }, { 4, 10, 24 }, { 4, 14, 16 }, { 4, 14, 18 },
2013 { 4, 14, 36 }, { 4, 16, 22 }, { 4, 16, 36 }, { 4, 18, 24 },
2014 { 4, 18, 36 }, { 4, 22, 24 }, { 4, 22, 36 }, { 4, 24, 36 },
2015 { 5, 6, 11 }, { 5, 6, 19 }, { 5, 6, 25 }, { 5, 9, 11 },
2016 { 5, 9, 21 }, { 5, 9, 27 }, { 5, 11, 25 }, { 5, 11, 27 },
2017 { 5, 15, 19 }, { 5, 15, 21 }, { 5, 15, 37 }, { 5, 19, 25 },
2018 { 5, 19, 37 }, { 5, 21, 27 }, { 5, 21, 37 }, { 5, 25, 27 },
2019 { 5, 25, 37 }, { 5, 27, 37 }, { 6, 10, 11 }, { 6, 10, 22 },
2020 { 6, 10, 28 }, { 6, 11, 25 }, { 6, 11, 28 }, { 6, 16, 19 },
2021 { 6, 16, 22 }, { 6, 16, 38 }, { 6, 19, 25 }, { 6, 19, 38 },
2022 { 6, 22, 28 }, { 6, 22, 38 }, { 6, 25, 28 }, { 6, 25, 38 },
2023 { 6, 28, 38 }, { 7, 8, 12 }, { 7, 8, 20 }, { 7, 8, 26 },
2024 { 7, 9, 12 }, { 7, 9, 23 }, { 7, 9, 29 }, { 7, 12, 26 },
2025 { 7, 12, 29 }, { 7, 17, 20 }, { 7, 17, 23 }, { 7, 17, 39 },
2026 { 7, 20, 26 }, { 7, 20, 39 }, { 7, 23, 29 }, { 7, 23, 39 },
2027 { 7, 26, 29 }, { 7, 26, 39 }, { 7, 29, 39 }, { 8, 10, 12 },
2028 { 8, 10, 24 }, { 8, 10, 30 }, { 8, 12, 26 }, { 8, 12, 30 },
2029 { 8, 18, 20 }, { 8, 18, 24 }, { 8, 18, 40 }, { 8, 20, 26 },
2030 { 8, 20, 40 }, { 8, 24, 30 }, { 8, 24, 40 }, { 8, 26, 30 },
2031 { 8, 26, 40 }, { 8, 30, 40 }, { 9, 11, 12 }, { 9, 11, 27 },
2032 { 9, 11, 31 }, { 9, 12, 29 }, { 9, 12, 31 }, { 9, 21, 23 },
2033 { 9, 21, 27 }, { 9, 21, 41 }, { 9, 23, 29 }, { 9, 23, 41 },
2034 { 9, 27, 31 }, { 9, 27, 41 }, { 9, 29, 31 }, { 9, 29, 41 },
2035 { 9, 31, 41 }, { 10, 11, 12 }, { 10, 11, 28 }, { 10, 11, 32 },
2036 { 10, 12, 30 }, { 10, 12, 32 }, { 10, 22, 24 }, { 10, 22, 28 },
2037 { 10, 22, 42 }, { 10, 24, 30 }, { 10, 24, 42 }, { 10, 28, 32 },
2038 { 10, 28, 42 }, { 10, 30, 32 }, { 10, 30, 42 }, { 10, 32, 42 },
2039 { 11, 12, 31 }, { 11, 12, 32 }, { 11, 25, 27 }, { 11, 25, 28 },
2040 { 11, 25, 43 }, { 11, 27, 31 }, { 11, 27, 43 }, { 11, 28, 32 },
2041 { 11, 28, 43 }, { 11, 31, 32 }, { 11, 31, 43 }, { 11, 32, 43 },
2042 { 12, 26, 29 }, { 12, 26, 30 }, { 12, 26, 44 }, { 12, 29, 31 },
2043 { 12, 29, 44 }, { 12, 30, 32 }, { 12, 30, 44 }, { 12, 31, 32 },
2044 { 12, 31, 44 }, { 12, 32, 44 }, { 13, 14, 33 }, { 13, 14, 34 },
2045 { 13, 14, 45 }, { 13, 15, 33 }, { 13, 15, 35 }, { 13, 15, 46 },
2046 { 13, 17, 34 }, { 13, 17, 35 }, { 13, 17, 48 }, { 13, 33, 45 },
2047 { 13, 33, 46 }, { 13, 34, 45 }, { 13, 34, 48 }, { 13, 35, 46 },
2048 { 13, 35, 48 }, { 13, 45, 46 }, { 13, 45, 48 }, { 13, 46, 48 },
2049 { 14, 16, 33 }, { 14, 16, 36 }, { 14, 16, 47 }, { 14, 18, 34 },
2050 { 14, 18, 36 }, { 14, 18, 49 }, { 14, 33, 45 }, { 14, 33, 47 },
2051 { 14, 34, 45 }, { 14, 34, 49 }, { 14, 36, 47 }, { 14, 36, 49 },
2052 { 14, 45, 47 }, { 14, 45, 49 }, { 14, 47, 49 }, { 15, 19, 33 },
2053 { 15, 19, 37 }, { 15, 19, 50 }, { 15, 21, 35 }, { 15, 21, 37 },
2054 { 15, 21, 54 }, { 15, 33, 46 }, { 15, 33, 50 }, { 15, 35, 46 },
2055 { 15, 35, 54 }, { 15, 37, 50 }, { 15, 37, 54 }, { 15, 46, 50 },
2056 { 15, 46, 54 }, { 15, 50, 54 }, { 16, 19, 33 }, { 16, 19, 38 },
2057 { 16, 19, 51 }, { 16, 22, 36 }, { 16, 22, 38 }, { 16, 22, 55 },
2058 { 16, 33, 47 }, { 16, 33, 51 }, { 16, 36, 47 }, { 16, 36, 55 },
2059 { 16, 38, 51 }, { 16, 38, 55 }, { 16, 47, 51 }, { 16, 47, 55 },
2060 { 16, 51, 55 }, { 17, 20, 34 }, { 17, 20, 39 }, { 17, 20, 52 },
2061 { 17, 23, 35 }, { 17, 23, 39 }, { 17, 23, 56 }, { 17, 34, 48 },
2062 { 17, 34, 52 }, { 17, 35, 48 }, { 17, 35, 56 }, { 17, 39, 52 },
2063 { 17, 39, 56 }, { 17, 48, 52 }, { 17, 48, 56 }, { 17, 52, 56 },
2064 { 18, 20, 34 }, { 18, 20, 40 }, { 18, 20, 53 }, { 18, 24, 36 },
2065 { 18, 24, 40 }, { 18, 24, 57 }, { 18, 34, 49 }, { 18, 34, 53 },
2066 { 18, 36, 49 }, { 18, 36, 57 }, { 18, 40, 53 }, { 18, 40, 57 },
2067 { 18, 49, 53 }, { 18, 49, 57 }, { 18, 53, 57 }, { 19, 25, 37 },
2068 { 19, 25, 38 }, { 19, 25, 58 }, { 19, 33, 50 }, { 19, 33, 51 },
2069 { 19, 37, 50 }, { 19, 37, 58 }, { 19, 38, 51 }, { 19, 38, 58 },
2070 { 19, 50, 51 }, { 19, 50, 58 }, { 19, 51, 58 }, { 20, 26, 39 },
2071 { 20, 26, 40 }, { 20, 26, 61 }, { 20, 34, 52 }, { 20, 34, 53 },
2072 { 20, 39, 52 }, { 20, 39, 61 }, { 20, 40, 53 }, { 20, 40, 61 },
2073 { 20, 52, 53 }, { 20, 52, 61 }, { 20, 53, 61 }, { 21, 23, 35 },
2074 { 21, 23, 41 }, { 21, 23, 59 }, { 21, 27, 37 }, { 21, 27, 41 },
2075 { 21, 27, 62 }, { 21, 35, 54 }, { 21, 35, 59 }, { 21, 37, 54 },
2076 { 21, 37, 62 }, { 21, 41, 59 }, { 21, 41, 62 }, { 21, 54, 59 },
2077 { 21, 54, 62 }, { 21, 59, 62 }, { 22, 24, 36 }, { 22, 24, 42 },
2078 { 22, 24, 60 }, { 22, 28, 38 }, { 22, 28, 42 }, { 22, 28, 63 },
2079 { 22, 36, 55 }, { 22, 36, 60 }, { 22, 38, 55 }, { 22, 38, 63 },
2080 { 22, 42, 60 }, { 22, 42, 63 }, { 22, 55, 60 }, { 22, 55, 63 },
2081 { 22, 60, 63 }, { 23, 29, 39 }, { 23, 29, 41 }, { 23, 29, 64 },
2082 { 23, 35, 56 }, { 23, 35, 59 }, { 23, 39, 56 }, { 23, 39, 64 },
2083 { 23, 41, 59 }, { 23, 41, 64 }, { 23, 56, 59 }, { 23, 56, 64 },
2084 { 23, 59, 64 }, { 24, 30, 40 }, { 24, 30, 42 }, { 24, 30, 65 },
2085 { 24, 36, 57 }, { 24, 36, 60 }, { 24, 40, 57 }, { 24, 40, 65 },
2086 { 24, 42, 60 }, { 24, 42, 65 }, { 24, 57, 60 }, { 24, 57, 65 },
2087 { 24, 60, 65 }, { 25, 27, 37 }, { 25, 27, 43 }, { 25, 27, 66 },
2088 { 25, 28, 38 }, { 25, 28, 43 }, { 25, 28, 67 }, { 25, 37, 58 },
2089 { 25, 37, 66 }, { 25, 38, 58 }, { 25, 38, 67 }, { 25, 43, 66 },
2090 { 25, 43, 67 }, { 25, 58, 66 }, { 25, 58, 67 }, { 25, 66, 67 },
2091 { 26, 29, 39 }, { 26, 29, 44 }, { 26, 29, 68 }, { 26, 30, 40 },
2092 { 26, 30, 44 }, { 26, 30, 69 }, { 26, 39, 61 }, { 26, 39, 68 },
2093 { 26, 40, 61 }, { 26, 40, 69 }, { 26, 44, 68 }, { 26, 44, 69 },
2094 { 26, 61, 68 }, { 26, 61, 69 }, { 26, 68, 69 }, { 27, 31, 41 },
2095 { 27, 31, 43 }, { 27, 31, 70 }, { 27, 37, 62 }, { 27, 37, 66 },
2096 { 27, 41, 62 }, { 27, 41, 70 }, { 27, 43, 66 }, { 27, 43, 70 },
2097 { 27, 62, 66 }, { 27, 62, 70 }, { 27, 66, 70 }, { 28, 32, 42 },
2098 { 28, 32, 43 }, { 28, 32, 71 }, { 28, 38, 63 }, { 28, 38, 67 },
2099 { 28, 42, 63 }, { 28, 42, 71 }, { 28, 43, 67 }, { 28, 43, 71 },
2100 { 28, 63, 67 }, { 28, 63, 71 }, { 28, 67, 71 }, { 29, 31, 41 },
2101 { 29, 31, 44 }, { 29, 31, 72 }, { 29, 39, 64 }, { 29, 39, 68 },
2102 { 29, 41, 64 }, { 29, 41, 72 }, { 29, 44, 68 }, { 29, 44, 72 },
2103 { 29, 64, 68 }, { 29, 64, 72 }, { 29, 68, 72 }, { 30, 32, 42 },
2104 { 30, 32, 44 }, { 30, 32, 73 }, { 30, 40, 65 }, { 30, 40, 69 },
2105 { 30, 42, 65 }, { 30, 42, 73 }, { 30, 44, 69 }, { 30, 44, 73 },
2106 { 30, 65, 69 }, { 30, 65, 73 }, { 30, 69, 73 }, { 31, 32, 43 },
2107 { 31, 32, 44 }, { 31, 32, 74 }, { 31, 41, 70 }, { 31, 41, 72 },
2108 { 31, 43, 70 }, { 31, 43, 74 }, { 31, 44, 72 }, { 31, 44, 74 },
2109 { 31, 70, 72 }, { 31, 70, 74 }, { 31, 72, 74 }, { 32, 42, 71 },
2110 { 32, 42, 73 }, { 32, 43, 71 }, { 32, 43, 74 }, { 32, 44, 73 },
2111 { 32, 44, 74 }, { 32, 71, 73 }, { 32, 71, 74 }, { 32, 73, 74 },
2112 { 33, 45, 46 }, { 33, 45, 47 }, { 33, 45, 75 }, { 33, 46, 50 },
2113 { 33, 46, 75 }, { 33, 47, 51 }, { 33, 47, 75 }, { 33, 50, 51 },
2114 { 33, 50, 75 }, { 33, 51, 75 }, { 34, 45, 48 }, { 34, 45, 49 },
2115 { 34, 45, 76 }, { 34, 48, 52 }, { 34, 48, 76 }, { 34, 49, 53 },
2116 { 34, 49, 76 }, { 34, 52, 53 }, { 34, 52, 76 }, { 34, 53, 76 },
2117 { 35, 46, 48 }, { 35, 46, 54 }, { 35, 46, 77 }, { 35, 48, 56 },
2118 { 35, 48, 77 }, { 35, 54, 59 }, { 35, 54, 77 }, { 35, 56, 59 },
2119 { 35, 56, 77 }, { 35, 59, 77 }, { 36, 47, 49 }, { 36, 47, 55 },
2120 { 36, 47, 78 }, { 36, 49, 57 }, { 36, 49, 78 }, { 36, 55, 60 },
2121 { 36, 55, 78 }, { 36, 57, 60 }, { 36, 57, 78 }, { 36, 60, 78 },
2122 { 37, 50, 54 }, { 37, 50, 58 }, { 37, 50, 79 }, { 37, 54, 62 },
2123 { 37, 54, 79 }, { 37, 58, 66 }, { 37, 58, 79 }, { 37, 62, 66 },
2124 { 37, 62, 79 }, { 37, 66, 79 }, { 38, 51, 55 }, { 38, 51, 58 },
2125 { 38, 51, 80 }, { 38, 55, 63 }, { 38, 55, 80 }, { 38, 58, 67 },
2126 { 38, 58, 80 }, { 38, 63, 67 }, { 38, 63, 80 }, { 38, 67, 80 },
2127 { 39, 52, 56 }, { 39, 52, 61 }, { 39, 52, 81 }, { 39, 56, 64 },
2128 { 39, 56, 81 }, { 39, 61, 68 }, { 39, 61, 81 }, { 39, 64, 68 },
2129 { 39, 64, 81 }, { 39, 68, 81 }, { 40, 53, 57 }, { 40, 53, 61 },
2130 { 40, 53, 82 }, { 40, 57, 65 }, { 40, 57, 82 }, { 40, 61, 69 },
2131 { 40, 61, 82 }, { 40, 65, 69 }, { 40, 65, 82 }, { 40, 69, 82 },
2132 { 41, 59, 62 }, { 41, 59, 64 }, { 41, 59, 83 }, { 41, 62, 70 },
2133 { 41, 62, 83 }, { 41, 64, 72 }, { 41, 64, 83 }, { 41, 70, 72 },
2134 { 41, 70, 83 }, { 41, 72, 83 }, { 42, 60, 63 }, { 42, 60, 65 },
2135 { 42, 60, 84 }, { 42, 63, 71 }, { 42, 63, 84 }, { 42, 65, 73 },
2136 { 42, 65, 84 }, { 42, 71, 73 }, { 42, 71, 84 }, { 42, 73, 84 },
2137 { 43, 66, 67 }, { 43, 66, 70 }, { 43, 66, 85 }, { 43, 67, 71 },
2138 { 43, 67, 85 }, { 43, 70, 74 }, { 43, 70, 85 }, { 43, 71, 74 },
2139 { 43, 71, 85 }, { 43, 74, 85 }, { 44, 68, 69 }, { 44, 68, 72 },
2140 { 44, 68, 86 }, { 44, 69, 73 }, { 44, 69, 86 }, { 44, 72, 74 },
2141 { 44, 72, 86 }, { 44, 73, 74 }, { 44, 73, 86 }, { 44, 74, 86 },
2142 { 45, 46, 48 }, { 45, 46, 75 }, { 45, 46, 87 }, { 45, 47, 49 },
2143 { 45, 47, 75 }, { 45, 47, 88 }, { 45, 48, 76 }, { 45, 48, 87 },
2144 { 45, 49, 76 }, { 45, 49, 88 }, { 45, 75, 87 }, { 45, 75, 88 },
2145 { 45, 76, 87 }, { 45, 76, 88 }, { 45, 87, 88 }, { 46, 48, 77 },
2146 { 46, 48, 87 }, { 46, 50, 54 }, { 46, 50, 75 }, { 46, 50, 89 },
2147 { 46, 54, 77 }, { 46, 54, 89 }, { 46, 75, 87 }, { 46, 75, 89 },
2148 { 46, 77, 87 }, { 46, 77, 89 }, { 46, 87, 89 }, { 47, 49, 78 },
2149 { 47, 49, 88 }, { 47, 51, 55 }, { 47, 51, 75 }, { 47, 51, 90 },
2150 { 47, 55, 78 }, { 47, 55, 90 }, { 47, 75, 88 }, { 47, 75, 90 },
2151 { 47, 78, 88 }, { 47, 78, 90 }, { 47, 88, 90 }, { 48, 52, 56 },
2152 { 48, 52, 76 }, { 48, 52, 91 }, { 48, 56, 77 }, { 48, 56, 91 },
2153 { 48, 76, 87 }, { 48, 76, 91 }, { 48, 77, 87 }, { 48, 77, 91 },
2154 { 48, 87, 91 }, { 49, 53, 57 }, { 49, 53, 76 }, { 49, 53, 92 },
2155 { 49, 57, 78 }, { 49, 57, 92 }, { 49, 76, 88 }, { 49, 76, 92 },
2156 { 49, 78, 88 }, { 49, 78, 92 }, { 49, 88, 92 }, { 50, 51, 58 },
2157 { 50, 51, 75 }, { 50, 51, 93 }, { 50, 54, 79 }, { 50, 54, 89 },
2158 { 50, 58, 79 }, { 50, 58, 93 }, { 50, 75, 89 }, { 50, 75, 93 },
2159 { 50, 79, 89 }, { 50, 79, 93 }, { 50, 89, 93 }, { 51, 55, 80 },
2160 { 51, 55, 90 }, { 51, 58, 80 }, { 51, 58, 93 }, { 51, 75, 90 },
2161 { 51, 75, 93 }, { 51, 80, 90 }, { 51, 80, 93 }, { 51, 90, 93 },
2162 { 52, 53, 61 }, { 52, 53, 76 }, { 52, 53, 94 }, { 52, 56, 81 },
2163 { 52, 56, 91 }, { 52, 61, 81 }, { 52, 61, 94 }, { 52, 76, 91 },
2164 { 52, 76, 94 }, { 52, 81, 91 }, { 52, 81, 94 }, { 52, 91, 94 },
2165 { 53, 57, 82 }, { 53, 57, 92 }, { 53, 61, 82 }, { 53, 61, 94 },
2166 { 53, 76, 92 }, { 53, 76, 94 }, { 53, 82, 92 }, { 53, 82, 94 },
2167 { 53, 92, 94 }, { 54, 59, 62 }, { 54, 59, 77 }, { 54, 59, 95 },
2168 { 54, 62, 79 }, { 54, 62, 95 }, { 54, 77, 89 }, { 54, 77, 95 },
2169 { 54, 79, 89 }, { 54, 79, 95 }, { 54, 89, 95 }, { 55, 60, 63 },
2170 { 55, 60, 78 }, { 55, 60, 96 }, { 55, 63, 80 }, { 55, 63, 96 },
2171 { 55, 78, 90 }, { 55, 78, 96 }, { 55, 80, 90 }, { 55, 80, 96 },
2172 { 55, 90, 96 }, { 56, 59, 64 }, { 56, 59, 77 }, { 56, 59, 97 },
2173 { 56, 64, 81 }, { 56, 64, 97 }, { 56, 77, 91 }, { 56, 77, 97 },
2174 { 56, 81, 91 }, { 56, 81, 97 }, { 56, 91, 97 }, { 57, 60, 65 },
2175 { 57, 60, 78 }, { 57, 60, 98 }, { 57, 65, 82 }, { 57, 65, 98 },
2176 { 57, 78, 92 }, { 57, 78, 98 }, { 57, 82, 92 }, { 57, 82, 98 },
2177 { 57, 92, 98 }, { 58, 66, 67 }, { 58, 66, 79 }, { 58, 66, 99 },
2178 { 58, 67, 80 }, { 58, 67, 99 }, { 58, 79, 93 }, { 58, 79, 99 },
2179 { 58, 80, 93 }, { 58, 80, 99 }, { 58, 93, 99 }, { 59, 62, 83 },
2180 { 59, 62, 95 }, { 59, 64, 83 }, { 59, 64, 97 }, { 59, 77, 95 },
2181 { 59, 77, 97 }, { 59, 83, 95 }, { 59, 83, 97 }, { 59, 95, 97 },
2182 { 60, 63, 84 }, { 60, 63, 96 }, { 60, 65, 84 }, { 60, 65, 98 },
2183 { 60, 78, 96 }, { 60, 78, 98 }, { 60, 84, 96 }, { 60, 84, 98 },
2184 { 60, 96, 98 }, { 61, 68, 69 }, { 61, 68, 81 }, { 61, 68, 100 },
2185 { 61, 69, 82 }, { 61, 69, 100 }, { 61, 81, 94 }, { 61, 81, 100 },
2186 { 61, 82, 94 }, { 61, 82, 100 }, { 61, 94, 100 }, { 62, 66, 70 },
2187 { 62, 66, 79 }, { 62, 66, 101 }, { 62, 70, 83 }, { 62, 70, 101 },
2188 { 62, 79, 95 }, { 62, 79, 101 }, { 62, 83, 95 }, { 62, 83, 101 },
2189 { 62, 95, 101 }, { 63, 67, 71 }, { 63, 67, 80 }, { 63, 67, 102 },
2190 { 63, 71, 84 }, { 63, 71, 102 }, { 63, 80, 96 }, { 63, 80, 102 },
2191 { 63, 84, 96 }, { 63, 84, 102 }, { 63, 96, 102 }, { 64, 68, 72 },
2192 { 64, 68, 81 }, { 64, 68, 103 }, { 64, 72, 83 }, { 64, 72, 103 },
2193 { 64, 81, 97 }, { 64, 81, 103 }, { 64, 83, 97 }, { 64, 83, 103 },
2194 { 64, 97, 103 }, { 65, 69, 73 }, { 65, 69, 82 }, { 65, 69, 104 },
2195 { 65, 73, 84 }, { 65, 73, 104 }, { 65, 82, 98 }, { 65, 82, 104 },
2196 { 65, 84, 98 }, { 65, 84, 104 }, { 65, 98, 104 }, { 66, 67, 85 },
2197 { 66, 67, 99 }, { 66, 70, 85 }, { 66, 70, 101 }, { 66, 79, 99 },
2198 { 66, 79, 101 }, { 66, 85, 99 }, { 66, 85, 101 }, { 66, 99, 101 },
2199 { 67, 71, 85 }, { 67, 71, 102 }, { 67, 80, 99 }, { 67, 80, 102 },
2200 { 67, 85, 99 }, { 67, 85, 102 }, { 67, 99, 102 }, { 68, 69, 86 },
2201 { 68, 69, 100 }, { 68, 72, 86 }, { 68, 72, 103 }, { 68, 81, 100 },
2202 { 68, 81, 103 }, { 68, 86, 100 }, { 68, 86, 103 }, { 68, 100, 103 },
2203 { 69, 73, 86 }, { 69, 73, 104 }, { 69, 82, 100 }, { 69, 82, 104 },
2204 { 69, 86, 100 }, { 69, 86, 104 }, { 69, 100, 104 }, { 70, 72, 74 },
2205 { 70, 72, 83 }, { 70, 72, 105 }, { 70, 74, 85 }, { 70, 74, 105 },
2206 { 70, 83, 101 }, { 70, 83, 105 }, { 70, 85, 101 }, { 70, 85, 105 },
2207 { 70, 101, 105 }, { 71, 73, 74 }, { 71, 73, 84 }, { 71, 73, 106 },
2208 { 71, 74, 85 }, { 71, 74, 106 }, { 71, 84, 102 }, { 71, 84, 106 },
2209 { 71, 85, 102 }, { 71, 85, 106 }, { 71, 102, 106 }, { 72, 74, 86 },
2210 { 72, 74, 105 }, { 72, 83, 103 }, { 72, 83, 105 }, { 72, 86, 103 },
2211 { 72, 86, 105 }, { 72, 103, 105 }, { 73, 74, 86 }, { 73, 74, 106 },
2212 { 73, 84, 104 }, { 73, 84, 106 }, { 73, 86, 104 }, { 73, 86, 106 },
2213 { 73, 104, 106 }, { 74, 85, 105 }, { 74, 85, 106 }, { 74, 86, 105 },
2214 { 74, 86, 106 }, { 74, 105, 106 }, { 75, 87, 88 }, { 75, 87, 89 },
2215 { 75, 87, 107 }, { 75, 88, 90 }, { 75, 88, 107 }, { 75, 89, 93 },
2216 { 75, 89, 107 }, { 75, 90, 93 }, { 75, 90, 107 }, { 75, 93, 107 },
2217 { 76, 87, 88 }, { 76, 87, 91 }, { 76, 87, 108 }, { 76, 88, 92 },
2218 { 76, 88, 108 }, { 76, 91, 94 }, { 76, 91, 108 }, { 76, 92, 94 },
2219 { 76, 92, 108 }, { 76, 94, 108 }, { 77, 87, 89 }, { 77, 87, 91 },
2220 { 77, 87, 109 }, { 77, 89, 95 }, { 77, 89, 109 }, { 77, 91, 97 },
2221 { 77, 91, 109 }, { 77, 95, 97 }, { 77, 95, 109 }, { 77, 97, 109 },
2222 { 78, 88, 90 }, { 78, 88, 92 }, { 78, 88, 110 }, { 78, 90, 96 },
2223 { 78, 90, 110 }, { 78, 92, 98 }, { 78, 92, 110 }, { 78, 96, 98 },
2224 { 78, 96, 110 }, { 78, 98, 110 }, { 79, 89, 93 }, { 79, 89, 95 },
2225 { 79, 89, 111 }, { 79, 93, 99 }, { 79, 93, 111 }, { 79, 95, 101 },
2226 { 79, 95, 111 }, { 79, 99, 101 }, { 79, 99, 111 }, { 79, 101, 111 },
2227 { 80, 90, 93 }, { 80, 90, 96 }, { 80, 90, 112 }, { 80, 93, 99 },
2228 { 80, 93, 112 }, { 80, 96, 102 }, { 80, 96, 112 }, { 80, 99, 102 },
2229 { 80, 99, 112 }, { 80, 102, 112 }, { 81, 91, 94 }, { 81, 91, 97 },
2230 { 81, 91, 113 }, { 81, 94, 100 }, { 81, 94, 113 }, { 81, 97, 103 },
2231 { 81, 97, 113 }, { 81, 100, 103 }, { 81, 100, 113 }, { 81, 103, 113 },
2232 { 82, 92, 94 }, { 82, 92, 98 }, { 82, 92, 114 }, { 82, 94, 100 },
2233 { 82, 94, 114 }, { 82, 98, 104 }, { 82, 98, 114 }, { 82, 100, 104 },
2234 { 82, 100, 114 }, { 82, 104, 114 }, { 83, 95, 97 }, { 83, 95, 101 },
2235 { 83, 95, 115 }, { 83, 97, 103 }, { 83, 97, 115 }, { 83, 101, 105 },
2236 { 83, 101, 115 }, { 83, 103, 105 }, { 83, 103, 115 }, { 83, 105, 115 },
2237 { 84, 96, 98 }, { 84, 96, 102 }, { 84, 96, 116 }, { 84, 98, 104 },
2238 { 84, 98, 116 }, { 84, 102, 106 }, { 84, 102, 116 }, { 84, 104, 106 },
2239 { 84, 104, 116 }, { 84, 106, 116 }, { 85, 99, 101 }, { 85, 99, 102 },
2240 { 85, 99, 117 }, { 85, 101, 105 }, { 85, 101, 117 }, { 85, 102, 106 },
2241 { 85, 102, 117 }, { 85, 105, 106 }, { 85, 105, 117 }, { 85, 106, 117 },
2242 { 86, 100, 103 }, { 86, 100, 104 }, { 86, 100, 118 }, { 86, 103, 105 },
2243 { 86, 103, 118 }, { 86, 104, 106 }, { 86, 104, 118 }, { 86, 105, 106 },
2244 { 86, 105, 118 }, { 86, 106, 118 }, { 87, 88, 107 }, { 87, 88, 108 },
2245 { 87, 89, 107 }, { 87, 89, 109 }, { 87, 91, 108 }, { 87, 91, 109 },
2246 { 87, 107, 108 }, { 87, 107, 109 }, { 87, 108, 109 }, { 88, 90, 107 },
2247 { 88, 90, 110 }, { 88, 92, 108 }, { 88, 92, 110 }, { 88, 107, 108 },
2248 { 88, 107, 110 }, { 88, 108, 110 }, { 89, 93, 107 }, { 89, 93, 111 },
2249 { 89, 95, 109 }, { 89, 95, 111 }, { 89, 107, 109 }, { 89, 107, 111 },
2250 { 89, 109, 111 }, { 90, 93, 107 }, { 90, 93, 112 }, { 90, 96, 110 },
2251 { 90, 96, 112 }, { 90, 107, 110 }, { 90, 107, 112 }, { 90, 110, 112 },
2252 { 91, 94, 108 }, { 91, 94, 113 }, { 91, 97, 109 }, { 91, 97, 113 },
2253 { 91, 108, 109 }, { 91, 108, 113 }, { 91, 109, 113 }, { 92, 94, 108 },
2254 { 92, 94, 114 }, { 92, 98, 110 }, { 92, 98, 114 }, { 92, 108, 110 },
2255 { 92, 108, 114 }, { 92, 110, 114 }, { 93, 99, 111 }, { 93, 99, 112 },
2256 { 93, 107, 111 }, { 93, 107, 112 }, { 93, 111, 112 }, { 94, 100, 113 },
2257 { 94, 100, 114 }, { 94, 108, 113 }, { 94, 108, 114 }, { 94, 113, 114 },
2258 { 95, 97, 109 }, { 95, 97, 115 }, { 95, 101, 111 }, { 95, 101, 115 },
2259 { 95, 109, 111 }, { 95, 109, 115 }, { 95, 111, 115 }, { 96, 98, 110 },
2260 { 96, 98, 116 }, { 96, 102, 112 }, { 96, 102, 116 }, { 96, 110, 112 },
2261 { 96, 110, 116 }, { 96, 112, 116 }, { 97, 103, 113 }, { 97, 103, 115 },
2262 { 97, 109, 113 }, { 97, 109, 115 }, { 97, 113, 115 }, { 98, 104, 114 },
2263 { 98, 104, 116 }, { 98, 110, 114 }, { 98, 110, 116 }, { 98, 114, 116 },
2264 { 99, 101, 111 }, { 99, 101, 117 }, { 99, 102, 112 }, { 99, 102, 117 },
2265 { 99, 111, 112 }, { 99, 111, 117 }, { 99, 112, 117 }, { 100, 103, 113 },
2266 { 100, 103, 118 }, { 100, 104, 114 }, { 100, 104, 118 }, { 100, 113, 114 },
2267 { 100, 113, 118 }, { 100, 114, 118 }, { 101, 105, 115 }, { 101, 105, 117 },
2268 { 101, 111, 115 }, { 101, 111, 117 }, { 101, 115, 117 }, { 102, 106, 116 },
2269 { 102, 106, 117 }, { 102, 112, 116 }, { 102, 112, 117 }, { 102, 116, 117 },
2270 { 103, 105, 115 }, { 103, 105, 118 }, { 103, 113, 115 }, { 103, 113, 118 },
2271 { 103, 115, 118 }, { 104, 106, 116 }, { 104, 106, 118 }, { 104, 114, 116 },
2272 { 104, 114, 118 }, { 104, 116, 118 }, { 105, 106, 117 }, { 105, 106, 118 },
2273 { 105, 115, 117 }, { 105, 115, 118 }, { 105, 117, 118 }, { 106, 116, 117 },
2274 { 106, 116, 118 }, { 106, 117, 118 }, { 107, 108, 109 }, { 107, 108, 110 },
2275 { 107, 108, 119 }, { 107, 109, 111 }, { 107, 109, 119 }, { 107, 110, 112 },
2276 { 107, 110, 119 }, { 107, 111, 112 }, { 107, 111, 119 }, { 107, 112, 119 },
2277 { 108, 109, 113 }, { 108, 109, 119 }, { 108, 110, 114 }, { 108, 110, 119 },
2278 { 108, 113, 114 }, { 108, 113, 119 }, { 108, 114, 119 }, { 109, 111, 115 },
2279 { 109, 111, 119 }, { 109, 113, 115 }, { 109, 113, 119 }, { 109, 115, 119 },
2280 { 110, 112, 116 }, { 110, 112, 119 }, { 110, 114, 116 }, { 110, 114, 119 },
2281 { 110, 116, 119 }, { 111, 112, 117 }, { 111, 112, 119 }, { 111, 115, 117 },
2282 { 111, 115, 119 }, { 111, 117, 119 }, { 112, 116, 117 }, { 112, 116, 119 },
2283 { 112, 117, 119 }, { 113, 114, 118 }, { 113, 114, 119 }, { 113, 115, 118 },
2284 { 113, 115, 119 }, { 113, 118, 119 }, { 114, 116, 118 }, { 114, 116, 119 },
2285 { 114, 118, 119 }, { 115, 117, 118 }, { 115, 117, 119 }, { 115, 118, 119 },
2286 { 116, 117, 118 }, { 116, 117, 119 }, { 116, 118, 119 }, { 117, 118, 119 }
2291 /* Add a rotation around the wx-plane to the matrix m. */
2292 static void rotatewx(float m[4][4], float phi)
2310 /* Add a rotation around the wy-plane to the matrix m. */
2311 static void rotatewy(float m[4][4], float phi)
2329 /* Add a rotation around the wz-plane to the matrix m. */
2330 static void rotatewz(float m[4][4], float phi)
2348 /* Add a rotation around the xy-plane to the matrix m. */
2349 static void rotatexy(float m[4][4], float phi)
2367 /* Add a rotation around the xz-plane to the matrix m. */
2368 static void rotatexz(float m[4][4], float phi)
2386 /* Add a rotation around the yz-plane to the matrix m. */
2387 static void rotateyz(float m[4][4], float phi)
2405 /* Compute the rotation matrix m from the rotation angles. */
2406 static void rotateall(float al, float be, float de, float ze, float et,
2407 float th, float m[4][4])
2423 /* Multiply two rotation matrices: o=m*n. */
2424 static void mult_rotmat(float m[4][4], float n[4][4], float o[4][4])
2434 o[i][j] += m[i][k]*n[k][j];
2440 /* Compute a 4D rotation matrix from two unit quaternions. */
2441 static void quats_to_rotmat(float p[4], float q[4], float m[4][4])
2443 double al, be, de, ze, et, th;
2444 double r00, r01, r02, r12, r22;
2446 r00 = 1.0-2.0*(p[1]*p[1]+p[2]*p[2]);
2447 r01 = 2.0*(p[0]*p[1]+p[2]*p[3]);
2448 r02 = 2.0*(p[2]*p[0]-p[1]*p[3]);
2449 r12 = 2.0*(p[1]*p[2]+p[0]*p[3]);
2450 r22 = 1.0-2.0*(p[1]*p[1]+p[0]*p[0]);
2452 al = atan2(-r12,r22)*180.0/M_PI;
2453 be = atan2(r02,sqrt(r00*r00+r01*r01))*180.0/M_PI;
2454 de = atan2(-r01,r00)*180.0/M_PI;
2456 r00 = 1.0-2.0*(q[1]*q[1]+q[2]*q[2]);
2457 r01 = 2.0*(q[0]*q[1]+q[2]*q[3]);
2458 r02 = 2.0*(q[2]*q[0]-q[1]*q[3]);
2459 r12 = 2.0*(q[1]*q[2]+q[0]*q[3]);
2460 r22 = 1.0-2.0*(q[1]*q[1]+q[0]*q[0]);
2462 et = atan2(-r12,r22)*180.0/M_PI;
2463 th = atan2(r02,sqrt(r00*r00+r01*r01))*180.0/M_PI;
2464 ze = atan2(-r01,r00)*180.0/M_PI;
2466 rotateall(al,be,de,ze,et,-th,m);
2470 /* Compute the normal vector of a plane based on three points in the plane. */
2471 static void normal(const float *p, const float *q, const float *r,
2474 float u[3], v[3], t;
2482 n[0] = u[1]*v[2]-u[2]*v[1];
2483 n[1] = u[2]*v[0]-u[0]*v[2];
2484 n[2] = u[0]*v[1]-u[1]*v[0];
2485 t = sqrt(n[0]*n[0]+n[1]*n[1]+n[2]*n[2]);
2492 /* Project an array of vertices from 4d to 3d. */
2493 static void project(ModeInfo *mi, const float vert[][4], float v[][4], int num)
2495 float s, q1[4], q2[4], r1[4][4], r2[4][4], m[4][4];
2497 polytopesstruct *pp = &poly[MI_SCREEN(mi)];
2499 rotateall(pp->alpha,pp->beta,pp->delta,pp->zeta,pp->eta,pp->theta,r1);
2501 gltrackball_get_quaternion(pp->trackballs[0],q1);
2502 gltrackball_get_quaternion(pp->trackballs[1],q2);
2503 quats_to_rotmat(q1,q2,r2);
2505 mult_rotmat(r2,r1,m);
2507 /* Project the vertices from 4d to 3d. */
2508 for (i=0; i<num; i++)
2514 s += m[j][k]*vert[i][k];
2515 v[i][j] = s+offset4d[j];
2517 if (projection_4d == DISP_4D_ORTHOGRAPHIC)
2530 /* Move the projected vertices along the z-axis so that they become visible
2532 for (i=0; i<num; i++)
2535 v[i][j] += offset3d[j];
2540 /* Draw a single polytope. */
2541 static void draw(ModeInfo *mi,
2543 const int edge[][2], int num_edge,
2544 const int face[], int num_face,
2546 float edge_color[][4],
2547 float face_color[][4],
2548 float face_color_trans[][4])
2552 GLfloat red[4] = { 1.0, 0.0, 0.0, 1.0 };
2553 GLfloat red_trans[4] = { 1.0, 0.0, 0.0, 1.0 };
2555 mi->polygon_count = 0;
2556 if (display_mode == DISP_WIREFRAME)
2558 if (color_mode == COLORS_SINGLE)
2561 for (i=0; i<num_edge; i++)
2563 if (color_mode == COLORS_DEPTH)
2564 glColor4fv(edge_color[i]);
2565 glVertex4fv(v[edge[i][0]]);
2566 glVertex4fv(v[edge[i][1]]);
2569 mi->polygon_count = num_edge;
2573 if (color_mode == COLORS_SINGLE)
2575 red_trans[3] = face_color_trans[0][3]/2.0;
2576 if (display_mode == DISP_TRANSPARENT)
2577 glMaterialfv(GL_FRONT_AND_BACK,GL_AMBIENT_AND_DIFFUSE,red_trans);
2579 glMaterialfv(GL_FRONT_AND_BACK,GL_AMBIENT_AND_DIFFUSE,red);
2581 for (i=0; i<num_face; i++)
2583 glBegin(GL_POLYGON);
2584 if (color_mode == COLORS_DEPTH)
2586 if (display_mode == DISP_TRANSPARENT)
2587 glMaterialfv(GL_FRONT_AND_BACK,GL_AMBIENT_AND_DIFFUSE,
2588 face_color_trans[i]);
2590 glMaterialfv(GL_FRONT_AND_BACK,GL_AMBIENT_AND_DIFFUSE,
2593 normal(v[face[i*vert_per_face]],v[face[i*vert_per_face+1]],
2594 v[face[i*vert_per_face+2]],n);
2596 for (j=0; j<vert_per_face; j++)
2597 glVertex4fv(v[face[i*vert_per_face+j]]);
2600 mi->polygon_count = num_face;
2605 /* Draw a 5-cell {3,3,3} projected into 3d. */
2606 static void cell_5(ModeInfo *mi)
2608 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2609 float v[NUM_VERT_5][4];
2611 project(mi,vert_5,v,NUM_VERT_5);
2612 draw(mi,v,edge_5,NUM_EDGE_5,(int *)face_5,NUM_FACE_5,
2613 VERT_PER_FACE_5,hp->edge_color_5,hp->face_color_5,
2614 hp->face_color_trans_5);
2618 /* Draw a 8-cell {4,3,3} projected into 3d. */
2619 static void cell_8(ModeInfo *mi)
2621 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2622 float v[NUM_VERT_8][4];
2624 project(mi,vert_8,v,NUM_VERT_8);
2625 draw(mi,v,edge_8,NUM_EDGE_8,(int *)face_8,NUM_FACE_8,
2626 VERT_PER_FACE_8,hp->edge_color_8,hp->face_color_8,
2627 hp->face_color_trans_8);
2631 /* Draw a 16-cell {3,3,4} projected into 3d. */
2632 static void cell_16(ModeInfo *mi)
2634 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2635 float v[NUM_VERT_16][4];
2637 project(mi,vert_16,v,NUM_VERT_16);
2638 draw(mi,v,edge_16,NUM_EDGE_16,(int *)face_16,NUM_FACE_16,
2639 VERT_PER_FACE_16,hp->edge_color_16,hp->face_color_16,
2640 hp->face_color_trans_16);
2644 /* Draw a 24-cell {3,4,3} projected into 3d. */
2645 static void cell_24(ModeInfo *mi)
2647 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2648 float v[NUM_VERT_24][4];
2650 project(mi,vert_24,v,NUM_VERT_24);
2651 draw(mi,v,edge_24,NUM_EDGE_24,(int *)face_24,NUM_FACE_24,
2652 VERT_PER_FACE_24,hp->edge_color_24,hp->face_color_24,
2653 hp->face_color_trans_24);
2657 /* Draw a 120-cell {5,3,3} projected into 3d. */
2658 static void cell_120(ModeInfo *mi)
2660 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2661 float v[NUM_VERT_120][4];
2663 project(mi,vert_120,v,NUM_VERT_120);
2664 draw(mi,v,edge_120,NUM_EDGE_120,(int *)face_120,NUM_FACE_120,
2665 VERT_PER_FACE_120,hp->edge_color_120,hp->face_color_120,
2666 hp->face_color_trans_120);
2670 /* Draw a 600-cell {3,3,5} projected into 3d. */
2671 static void cell_600(ModeInfo *mi)
2673 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2674 float v[NUM_VERT_600][4];
2676 project(mi,vert_600,v,NUM_VERT_600);
2677 draw(mi,v,edge_600,NUM_EDGE_600,(int *)face_600,NUM_FACE_600,
2678 VERT_PER_FACE_600,hp->edge_color_600,hp->face_color_600,
2679 hp->face_color_trans_600);
2683 /* Compute a color based on the w-depth of a point. */
2684 static void color(float depth, float alpha, float min, float max,
2690 d = (depth-min)/(max-min);
2734 /* Set the colors of a single polytope's edges and faces. */
2735 static void colors(const float vert[][4],
2736 const int edge[][2], int num_edge,
2737 const int face[], int num_face,
2739 float edge_color[][4],
2740 float face_color[][4],
2741 float face_color_trans[][4],
2743 float min_edge_depth, float max_edge_depth,
2744 float min_face_depth, float max_face_depth)
2749 for (i=0; i<num_edge; i++)
2751 depth = (vert[edge[i][0]][3]+vert[edge[i][1]][3])/2.0;
2752 color(depth,1.0,min_edge_depth,max_edge_depth,edge_color[i]);
2754 for (i=0; i<num_face; i++)
2757 for (j=0; j<vert_per_face; j++)
2758 depth += vert[face[i*vert_per_face+j]][3];
2759 depth /= vert_per_face;
2760 color(depth,1.0,min_face_depth,max_face_depth,face_color[i]);
2761 color(depth,alpha,min_face_depth,max_face_depth,face_color_trans[i]);
2766 /* Set the colors of the polytopes' edges and faces. */
2767 static void set_colors(ModeInfo *mi)
2769 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
2771 colors(vert_5,edge_5,NUM_EDGE_5,(int *)face_5,NUM_FACE_5,
2772 VERT_PER_FACE_5,hp->edge_color_5,hp->face_color_5,
2773 hp->face_color_trans_5,0.5,MIN_EDGE_DEPTH_5,
2774 MAX_EDGE_DEPTH_5,MIN_FACE_DEPTH_5,MAX_FACE_DEPTH_5);
2777 colors(vert_8,edge_8,NUM_EDGE_8,(int *)face_8,NUM_FACE_8,
2778 VERT_PER_FACE_8,hp->edge_color_8,hp->face_color_8,
2779 hp->face_color_trans_8,0.4,MIN_EDGE_DEPTH_8,
2780 MAX_EDGE_DEPTH_8,MIN_FACE_DEPTH_8,MAX_FACE_DEPTH_8);
2783 colors(vert_16,edge_16,NUM_EDGE_16,(int *)face_16,NUM_FACE_16,
2784 VERT_PER_FACE_16,hp->edge_color_16,hp->face_color_16,
2785 hp->face_color_trans_16,0.25,MIN_EDGE_DEPTH_16,
2786 MAX_EDGE_DEPTH_16,MIN_FACE_DEPTH_16,MAX_FACE_DEPTH_16);
2789 colors(vert_24,edge_24,NUM_EDGE_24,(int *)face_24,NUM_FACE_24,
2790 VERT_PER_FACE_24,hp->edge_color_24,hp->face_color_24,
2791 hp->face_color_trans_24,0.25,MIN_EDGE_DEPTH_24,
2792 MAX_EDGE_DEPTH_24,MIN_FACE_DEPTH_24,MAX_FACE_DEPTH_24);
2795 colors(vert_120,edge_120,NUM_EDGE_120,(int *)face_120,NUM_FACE_120,
2796 VERT_PER_FACE_120,hp->edge_color_120,hp->face_color_120,
2797 hp->face_color_trans_120,0.15,MIN_EDGE_DEPTH_120,
2798 MAX_EDGE_DEPTH_120,MIN_FACE_DEPTH_120,MAX_FACE_DEPTH_120);
2801 colors(vert_600,edge_600,NUM_EDGE_600,(int *)face_600,NUM_FACE_600,
2802 VERT_PER_FACE_600,hp->edge_color_600,hp->face_color_600,
2803 hp->face_color_trans_600,0.06,MIN_EDGE_DEPTH_600,
2804 MAX_EDGE_DEPTH_600,MIN_FACE_DEPTH_600,MAX_FACE_DEPTH_600);
2808 static void init(ModeInfo *mi)
2810 static const GLfloat light_ambient[] = { 0.0, 0.0, 0.0, 1.0 };
2811 static const GLfloat light_diffuse[] = { 1.0, 1.0, 1.0, 1.0 };
2812 static const GLfloat light_specular[] = { 0.0, 0.0, 0.0, 1.0 };
2813 static const GLfloat light_position[] = { 0.0, 0.0, 1.0, 0.0 };
2814 static const GLfloat mat_specular[] = { 1.0, 1.0, 1.0, 1.0 };
2815 polytopesstruct *pp = &poly[MI_SCREEN(mi)];
2829 glMatrixMode(GL_PROJECTION);
2831 if (projection_3d == DISP_3D_PERSPECTIVE)
2832 gluPerspective(60.0,1.0,0.1,100.0);
2834 glOrtho(-1.0,1.0,-1.0,1.0,0.1,100.0);;
2835 glMatrixMode(GL_MODELVIEW);
2838 if (display_mode == DISP_WIREFRAME)
2840 glDisable(GL_DEPTH_TEST);
2841 glDisable(GL_LIGHTING);
2842 glDisable(GL_LIGHT0);
2843 glDisable(GL_BLEND);
2845 else if (display_mode == DISP_SURFACE)
2847 glEnable(GL_DEPTH_TEST);
2848 glDepthFunc(GL_LESS);
2849 glLightModeli(GL_LIGHT_MODEL_TWO_SIDE,GL_TRUE);
2850 glEnable(GL_LIGHTING);
2851 glEnable(GL_LIGHT0);
2852 glLightfv(GL_LIGHT0,GL_AMBIENT,light_ambient);
2853 glLightfv(GL_LIGHT0,GL_DIFFUSE,light_diffuse);
2854 glLightfv(GL_LIGHT0,GL_SPECULAR,light_specular);
2855 glLightfv(GL_LIGHT0,GL_POSITION,light_position);
2856 glMaterialfv(GL_FRONT_AND_BACK,GL_SPECULAR,mat_specular);
2857 glMaterialf(GL_FRONT_AND_BACK,GL_SHININESS,0.0);
2858 glDepthMask(GL_TRUE);
2859 glDisable(GL_BLEND);
2861 else if (display_mode == DISP_TRANSPARENT)
2863 glDisable(GL_DEPTH_TEST);
2864 glLightModeli(GL_LIGHT_MODEL_TWO_SIDE,GL_TRUE);
2865 glEnable(GL_LIGHTING);
2866 glEnable(GL_LIGHT0);
2867 glLightfv(GL_LIGHT0,GL_AMBIENT,light_ambient);
2868 glLightfv(GL_LIGHT0,GL_DIFFUSE,light_diffuse);
2869 glLightfv(GL_LIGHT0,GL_SPECULAR,light_specular);
2870 glLightfv(GL_LIGHT0,GL_POSITION,light_position);
2871 glMaterialfv(GL_FRONT_AND_BACK,GL_SPECULAR,mat_specular);
2872 glMaterialf(GL_FRONT_AND_BACK,GL_SHININESS,0.0);
2873 glDepthMask(GL_FALSE);
2875 glBlendFunc(GL_SRC_ALPHA,GL_ONE);
2879 glDisable(GL_DEPTH_TEST);
2880 glDisable(GL_LIGHTING);
2881 glDisable(GL_LIGHT0);
2882 glDisable(GL_BLEND);
2887 /* Redisplay the polytopes. */
2888 static void display_polytopes(ModeInfo *mi)
2890 polytopesstruct *pp = &poly[MI_SCREEN(mi)];
2892 if (!pp->button_pressed)
2894 pp->alpha += speed_wx * pp->speed_scale;
2895 if (pp->alpha >= 360.0)
2897 pp->beta += speed_wy * pp->speed_scale;
2898 if (pp->beta >= 360.0)
2900 pp->delta += speed_wz * pp->speed_scale;
2901 if (pp->delta >= 360.0)
2903 pp->zeta += speed_xy * pp->speed_scale;
2904 if (pp->zeta >= 360.0)
2906 pp->eta += speed_xz * pp->speed_scale;
2907 if (pp->eta >= 360.0)
2909 pp->theta += speed_yz * pp->speed_scale;
2910 if (pp->theta >= 360.0)
2914 glMatrixMode(GL_PROJECTION);
2916 if (projection_3d == DISP_3D_ORTHOGRAPHIC)
2918 if (pp->aspect >= 1.0)
2919 glOrtho(-pp->aspect,pp->aspect,-1.0,1.0,0.1,100.0);
2921 glOrtho(-1.0,1.0,-1.0/pp->aspect,1.0/pp->aspect,0.1,100.0);
2925 gluPerspective(60.0,pp->aspect,0.1,100.0);
2927 glMatrixMode(GL_MODELVIEW);
2932 if (polytope == POLYTOPE_RANDOM)
2933 pp->poly = random() % (POLYTOPE_LAST_CELL+1);
2935 pp->poly = polytope;
2937 if (++pp->tick > 1000)
2940 if (pp->poly == POLYTOPE_5_CELL)
2942 else if (pp->poly == POLYTOPE_8_CELL)
2944 else if (pp->poly == POLYTOPE_16_CELL)
2946 else if (pp->poly == POLYTOPE_24_CELL)
2948 else if (pp->poly == POLYTOPE_120_CELL)
2950 else if (pp->poly == POLYTOPE_600_CELL)
2957 ENTRYPOINT void reshape_polytopes(ModeInfo *mi, int width, int height)
2959 polytopesstruct *pp = &poly[MI_SCREEN(mi)];
2961 pp->WindW = (GLint)width;
2962 pp->WindH = (GLint)height;
2963 glViewport(0,0,width,height);
2964 pp->aspect = (GLfloat)width/(GLfloat)height;
2968 ENTRYPOINT Bool polytopes_handle_event(ModeInfo *mi, XEvent *event)
2970 Display *display = MI_DISPLAY(mi);
2971 polytopesstruct *pp = &poly[MI_SCREEN(mi)];
2974 if (event->xany.type == ButtonPress &&
2975 event->xbutton.button == Button1)
2977 pp->button_pressed = True;
2978 gltrackball_start(pp->trackballs[pp->current_trackball],
2979 event->xbutton.x, event->xbutton.y,
2980 MI_WIDTH(mi), MI_HEIGHT(mi));
2983 else if (event->xany.type == ButtonRelease &&
2984 event->xbutton.button == Button1)
2986 pp->button_pressed = False;
2989 else if (event->xany.type == KeyPress)
2991 sym = XKeycodeToKeysym(display,event->xkey.keycode,0);
2992 if (sym == XK_Shift_L || sym == XK_Shift_R)
2994 pp->current_trackball = 1;
2995 if (pp->button_pressed)
2996 gltrackball_start(pp->trackballs[pp->current_trackball],
2997 event->xbutton.x, event->xbutton.y,
2998 MI_WIDTH(mi), MI_HEIGHT(mi));
3002 else if (event->xany.type == KeyRelease)
3004 sym = XKeycodeToKeysym(display,event->xkey.keycode,0);
3005 if (sym == XK_Shift_L || sym == XK_Shift_R)
3007 pp->current_trackball = 0;
3008 if (pp->button_pressed)
3009 gltrackball_start(pp->trackballs[pp->current_trackball],
3010 event->xbutton.x, event->xbutton.y,
3011 MI_WIDTH(mi), MI_HEIGHT(mi));
3015 else if (event->xany.type == MotionNotify && pp->button_pressed)
3017 gltrackball_track(pp->trackballs[pp->current_trackball],
3018 event->xmotion.x, event->xmotion.y,
3019 MI_WIDTH(mi), MI_HEIGHT(mi));
3028 *-----------------------------------------------------------------------------
3029 *-----------------------------------------------------------------------------
3031 *-----------------------------------------------------------------------------
3032 *-----------------------------------------------------------------------------
3036 *-----------------------------------------------------------------------------
3037 * Initialize polytopes. Called each time the window changes.
3038 *-----------------------------------------------------------------------------
3041 ENTRYPOINT void init_polytopes(ModeInfo *mi)
3043 polytopesstruct *pp;
3047 poly = (polytopesstruct *)calloc(MI_NUM_SCREENS(mi),
3048 sizeof(polytopesstruct));
3052 pp = &poly[MI_SCREEN(mi)];
3054 pp->trackballs[0] = gltrackball_init();
3055 pp->trackballs[1] = gltrackball_init();
3056 pp->current_trackball = 0;
3057 pp->button_pressed = False;
3059 /* make multiple screens rotate at slightly different rates. */
3060 pp->speed_scale = 0.9 + frand(0.3);
3062 if ((pp->glx_context = init_GL(mi)) != NULL)
3064 reshape_polytopes(mi,MI_WIDTH(mi),MI_HEIGHT(mi));
3065 glDrawBuffer(GL_BACK);
3075 *-----------------------------------------------------------------------------
3076 * Called by the mainline code periodically to update the display.
3077 *-----------------------------------------------------------------------------
3079 ENTRYPOINT void draw_polytopes(ModeInfo *mi)
3081 Display *display = MI_DISPLAY(mi);
3082 Window window = MI_WINDOW(mi);
3083 polytopesstruct *hp;
3087 hp = &poly[MI_SCREEN(mi)];
3089 MI_IS_DRAWN(mi) = True;
3090 if (!hp->glx_context)
3093 glXMakeCurrent(display,window,*(hp->glx_context));
3095 glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
3098 display_polytopes(mi);
3105 glXSwapBuffers(display,window);
3110 *-----------------------------------------------------------------------------
3111 * The display is being taken away from us. Free up malloc'ed
3112 * memory and X resources that we've alloc'ed. Only called
3113 * once, we must zap everything for every screen.
3114 *-----------------------------------------------------------------------------
3117 ENTRYPOINT void release_polytopes(ModeInfo *mi)
3123 for (screen = 0; screen < MI_NUM_SCREENS(mi); screen++)
3125 polytopesstruct *hp = &poly[screen];
3127 if (hp->glx_context)
3128 hp->glx_context = (GLXContext *)NULL;
3130 (void) free((void *)poly);
3131 poly = (polytopesstruct *)NULL;
3137 ENTRYPOINT void change_polytopes(ModeInfo *mi)
3139 polytopesstruct *hp = &poly[MI_SCREEN(mi)];
3141 if (!hp->glx_context)
3144 glXMakeCurrent(MI_DISPLAY(mi),MI_WINDOW(mi),*(hp->glx_context));
3147 #endif /* !STANDALONE */
3149 XSCREENSAVER_MODULE ("Polytopes", polytopes)