]> www.wagner.pp.ru Git - openssl-gost/engine.git/blob - ecp_id_tc26_gost_3410_2012_512_paramSetA.c
GOST ECC optimizations (#263)
[openssl-gost/engine.git] / ecp_id_tc26_gost_3410_2012_512_paramSetA.c
1 /* Autogenerated: ECCKiila https://gitlab.com/nisec/ecckiila */
2 /*-
3  * MIT License
4  * 
5  * Copyright (c) 2020 Luis Rivera-Zamarripa, Jesús-Javier Chi-Domínguez, Billy Bob Brumley
6  * 
7  * Permission is hereby granted, free of charge, to any person obtaining a copy
8  * of this software and associated documentation files (the "Software"), to deal
9  * in the Software without restriction, including without limitation the rights
10  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11  * copies of the Software, and to permit persons to whom the Software is
12  * furnished to do so, subject to the following conditions:
13  * 
14  * The above copyright notice and this permission notice shall be included in all
15  * copies or substantial portions of the Software.
16  * 
17  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23  * SOFTWARE.
24  */
25 #if defined(__SIZEOF_INT128__) && !defined(PEDANTIC)
26
27 #include <stdint.h>
28 #include <string.h>
29 #define LIMB_BITS 64
30 #define LIMB_CNT 10
31 /* Field elements */
32 typedef uint64_t fe_t[LIMB_CNT];
33 typedef uint64_t limb_t;
34
35 #define fe_copy(d, s) memcpy(d, s, sizeof(fe_t))
36 #define fe_set_zero(d) memset(d, 0, sizeof(fe_t))
37
38 #define fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(c, a, b) \
39     fiat_id_tc26_gost_3410_2012_512_paramSetA_add(c, a, b);          \
40     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry(c, c)
41 #define fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(c, a, b) \
42     fiat_id_tc26_gost_3410_2012_512_paramSetA_sub(c, a, b);          \
43     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry(c, c)
44
45 /* Projective points */
46 typedef struct {
47     fe_t X;
48     fe_t Y;
49     fe_t Z;
50 } pt_prj_t;
51
52 /* Affine points */
53 typedef struct {
54     fe_t X;
55     fe_t Y;
56 } pt_aff_t;
57
58 /* BEGIN verbatim fiat code https://github.com/mit-plv/fiat-crypto */
59 /*-
60  * MIT License
61  *
62  * Copyright (c) 2020 the fiat-crypto authors (see the AUTHORS file)
63  *
64  * Permission is hereby granted, free of charge, to any person obtaining a copy
65  * of this software and associated documentation files (the "Software"), to deal
66  * in the Software without restriction, including without limitation the rights
67  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
68  * copies of the Software, and to permit persons to whom the Software is
69  * furnished to do so, subject to the following conditions:
70  *
71  * The above copyright notice and this permission notice shall be included in
72  * all copies or substantial portions of the Software.
73  *
74  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
75  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
76  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
77  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
78  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
79  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
80  * SOFTWARE.
81  */
82
83 /* Autogenerated: unsaturated_solinas --static id_tc26_gost_3410_2012_512_paramSetA 64 '(auto)' '2^512 - 569' */
84 /* curve description: id_tc26_gost_3410_2012_512_paramSetA */
85 /* machine_wordsize = 64 (from "64") */
86 /* requested operations: (all) */
87 /* n = 10 (from "(auto)") */
88 /* s-c = 2^512 - [(1, 569)] (from "2^512 - 569") */
89 /* tight_bounds_multiplier = 1.1 (from "") */
90 /*  */
91 /* Computed values: */
92 /* carry_chain = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1] */
93 /* eval z = z[0] + (z[1] << 52) + (z[2] << 103) + (z[3] << 154) + (z[4] << 205) + (z[5] << 256) + (z[6] << 0x134) + (z[7] << 0x167) + (z[8] << 0x19a) + (z[9] << 0x1cd) */
94 /* bytes_eval z = z[0] + (z[1] << 8) + (z[2] << 16) + (z[3] << 24) + (z[4] << 32) + (z[5] << 40) + (z[6] << 48) + (z[7] << 56) + (z[8] << 64) + (z[9] << 72) + (z[10] << 80) + (z[11] << 88) + (z[12] << 96) + (z[13] << 104) + (z[14] << 112) + (z[15] << 120) + (z[16] << 128) + (z[17] << 136) + (z[18] << 144) + (z[19] << 152) + (z[20] << 160) + (z[21] << 168) + (z[22] << 176) + (z[23] << 184) + (z[24] << 192) + (z[25] << 200) + (z[26] << 208) + (z[27] << 216) + (z[28] << 224) + (z[29] << 232) + (z[30] << 240) + (z[31] << 248) + (z[32] << 256) + (z[33] << 0x108) + (z[34] << 0x110) + (z[35] << 0x118) + (z[36] << 0x120) + (z[37] << 0x128) + (z[38] << 0x130) + (z[39] << 0x138) + (z[40] << 0x140) + (z[41] << 0x148) + (z[42] << 0x150) + (z[43] << 0x158) + (z[44] << 0x160) + (z[45] << 0x168) + (z[46] << 0x170) + (z[47] << 0x178) + (z[48] << 0x180) + (z[49] << 0x188) + (z[50] << 0x190) + (z[51] << 0x198) + (z[52] << 0x1a0) + (z[53] << 0x1a8) + (z[54] << 0x1b0) + (z[55] << 0x1b8) + (z[56] << 0x1c0) + (z[57] << 0x1c8) + (z[58] << 0x1d0) + (z[59] << 0x1d8) + (z[60] << 0x1e0) + (z[61] << 0x1e8) + (z[62] << 0x1f0) + (z[63] << 0x1f8) */
95
96 #include <stdint.h>
97 typedef unsigned char fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1;
98 typedef signed char fiat_id_tc26_gost_3410_2012_512_paramSetA_int1;
99 typedef signed __int128 fiat_id_tc26_gost_3410_2012_512_paramSetA_int128;
100 typedef unsigned __int128 fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128;
101
102 #if (-1 & 3) != 3
103 #error "This code only works on a two's complement system"
104 #endif
105
106 /*
107  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u52 is an addition with carry.
108  * Postconditions:
109  *   out1 = (arg1 + arg2 + arg3) mod 2^52
110  *   out2 = ⌊(arg1 + arg2 + arg3) / 2^52⌋
111  *
112  * Input Bounds:
113  *   arg1: [0x0 ~> 0x1]
114  *   arg2: [0x0 ~> 0xfffffffffffff]
115  *   arg3: [0x0 ~> 0xfffffffffffff]
116  * Output Bounds:
117  *   out1: [0x0 ~> 0xfffffffffffff]
118  *   out2: [0x0 ~> 0x1]
119  */
120 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u52(
121     uint64_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
122     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint64_t arg2,
123     uint64_t arg3) {
124     uint64_t x1;
125     uint64_t x2;
126     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x3;
127     x1 = ((arg1 + arg2) + arg3);
128     x2 = (x1 & UINT64_C(0xfffffffffffff));
129     x3 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x1 >> 52);
130     *out1 = x2;
131     *out2 = x3;
132 }
133
134 /*
135  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u52 is a subtraction with borrow.
136  * Postconditions:
137  *   out1 = (-arg1 + arg2 + -arg3) mod 2^52
138  *   out2 = -⌊(-arg1 + arg2 + -arg3) / 2^52⌋
139  *
140  * Input Bounds:
141  *   arg1: [0x0 ~> 0x1]
142  *   arg2: [0x0 ~> 0xfffffffffffff]
143  *   arg3: [0x0 ~> 0xfffffffffffff]
144  * Output Bounds:
145  *   out1: [0x0 ~> 0xfffffffffffff]
146  *   out2: [0x0 ~> 0x1]
147  */
148 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u52(
149     uint64_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
150     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint64_t arg2,
151     uint64_t arg3) {
152     int64_t x1;
153     fiat_id_tc26_gost_3410_2012_512_paramSetA_int1 x2;
154     uint64_t x3;
155     x1 = ((int64_t)(arg2 - (int64_t)arg1) - (int64_t)arg3);
156     x2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_int1)(x1 >> 52);
157     x3 = (x1 & UINT64_C(0xfffffffffffff));
158     *out1 = x3;
159     *out2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(0x0 - x2);
160 }
161
162 /*
163  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51 is an addition with carry.
164  * Postconditions:
165  *   out1 = (arg1 + arg2 + arg3) mod 2^51
166  *   out2 = ⌊(arg1 + arg2 + arg3) / 2^51⌋
167  *
168  * Input Bounds:
169  *   arg1: [0x0 ~> 0x1]
170  *   arg2: [0x0 ~> 0x7ffffffffffff]
171  *   arg3: [0x0 ~> 0x7ffffffffffff]
172  * Output Bounds:
173  *   out1: [0x0 ~> 0x7ffffffffffff]
174  *   out2: [0x0 ~> 0x1]
175  */
176 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
177     uint64_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
178     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint64_t arg2,
179     uint64_t arg3) {
180     uint64_t x1;
181     uint64_t x2;
182     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x3;
183     x1 = ((arg1 + arg2) + arg3);
184     x2 = (x1 & UINT64_C(0x7ffffffffffff));
185     x3 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x1 >> 51);
186     *out1 = x2;
187     *out2 = x3;
188 }
189
190 /*
191  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51 is a subtraction with borrow.
192  * Postconditions:
193  *   out1 = (-arg1 + arg2 + -arg3) mod 2^51
194  *   out2 = -⌊(-arg1 + arg2 + -arg3) / 2^51⌋
195  *
196  * Input Bounds:
197  *   arg1: [0x0 ~> 0x1]
198  *   arg2: [0x0 ~> 0x7ffffffffffff]
199  *   arg3: [0x0 ~> 0x7ffffffffffff]
200  * Output Bounds:
201  *   out1: [0x0 ~> 0x7ffffffffffff]
202  *   out2: [0x0 ~> 0x1]
203  */
204 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
205     uint64_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
206     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint64_t arg2,
207     uint64_t arg3) {
208     int64_t x1;
209     fiat_id_tc26_gost_3410_2012_512_paramSetA_int1 x2;
210     uint64_t x3;
211     x1 = ((int64_t)(arg2 - (int64_t)arg1) - (int64_t)arg3);
212     x2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_int1)(x1 >> 51);
213     x3 = (x1 & UINT64_C(0x7ffffffffffff));
214     *out1 = x3;
215     *out2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(0x0 - x2);
216 }
217
218 /*
219  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64 is a single-word conditional move.
220  * Postconditions:
221  *   out1 = (if arg1 = 0 then arg2 else arg3)
222  *
223  * Input Bounds:
224  *   arg1: [0x0 ~> 0x1]
225  *   arg2: [0x0 ~> 0xffffffffffffffff]
226  *   arg3: [0x0 ~> 0xffffffffffffffff]
227  * Output Bounds:
228  *   out1: [0x0 ~> 0xffffffffffffffff]
229  */
230 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(
231     uint64_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1,
232     uint64_t arg2, uint64_t arg3) {
233     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x1;
234     uint64_t x2;
235     uint64_t x3;
236     x1 = (!(!arg1));
237     x2 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_int1)(0x0 - x1) &
238           UINT64_C(0xffffffffffffffff));
239     x3 = ((x2 & arg3) | ((~x2) & arg2));
240     *out1 = x3;
241 }
242
243 /*
244  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul multiplies two field elements and reduces the result.
245  * Postconditions:
246  *   eval out1 mod m = (eval arg1 * eval arg2) mod m
247  *
248  * Input Bounds:
249  *   arg1: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
250  *   arg2: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
251  * Output Bounds:
252  *   out1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
253  */
254 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(
255     uint64_t out1[10], const uint64_t arg1[10], const uint64_t arg2[10]) {
256     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x1;
257     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x2;
258     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x3;
259     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x4;
260     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x5;
261     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x6;
262     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x7;
263     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x8;
264     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x9;
265     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x10;
266     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x11;
267     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x12;
268     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x13;
269     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x14;
270     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x15;
271     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x16;
272     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x17;
273     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x18;
274     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x19;
275     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x20;
276     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x21;
277     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x22;
278     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x23;
279     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x24;
280     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x25;
281     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x26;
282     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x27;
283     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x28;
284     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x29;
285     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x30;
286     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x31;
287     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x32;
288     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x33;
289     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x34;
290     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x35;
291     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x36;
292     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x37;
293     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x38;
294     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x39;
295     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x40;
296     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x41;
297     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x42;
298     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x43;
299     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x44;
300     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x45;
301     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x46;
302     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x47;
303     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x48;
304     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x49;
305     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x50;
306     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x51;
307     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x52;
308     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x53;
309     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x54;
310     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x55;
311     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x56;
312     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x57;
313     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x58;
314     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x59;
315     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x60;
316     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x61;
317     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x62;
318     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x63;
319     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x64;
320     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x65;
321     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x66;
322     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x67;
323     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x68;
324     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x69;
325     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x70;
326     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x71;
327     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x72;
328     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x73;
329     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x74;
330     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x75;
331     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x76;
332     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x77;
333     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x78;
334     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x79;
335     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x80;
336     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x81;
337     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x82;
338     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x83;
339     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x84;
340     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x85;
341     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x86;
342     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x87;
343     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x88;
344     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x89;
345     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x90;
346     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x91;
347     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x92;
348     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x93;
349     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x94;
350     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x95;
351     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x96;
352     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x97;
353     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x98;
354     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x99;
355     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x100;
356     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x101;
357     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x102;
358     uint64_t x103;
359     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x104;
360     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x105;
361     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x106;
362     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x107;
363     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x108;
364     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x109;
365     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x110;
366     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x111;
367     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x112;
368     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x113;
369     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x114;
370     uint64_t x115;
371     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x116;
372     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x117;
373     uint64_t x118;
374     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x119;
375     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x120;
376     uint64_t x121;
377     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x122;
378     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x123;
379     uint64_t x124;
380     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x125;
381     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x126;
382     uint64_t x127;
383     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x128;
384     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x129;
385     uint64_t x130;
386     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x131;
387     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x132;
388     uint64_t x133;
389     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x134;
390     uint64_t x135;
391     uint64_t x136;
392     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x137;
393     uint64_t x138;
394     uint64_t x139;
395     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x140;
396     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x141;
397     uint64_t x142;
398     uint64_t x143;
399     uint64_t x144;
400     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x145;
401     uint64_t x146;
402     uint64_t x147;
403     x1 = (UINT16_C(0x239) *
404           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
405            (arg2[9])));
406     x2 = (UINT16_C(0x239) *
407           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
408            (arg2[8])));
409     x3 = (UINT16_C(0x239) *
410           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
411            (arg2[7])));
412     x4 = (UINT16_C(0x239) *
413           (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
414             (arg2[6])) *
415            0x2));
416     x5 = (UINT16_C(0x239) *
417           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
418            (arg2[5])));
419     x6 = (UINT16_C(0x239) *
420           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
421            (arg2[4])));
422     x7 = (UINT16_C(0x239) *
423           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
424            (arg2[3])));
425     x8 = (UINT16_C(0x239) *
426           ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
427            (arg2[2])));
428     x9 = (UINT16_C(0x239) *
429           (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
430             (arg2[1])) *
431            0x2));
432     x10 = (UINT16_C(0x239) *
433            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
434             (arg2[9])));
435     x11 = (UINT16_C(0x239) *
436            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
437             (arg2[8])));
438     x12 = (UINT16_C(0x239) *
439            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
440              (arg2[7])) *
441             0x2));
442     x13 = (UINT16_C(0x239) *
443            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
444              (arg2[6])) *
445             0x2));
446     x14 = (UINT16_C(0x239) *
447            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
448             (arg2[5])));
449     x15 = (UINT16_C(0x239) *
450            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
451             (arg2[4])));
452     x16 = (UINT16_C(0x239) *
453            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
454             (arg2[3])));
455     x17 = (UINT16_C(0x239) *
456            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
457              (arg2[2])) *
458             0x2));
459     x18 = (UINT16_C(0x239) *
460            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
461             (arg2[9])));
462     x19 = (UINT16_C(0x239) *
463            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
464              (arg2[8])) *
465             0x2));
466     x20 = (UINT16_C(0x239) *
467            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
468              (arg2[7])) *
469             0x2));
470     x21 = (UINT16_C(0x239) *
471            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
472              (arg2[6])) *
473             0x2));
474     x22 = (UINT16_C(0x239) *
475            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
476             (arg2[5])));
477     x23 = (UINT16_C(0x239) *
478            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
479             (arg2[4])));
480     x24 = (UINT16_C(0x239) *
481            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
482              (arg2[3])) *
483             0x2));
484     x25 = (UINT16_C(0x239) *
485            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
486              (arg2[9])) *
487             0x2));
488     x26 = (UINT16_C(0x239) *
489            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
490              (arg2[8])) *
491             0x2));
492     x27 = (UINT16_C(0x239) *
493            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
494              (arg2[7])) *
495             0x2));
496     x28 = (UINT16_C(0x239) *
497            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
498              (arg2[6])) *
499             0x2));
500     x29 = (UINT16_C(0x239) *
501            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
502             (arg2[5])));
503     x30 = (UINT16_C(0x239) *
504            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
505              (arg2[4])) *
506             0x2));
507     x31 = (UINT16_C(0x239) *
508            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
509             (arg2[9])));
510     x32 = (UINT16_C(0x239) *
511            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
512             (arg2[8])));
513     x33 = (UINT16_C(0x239) *
514            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
515             (arg2[7])));
516     x34 = (UINT16_C(0x239) *
517            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
518             (arg2[6])));
519     x35 = (UINT16_C(0x239) *
520            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
521             (arg2[5])));
522     x36 = (UINT16_C(0x239) *
523            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
524             (arg2[9])));
525     x37 = (UINT16_C(0x239) *
526            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
527             (arg2[8])));
528     x38 = (UINT16_C(0x239) *
529            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
530             (arg2[7])));
531     x39 = (UINT16_C(0x239) *
532            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
533              (arg2[6])) *
534             0x2));
535     x40 = (UINT16_C(0x239) *
536            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
537             (arg2[9])));
538     x41 = (UINT16_C(0x239) *
539            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
540             (arg2[8])));
541     x42 = (UINT16_C(0x239) *
542            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
543              (arg2[7])) *
544             0x2));
545     x43 = (UINT16_C(0x239) *
546            ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
547             (arg2[9])));
548     x44 = (UINT16_C(0x239) *
549            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
550              (arg2[8])) *
551             0x2));
552     x45 = (UINT16_C(0x239) *
553            (((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
554              (arg2[9])) *
555             0x2));
556     x46 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) *
557            (arg2[0]));
558     x47 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
559            ((arg2[1]) * 0x2));
560     x48 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) *
561            (arg2[0]));
562     x49 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
563            ((arg2[2]) * 0x2));
564     x50 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
565            ((arg2[1]) * 0x2));
566     x51 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
567            (arg2[0]));
568     x52 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
569            ((arg2[3]) * 0x2));
570     x53 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
571            ((arg2[2]) * 0x2));
572     x54 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
573            ((arg2[1]) * 0x2));
574     x55 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
575            (arg2[0]));
576     x56 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
577            (arg2[4]));
578     x57 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
579            (arg2[3]));
580     x58 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
581            (arg2[2]));
582     x59 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
583            (arg2[1]));
584     x60 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) *
585            (arg2[0]));
586     x61 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
587            (arg2[5]));
588     x62 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
589            (arg2[4]));
590     x63 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
591            (arg2[3]));
592     x64 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
593            (arg2[2]));
594     x65 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
595            ((arg2[1]) * 0x2));
596     x66 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
597            (arg2[0]));
598     x67 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
599            ((arg2[6]) * 0x2));
600     x68 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
601            (arg2[5]));
602     x69 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
603            (arg2[4]));
604     x70 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
605            (arg2[3]));
606     x71 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
607            ((arg2[2]) * 0x2));
608     x72 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
609            ((arg2[1]) * 0x2));
610     x73 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
611            (arg2[0]));
612     x74 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
613            ((arg2[7]) * 0x2));
614     x75 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
615            ((arg2[6]) * 0x2));
616     x76 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
617            (arg2[5]));
618     x77 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
619            (arg2[4]));
620     x78 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
621            ((arg2[3]) * 0x2));
622     x79 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
623            ((arg2[2]) * 0x2));
624     x80 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
625            ((arg2[1]) * 0x2));
626     x81 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
627            (arg2[0]));
628     x82 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
629            ((arg2[8]) * 0x2));
630     x83 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
631            ((arg2[7]) * 0x2));
632     x84 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
633            ((arg2[6]) * 0x2));
634     x85 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
635            (arg2[5]));
636     x86 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
637            ((arg2[4]) * 0x2));
638     x87 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
639            ((arg2[3]) * 0x2));
640     x88 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
641            ((arg2[2]) * 0x2));
642     x89 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
643            ((arg2[1]) * 0x2));
644     x90 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
645            (arg2[0]));
646     x91 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
647            (arg2[9]));
648     x92 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
649            (arg2[8]));
650     x93 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
651            (arg2[7]));
652     x94 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
653            (arg2[6]));
654     x95 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
655            (arg2[5]));
656     x96 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
657            (arg2[4]));
658     x97 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
659            (arg2[3]));
660     x98 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
661            (arg2[2]));
662     x99 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
663            (arg2[1]));
664     x100 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
665             (arg2[0]));
666     x101 = (x100 +
667             (x45 + (x44 + (x42 + (x39 + (x35 + (x30 + (x24 + (x17 + x9)))))))));
668     x102 = (x101 >> 52);
669     x103 = (uint64_t)(x101 & UINT64_C(0xfffffffffffff));
670     x104 =
671         (x91 +
672          (x82 + (x74 + (x67 + (x61 + (x56 + (x52 + (x49 + (x47 + x46)))))))));
673     x105 = (x92 +
674             (x83 + (x75 + (x68 + (x62 + (x57 + (x53 + (x50 + (x48 + x1)))))))));
675     x106 = (x93 +
676             (x84 + (x76 + (x69 + (x63 + (x58 + (x54 + (x51 + (x10 + x2)))))))));
677     x107 = (x94 +
678             (x85 + (x77 + (x70 + (x64 + (x59 + (x55 + (x18 + (x11 + x3)))))))));
679     x108 = (x95 +
680             (x86 + (x78 + (x71 + (x65 + (x60 + (x25 + (x19 + (x12 + x4)))))))));
681     x109 = (x96 +
682             (x87 + (x79 + (x72 + (x66 + (x31 + (x26 + (x20 + (x13 + x5)))))))));
683     x110 = (x97 +
684             (x88 + (x80 + (x73 + (x36 + (x32 + (x27 + (x21 + (x14 + x6)))))))));
685     x111 = (x98 +
686             (x89 + (x81 + (x40 + (x37 + (x33 + (x28 + (x22 + (x15 + x7)))))))));
687     x112 = (x99 +
688             (x90 + (x43 + (x41 + (x38 + (x34 + (x29 + (x23 + (x16 + x8)))))))));
689     x113 = (x102 + x112);
690     x114 = (x113 >> 51);
691     x115 = (uint64_t)(x113 & UINT64_C(0x7ffffffffffff));
692     x116 = (x114 + x111);
693     x117 = (x116 >> 51);
694     x118 = (uint64_t)(x116 & UINT64_C(0x7ffffffffffff));
695     x119 = (x117 + x110);
696     x120 = (x119 >> 51);
697     x121 = (uint64_t)(x119 & UINT64_C(0x7ffffffffffff));
698     x122 = (x120 + x109);
699     x123 = (x122 >> 51);
700     x124 = (uint64_t)(x122 & UINT64_C(0x7ffffffffffff));
701     x125 = (x123 + x108);
702     x126 = (x125 >> 52);
703     x127 = (uint64_t)(x125 & UINT64_C(0xfffffffffffff));
704     x128 = (x126 + x107);
705     x129 = (x128 >> 51);
706     x130 = (uint64_t)(x128 & UINT64_C(0x7ffffffffffff));
707     x131 = (x129 + x106);
708     x132 = (x131 >> 51);
709     x133 = (uint64_t)(x131 & UINT64_C(0x7ffffffffffff));
710     x134 = (x132 + x105);
711     x135 = (uint64_t)(x134 >> 51);
712     x136 = (uint64_t)(x134 & UINT64_C(0x7ffffffffffff));
713     x137 = (x135 + x104);
714     x138 = (uint64_t)(x137 >> 51);
715     x139 = (uint64_t)(x137 & UINT64_C(0x7ffffffffffff));
716     x140 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)UINT16_C(0x239) *
717             x138);
718     x141 = (x103 + x140);
719     x142 = (uint64_t)(x141 >> 52);
720     x143 = (uint64_t)(x141 & UINT64_C(0xfffffffffffff));
721     x144 = (x142 + x115);
722     x145 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x144 >> 51);
723     x146 = (x144 & UINT64_C(0x7ffffffffffff));
724     x147 = (x145 + x118);
725     out1[0] = x143;
726     out1[1] = x146;
727     out1[2] = x147;
728     out1[3] = x121;
729     out1[4] = x124;
730     out1[5] = x127;
731     out1[6] = x130;
732     out1[7] = x133;
733     out1[8] = x136;
734     out1[9] = x139;
735 }
736
737 /*
738  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square squares a field element and reduces the result.
739  * Postconditions:
740  *   eval out1 mod m = (eval arg1 * eval arg1) mod m
741  *
742  * Input Bounds:
743  *   arg1: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
744  * Output Bounds:
745  *   out1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
746  */
747 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(
748     uint64_t out1[10], const uint64_t arg1[10]) {
749     uint64_t x1;
750     uint64_t x2;
751     uint64_t x3;
752     uint64_t x4;
753     uint64_t x5;
754     uint64_t x6;
755     uint64_t x7;
756     uint64_t x8;
757     uint64_t x9;
758     uint64_t x10;
759     uint64_t x11;
760     uint64_t x12;
761     uint64_t x13;
762     uint64_t x14;
763     uint64_t x15;
764     uint64_t x16;
765     uint64_t x17;
766     uint64_t x18;
767     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x19;
768     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x20;
769     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x21;
770     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x22;
771     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x23;
772     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x24;
773     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x25;
774     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x26;
775     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x27;
776     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x28;
777     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x29;
778     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x30;
779     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x31;
780     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x32;
781     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x33;
782     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x34;
783     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x35;
784     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x36;
785     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x37;
786     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x38;
787     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x39;
788     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x40;
789     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x41;
790     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x42;
791     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x43;
792     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x44;
793     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x45;
794     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x46;
795     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x47;
796     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x48;
797     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x49;
798     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x50;
799     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x51;
800     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x52;
801     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x53;
802     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x54;
803     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x55;
804     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x56;
805     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x57;
806     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x58;
807     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x59;
808     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x60;
809     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x61;
810     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x62;
811     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x63;
812     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x64;
813     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x65;
814     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x66;
815     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x67;
816     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x68;
817     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x69;
818     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x70;
819     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x71;
820     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x72;
821     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x73;
822     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x74;
823     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x75;
824     uint64_t x76;
825     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x77;
826     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x78;
827     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x79;
828     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x80;
829     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x81;
830     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x82;
831     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x83;
832     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x84;
833     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x85;
834     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x86;
835     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x87;
836     uint64_t x88;
837     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x89;
838     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x90;
839     uint64_t x91;
840     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x92;
841     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x93;
842     uint64_t x94;
843     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x95;
844     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x96;
845     uint64_t x97;
846     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x98;
847     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x99;
848     uint64_t x100;
849     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x101;
850     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x102;
851     uint64_t x103;
852     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x104;
853     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x105;
854     uint64_t x106;
855     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x107;
856     uint64_t x108;
857     uint64_t x109;
858     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x110;
859     uint64_t x111;
860     uint64_t x112;
861     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x113;
862     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128 x114;
863     uint64_t x115;
864     uint64_t x116;
865     uint64_t x117;
866     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x118;
867     uint64_t x119;
868     uint64_t x120;
869     x1 = ((arg1[9]) * UINT16_C(0x239));
870     x2 = (x1 * 0x2);
871     x3 = ((arg1[9]) * 0x2);
872     x4 = ((arg1[8]) * UINT16_C(0x239));
873     x5 = (x4 * 0x2);
874     x6 = ((arg1[8]) * 0x2);
875     x7 = ((arg1[7]) * UINT16_C(0x239));
876     x8 = (x7 * 0x2);
877     x9 = ((arg1[7]) * 0x2);
878     x10 = ((arg1[6]) * UINT16_C(0x239));
879     x11 = (x10 * 0x2);
880     x12 = ((arg1[6]) * 0x2);
881     x13 = ((arg1[5]) * UINT16_C(0x239));
882     x14 = ((arg1[5]) * 0x2);
883     x15 = ((arg1[4]) * 0x2);
884     x16 = ((arg1[3]) * 0x2);
885     x17 = ((arg1[2]) * 0x2);
886     x18 = ((arg1[1]) * 0x2);
887     x19 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[9]) * x1);
888     x20 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) * x2);
889     x21 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[8]) * x4);
890     x22 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) * x2);
891     x23 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
892            (x5 * 0x2));
893     x24 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[7]) *
894            (x7 * 0x2));
895     x25 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
896            (x2 * 0x2));
897     x26 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
898            (x5 * 0x2));
899     x27 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
900            (x8 * 0x2));
901     x28 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[6]) *
902            (x10 * 0x2));
903     x29 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) * x2);
904     x30 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) * x5);
905     x31 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) * x8);
906     x32 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) * x11);
907     x33 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[5]) * x13);
908     x34 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) * x2);
909     x35 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) * x5);
910     x36 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) * x8);
911     x37 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
912            (x11 * 0x2));
913     x38 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) * x14);
914     x39 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[4]) *
915            (arg1[4]));
916     x40 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) * x2);
917     x41 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) * x5);
918     x42 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
919            (x8 * 0x2));
920     x43 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
921            (x12 * 0x2));
922     x44 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) * x14);
923     x45 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) * x15);
924     x46 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[3]) *
925            (arg1[3]));
926     x47 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) * x2);
927     x48 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
928            (x5 * 0x2));
929     x49 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
930            (x9 * 0x2));
931     x50 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
932            (x12 * 0x2));
933     x51 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) * x14);
934     x52 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) * x15);
935     x53 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
936            (x16 * 0x2));
937     x54 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[2]) *
938            ((arg1[2]) * 0x2));
939     x55 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
940            (x2 * 0x2));
941     x56 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
942            (x6 * 0x2));
943     x57 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
944            (x9 * 0x2));
945     x58 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
946            (x12 * 0x2));
947     x59 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) * x14);
948     x60 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
949            (x15 * 0x2));
950     x61 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
951            (x16 * 0x2));
952     x62 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
953            (x17 * 0x2));
954     x63 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[1]) *
955            ((arg1[1]) * 0x2));
956     x64 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x3);
957     x65 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x6);
958     x66 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x9);
959     x67 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x12);
960     x68 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x14);
961     x69 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x15);
962     x70 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x16);
963     x71 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x17);
964     x72 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) * x18);
965     x73 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)(arg1[0]) *
966            (arg1[0]));
967     x74 = (x73 + (x55 + (x48 + (x42 + (x37 + x33)))));
968     x75 = (x74 >> 52);
969     x76 = (uint64_t)(x74 & UINT64_C(0xfffffffffffff));
970     x77 = (x64 + (x56 + (x49 + (x43 + x38))));
971     x78 = (x65 + (x57 + (x50 + (x44 + (x39 + x19)))));
972     x79 = (x66 + (x58 + (x51 + (x45 + x20))));
973     x80 = (x67 + (x59 + (x52 + (x46 + (x22 + x21)))));
974     x81 = (x68 + (x60 + (x53 + (x25 + x23))));
975     x82 = (x69 + (x61 + (x54 + (x29 + (x26 + x24)))));
976     x83 = (x70 + (x62 + (x34 + (x30 + x27))));
977     x84 = (x71 + (x63 + (x40 + (x35 + (x31 + x28)))));
978     x85 = (x72 + (x47 + (x41 + (x36 + x32))));
979     x86 = (x75 + x85);
980     x87 = (x86 >> 51);
981     x88 = (uint64_t)(x86 & UINT64_C(0x7ffffffffffff));
982     x89 = (x87 + x84);
983     x90 = (x89 >> 51);
984     x91 = (uint64_t)(x89 & UINT64_C(0x7ffffffffffff));
985     x92 = (x90 + x83);
986     x93 = (x92 >> 51);
987     x94 = (uint64_t)(x92 & UINT64_C(0x7ffffffffffff));
988     x95 = (x93 + x82);
989     x96 = (x95 >> 51);
990     x97 = (uint64_t)(x95 & UINT64_C(0x7ffffffffffff));
991     x98 = (x96 + x81);
992     x99 = (x98 >> 52);
993     x100 = (uint64_t)(x98 & UINT64_C(0xfffffffffffff));
994     x101 = (x99 + x80);
995     x102 = (x101 >> 51);
996     x103 = (uint64_t)(x101 & UINT64_C(0x7ffffffffffff));
997     x104 = (x102 + x79);
998     x105 = (x104 >> 51);
999     x106 = (uint64_t)(x104 & UINT64_C(0x7ffffffffffff));
1000     x107 = (x105 + x78);
1001     x108 = (uint64_t)(x107 >> 51);
1002     x109 = (uint64_t)(x107 & UINT64_C(0x7ffffffffffff));
1003     x110 = (x108 + x77);
1004     x111 = (uint64_t)(x110 >> 51);
1005     x112 = (uint64_t)(x110 & UINT64_C(0x7ffffffffffff));
1006     x113 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint128)UINT16_C(0x239) *
1007             x111);
1008     x114 = (x76 + x113);
1009     x115 = (uint64_t)(x114 >> 52);
1010     x116 = (uint64_t)(x114 & UINT64_C(0xfffffffffffff));
1011     x117 = (x115 + x88);
1012     x118 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x117 >> 51);
1013     x119 = (x117 & UINT64_C(0x7ffffffffffff));
1014     x120 = (x118 + x91);
1015     out1[0] = x116;
1016     out1[1] = x119;
1017     out1[2] = x120;
1018     out1[3] = x94;
1019     out1[4] = x97;
1020     out1[5] = x100;
1021     out1[6] = x103;
1022     out1[7] = x106;
1023     out1[8] = x109;
1024     out1[9] = x112;
1025 }
1026
1027 /*
1028  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_carry reduces a field element.
1029  * Postconditions:
1030  *   eval out1 mod m = eval arg1 mod m
1031  *
1032  * Input Bounds:
1033  *   arg1: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
1034  * Output Bounds:
1035  *   out1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1036  */
1037 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_carry(
1038     uint64_t out1[10], const uint64_t arg1[10]) {
1039     uint64_t x1;
1040     uint64_t x2;
1041     uint64_t x3;
1042     uint64_t x4;
1043     uint64_t x5;
1044     uint64_t x6;
1045     uint64_t x7;
1046     uint64_t x8;
1047     uint64_t x9;
1048     uint64_t x10;
1049     uint64_t x11;
1050     uint64_t x12;
1051     uint64_t x13;
1052     uint64_t x14;
1053     uint64_t x15;
1054     uint64_t x16;
1055     uint64_t x17;
1056     uint64_t x18;
1057     uint64_t x19;
1058     uint64_t x20;
1059     uint64_t x21;
1060     uint64_t x22;
1061     x1 = (arg1[0]);
1062     x2 = ((x1 >> 52) + (arg1[1]));
1063     x3 = ((x2 >> 51) + (arg1[2]));
1064     x4 = ((x3 >> 51) + (arg1[3]));
1065     x5 = ((x4 >> 51) + (arg1[4]));
1066     x6 = ((x5 >> 51) + (arg1[5]));
1067     x7 = ((x6 >> 52) + (arg1[6]));
1068     x8 = ((x7 >> 51) + (arg1[7]));
1069     x9 = ((x8 >> 51) + (arg1[8]));
1070     x10 = ((x9 >> 51) + (arg1[9]));
1071     x11 = ((x1 & UINT64_C(0xfffffffffffff)) + (UINT16_C(0x239) * (x10 >> 51)));
1072     x12 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x11 >> 52) +
1073            (x2 & UINT64_C(0x7ffffffffffff)));
1074     x13 = (x11 & UINT64_C(0xfffffffffffff));
1075     x14 = (x12 & UINT64_C(0x7ffffffffffff));
1076     x15 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x12 >> 51) +
1077            (x3 & UINT64_C(0x7ffffffffffff)));
1078     x16 = (x4 & UINT64_C(0x7ffffffffffff));
1079     x17 = (x5 & UINT64_C(0x7ffffffffffff));
1080     x18 = (x6 & UINT64_C(0xfffffffffffff));
1081     x19 = (x7 & UINT64_C(0x7ffffffffffff));
1082     x20 = (x8 & UINT64_C(0x7ffffffffffff));
1083     x21 = (x9 & UINT64_C(0x7ffffffffffff));
1084     x22 = (x10 & UINT64_C(0x7ffffffffffff));
1085     out1[0] = x13;
1086     out1[1] = x14;
1087     out1[2] = x15;
1088     out1[3] = x16;
1089     out1[4] = x17;
1090     out1[5] = x18;
1091     out1[6] = x19;
1092     out1[7] = x20;
1093     out1[8] = x21;
1094     out1[9] = x22;
1095 }
1096
1097 /*
1098  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_add adds two field elements.
1099  * Postconditions:
1100  *   eval out1 mod m = (eval arg1 + eval arg2) mod m
1101  *
1102  * Input Bounds:
1103  *   arg1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1104  *   arg2: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1105  * Output Bounds:
1106  *   out1: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
1107  */
1108 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_add(
1109     uint64_t out1[10], const uint64_t arg1[10], const uint64_t arg2[10]) {
1110     uint64_t x1;
1111     uint64_t x2;
1112     uint64_t x3;
1113     uint64_t x4;
1114     uint64_t x5;
1115     uint64_t x6;
1116     uint64_t x7;
1117     uint64_t x8;
1118     uint64_t x9;
1119     uint64_t x10;
1120     x1 = ((arg1[0]) + (arg2[0]));
1121     x2 = ((arg1[1]) + (arg2[1]));
1122     x3 = ((arg1[2]) + (arg2[2]));
1123     x4 = ((arg1[3]) + (arg2[3]));
1124     x5 = ((arg1[4]) + (arg2[4]));
1125     x6 = ((arg1[5]) + (arg2[5]));
1126     x7 = ((arg1[6]) + (arg2[6]));
1127     x8 = ((arg1[7]) + (arg2[7]));
1128     x9 = ((arg1[8]) + (arg2[8]));
1129     x10 = ((arg1[9]) + (arg2[9]));
1130     out1[0] = x1;
1131     out1[1] = x2;
1132     out1[2] = x3;
1133     out1[3] = x4;
1134     out1[4] = x5;
1135     out1[5] = x6;
1136     out1[6] = x7;
1137     out1[7] = x8;
1138     out1[8] = x9;
1139     out1[9] = x10;
1140 }
1141
1142 /*
1143  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_sub subtracts two field elements.
1144  * Postconditions:
1145  *   eval out1 mod m = (eval arg1 - eval arg2) mod m
1146  *
1147  * Input Bounds:
1148  *   arg1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1149  *   arg2: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1150  * Output Bounds:
1151  *   out1: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
1152  */
1153 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_sub(
1154     uint64_t out1[10], const uint64_t arg1[10], const uint64_t arg2[10]) {
1155     uint64_t x1;
1156     uint64_t x2;
1157     uint64_t x3;
1158     uint64_t x4;
1159     uint64_t x5;
1160     uint64_t x6;
1161     uint64_t x7;
1162     uint64_t x8;
1163     uint64_t x9;
1164     uint64_t x10;
1165     x1 = ((UINT64_C(0x1ffffffffffb8e) + (arg1[0])) - (arg2[0]));
1166     x2 = ((UINT64_C(0xffffffffffffe) + (arg1[1])) - (arg2[1]));
1167     x3 = ((UINT64_C(0xffffffffffffe) + (arg1[2])) - (arg2[2]));
1168     x4 = ((UINT64_C(0xffffffffffffe) + (arg1[3])) - (arg2[3]));
1169     x5 = ((UINT64_C(0xffffffffffffe) + (arg1[4])) - (arg2[4]));
1170     x6 = ((UINT64_C(0x1ffffffffffffe) + (arg1[5])) - (arg2[5]));
1171     x7 = ((UINT64_C(0xffffffffffffe) + (arg1[6])) - (arg2[6]));
1172     x8 = ((UINT64_C(0xffffffffffffe) + (arg1[7])) - (arg2[7]));
1173     x9 = ((UINT64_C(0xffffffffffffe) + (arg1[8])) - (arg2[8]));
1174     x10 = ((UINT64_C(0xffffffffffffe) + (arg1[9])) - (arg2[9]));
1175     out1[0] = x1;
1176     out1[1] = x2;
1177     out1[2] = x3;
1178     out1[3] = x4;
1179     out1[4] = x5;
1180     out1[5] = x6;
1181     out1[6] = x7;
1182     out1[7] = x8;
1183     out1[8] = x9;
1184     out1[9] = x10;
1185 }
1186
1187 /*
1188  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_opp negates a field element.
1189  * Postconditions:
1190  *   eval out1 mod m = -eval arg1 mod m
1191  *
1192  * Input Bounds:
1193  *   arg1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1194  * Output Bounds:
1195  *   out1: [[0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x34cccccccccccb], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664], [0x0 ~> 0x1a666666666664]]
1196  */
1197 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(
1198     uint64_t out1[10], const uint64_t arg1[10]) {
1199     uint64_t x1;
1200     uint64_t x2;
1201     uint64_t x3;
1202     uint64_t x4;
1203     uint64_t x5;
1204     uint64_t x6;
1205     uint64_t x7;
1206     uint64_t x8;
1207     uint64_t x9;
1208     uint64_t x10;
1209     x1 = (UINT64_C(0x1ffffffffffb8e) - (arg1[0]));
1210     x2 = (UINT64_C(0xffffffffffffe) - (arg1[1]));
1211     x3 = (UINT64_C(0xffffffffffffe) - (arg1[2]));
1212     x4 = (UINT64_C(0xffffffffffffe) - (arg1[3]));
1213     x5 = (UINT64_C(0xffffffffffffe) - (arg1[4]));
1214     x6 = (UINT64_C(0x1ffffffffffffe) - (arg1[5]));
1215     x7 = (UINT64_C(0xffffffffffffe) - (arg1[6]));
1216     x8 = (UINT64_C(0xffffffffffffe) - (arg1[7]));
1217     x9 = (UINT64_C(0xffffffffffffe) - (arg1[8]));
1218     x10 = (UINT64_C(0xffffffffffffe) - (arg1[9]));
1219     out1[0] = x1;
1220     out1[1] = x2;
1221     out1[2] = x3;
1222     out1[3] = x4;
1223     out1[4] = x5;
1224     out1[5] = x6;
1225     out1[6] = x7;
1226     out1[7] = x8;
1227     out1[8] = x9;
1228     out1[9] = x10;
1229 }
1230
1231 /*
1232  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz is a multi-limb conditional select.
1233  * Postconditions:
1234  *   eval out1 = (if arg1 = 0 then eval arg2 else eval arg3)
1235  *
1236  * Input Bounds:
1237  *   arg1: [0x0 ~> 0x1]
1238  *   arg2: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1239  *   arg3: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1240  * Output Bounds:
1241  *   out1: [[0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff], [0x0 ~> 0xffffffffffffffff]]
1242  */
1243 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
1244     uint64_t out1[10], fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1,
1245     const uint64_t arg2[10], const uint64_t arg3[10]) {
1246     uint64_t x1;
1247     uint64_t x2;
1248     uint64_t x3;
1249     uint64_t x4;
1250     uint64_t x5;
1251     uint64_t x6;
1252     uint64_t x7;
1253     uint64_t x8;
1254     uint64_t x9;
1255     uint64_t x10;
1256     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x1, arg1, (arg2[0]),
1257                                                           (arg3[0]));
1258     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x2, arg1, (arg2[1]),
1259                                                           (arg3[1]));
1260     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x3, arg1, (arg2[2]),
1261                                                           (arg3[2]));
1262     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x4, arg1, (arg2[3]),
1263                                                           (arg3[3]));
1264     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x5, arg1, (arg2[4]),
1265                                                           (arg3[4]));
1266     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x6, arg1, (arg2[5]),
1267                                                           (arg3[5]));
1268     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x7, arg1, (arg2[6]),
1269                                                           (arg3[6]));
1270     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x8, arg1, (arg2[7]),
1271                                                           (arg3[7]));
1272     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x9, arg1, (arg2[8]),
1273                                                           (arg3[8]));
1274     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(&x10, arg1, (arg2[9]),
1275                                                           (arg3[9]));
1276     out1[0] = x1;
1277     out1[1] = x2;
1278     out1[2] = x3;
1279     out1[3] = x4;
1280     out1[4] = x5;
1281     out1[5] = x6;
1282     out1[6] = x7;
1283     out1[7] = x8;
1284     out1[8] = x9;
1285     out1[9] = x10;
1286 }
1287
1288 /*
1289  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes serializes a field element to bytes in little-endian order.
1290  * Postconditions:
1291  *   out1 = map (λ x, ⌊((eval arg1 mod m) mod 2^(8 * (x + 1))) / 2^(8 * x)⌋) [0..63]
1292  *
1293  * Input Bounds:
1294  *   arg1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1295  * Output Bounds:
1296  *   out1: [[0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff]]
1297  */
1298 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(
1299     uint8_t out1[64], const uint64_t arg1[10]) {
1300     uint64_t x1;
1301     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x2;
1302     uint64_t x3;
1303     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x4;
1304     uint64_t x5;
1305     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x6;
1306     uint64_t x7;
1307     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x8;
1308     uint64_t x9;
1309     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x10;
1310     uint64_t x11;
1311     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x12;
1312     uint64_t x13;
1313     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x14;
1314     uint64_t x15;
1315     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x16;
1316     uint64_t x17;
1317     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x18;
1318     uint64_t x19;
1319     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x20;
1320     uint64_t x21;
1321     uint64_t x22;
1322     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x23;
1323     uint64_t x24;
1324     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x25;
1325     uint64_t x26;
1326     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x27;
1327     uint64_t x28;
1328     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x29;
1329     uint64_t x30;
1330     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x31;
1331     uint64_t x32;
1332     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x33;
1333     uint64_t x34;
1334     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x35;
1335     uint64_t x36;
1336     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x37;
1337     uint64_t x38;
1338     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x39;
1339     uint64_t x40;
1340     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x41;
1341     uint64_t x42;
1342     uint64_t x43;
1343     uint64_t x44;
1344     uint64_t x45;
1345     uint64_t x46;
1346     uint64_t x47;
1347     uint64_t x48;
1348     uint64_t x49;
1349     uint64_t x50;
1350     uint8_t x51;
1351     uint64_t x52;
1352     uint8_t x53;
1353     uint64_t x54;
1354     uint8_t x55;
1355     uint64_t x56;
1356     uint8_t x57;
1357     uint64_t x58;
1358     uint8_t x59;
1359     uint8_t x60;
1360     uint8_t x61;
1361     uint64_t x62;
1362     uint64_t x63;
1363     uint8_t x64;
1364     uint64_t x65;
1365     uint8_t x66;
1366     uint64_t x67;
1367     uint8_t x68;
1368     uint64_t x69;
1369     uint8_t x70;
1370     uint64_t x71;
1371     uint8_t x72;
1372     uint8_t x73;
1373     uint8_t x74;
1374     uint64_t x75;
1375     uint64_t x76;
1376     uint8_t x77;
1377     uint64_t x78;
1378     uint8_t x79;
1379     uint64_t x80;
1380     uint8_t x81;
1381     uint64_t x82;
1382     uint8_t x83;
1383     uint64_t x84;
1384     uint8_t x85;
1385     uint64_t x86;
1386     uint8_t x87;
1387     uint8_t x88;
1388     uint8_t x89;
1389     uint64_t x90;
1390     uint64_t x91;
1391     uint8_t x92;
1392     uint64_t x93;
1393     uint8_t x94;
1394     uint64_t x95;
1395     uint8_t x96;
1396     uint64_t x97;
1397     uint8_t x98;
1398     uint64_t x99;
1399     uint8_t x100;
1400     uint8_t x101;
1401     uint8_t x102;
1402     uint64_t x103;
1403     uint64_t x104;
1404     uint8_t x105;
1405     uint64_t x106;
1406     uint8_t x107;
1407     uint64_t x108;
1408     uint8_t x109;
1409     uint64_t x110;
1410     uint8_t x111;
1411     uint64_t x112;
1412     uint8_t x113;
1413     uint8_t x114;
1414     uint8_t x115;
1415     uint8_t x116;
1416     uint64_t x117;
1417     uint8_t x118;
1418     uint64_t x119;
1419     uint8_t x120;
1420     uint64_t x121;
1421     uint8_t x122;
1422     uint64_t x123;
1423     uint8_t x124;
1424     uint64_t x125;
1425     uint8_t x126;
1426     uint8_t x127;
1427     uint8_t x128;
1428     uint64_t x129;
1429     uint64_t x130;
1430     uint8_t x131;
1431     uint64_t x132;
1432     uint8_t x133;
1433     uint64_t x134;
1434     uint8_t x135;
1435     uint64_t x136;
1436     uint8_t x137;
1437     uint64_t x138;
1438     uint8_t x139;
1439     uint8_t x140;
1440     uint8_t x141;
1441     uint64_t x142;
1442     uint64_t x143;
1443     uint8_t x144;
1444     uint64_t x145;
1445     uint8_t x146;
1446     uint64_t x147;
1447     uint8_t x148;
1448     uint64_t x149;
1449     uint8_t x150;
1450     uint64_t x151;
1451     uint8_t x152;
1452     uint64_t x153;
1453     uint8_t x154;
1454     uint8_t x155;
1455     uint8_t x156;
1456     uint64_t x157;
1457     uint64_t x158;
1458     uint8_t x159;
1459     uint64_t x160;
1460     uint8_t x161;
1461     uint64_t x162;
1462     uint8_t x163;
1463     uint64_t x164;
1464     uint8_t x165;
1465     uint64_t x166;
1466     uint8_t x167;
1467     uint8_t x168;
1468     uint8_t x169;
1469     uint64_t x170;
1470     uint64_t x171;
1471     uint8_t x172;
1472     uint64_t x173;
1473     uint8_t x174;
1474     uint64_t x175;
1475     uint8_t x176;
1476     uint64_t x177;
1477     uint8_t x178;
1478     uint64_t x179;
1479     uint8_t x180;
1480     uint8_t x181;
1481     uint8_t x182;
1482     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u52(
1483         &x1, &x2, 0x0, (arg1[0]), UINT64_C(0xffffffffffdc7));
1484     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1485         &x3, &x4, x2, (arg1[1]), UINT64_C(0x7ffffffffffff));
1486     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1487         &x5, &x6, x4, (arg1[2]), UINT64_C(0x7ffffffffffff));
1488     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1489         &x7, &x8, x6, (arg1[3]), UINT64_C(0x7ffffffffffff));
1490     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1491         &x9, &x10, x8, (arg1[4]), UINT64_C(0x7ffffffffffff));
1492     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u52(
1493         &x11, &x12, x10, (arg1[5]), UINT64_C(0xfffffffffffff));
1494     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1495         &x13, &x14, x12, (arg1[6]), UINT64_C(0x7ffffffffffff));
1496     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1497         &x15, &x16, x14, (arg1[7]), UINT64_C(0x7ffffffffffff));
1498     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1499         &x17, &x18, x16, (arg1[8]), UINT64_C(0x7ffffffffffff));
1500     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u51(
1501         &x19, &x20, x18, (arg1[9]), UINT64_C(0x7ffffffffffff));
1502     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u64(
1503         &x21, x20, 0x0, UINT64_C(0xffffffffffffffff));
1504     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u52(
1505         &x22, &x23, 0x0, x1, (x21 & UINT64_C(0xffffffffffdc7)));
1506     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1507         &x24, &x25, x23, x3, (x21 & UINT64_C(0x7ffffffffffff)));
1508     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1509         &x26, &x27, x25, x5, (x21 & UINT64_C(0x7ffffffffffff)));
1510     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1511         &x28, &x29, x27, x7, (x21 & UINT64_C(0x7ffffffffffff)));
1512     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1513         &x30, &x31, x29, x9, (x21 & UINT64_C(0x7ffffffffffff)));
1514     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u52(
1515         &x32, &x33, x31, x11, (x21 & UINT64_C(0xfffffffffffff)));
1516     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1517         &x34, &x35, x33, x13, (x21 & UINT64_C(0x7ffffffffffff)));
1518     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1519         &x36, &x37, x35, x15, (x21 & UINT64_C(0x7ffffffffffff)));
1520     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1521         &x38, &x39, x37, x17, (x21 & UINT64_C(0x7ffffffffffff)));
1522     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u51(
1523         &x40, &x41, x39, x19, (x21 & UINT64_C(0x7ffffffffffff)));
1524     x42 = (x40 << 5);
1525     x43 = (x38 << 2);
1526     x44 = (x36 << 7);
1527     x45 = (x34 << 4);
1528     x46 = (x30 << 5);
1529     x47 = (x28 << 2);
1530     x48 = (x26 << 7);
1531     x49 = (x24 << 4);
1532     x50 = (x22 >> 8);
1533     x51 = (uint8_t)(x22 & UINT8_C(0xff));
1534     x52 = (x50 >> 8);
1535     x53 = (uint8_t)(x50 & UINT8_C(0xff));
1536     x54 = (x52 >> 8);
1537     x55 = (uint8_t)(x52 & UINT8_C(0xff));
1538     x56 = (x54 >> 8);
1539     x57 = (uint8_t)(x54 & UINT8_C(0xff));
1540     x58 = (x56 >> 8);
1541     x59 = (uint8_t)(x56 & UINT8_C(0xff));
1542     x60 = (uint8_t)(x58 >> 8);
1543     x61 = (uint8_t)(x58 & UINT8_C(0xff));
1544     x62 = (x60 + x49);
1545     x63 = (x62 >> 8);
1546     x64 = (uint8_t)(x62 & UINT8_C(0xff));
1547     x65 = (x63 >> 8);
1548     x66 = (uint8_t)(x63 & UINT8_C(0xff));
1549     x67 = (x65 >> 8);
1550     x68 = (uint8_t)(x65 & UINT8_C(0xff));
1551     x69 = (x67 >> 8);
1552     x70 = (uint8_t)(x67 & UINT8_C(0xff));
1553     x71 = (x69 >> 8);
1554     x72 = (uint8_t)(x69 & UINT8_C(0xff));
1555     x73 = (uint8_t)(x71 >> 8);
1556     x74 = (uint8_t)(x71 & UINT8_C(0xff));
1557     x75 = (x73 + x48);
1558     x76 = (x75 >> 8);
1559     x77 = (uint8_t)(x75 & UINT8_C(0xff));
1560     x78 = (x76 >> 8);
1561     x79 = (uint8_t)(x76 & UINT8_C(0xff));
1562     x80 = (x78 >> 8);
1563     x81 = (uint8_t)(x78 & UINT8_C(0xff));
1564     x82 = (x80 >> 8);
1565     x83 = (uint8_t)(x80 & UINT8_C(0xff));
1566     x84 = (x82 >> 8);
1567     x85 = (uint8_t)(x82 & UINT8_C(0xff));
1568     x86 = (x84 >> 8);
1569     x87 = (uint8_t)(x84 & UINT8_C(0xff));
1570     x88 = (uint8_t)(x86 >> 8);
1571     x89 = (uint8_t)(x86 & UINT8_C(0xff));
1572     x90 = (x88 + x47);
1573     x91 = (x90 >> 8);
1574     x92 = (uint8_t)(x90 & UINT8_C(0xff));
1575     x93 = (x91 >> 8);
1576     x94 = (uint8_t)(x91 & UINT8_C(0xff));
1577     x95 = (x93 >> 8);
1578     x96 = (uint8_t)(x93 & UINT8_C(0xff));
1579     x97 = (x95 >> 8);
1580     x98 = (uint8_t)(x95 & UINT8_C(0xff));
1581     x99 = (x97 >> 8);
1582     x100 = (uint8_t)(x97 & UINT8_C(0xff));
1583     x101 = (uint8_t)(x99 >> 8);
1584     x102 = (uint8_t)(x99 & UINT8_C(0xff));
1585     x103 = (x101 + x46);
1586     x104 = (x103 >> 8);
1587     x105 = (uint8_t)(x103 & UINT8_C(0xff));
1588     x106 = (x104 >> 8);
1589     x107 = (uint8_t)(x104 & UINT8_C(0xff));
1590     x108 = (x106 >> 8);
1591     x109 = (uint8_t)(x106 & UINT8_C(0xff));
1592     x110 = (x108 >> 8);
1593     x111 = (uint8_t)(x108 & UINT8_C(0xff));
1594     x112 = (x110 >> 8);
1595     x113 = (uint8_t)(x110 & UINT8_C(0xff));
1596     x114 = (uint8_t)(x112 >> 8);
1597     x115 = (uint8_t)(x112 & UINT8_C(0xff));
1598     x116 = (uint8_t)(x114 & UINT8_C(0xff));
1599     x117 = (x32 >> 8);
1600     x118 = (uint8_t)(x32 & UINT8_C(0xff));
1601     x119 = (x117 >> 8);
1602     x120 = (uint8_t)(x117 & UINT8_C(0xff));
1603     x121 = (x119 >> 8);
1604     x122 = (uint8_t)(x119 & UINT8_C(0xff));
1605     x123 = (x121 >> 8);
1606     x124 = (uint8_t)(x121 & UINT8_C(0xff));
1607     x125 = (x123 >> 8);
1608     x126 = (uint8_t)(x123 & UINT8_C(0xff));
1609     x127 = (uint8_t)(x125 >> 8);
1610     x128 = (uint8_t)(x125 & UINT8_C(0xff));
1611     x129 = (x127 + x45);
1612     x130 = (x129 >> 8);
1613     x131 = (uint8_t)(x129 & UINT8_C(0xff));
1614     x132 = (x130 >> 8);
1615     x133 = (uint8_t)(x130 & UINT8_C(0xff));
1616     x134 = (x132 >> 8);
1617     x135 = (uint8_t)(x132 & UINT8_C(0xff));
1618     x136 = (x134 >> 8);
1619     x137 = (uint8_t)(x134 & UINT8_C(0xff));
1620     x138 = (x136 >> 8);
1621     x139 = (uint8_t)(x136 & UINT8_C(0xff));
1622     x140 = (uint8_t)(x138 >> 8);
1623     x141 = (uint8_t)(x138 & UINT8_C(0xff));
1624     x142 = (x140 + x44);
1625     x143 = (x142 >> 8);
1626     x144 = (uint8_t)(x142 & UINT8_C(0xff));
1627     x145 = (x143 >> 8);
1628     x146 = (uint8_t)(x143 & UINT8_C(0xff));
1629     x147 = (x145 >> 8);
1630     x148 = (uint8_t)(x145 & UINT8_C(0xff));
1631     x149 = (x147 >> 8);
1632     x150 = (uint8_t)(x147 & UINT8_C(0xff));
1633     x151 = (x149 >> 8);
1634     x152 = (uint8_t)(x149 & UINT8_C(0xff));
1635     x153 = (x151 >> 8);
1636     x154 = (uint8_t)(x151 & UINT8_C(0xff));
1637     x155 = (uint8_t)(x153 >> 8);
1638     x156 = (uint8_t)(x153 & UINT8_C(0xff));
1639     x157 = (x155 + x43);
1640     x158 = (x157 >> 8);
1641     x159 = (uint8_t)(x157 & UINT8_C(0xff));
1642     x160 = (x158 >> 8);
1643     x161 = (uint8_t)(x158 & UINT8_C(0xff));
1644     x162 = (x160 >> 8);
1645     x163 = (uint8_t)(x160 & UINT8_C(0xff));
1646     x164 = (x162 >> 8);
1647     x165 = (uint8_t)(x162 & UINT8_C(0xff));
1648     x166 = (x164 >> 8);
1649     x167 = (uint8_t)(x164 & UINT8_C(0xff));
1650     x168 = (uint8_t)(x166 >> 8);
1651     x169 = (uint8_t)(x166 & UINT8_C(0xff));
1652     x170 = (x168 + x42);
1653     x171 = (x170 >> 8);
1654     x172 = (uint8_t)(x170 & UINT8_C(0xff));
1655     x173 = (x171 >> 8);
1656     x174 = (uint8_t)(x171 & UINT8_C(0xff));
1657     x175 = (x173 >> 8);
1658     x176 = (uint8_t)(x173 & UINT8_C(0xff));
1659     x177 = (x175 >> 8);
1660     x178 = (uint8_t)(x175 & UINT8_C(0xff));
1661     x179 = (x177 >> 8);
1662     x180 = (uint8_t)(x177 & UINT8_C(0xff));
1663     x181 = (uint8_t)(x179 >> 8);
1664     x182 = (uint8_t)(x179 & UINT8_C(0xff));
1665     out1[0] = x51;
1666     out1[1] = x53;
1667     out1[2] = x55;
1668     out1[3] = x57;
1669     out1[4] = x59;
1670     out1[5] = x61;
1671     out1[6] = x64;
1672     out1[7] = x66;
1673     out1[8] = x68;
1674     out1[9] = x70;
1675     out1[10] = x72;
1676     out1[11] = x74;
1677     out1[12] = x77;
1678     out1[13] = x79;
1679     out1[14] = x81;
1680     out1[15] = x83;
1681     out1[16] = x85;
1682     out1[17] = x87;
1683     out1[18] = x89;
1684     out1[19] = x92;
1685     out1[20] = x94;
1686     out1[21] = x96;
1687     out1[22] = x98;
1688     out1[23] = x100;
1689     out1[24] = x102;
1690     out1[25] = x105;
1691     out1[26] = x107;
1692     out1[27] = x109;
1693     out1[28] = x111;
1694     out1[29] = x113;
1695     out1[30] = x115;
1696     out1[31] = x116;
1697     out1[32] = x118;
1698     out1[33] = x120;
1699     out1[34] = x122;
1700     out1[35] = x124;
1701     out1[36] = x126;
1702     out1[37] = x128;
1703     out1[38] = x131;
1704     out1[39] = x133;
1705     out1[40] = x135;
1706     out1[41] = x137;
1707     out1[42] = x139;
1708     out1[43] = x141;
1709     out1[44] = x144;
1710     out1[45] = x146;
1711     out1[46] = x148;
1712     out1[47] = x150;
1713     out1[48] = x152;
1714     out1[49] = x154;
1715     out1[50] = x156;
1716     out1[51] = x159;
1717     out1[52] = x161;
1718     out1[53] = x163;
1719     out1[54] = x165;
1720     out1[55] = x167;
1721     out1[56] = x169;
1722     out1[57] = x172;
1723     out1[58] = x174;
1724     out1[59] = x176;
1725     out1[60] = x178;
1726     out1[61] = x180;
1727     out1[62] = x182;
1728     out1[63] = x181;
1729 }
1730
1731 /*
1732  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes deserializes a field element from bytes in little-endian order.
1733  * Postconditions:
1734  *   eval out1 mod m = bytes_eval arg1 mod m
1735  *
1736  * Input Bounds:
1737  *   arg1: [[0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff]]
1738  * Output Bounds:
1739  *   out1: [[0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x11999999999999], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc], [0x0 ~> 0x8cccccccccccc]]
1740  */
1741 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(
1742     uint64_t out1[10], const uint8_t arg1[64]) {
1743     uint64_t x1;
1744     uint64_t x2;
1745     uint64_t x3;
1746     uint64_t x4;
1747     uint64_t x5;
1748     uint64_t x6;
1749     uint64_t x7;
1750     uint64_t x8;
1751     uint64_t x9;
1752     uint64_t x10;
1753     uint64_t x11;
1754     uint64_t x12;
1755     uint64_t x13;
1756     uint64_t x14;
1757     uint64_t x15;
1758     uint64_t x16;
1759     uint64_t x17;
1760     uint64_t x18;
1761     uint64_t x19;
1762     uint64_t x20;
1763     uint64_t x21;
1764     uint64_t x22;
1765     uint64_t x23;
1766     uint64_t x24;
1767     uint64_t x25;
1768     uint64_t x26;
1769     uint64_t x27;
1770     uint64_t x28;
1771     uint64_t x29;
1772     uint64_t x30;
1773     uint64_t x31;
1774     uint8_t x32;
1775     uint64_t x33;
1776     uint64_t x34;
1777     uint64_t x35;
1778     uint64_t x36;
1779     uint64_t x37;
1780     uint64_t x38;
1781     uint64_t x39;
1782     uint64_t x40;
1783     uint64_t x41;
1784     uint64_t x42;
1785     uint64_t x43;
1786     uint64_t x44;
1787     uint64_t x45;
1788     uint64_t x46;
1789     uint64_t x47;
1790     uint64_t x48;
1791     uint64_t x49;
1792     uint64_t x50;
1793     uint64_t x51;
1794     uint64_t x52;
1795     uint64_t x53;
1796     uint64_t x54;
1797     uint64_t x55;
1798     uint64_t x56;
1799     uint64_t x57;
1800     uint64_t x58;
1801     uint64_t x59;
1802     uint64_t x60;
1803     uint64_t x61;
1804     uint64_t x62;
1805     uint64_t x63;
1806     uint8_t x64;
1807     uint64_t x65;
1808     uint8_t x66;
1809     uint64_t x67;
1810     uint64_t x68;
1811     uint64_t x69;
1812     uint64_t x70;
1813     uint64_t x71;
1814     uint64_t x72;
1815     uint64_t x73;
1816     uint64_t x74;
1817     uint64_t x75;
1818     uint64_t x76;
1819     uint64_t x77;
1820     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x78;
1821     uint64_t x79;
1822     uint64_t x80;
1823     uint8_t x81;
1824     uint64_t x82;
1825     uint64_t x83;
1826     uint8_t x84;
1827     uint64_t x85;
1828     uint64_t x86;
1829     uint64_t x87;
1830     uint8_t x88;
1831     uint64_t x89;
1832     uint64_t x90;
1833     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x91;
1834     uint64_t x92;
1835     uint64_t x93;
1836     uint8_t x94;
1837     uint64_t x95;
1838     uint64_t x96;
1839     uint8_t x97;
1840     uint64_t x98;
1841     uint64_t x99;
1842     x1 = ((uint64_t)(arg1[63]) << 43);
1843     x2 = ((uint64_t)(arg1[62]) << 35);
1844     x3 = ((uint64_t)(arg1[61]) << 27);
1845     x4 = ((uint64_t)(arg1[60]) << 19);
1846     x5 = ((uint64_t)(arg1[59]) << 11);
1847     x6 = ((uint64_t)(arg1[58]) << 3);
1848     x7 = ((uint64_t)(arg1[57]) << 46);
1849     x8 = ((uint64_t)(arg1[56]) << 38);
1850     x9 = ((uint64_t)(arg1[55]) << 30);
1851     x10 = ((uint64_t)(arg1[54]) << 22);
1852     x11 = ((uint64_t)(arg1[53]) << 14);
1853     x12 = ((uint64_t)(arg1[52]) << 6);
1854     x13 = ((uint64_t)(arg1[51]) << 49);
1855     x14 = ((uint64_t)(arg1[50]) << 41);
1856     x15 = ((uint64_t)(arg1[49]) << 33);
1857     x16 = ((uint64_t)(arg1[48]) << 25);
1858     x17 = ((uint64_t)(arg1[47]) << 17);
1859     x18 = ((uint64_t)(arg1[46]) << 9);
1860     x19 = ((uint64_t)(arg1[45]) * 0x2);
1861     x20 = ((uint64_t)(arg1[44]) << 44);
1862     x21 = ((uint64_t)(arg1[43]) << 36);
1863     x22 = ((uint64_t)(arg1[42]) << 28);
1864     x23 = ((uint64_t)(arg1[41]) << 20);
1865     x24 = ((uint64_t)(arg1[40]) << 12);
1866     x25 = ((uint64_t)(arg1[39]) << 4);
1867     x26 = ((uint64_t)(arg1[38]) << 48);
1868     x27 = ((uint64_t)(arg1[37]) << 40);
1869     x28 = ((uint64_t)(arg1[36]) << 32);
1870     x29 = ((uint64_t)(arg1[35]) << 24);
1871     x30 = ((uint64_t)(arg1[34]) << 16);
1872     x31 = ((uint64_t)(arg1[33]) << 8);
1873     x32 = (arg1[32]);
1874     x33 = ((uint64_t)(arg1[31]) << 43);
1875     x34 = ((uint64_t)(arg1[30]) << 35);
1876     x35 = ((uint64_t)(arg1[29]) << 27);
1877     x36 = ((uint64_t)(arg1[28]) << 19);
1878     x37 = ((uint64_t)(arg1[27]) << 11);
1879     x38 = ((uint64_t)(arg1[26]) << 3);
1880     x39 = ((uint64_t)(arg1[25]) << 46);
1881     x40 = ((uint64_t)(arg1[24]) << 38);
1882     x41 = ((uint64_t)(arg1[23]) << 30);
1883     x42 = ((uint64_t)(arg1[22]) << 22);
1884     x43 = ((uint64_t)(arg1[21]) << 14);
1885     x44 = ((uint64_t)(arg1[20]) << 6);
1886     x45 = ((uint64_t)(arg1[19]) << 49);
1887     x46 = ((uint64_t)(arg1[18]) << 41);
1888     x47 = ((uint64_t)(arg1[17]) << 33);
1889     x48 = ((uint64_t)(arg1[16]) << 25);
1890     x49 = ((uint64_t)(arg1[15]) << 17);
1891     x50 = ((uint64_t)(arg1[14]) << 9);
1892     x51 = ((uint64_t)(arg1[13]) * 0x2);
1893     x52 = ((uint64_t)(arg1[12]) << 44);
1894     x53 = ((uint64_t)(arg1[11]) << 36);
1895     x54 = ((uint64_t)(arg1[10]) << 28);
1896     x55 = ((uint64_t)(arg1[9]) << 20);
1897     x56 = ((uint64_t)(arg1[8]) << 12);
1898     x57 = ((uint64_t)(arg1[7]) << 4);
1899     x58 = ((uint64_t)(arg1[6]) << 48);
1900     x59 = ((uint64_t)(arg1[5]) << 40);
1901     x60 = ((uint64_t)(arg1[4]) << 32);
1902     x61 = ((uint64_t)(arg1[3]) << 24);
1903     x62 = ((uint64_t)(arg1[2]) << 16);
1904     x63 = ((uint64_t)(arg1[1]) << 8);
1905     x64 = (arg1[0]);
1906     x65 = (x64 + (x63 + (x62 + (x61 + (x60 + (x59 + x58))))));
1907     x66 = (uint8_t)(x65 >> 52);
1908     x67 = (x65 & UINT64_C(0xfffffffffffff));
1909     x68 = (x6 + (x5 + (x4 + (x3 + (x2 + x1)))));
1910     x69 = (x12 + (x11 + (x10 + (x9 + (x8 + x7)))));
1911     x70 = (x19 + (x18 + (x17 + (x16 + (x15 + (x14 + x13))))));
1912     x71 = (x25 + (x24 + (x23 + (x22 + (x21 + x20)))));
1913     x72 = (x32 + (x31 + (x30 + (x29 + (x28 + (x27 + x26))))));
1914     x73 = (x38 + (x37 + (x36 + (x35 + (x34 + x33)))));
1915     x74 = (x44 + (x43 + (x42 + (x41 + (x40 + x39)))));
1916     x75 = (x51 + (x50 + (x49 + (x48 + (x47 + (x46 + x45))))));
1917     x76 = (x57 + (x56 + (x55 + (x54 + (x53 + x52)))));
1918     x77 = (x66 + x76);
1919     x78 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x77 >> 51);
1920     x79 = (x77 & UINT64_C(0x7ffffffffffff));
1921     x80 = (x78 + x75);
1922     x81 = (uint8_t)(x80 >> 51);
1923     x82 = (x80 & UINT64_C(0x7ffffffffffff));
1924     x83 = (x81 + x74);
1925     x84 = (uint8_t)(x83 >> 51);
1926     x85 = (x83 & UINT64_C(0x7ffffffffffff));
1927     x86 = (x84 + x73);
1928     x87 = (x86 & UINT64_C(0x7ffffffffffff));
1929     x88 = (uint8_t)(x72 >> 52);
1930     x89 = (x72 & UINT64_C(0xfffffffffffff));
1931     x90 = (x88 + x71);
1932     x91 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x90 >> 51);
1933     x92 = (x90 & UINT64_C(0x7ffffffffffff));
1934     x93 = (x91 + x70);
1935     x94 = (uint8_t)(x93 >> 51);
1936     x95 = (x93 & UINT64_C(0x7ffffffffffff));
1937     x96 = (x94 + x69);
1938     x97 = (uint8_t)(x96 >> 51);
1939     x98 = (x96 & UINT64_C(0x7ffffffffffff));
1940     x99 = (x97 + x68);
1941     out1[0] = x67;
1942     out1[1] = x79;
1943     out1[2] = x82;
1944     out1[3] = x85;
1945     out1[4] = x87;
1946     out1[5] = x89;
1947     out1[6] = x92;
1948     out1[7] = x95;
1949     out1[8] = x98;
1950     out1[9] = x99;
1951 }
1952
1953 /* END verbatim fiat code */
1954
1955 /*-
1956  * Finite field inversion via FLT.
1957  * NB: this is not a real Fiat function, just named that way for consistency.
1958  * Autogenerated: ecp/id_tc26_gost_3410_2012_512_paramSetA/fe_inv.op3
1959  * custom repunit addition chain
1960  */
1961 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(fe_t output,
1962                                                           const fe_t t1) {
1963     int i;
1964     /* temporary variables */
1965     fe_t acc, t102, t12, t198, t2, t200, t24, t3, t400, t48, t502, t6, t96;
1966
1967     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t1);
1968     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, acc, t1);
1969     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t2);
1970     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, acc, t1);
1971     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t3);
1972     for (i = 0; i < 2; i++)
1973         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1974     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t6, acc, t3);
1975     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t6);
1976     for (i = 0; i < 5; i++)
1977         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1978     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t12, acc, t6);
1979     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t12);
1980     for (i = 0; i < 11; i++)
1981         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1982     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t24, acc, t12);
1983     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t24);
1984     for (i = 0; i < 23; i++)
1985         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1986     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t48, acc, t24);
1987     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t48);
1988     for (i = 0; i < 47; i++)
1989         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1990     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t96, acc, t48);
1991     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t96);
1992     for (i = 0; i < 5; i++)
1993         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1994     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t102, acc, t6);
1995     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t102);
1996     for (i = 0; i < 95; i++)
1997         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
1998     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t198, acc, t96);
1999     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t198);
2000     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
2001     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t200, acc, t2);
2002     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t200);
2003     for (i = 0; i < 199; i++)
2004         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
2005     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t400, acc, t200);
2006     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t400);
2007     for (i = 0; i < 101; i++)
2008         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
2009     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t502, acc, t102);
2010     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t502);
2011     for (i = 0; i < 3; i++)
2012         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
2013     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(acc, acc, t3);
2014     for (i = 0; i < 4; i++)
2015         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
2016     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(acc, acc, t1);
2017     for (i = 0; i < 2; i++)
2018         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
2019     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(output, acc, t1);
2020 }
2021
2022 /* curve coefficient constants */
2023
2024 static const limb_t const_one[10] = {
2025     UINT64_C(0x0000000000000001), UINT64_C(0x0000000000000000),
2026     UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000),
2027     UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000),
2028     UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000),
2029     UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000)};
2030
2031 static const limb_t const_b[10] = {
2032     UINT64_C(0x000190785A71C760), UINT64_C(0x00054EBEE4761503),
2033     UINT64_C(0x0001B521BB0C5DF3), UINT64_C(0x0001D8532D15D004),
2034     UINT64_C(0x000771E584879869), UINT64_C(0x000D081CFD0B6265),
2035     UINT64_C(0x00074761CB0E879B), UINT64_C(0x0004CFE3B469704A),
2036     UINT64_C(0x0001B7706F42CAD9), UINT64_C(0x0007461282EF6FE4)};
2037
2038 /* LUT for scalar multiplication by comb interleaving */
2039 static const pt_aff_t lut_cmb[12][16] = {
2040     {
2041         {{UINT64_C(0x0000000000000003), UINT64_C(0x0000000000000000),
2042           UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000),
2043           UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000),
2044           UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000),
2045           UINT64_C(0x0000000000000000), UINT64_C(0x0000000000000000)},
2046          {UINT64_C(0x000589CB5215F2A4), UINT64_C(0x0005FC235F5B889A),
2047           UINT64_C(0x00047483D30051FC), UINT64_C(0x0005BA4F5D79A943),
2048           UINT64_C(0x0006F8B135F27E81), UINT64_C(0x000064FDCBEFA921),
2049           UINT64_C(0x00013ACF1ABC1778), UINT64_C(0x0004A8A1CD9CBC39),
2050           UINT64_C(0x0002B8E986E205B8), UINT64_C(0x0003A81E7F43D41B)}},
2051         {{UINT64_C(0x000134687CCB87C3), UINT64_C(0x0003A10544E8416E),
2052           UINT64_C(0x00061120F5D8AB9F), UINT64_C(0x0004D75D92CBD5EC),
2053           UINT64_C(0x00021E94205A696E), UINT64_C(0x000291D5F488FBA5),
2054           UINT64_C(0x0004C096168A1174), UINT64_C(0x00034ACFF09B62AD),
2055           UINT64_C(0x00019FAD4E4D776D), UINT64_C(0x00050FF8D5938951)},
2056          {UINT64_C(0x000CD7EC518D90D6), UINT64_C(0x000711A4FB6C7125),
2057           UINT64_C(0x000298DBA98C6CDE), UINT64_C(0x00005BBAB3EB0BFA),
2058           UINT64_C(0x00008E9D7BF33E26), UINT64_C(0x00019E3F333F7EB3),
2059           UINT64_C(0x00048D7F84FBFA38), UINT64_C(0x00076B7309883C74),
2060           UINT64_C(0x0000DFCC0DD3C626), UINT64_C(0x0001E5AE220BF623)}},
2061         {{UINT64_C(0x000AEA0CE47F1E5F), UINT64_C(0x0006DA872DC7D9E3),
2062           UINT64_C(0x0004026E133CB612), UINT64_C(0x0001D4C81CBDD5C9),
2063           UINT64_C(0x000116A46100FB10), UINT64_C(0x000C71645B8C9FFB),
2064           UINT64_C(0x0006AFE06F1C1484), UINT64_C(0x0000B6FF2FF4E6C1),
2065           UINT64_C(0x0000A642376D824E), UINT64_C(0x0002B4540E895C56)},
2066          {UINT64_C(0x000BB3B92706CBC6), UINT64_C(0x0005700DE178E056),
2067           UINT64_C(0x000197807544BFFA), UINT64_C(0x000706F69DD298A6),
2068           UINT64_C(0x000205A8622A4E8B), UINT64_C(0x000109A43ED36596),
2069           UINT64_C(0x00049AB5B2BD5C17), UINT64_C(0x000515CF2C048D7F),
2070           UINT64_C(0x000651FD0ECDF273), UINT64_C(0x0003C6B66DABD057)}},
2071         {{UINT64_C(0x000ABFC1B7D256E0), UINT64_C(0x00022DFADD1D6E68),
2072           UINT64_C(0x00033EEC39057D08), UINT64_C(0x00075EC5CD3B3AFE),
2073           UINT64_C(0x000073336BE8A8F9), UINT64_C(0x000528C313659874),
2074           UINT64_C(0x000045D76D6402E5), UINT64_C(0x0007B1F5060389E6),
2075           UINT64_C(0x0005D713A16A99F2), UINT64_C(0x0003C394B1ED6CB5)},
2076          {UINT64_C(0x000A8C1A38755E5A), UINT64_C(0x0005CA589C9447E1),
2077           UINT64_C(0x0002D738BA7D236E), UINT64_C(0x00005E7DB74C629B),
2078           UINT64_C(0x000062E362468963), UINT64_C(0x000EBFCB8EE6AF9E),
2079           UINT64_C(0x000193EA82E68F84), UINT64_C(0x00003CAA0E7EFC3A),
2080           UINT64_C(0x00054937BC67C142), UINT64_C(0x000432F67FAB85C5)}},
2081         {{UINT64_C(0x000C34CEE53642A2), UINT64_C(0x00048BA44E987AEF),
2082           UINT64_C(0x0007CFBA481AC93A), UINT64_C(0x000252C52E6724E2),
2083           UINT64_C(0x00069C1386DDE181), UINT64_C(0x0003FE183213C47A),
2084           UINT64_C(0x0006C13A8DC37861), UINT64_C(0x0004546EA0F50627),
2085           UINT64_C(0x0007B6C23C692349), UINT64_C(0x0004307D8079E6F2)},
2086          {UINT64_C(0x000812879D2E3C8E), UINT64_C(0x000191C73044FE47),
2087           UINT64_C(0x00077218289340D5), UINT64_C(0x0005DA711BBBFF71),
2088           UINT64_C(0x0001C57405B59E36), UINT64_C(0x000C7F1B91C21105),
2089           UINT64_C(0x000066E23EF3A609), UINT64_C(0x00012EB6D5C73D15),
2090           UINT64_C(0x00020C3294080ED7), UINT64_C(0x00033ABC6BDE0FD2)}},
2091         {{UINT64_C(0x00002EE1E7135C5B), UINT64_C(0x000147440718098F),
2092           UINT64_C(0x000742216A0AD24C), UINT64_C(0x000209FAE0414762),
2093           UINT64_C(0x0007523CACA53442), UINT64_C(0x0002240ADDECED0B),
2094           UINT64_C(0x00023970F6F47640), UINT64_C(0x000799A6033CA82E),
2095           UINT64_C(0x00013F8D7EBD8951), UINT64_C(0x0003167F9B05B77B)},
2096          {UINT64_C(0x00084059554ECF79), UINT64_C(0x0005753C6736FF73),
2097           UINT64_C(0x000619A371C7BA90), UINT64_C(0x00007A6287324180),
2098           UINT64_C(0x00037396508E43B1), UINT64_C(0x000B92328505DD45),
2099           UINT64_C(0x00055C92400C6EE2), UINT64_C(0x0002654406A9F655),
2100           UINT64_C(0x0003AF03185F59DF), UINT64_C(0x0000C9632A02E2DE)}},
2101         {{UINT64_C(0x00082288639F2EBD), UINT64_C(0x0004E3BE5A9F335C),
2102           UINT64_C(0x0000475B64CDF3D5), UINT64_C(0x00003AD875B443CE),
2103           UINT64_C(0x0005A22CF276D7D8), UINT64_C(0x00059A094CC2E917),
2104           UINT64_C(0x0002CAA724BAEBC5), UINT64_C(0x0001CB230407F535),
2105           UINT64_C(0x00043A679D215417), UINT64_C(0x00032069427B390F)},
2106          {UINT64_C(0x00005AAE7CCDEA72), UINT64_C(0x000227E312EBD77B),
2107           UINT64_C(0x0006C48359C093AD), UINT64_C(0x00066AE122001431),
2108           UINT64_C(0x0002A7685789D1A1), UINT64_C(0x000DDDC9B1721593),
2109           UINT64_C(0x0002EB3A73075BAE), UINT64_C(0x00010D483A062D6E),
2110           UINT64_C(0x000414E1A10675C2), UINT64_C(0x0003FC179BB802A2)}},
2111         {{UINT64_C(0x000FA7D670E14D45), UINT64_C(0x0005B60822C15C07),
2112           UINT64_C(0x0006E1C8DC8B953D), UINT64_C(0x0003AA1F0C09E3C3),
2113           UINT64_C(0x0004C494E672EDE4), UINT64_C(0x00061EB986E7C9B9),
2114           UINT64_C(0x0003EDBB8C82ECC2), UINT64_C(0x0007B7E098625DE1),
2115           UINT64_C(0x0001652C34790E48), UINT64_C(0x000181E9C44FB652)},
2116          {UINT64_C(0x00026B7BFCB41422), UINT64_C(0x0004420662645444),
2117           UINT64_C(0x0005427FA987FF52), UINT64_C(0x0005B9040DF26326),
2118           UINT64_C(0x000334DEEC131B7C), UINT64_C(0x0009976A9AEB37C6),
2119           UINT64_C(0x0005DE6BDA0EE26F), UINT64_C(0x00046CD4B8DA22BF),
2120           UINT64_C(0x0001A9277ED46EDA), UINT64_C(0x00048FE9C8EA98F0)}},
2121         {{UINT64_C(0x00069292A4F09AE6), UINT64_C(0x00059EEEC0228FDC),
2122           UINT64_C(0x0002E6A2EB99E1C1), UINT64_C(0x00028B36B1CB7EDC),
2123           UINT64_C(0x0007C4D51AEABB6E), UINT64_C(0x00040FA7C5F982AC),
2124           UINT64_C(0x0000A163AFAB5A89), UINT64_C(0x000436DC36654D6F),
2125           UINT64_C(0x0006E7E4EFBDBA76), UINT64_C(0x000469D46D1AEC82)},
2126          {UINT64_C(0x0003F3770683CF55), UINT64_C(0x0007581899AFCAA5),
2127           UINT64_C(0x00021BB9291EC382), UINT64_C(0x000725C1812F5867),
2128           UINT64_C(0x00010D68EF013EA6), UINT64_C(0x000D8AD6CCEEDD36),
2129           UINT64_C(0x0004145477456E2A), UINT64_C(0x000350F4CCCDD3ED),
2130           UINT64_C(0x0006D247F4FCCCBC), UINT64_C(0x0002C35AD24695CC)}},
2131         {{UINT64_C(0x0000563E3BB2C9A3), UINT64_C(0x0004731F28271C7E),
2132           UINT64_C(0x00006474AEE84E9A), UINT64_C(0x00079618BA66931E),
2133           UINT64_C(0x0005DEEC306DF549), UINT64_C(0x000A49F4075B243E),
2134           UINT64_C(0x00072F449585855D), UINT64_C(0x000031C0CC652EF1),
2135           UINT64_C(0x00003DDAA420F12A), UINT64_C(0x00027047A35D3C45)},
2136          {UINT64_C(0x0008D45AEA9F97DE), UINT64_C(0x00031B40D05861EA),
2137           UINT64_C(0x00022DF5AC218686), UINT64_C(0x000237062CC05B46),
2138           UINT64_C(0x000511B267DD6BA7), UINT64_C(0x000818297550A398),
2139           UINT64_C(0x000702FE7A56CB70), UINT64_C(0x00053C7D673599DE),
2140           UINT64_C(0x0003ED45D15B6C15), UINT64_C(0x0001806F568245B9)}},
2141         {{UINT64_C(0x0009351072DB2170), UINT64_C(0x00033196A2CEF459),
2142           UINT64_C(0x0006744E6383FCEF), UINT64_C(0x0005C51252A32D28),
2143           UINT64_C(0x00005FA2110CC455), UINT64_C(0x0004B8063421A324),
2144           UINT64_C(0x0007D30325E5137D), UINT64_C(0x0002AFA7F320E835),
2145           UINT64_C(0x00011A9719C3D5ED), UINT64_C(0x0006DFED78D57C93)},
2146          {UINT64_C(0x000CD2B1C06C89E0), UINT64_C(0x00005887BE69BEF0),
2147           UINT64_C(0x00023A5834EEE4F0), UINT64_C(0x00064984FA6CCD98),
2148           UINT64_C(0x00006FB77FDF3397), UINT64_C(0x0001EBEBCE68907A),
2149           UINT64_C(0x0006784C0935BED2), UINT64_C(0x00050FF3F3DFF454),
2150           UINT64_C(0x0004036C327922ED), UINT64_C(0x00008DE3F2C6A92E)}},
2151         {{UINT64_C(0x0006E03B0A49FC14), UINT64_C(0x0002D86C93A83EE0),
2152           UINT64_C(0x0004A7F892C15148), UINT64_C(0x0002FC12A44E72B1),
2153           UINT64_C(0x0000F1222DB270EC), UINT64_C(0x0005C305D53F498F),
2154           UINT64_C(0x0005C15989BD840C), UINT64_C(0x0005FD28651837A4),
2155           UINT64_C(0x0001F44FE46C7F06), UINT64_C(0x00025B96CDAFE605)},
2156          {UINT64_C(0x0009FDD223F15C01), UINT64_C(0x0007578682CC2965),
2157           UINT64_C(0x0006222B764EE30D), UINT64_C(0x0002695A8C2DDC09),
2158           UINT64_C(0x0003EED3043E0B4D), UINT64_C(0x000DF4BA29380423),
2159           UINT64_C(0x000799CE51DCFEE3), UINT64_C(0x0001DC423C4607A6),
2160           UINT64_C(0x000353F2E08F2F67), UINT64_C(0x0002DE3BCB26FB64)}},
2161         {{UINT64_C(0x000121C2DFF5C5F8), UINT64_C(0x0002C6372966E3BB),
2162           UINT64_C(0x00040EDCBB6FAE3D), UINT64_C(0x00045E8590C45B65),
2163           UINT64_C(0x00057F2556A1008A), UINT64_C(0x000D2C63669622C2),
2164           UINT64_C(0x00053762BBDA6A4D), UINT64_C(0x000638814A3C0C15),
2165           UINT64_C(0x0006306A8C676FEC), UINT64_C(0x00039FEA5B5F2932)},
2166          {UINT64_C(0x00045B18CC6F6BD4), UINT64_C(0x000572570661CF49),
2167           UINT64_C(0x0003DB3E7E6325C0), UINT64_C(0x0000D4366AC3C833),
2168           UINT64_C(0x0000BA40102D6C2B), UINT64_C(0x000D88CD5627BDAA),
2169           UINT64_C(0x0001A191F2BD95D8), UINT64_C(0x0007B490EB1F6E2E),
2170           UINT64_C(0x0001854754C42C14), UINT64_C(0x0004F9B402BCF150)}},
2171         {{UINT64_C(0x00062710FFD6E4C3), UINT64_C(0x00075F168936C9E7),
2172           UINT64_C(0x0005EBCC23DECE92), UINT64_C(0x0006A533FC0618A4),
2173           UINT64_C(0x00006276D8296DCC), UINT64_C(0x000C6FDBE7DDD556),
2174           UINT64_C(0x0005F77BF0F1421B), UINT64_C(0x00021327FBB8BE4C),
2175           UINT64_C(0x00039F51E09D0F1B), UINT64_C(0x00036B0DC0560BD1)},
2176          {UINT64_C(0x00090F866EA9C581), UINT64_C(0x0001BB6C84E218AF),
2177           UINT64_C(0x00016801E510D5D1), UINT64_C(0x00048969111EF218),
2178           UINT64_C(0x00032F01F97E8EAC), UINT64_C(0x000846529FDA255F),
2179           UINT64_C(0x00003E0DA43E7BC5), UINT64_C(0x0005377E9AD3A533),
2180           UINT64_C(0x00054F1C41B443CC), UINT64_C(0x0001E2C9C182A7B8)}},
2181         {{UINT64_C(0x0006822BBEC85A6F), UINT64_C(0x00037FF627207C7D),
2182           UINT64_C(0x000099E1EDB38619), UINT64_C(0x00024EABAAEF4727),
2183           UINT64_C(0x0001634583C11813), UINT64_C(0x0005BF27EB8FC0B2),
2184           UINT64_C(0x0002C5E6D68AED81), UINT64_C(0x00051011E59FEFC1),
2185           UINT64_C(0x0005BDE68E16008B), UINT64_C(0x00001CDB6AC4A926)},
2186          {UINT64_C(0x000F9C8354532F1F), UINT64_C(0x0003B7D13F24D465),
2187           UINT64_C(0x0001EE14FAFB642C), UINT64_C(0x0003086537C154F6),
2188           UINT64_C(0x000498FB21A3549B), UINT64_C(0x000D5F9768C501AF),
2189           UINT64_C(0x0007358BD9264583), UINT64_C(0x00020604DE0C73BC),
2190           UINT64_C(0x0004C1EFB4D90397), UINT64_C(0x000316FD7FD552FA)}},
2191         {{UINT64_C(0x000DF775325B2BEF), UINT64_C(0x0007C981BDB56B5B),
2192           UINT64_C(0x00030415FEF5D1EB), UINT64_C(0x00066427FB342115),
2193           UINT64_C(0x00039F275DCEB907), UINT64_C(0x000FC52CB944765D),
2194           UINT64_C(0x00063BA40ACC8623), UINT64_C(0x000217B5022687A4),
2195           UINT64_C(0x0003782EE74343F6), UINT64_C(0x0006E344AF9791BC)},
2196          {UINT64_C(0x0006A094A3D00C90), UINT64_C(0x0000A8C2AF5A4ED6),
2197           UINT64_C(0x0002593EB8606459), UINT64_C(0x0006BB706B63F1A3),
2198           UINT64_C(0x0001AC9ABD940E22), UINT64_C(0x000A8AFEAB077BE2),
2199           UINT64_C(0x000053C3E6DE9695), UINT64_C(0x00035197B6C50B68),
2200           UINT64_C(0x0005F05ED56144C6), UINT64_C(0x0005D16C6B2F7A7D)}},
2201     },
2202     {
2203         {{UINT64_C(0x0009697EFB5343B1), UINT64_C(0x00030F79CEE2F4D7),
2204           UINT64_C(0x0007C57239C2BFFF), UINT64_C(0x0005E177E6306573),
2205           UINT64_C(0x00058AECAB18B5E4), UINT64_C(0x000C2D8B42DA873F),
2206           UINT64_C(0x00067CEC60F40D7C), UINT64_C(0x0001CD069631374B),
2207           UINT64_C(0x00053BF89F276A0A), UINT64_C(0x000211BC2F82ABCC)},
2208          {UINT64_C(0x000F42F918BECCB0), UINT64_C(0x00050BCCFB9278C6),
2209           UINT64_C(0x000521F422BE023A), UINT64_C(0x000247E206708DFF),
2210           UINT64_C(0x000603F8EAFA08E8), UINT64_C(0x0001C8FA49E8E7A9),
2211           UINT64_C(0x0000ED2F247FA8F2), UINT64_C(0x00054F2BD90FC41F),
2212           UINT64_C(0x000613E3F3A0E141), UINT64_C(0x00058F502829C1A3)}},
2213         {{UINT64_C(0x000FA958A02414EA), UINT64_C(0x0005694D8B531753),
2214           UINT64_C(0x0002596B7F70E2D2), UINT64_C(0x0006F58C437031E9),
2215           UINT64_C(0x0005E52B9AB2FC87), UINT64_C(0x00047681FFAD52A2),
2216           UINT64_C(0x00054CFD109661E6), UINT64_C(0x0002642E41E026F7),
2217           UINT64_C(0x00015A4C0B3E2C49), UINT64_C(0x00012DBAB3D25C66)},
2218          {UINT64_C(0x000F66D444F2C6A3), UINT64_C(0x000465ABD7FBD63E),
2219           UINT64_C(0x000346682E14F62C), UINT64_C(0x0007D1BFDC2BDD7C),
2220           UINT64_C(0x00014B50150CDD7D), UINT64_C(0x000F1BAD6F065607),
2221           UINT64_C(0x0001B669F08E4917), UINT64_C(0x0007147465D09FD0),
2222           UINT64_C(0x0002E2E3DF8C1CE5), UINT64_C(0x0003E168C6A9219B)}},
2223         {{UINT64_C(0x00026E66F048E71C), UINT64_C(0x00021DA6DDB4379F),
2224           UINT64_C(0x0006A446FCD70668), UINT64_C(0x0000ED5A782862E2),
2225           UINT64_C(0x000600DB452AEA1A), UINT64_C(0x00070E2B0EE96B31),
2226           UINT64_C(0x000272BCDA0E468B), UINT64_C(0x0006754F74551E8E),
2227           UINT64_C(0x00030B2901255489), UINT64_C(0x00018BA394D8F24B)},
2228          {UINT64_C(0x000EF5DAB92AD60C), UINT64_C(0x0007A4E353682E4C),
2229           UINT64_C(0x0004D92B14F64543), UINT64_C(0x0006FB1C445C4562),
2230           UINT64_C(0x00005F0C73553832), UINT64_C(0x000F219585C811FA),
2231           UINT64_C(0x00002373528CE90C), UINT64_C(0x0005AEFE0F86FFD6),
2232           UINT64_C(0x000065686EF3DFA1), UINT64_C(0x0004BCFCBABBE76F)}},
2233         {{UINT64_C(0x000A04E942DB5726), UINT64_C(0x0004E0A8E957D2EB),
2234           UINT64_C(0x000042171E8C74B0), UINT64_C(0x0002CD5D9C992A32),
2235           UINT64_C(0x00021775A666DF3B), UINT64_C(0x0009B1719FCE5AFD),
2236           UINT64_C(0x00070479A5510650), UINT64_C(0x00076CA597F5197E),
2237           UINT64_C(0x0002FF8004DC7298), UINT64_C(0x000427FBA3F2118F)},
2238          {UINT64_C(0x000B2B7F0F1BC525), UINT64_C(0x0004F49FDAF0E9F8),
2239           UINT64_C(0x000119E1F8B31D5C), UINT64_C(0x00002C2E70F7717A),
2240           UINT64_C(0x000547EB13E64F24), UINT64_C(0x00061C10285CB68B),
2241           UINT64_C(0x00027F33F80AC82B), UINT64_C(0x00007A73F720ACD1),
2242           UINT64_C(0x0000FA4783E28EA8), UINT64_C(0x0005E1B01569FE4A)}},
2243         {{UINT64_C(0x000C8833182EEC18), UINT64_C(0x0005188EE3CCBD7D),
2244           UINT64_C(0x000145800FA7D3B9), UINT64_C(0x00015F410C821BF2),
2245           UINT64_C(0x0006D6985D22BB97), UINT64_C(0x000ACE8A202EEB11),
2246           UINT64_C(0x000000D3BC5FFCBC), UINT64_C(0x0005A94DE37C5B1E),
2247           UINT64_C(0x0006A3E90AE676A0), UINT64_C(0x0003DC3E9B9DEA03)},
2248          {UINT64_C(0x000ADDB18897A653), UINT64_C(0x00028BB1348E369A),
2249           UINT64_C(0x0000E0EF15D097A0), UINT64_C(0x000369538A36A67C),
2250           UINT64_C(0x0004F11787ECB811), UINT64_C(0x000DAB579DC3F6E7),
2251           UINT64_C(0x00051EEDC98205E1), UINT64_C(0x000296B14C5B057C),
2252           UINT64_C(0x0006A6B518D5A499), UINT64_C(0x0004B973FBCAD781)}},
2253         {{UINT64_C(0x00092403168F568C), UINT64_C(0x00050C76745944DA),
2254           UINT64_C(0x00045586DDAA3849), UINT64_C(0x0002424F7A393AE3),
2255           UINT64_C(0x0003613FCF452DAE), UINT64_C(0x000483477F08760D),
2256           UINT64_C(0x0006DE9C9C30A9F7), UINT64_C(0x0006DE3DC9E26B78),
2257           UINT64_C(0x00072E8A269F2328), UINT64_C(0x0001A0904E3E62B3)},
2258          {UINT64_C(0x000F53CF7A63B520), UINT64_C(0x00016E19E79779D7),
2259           UINT64_C(0x0003BA73148BC41B), UINT64_C(0x0000A0B9CB876955),
2260           UINT64_C(0x0002C3678483C9E4), UINT64_C(0x0001717604F49F0C),
2261           UINT64_C(0x0006DA52AE47D9A6), UINT64_C(0x00018A068DEAD248),
2262           UINT64_C(0x0000A45F44D54D0B), UINT64_C(0x000201738C7D6750)}},
2263         {{UINT64_C(0x000BFD50B6C0ED05), UINT64_C(0x0003B59B6181691D),
2264           UINT64_C(0x00036E5595022312), UINT64_C(0x0006371166F016C4),
2265           UINT64_C(0x0000D2463D93685C), UINT64_C(0x0000FB99CEC22230),
2266           UINT64_C(0x000662B7CA84328B), UINT64_C(0x0005B058F277AA90),
2267           UINT64_C(0x000744C6285E6BE8), UINT64_C(0x00044924B43A399C)},
2268          {UINT64_C(0x0009FE2EF5756858), UINT64_C(0x0002609FAC19675C),
2269           UINT64_C(0x0001EDB73C43A527), UINT64_C(0x00018040218709B5),
2270           UINT64_C(0x00038E60561A169C), UINT64_C(0x000716A3DE9C2728),
2271           UINT64_C(0x0001312CD53738AB), UINT64_C(0x00003A5EADF12479),
2272           UINT64_C(0x0004F1C4C30A626A), UINT64_C(0x00017077F028932B)}},
2273         {{UINT64_C(0x0005E4B52DDE7879), UINT64_C(0x0000DD824234AF86),
2274           UINT64_C(0x0007E33F8D4E4720), UINT64_C(0x0007DE0000448CDA),
2275           UINT64_C(0x00033984E740002A), UINT64_C(0x000C47E6A3586EA2),
2276           UINT64_C(0x00044D0958EBE073), UINT64_C(0x00001246801B8077),
2277           UINT64_C(0x0002F9FC5AA5757F), UINT64_C(0x0001A2DCE0976101)},
2278          {UINT64_C(0x000660A83163C88F), UINT64_C(0x000537D8B7F6309C),
2279           UINT64_C(0x00008DD86923D2DE), UINT64_C(0x0001EDCB48974621),
2280           UINT64_C(0x00006C01F610F051), UINT64_C(0x0008C9E7599C4A9D),
2281           UINT64_C(0x00036EA13E261953), UINT64_C(0x0003ED8BC32C0F96),
2282           UINT64_C(0x000755A3B7B81967), UINT64_C(0x00013DE89A6B4D9D)}},
2283         {{UINT64_C(0x000CA6E0EB363C7F), UINT64_C(0x0005F55CE82062CB),
2284           UINT64_C(0x00054C8A253358D0), UINT64_C(0x0002C5D656290FF8),
2285           UINT64_C(0x00057F5B9325F1DA), UINT64_C(0x0001FEF7C4623421),
2286           UINT64_C(0x000751B35DC509CC), UINT64_C(0x0000D577E46356BC),
2287           UINT64_C(0x0001AE1750B963E0), UINT64_C(0x000101926AD538C7)},
2288          {UINT64_C(0x000ADB8B609BBDFF), UINT64_C(0x00071752C179ED60),
2289           UINT64_C(0x0001F4F46D3CDA68), UINT64_C(0x0006AB70B8479B34),
2290           UINT64_C(0x00025F7ED7DEE309), UINT64_C(0x000DDC2D9609A612),
2291           UINT64_C(0x0004E68BAF1E467F), UINT64_C(0x00040F9B19D3CBE2),
2292           UINT64_C(0x00037E8C1EC0C6A4), UINT64_C(0x0003125691C2193B)}},
2293         {{UINT64_C(0x00067DA2BD46C9EA), UINT64_C(0x00026B6CAB294387),
2294           UINT64_C(0x0001D6166D7C9065), UINT64_C(0x00062BF47248BD53),
2295           UINT64_C(0x0002E90A5DD8639A), UINT64_C(0x0003936168470E19),
2296           UINT64_C(0x000528F76D8AF696), UINT64_C(0x0006ED2117C0F595),
2297           UINT64_C(0x00053A94B0075896), UINT64_C(0x00029EA83F539A1E)},
2298          {UINT64_C(0x0002028A9BD76B91), UINT64_C(0x0004FD251AA0E6F2),
2299           UINT64_C(0x0005AC8CC0D23EFF), UINT64_C(0x000128939573B39C),
2300           UINT64_C(0x000672B16EA38AE5), UINT64_C(0x0004D9266E6063F1),
2301           UINT64_C(0x000059E6A8535CE8), UINT64_C(0x0000599ECB0EF8DD),
2302           UINT64_C(0x0007013D35E8201F), UINT64_C(0x0002C65B4B7CFED7)}},
2303         {{UINT64_C(0x0008F58A1E3612AD), UINT64_C(0x0003A9FB96EDB71F),
2304           UINT64_C(0x0001F18D41C781FC), UINT64_C(0x00018367EBB23895),
2305           UINT64_C(0x0005D1FCD3BE526A), UINT64_C(0x000A42281101E568),
2306           UINT64_C(0x0005BABB0531BAFA), UINT64_C(0x0000A5F2A706F2D0),
2307           UINT64_C(0x00004127B930A594), UINT64_C(0x0000EB497CC34685)},
2308          {UINT64_C(0x00073B79A1945681), UINT64_C(0x000752EA80F8AC71),
2309           UINT64_C(0x0006302573AC640B), UINT64_C(0x00078867625480E5),
2310           UINT64_C(0x0007079395B2C6EF), UINT64_C(0x000C10FF5DD268D7),
2311           UINT64_C(0x00057909D9F5E805), UINT64_C(0x0003A161EE637F23),
2312           UINT64_C(0x00076AA86D84AD92), UINT64_C(0x0001EF085DE6C3AC)}},
2313         {{UINT64_C(0x000C311C4599BCA4), UINT64_C(0x00071D198CA022EA),
2314           UINT64_C(0x0007BCCA6C1EA7A9), UINT64_C(0x0005A91F6CE54B62),
2315           UINT64_C(0x00040F2F68ADFDE8), UINT64_C(0x0006DA7F20DC869C),
2316           UINT64_C(0x00059DD3EE431C99), UINT64_C(0x000714D6993F24A2),
2317           UINT64_C(0x0007C5152642D91F), UINT64_C(0x0002F4E11F2CC27F)},
2318          {UINT64_C(0x000A8ACA2FD26CFD), UINT64_C(0x0002EB39C4AC80BE),
2319           UINT64_C(0x0005BFAD35FC99F2), UINT64_C(0x0002BFAB444638F8),
2320           UINT64_C(0x000355F04D6D03C9), UINT64_C(0x000EB7D307BB548E),
2321           UINT64_C(0x00045256FDC37CFF), UINT64_C(0x000455EACB7CD74C),
2322           UINT64_C(0x0005F5BC0A0265A1), UINT64_C(0x0004E4B55474C1FB)}},
2323         {{UINT64_C(0x000405C3B4CBBA99), UINT64_C(0x0003A2CFD9BA8CE7),
2324           UINT64_C(0x0004D38F33BA729F), UINT64_C(0x00058368002B41A8),
2325           UINT64_C(0x0001EB778063FAFA), UINT64_C(0x00000CB2D95428C0),
2326           UINT64_C(0x0007A5F40E6F6248), UINT64_C(0x00066402E02185E2),
2327           UINT64_C(0x0002874AE640E9BA), UINT64_C(0x00025092EF1270C6)},
2328          {UINT64_C(0x0004F5A43B7EA260), UINT64_C(0x00024FC17540A356),
2329           UINT64_C(0x0001076B47F9F931), UINT64_C(0x0002FB78183398A6),
2330           UINT64_C(0x000229276794FECA), UINT64_C(0x0001B56FD26AC511),
2331           UINT64_C(0x00013652FDA2807D), UINT64_C(0x0000AD7AC8AF8820),
2332           UINT64_C(0x00059580D670358C), UINT64_C(0x0007B37AB910DB85)}},
2333         {{UINT64_C(0x000E7AAFAA81120D), UINT64_C(0x0001EFCC9131C28F),
2334           UINT64_C(0x0000F04662F79A92), UINT64_C(0x00018481A743283F),
2335           UINT64_C(0x0003227CCC1B0051), UINT64_C(0x000889F9DEBDBBB6),
2336           UINT64_C(0x00026E53C8DB36F4), UINT64_C(0x00040E757FC7CCB6),
2337           UINT64_C(0x000796C1E48AF493), UINT64_C(0x0005CD8E286C308F)},
2338          {UINT64_C(0x000FEEF26280024C), UINT64_C(0x00008656CE73F334),
2339           UINT64_C(0x000047F19B4CCB60), UINT64_C(0x0003E09FD007DE6A),
2340           UINT64_C(0x0006DFDC10446128), UINT64_C(0x0001C5059DDF7FB5),
2341           UINT64_C(0x0000C6D4835DEC52), UINT64_C(0x0001ECDEF9FA549E),
2342           UINT64_C(0x00004A50331A27BB), UINT64_C(0x0007445C7A2F53C4)}},
2343         {{UINT64_C(0x000919F3EC9CCC4F), UINT64_C(0x0005F2F6CF149577),
2344           UINT64_C(0x00060C560F67551A), UINT64_C(0x0007E358E045685B),
2345           UINT64_C(0x00070CCBF13484CF), UINT64_C(0x000C37725A783FCF),
2346           UINT64_C(0x00054AB9E7EE7B1E), UINT64_C(0x0003333BAB51E43A),
2347           UINT64_C(0x000017DC7BC018D7), UINT64_C(0x00003CA4BCFA7DD5)},
2348          {UINT64_C(0x0003E1A7A3069435), UINT64_C(0x000480EFF4E48BC7),
2349           UINT64_C(0x00062115BD5D5E69), UINT64_C(0x0007096DD6C931AD),
2350           UINT64_C(0x0002608249CB7A58), UINT64_C(0x0008A26364C8096A),
2351           UINT64_C(0x0003C1F2D4A059E3), UINT64_C(0x00010E330E128864),
2352           UINT64_C(0x0003B581FC1DE5C7), UINT64_C(0x000588DBEAEEB225)}},
2353         {{UINT64_C(0x0003AC2924B671D6), UINT64_C(0x00027D78B698A45A),
2354           UINT64_C(0x00015C6FF89B42E6), UINT64_C(0x000480FF26EC1381),
2355           UINT64_C(0x0000CC4426AAA245), UINT64_C(0x000FB55D009EF0BB),
2356           UINT64_C(0x000298CBBB4ADE83), UINT64_C(0x000718B823375BD8),
2357           UINT64_C(0x0007751B44E5F80F), UINT64_C(0x00059A1E5D2A4A5C)},
2358          {UINT64_C(0x000CB0EE2657342C), UINT64_C(0x00055C4B6D401505),
2359           UINT64_C(0x00056E99CE0E1574), UINT64_C(0x00002F6CB06EAD80),
2360           UINT64_C(0x000476059C9E6EB0), UINT64_C(0x000C60BC1D3204D4),
2361           UINT64_C(0x00050DC61142023B), UINT64_C(0x000726C34A8A210F),
2362           UINT64_C(0x0005C72290CE928B), UINT64_C(0x0004DFA0CEB1B72D)}},
2363     },
2364     {
2365         {{UINT64_C(0x000247F93F2BDD27), UINT64_C(0x0007C93034C92904),
2366           UINT64_C(0x00027DAD72E4B40B), UINT64_C(0x00014E25E82ABBD1),
2367           UINT64_C(0x00060E4F42A6C475), UINT64_C(0x000DC708D6D66CCB),
2368           UINT64_C(0x00036DB87A4B6343), UINT64_C(0x0003C58123691EAF),
2369           UINT64_C(0x0004DAD470664927), UINT64_C(0x0006A82E32F9C5E6)},
2370          {UINT64_C(0x0002A35EDD030037), UINT64_C(0x000219F0D4AE2250),
2371           UINT64_C(0x0003A7450131A667), UINT64_C(0x00061472E2C5CAD3),
2372           UINT64_C(0x0000BDF65BE7AF81), UINT64_C(0x0007F887A21C419E),
2373           UINT64_C(0x00048915425E3C2E), UINT64_C(0x00046299A3659CE9),
2374           UINT64_C(0x00044FD643C6825F), UINT64_C(0x00041408EE3F7EE7)}},
2375         {{UINT64_C(0x0001D71DC21EAB28), UINT64_C(0x00065A53D38F953D),
2376           UINT64_C(0x00032DEB59D8023C), UINT64_C(0x0004054571AECBAF),
2377           UINT64_C(0x0006227C20ADC1B1), UINT64_C(0x0004052B60ED5E09),
2378           UINT64_C(0x0007D536170CE49B), UINT64_C(0x000133F69C75D93C),
2379           UINT64_C(0x000631A47E596690), UINT64_C(0x0007BE94B2BCFA10)},
2380          {UINT64_C(0x000D3D75C6EDBD10), UINT64_C(0x0002F0C1700CF75C),
2381           UINT64_C(0x0000880BD06AC9F8), UINT64_C(0x0007F4DE75015506),
2382           UINT64_C(0x0004F7D9218E4531), UINT64_C(0x000525D094B57596),
2383           UINT64_C(0x000303BA4ADC93BE), UINT64_C(0x000781A6DDE92BB0),
2384           UINT64_C(0x0000145A33FB664A), UINT64_C(0x0003075364E801EA)}},
2385         {{UINT64_C(0x000B5C724B664A37), UINT64_C(0x0002503E28109C51),
2386           UINT64_C(0x00025B829904E428), UINT64_C(0x00069506DB016812),
2387           UINT64_C(0x0004A750C8A64E1B), UINT64_C(0x000B87DB220A7C57),
2388           UINT64_C(0x00031EFD957F4D41), UINT64_C(0x000049A333D86B06),
2389           UINT64_C(0x0001D8EAEB6440B9), UINT64_C(0x000276C32B4CE41C)},
2390          {UINT64_C(0x0008857C83EF71E8), UINT64_C(0x0005E721B3AB9D6B),
2391           UINT64_C(0x00017EACB90E5F00), UINT64_C(0x0005C3E831C481C5),
2392           UINT64_C(0x0007C0B8197E5462), UINT64_C(0x000DBDC919F92AA9),
2393           UINT64_C(0x0002200849E9CAEE), UINT64_C(0x0004BE6C719C5906),
2394           UINT64_C(0x0004E280855B1920), UINT64_C(0x0005C5B91DB6D1EA)}},
2395         {{UINT64_C(0x000424B6E394CF88), UINT64_C(0x0003C2C97C04AC74),
2396           UINT64_C(0x00063ADB5E77144A), UINT64_C(0x0005D883FF8E6B47),
2397           UINT64_C(0x0004F87D0A1CC558), UINT64_C(0x000BB8A228CF7739),
2398           UINT64_C(0x0004B3A03FA0D71F), UINT64_C(0x000753D34ABABB8E),
2399           UINT64_C(0x000562AB4C8CB943), UINT64_C(0x0001CEBF9BBC430C)},
2400          {UINT64_C(0x0007223CBD30A33E), UINT64_C(0x0007335C7215C6C3),
2401           UINT64_C(0x000603E2856D2862), UINT64_C(0x0002A848E65B42A0),
2402           UINT64_C(0x0004218F69174E09), UINT64_C(0x0005FFA3227A0A23),
2403           UINT64_C(0x00005B5868C2514B), UINT64_C(0x0004938AFADAD730),
2404           UINT64_C(0x0007660F9A69E6DE), UINT64_C(0x00065102D85E579B)}},
2405         {{UINT64_C(0x000D8ADCE1ED036C), UINT64_C(0x00075B271EA827E2),
2406           UINT64_C(0x00076B7F6030D0B9), UINT64_C(0x0001CF9A9998A24D),
2407           UINT64_C(0x0003EAAA8D599E8C), UINT64_C(0x000926867BCB228B),
2408           UINT64_C(0x0005C256FF24300F), UINT64_C(0x0002D2C9DDD6690E),
2409           UINT64_C(0x000318EC38CFD857), UINT64_C(0x00040F4D05884680)},
2410          {UINT64_C(0x000BA16121F40EA5), UINT64_C(0x0003E1A3C8625ED4),
2411           UINT64_C(0x0003A030ED90ADCB), UINT64_C(0x00051906502C4E1E),
2412           UINT64_C(0x00056353D129BB9B), UINT64_C(0x00097E025B071B0B),
2413           UINT64_C(0x0007FEFDDBE2C9B0), UINT64_C(0x0005B33FC31E9599),
2414           UINT64_C(0x0004B5E596C70338), UINT64_C(0x0001C9B00B315DC4)}},
2415         {{UINT64_C(0x000607DBC162717D), UINT64_C(0x0000D1169F3006DA),
2416           UINT64_C(0x0000DD28C7A17F77), UINT64_C(0x000575B9A5BE6190),
2417           UINT64_C(0x0001608A9002E304), UINT64_C(0x0008355DA341F5E9),
2418           UINT64_C(0x0006F9C8170EE63C), UINT64_C(0x00014428C0115E5D),
2419           UINT64_C(0x00023A2E2E57272F), UINT64_C(0x000688C75933F079)},
2420          {UINT64_C(0x000FF6A2CDB10A3C), UINT64_C(0x00011BFAEC3923D3),
2421           UINT64_C(0x00042ED75727E176), UINT64_C(0x00014FA777DC3A6C),
2422           UINT64_C(0x000160BDE1742549), UINT64_C(0x000AB16C591470C7),
2423           UINT64_C(0x00028D130B66A9E4), UINT64_C(0x00047E950B4F11C5),
2424           UINT64_C(0x000135717CA7A661), UINT64_C(0x000654B545B4E06F)}},
2425         {{UINT64_C(0x00021C7F20682330), UINT64_C(0x0006E09BA4DD4E28),
2426           UINT64_C(0x0005ED0838CEDFB5), UINT64_C(0x00046FAAD6213185),
2427           UINT64_C(0x00042F098929C355), UINT64_C(0x0002587008E96E6D),
2428           UINT64_C(0x000705A22499C027), UINT64_C(0x0000D8B3B0087A17),
2429           UINT64_C(0x0003A94A483422C6), UINT64_C(0x0003D967C7D3D6FD)},
2430          {UINT64_C(0x0009965DB7927E5D), UINT64_C(0x0005AB719C5CAE45),
2431           UINT64_C(0x00033CCD1F896812), UINT64_C(0x0001AE9A7A4BA5D3),
2432           UINT64_C(0x00072043806DB7CF), UINT64_C(0x0008763B930B883A),
2433           UINT64_C(0x0002E90170B740E5), UINT64_C(0x00058F5C1631E156),
2434           UINT64_C(0x0000C3D179B466C2), UINT64_C(0x0005E600D05FAA9D)}},
2435         {{UINT64_C(0x0001BDEA3D7E7C27), UINT64_C(0x0000D69B04E78772),
2436           UINT64_C(0x0006FD1A96FF1C3D), UINT64_C(0x000704C7BCD74C67),
2437           UINT64_C(0x0006587D24D60D0B), UINT64_C(0x0009A72FB4EDBDF3),
2438           UINT64_C(0x0005F66F2FC11A22), UINT64_C(0x0005C07A5C028CB3),
2439           UINT64_C(0x000427DC53252FD7), UINT64_C(0x00000C0FE0D5E259)},
2440          {UINT64_C(0x00015C9DCE11A938), UINT64_C(0x0002F708542BA021),
2441           UINT64_C(0x0006DAB5EC8723B2), UINT64_C(0x0003151DBC6DBEA3),
2442           UINT64_C(0x000309C003EEA187), UINT64_C(0x000986E93A4AD727),
2443           UINT64_C(0x0005A27640EB41AD), UINT64_C(0x00064B4B969CE91A),
2444           UINT64_C(0x00058AD60A48BA18), UINT64_C(0x0007DE07E6483D46)}},
2445         {{UINT64_C(0x0001C747EC0357A9), UINT64_C(0x00053CBE4FDF72AE),
2446           UINT64_C(0x0001FB453499F9E9), UINT64_C(0x0004C4167C9B02FD),
2447           UINT64_C(0x000127DCADD50EB4), UINT64_C(0x000805FB4E216AE0),
2448           UINT64_C(0x00029FAA52099B86), UINT64_C(0x00047C3F68455806),
2449           UINT64_C(0x0001B9FA50F58DBC), UINT64_C(0x0003BD919AFF02A8)},
2450          {UINT64_C(0x0000E4A059AF4846), UINT64_C(0x0007E18DF861A61A),
2451           UINT64_C(0x0006C2588CE7246D), UINT64_C(0x000662D80DEF8736),
2452           UINT64_C(0x00067C77B3EBB3CB), UINT64_C(0x000DB319339B4754),
2453           UINT64_C(0x0002F3DAFE1D02AD), UINT64_C(0x0001AB8E0CEDA23A),
2454           UINT64_C(0x0000839E55FF286D), UINT64_C(0x000427E6A937B04C)}},
2455         {{UINT64_C(0x0009CD5E8F10490A), UINT64_C(0x000770DEE503609F),
2456           UINT64_C(0x0002F4D1F9822AF0), UINT64_C(0x000209D7D6C6D432),
2457           UINT64_C(0x000577EE861AD61E), UINT64_C(0x000D96564BC24BF1),
2458           UINT64_C(0x0007205D262B6DBF), UINT64_C(0x0003C7E6251A1A93),
2459           UINT64_C(0x00013FC13A41D60E), UINT64_C(0x000213F2333B026A)},
2460          {UINT64_C(0x0008E0F9A2F3F058), UINT64_C(0x00052D3E4E010B53),
2461           UINT64_C(0x00048FB0F03593BF), UINT64_C(0x0007400230A674D3),
2462           UINT64_C(0x0007D42DE3498D1B), UINT64_C(0x00088D98507324A9),
2463           UINT64_C(0x0006FEBD72D5E2AE), UINT64_C(0x00023587543DE864),
2464           UINT64_C(0x0006101B209DB09C), UINT64_C(0x0007176D895A251A)}},
2465         {{UINT64_C(0x0005B6A111C3F2A8), UINT64_C(0x000287D5A1A25472),
2466           UINT64_C(0x0004C3C87F77626A), UINT64_C(0x0007EAFB9945BB03),
2467           UINT64_C(0x0000B01EC3BD3FD6), UINT64_C(0x0003CFA14713C9F7),
2468           UINT64_C(0x00055DC5C2B54DF9), UINT64_C(0x00040CB8F2FD4F74),
2469           UINT64_C(0x0002B2C21AAD7697), UINT64_C(0x0006A800C6F15DE5)},
2470          {UINT64_C(0x00087EBAC501C1CD), UINT64_C(0x0004B94A8B9744A9),
2471           UINT64_C(0x00071EA1C4951821), UINT64_C(0x0002F01B39CE1A3C),
2472           UINT64_C(0x0005D4D68C89745D), UINT64_C(0x000CDC8D00E9F950),
2473           UINT64_C(0x0004C2450A80D882), UINT64_C(0x0002B0D6F20496F6),
2474           UINT64_C(0x0000E2B53712BC8E), UINT64_C(0x0004FB508F36E069)}},
2475         {{UINT64_C(0x0009905B853D75DD), UINT64_C(0x0002202313A58A10),
2476           UINT64_C(0x00047F9FAA6A8086), UINT64_C(0x0006997CD94C68DB),
2477           UINT64_C(0x00053560DF08CE67), UINT64_C(0x00058B243F1C8213),
2478           UINT64_C(0x00023330F3EAC431), UINT64_C(0x00029615BF1FDC4B),
2479           UINT64_C(0x0000E02FFE4339AB), UINT64_C(0x0006701924C686EC)},
2480          {UINT64_C(0x00028B574C85D822), UINT64_C(0x00023BDBC197A77D),
2481           UINT64_C(0x0000CA80105F893D), UINT64_C(0x0004A4B3F8BA0A40),
2482           UINT64_C(0x0006606848556101), UINT64_C(0x0002691001720525),
2483           UINT64_C(0x000492966DED5935), UINT64_C(0x0004330B122DF4B0),
2484           UINT64_C(0x0003F277BB31C2EC), UINT64_C(0x000415C4C2A49A50)}},
2485         {{UINT64_C(0x00067B9FED7E7EA9), UINT64_C(0x0000C6210735C315),
2486           UINT64_C(0x000015C61BE12C57), UINT64_C(0x00031A65953D8E09),
2487           UINT64_C(0x0000C16E4265E92A), UINT64_C(0x00038511318F2F8F),
2488           UINT64_C(0x0006D2553216EB6C), UINT64_C(0x00014C8A2AC5A158),
2489           UINT64_C(0x000155D5D24C02F3), UINT64_C(0x00028479C9ACA656)},
2490          {UINT64_C(0x0007F082D316A5DE), UINT64_C(0x0003727A88716E25),
2491           UINT64_C(0x000759E99508C576), UINT64_C(0x000268F8E924CE60),
2492           UINT64_C(0x0006584B44F67E86), UINT64_C(0x00010FC03061696C),
2493           UINT64_C(0x000111F962EADA3C), UINT64_C(0x000287220D2E4A6F),
2494           UINT64_C(0x0003DB8A5947F03E), UINT64_C(0x00063C396A142480)}},
2495         {{UINT64_C(0x0008D64DDD35262C), UINT64_C(0x0000E4419BEEDCBC),
2496           UINT64_C(0x0002644C710FD7DF), UINT64_C(0x0002B9FD57D1EDA6),
2497           UINT64_C(0x0001B443D6794EE2), UINT64_C(0x00066E8A571BA2F0),
2498           UINT64_C(0x0002A7DDA194FF52), UINT64_C(0x0000F1F9B9EB114E),
2499           UINT64_C(0x0002D0C71939AF7D), UINT64_C(0x0007B1CF36555692)},
2500          {UINT64_C(0x000E6FC6E690E6C9), UINT64_C(0x00025FE13962D085),
2501           UINT64_C(0x00057EF392B58263), UINT64_C(0x0000601F80D88963),
2502           UINT64_C(0x0000F77167FACF40), UINT64_C(0x0005C1EB1F4AF8D3),
2503           UINT64_C(0x0004E45CA91A75A3), UINT64_C(0x0007A538AF4D39AB),
2504           UINT64_C(0x0002FC7EF186BF83), UINT64_C(0x0002BB96633B032F)}},
2505         {{UINT64_C(0x000A511387235D97), UINT64_C(0x0000C5AEBD7CD669),
2506           UINT64_C(0x0001E2B79B37FC76), UINT64_C(0x000633A0ED45A1B2),
2507           UINT64_C(0x00002A485310156D), UINT64_C(0x000CF71C1E86A953),
2508           UINT64_C(0x000380A9470BDE9B), UINT64_C(0x0006C3A16CD16C98),
2509           UINT64_C(0x0003FD675030BD33), UINT64_C(0x0005733732E1E8BD)},
2510          {UINT64_C(0x0005DC87E99B96E0), UINT64_C(0x00061EEB65283A4A),
2511           UINT64_C(0x00066868AD05A9F6), UINT64_C(0x0003149FA1801E6C),
2512           UINT64_C(0x00009D644B39DFC5), UINT64_C(0x00088AA6A5735E82),
2513           UINT64_C(0x000329D82B26F648), UINT64_C(0x00038BF5BA7C68AD),
2514           UINT64_C(0x0000C5080B2DF90F), UINT64_C(0x00038D1F9AC2EAFD)}},
2515         {{UINT64_C(0x000DB14BDA7C7B66), UINT64_C(0x0000C49B073976FE),
2516           UINT64_C(0x000594F284FFA26E), UINT64_C(0x000082CF489F3922),
2517           UINT64_C(0x00052C957BF245F7), UINT64_C(0x0006E308A2AB1201),
2518           UINT64_C(0x000099B40ACA95A7), UINT64_C(0x0002815B6839730D),
2519           UINT64_C(0x0000B4295FDA8783), UINT64_C(0x00056F95752DE2DE)},
2520          {UINT64_C(0x000F056FEC9E88EA), UINT64_C(0x0007747F406F4246),
2521           UINT64_C(0x000125F62E04125C), UINT64_C(0x000286A0E4919620),
2522           UINT64_C(0x000691348CCDE24C), UINT64_C(0x0000010E5ED700B6),
2523           UINT64_C(0x0000B69D2C21F3C6), UINT64_C(0x00073767577F6F02),
2524           UINT64_C(0x0005344DA12140FD), UINT64_C(0x00063AC1FFD1B34E)}},
2525     },
2526     {
2527         {{UINT64_C(0x00073DCFA4CC1F6E), UINT64_C(0x000058B4C7ED3A6B),
2528           UINT64_C(0x00044FC7BBBB4D1C), UINT64_C(0x00073AA6DD4CD996),
2529           UINT64_C(0x000603CE62F0768C), UINT64_C(0x000DDF011F0B6AB3),
2530           UINT64_C(0x0003E05089170D90), UINT64_C(0x0005874DCC299BE8),
2531           UINT64_C(0x0001472869B59056), UINT64_C(0x000509DDD9B76FFE)},
2532          {UINT64_C(0x000EF415076C2F66), UINT64_C(0x00011E95B1CD79BE),
2533           UINT64_C(0x00072B66656ECB77), UINT64_C(0x0000C32231A4FA37),
2534           UINT64_C(0x000078B2D3568104), UINT64_C(0x00071892DBCB8007),
2535           UINT64_C(0x00003A0D60762137), UINT64_C(0x0001972E82FD7568),
2536           UINT64_C(0x0003B928B40F35C4), UINT64_C(0x00008D70A3EF6199)}},
2537         {{UINT64_C(0x000AFC3506C0703F), UINT64_C(0x000624FB1C5785C2),
2538           UINT64_C(0x0000AABC82587858), UINT64_C(0x0004C835073ADCF9),
2539           UINT64_C(0x000687A3E10BEBEC), UINT64_C(0x000594AAE6A6AE1A),
2540           UINT64_C(0x00065326690F40A8), UINT64_C(0x0000FAAF35DCEA85),
2541           UINT64_C(0x0000F2D71EE73779), UINT64_C(0x00066971F9CF6697)},
2542          {UINT64_C(0x000438C3AE869675), UINT64_C(0x00058F4A97CCECEE),
2543           UINT64_C(0x00038C0DA4EAB715), UINT64_C(0x0002EFF5EC967DA5),
2544           UINT64_C(0x0004EC8C45F8A0B7), UINT64_C(0x0001A00E90F5CDF1),
2545           UINT64_C(0x00008DEA644831E0), UINT64_C(0x000344FDFCB694A6),
2546           UINT64_C(0x0001645897F09A36), UINT64_C(0x0003CD2366934F24)}},
2547         {{UINT64_C(0x0003A9CBC10E78A2), UINT64_C(0x0005680C903EE3AA),
2548           UINT64_C(0x0006148C4134D494), UINT64_C(0x0000B708AB89AB5E),
2549           UINT64_C(0x0004077F94E08257), UINT64_C(0x0006E5183D078408),
2550           UINT64_C(0x000100C1D80D49CE), UINT64_C(0x00077E3B5B1FD1E9),
2551           UINT64_C(0x0001D5173866042B), UINT64_C(0x0002EC241DBE6604)},
2552          {UINT64_C(0x000D707611B80741), UINT64_C(0x000004EDC429B806),
2553           UINT64_C(0x00025B85B91E12D5), UINT64_C(0x0005A874EFD18EE2),
2554           UINT64_C(0x000679D292E2E5E8), UINT64_C(0x0007C4E1CF9D2493),
2555           UINT64_C(0x00007FEC8151F6C5), UINT64_C(0x0007077C6CE7BCBD),
2556           UINT64_C(0x0004E603D2D1C045), UINT64_C(0x000120DC52FC4C28)}},
2557         {{UINT64_C(0x00024CAB433F1EE9), UINT64_C(0x00029390B5399AC6),
2558           UINT64_C(0x0000A140735E1061), UINT64_C(0x0006209FAAABDAEB),
2559           UINT64_C(0x000313939B1E27F8), UINT64_C(0x00071218CE90C274),
2560           UINT64_C(0x00004D454CA99B52), UINT64_C(0x000244DC876EE217),
2561           UINT64_C(0x0007B9AEDFF13E10), UINT64_C(0x0007C60093FD8081)},
2562          {UINT64_C(0x000DA5DEA4CAF297), UINT64_C(0x00068C8666E24B9C),
2563           UINT64_C(0x0002429BB8CB157C), UINT64_C(0x00075FA673A5EDA2),
2564           UINT64_C(0x000374A3EAD4DEAA), UINT64_C(0x000BDA91FD4D7B4C),
2565           UINT64_C(0x000219669647B2DF), UINT64_C(0x0003EDAFFBB15EF4),
2566           UINT64_C(0x00024CF5BC63EF28), UINT64_C(0x00027124899C9A4B)}},
2567         {{UINT64_C(0x00040B019B1261D0), UINT64_C(0x0000B4F4F45584EA),
2568           UINT64_C(0x00010867C36FE3B7), UINT64_C(0x0001B956EFC67D1C),
2569           UINT64_C(0x00060551212213FD), UINT64_C(0x00045B1AC4D20479),
2570           UINT64_C(0x00031E79405F14E6), UINT64_C(0x00054F01E909A81E),
2571           UINT64_C(0x00001536D9DE39DB), UINT64_C(0x0000B62D820D6FE3)},
2572          {UINT64_C(0x0003F4243CF34066), UINT64_C(0x00024F7957E1D750),
2573           UINT64_C(0x000080B613A16A90), UINT64_C(0x0004FFBB7D0412AA),
2574           UINT64_C(0x00048AADB4617EEB), UINT64_C(0x0005590404BF6350),
2575           UINT64_C(0x0005FB0DEC254DD3), UINT64_C(0x0006E456239D68DC),
2576           UINT64_C(0x0006AA0BAC97FBC4), UINT64_C(0x0007C0F318810C9E)}},
2577         {{UINT64_C(0x00095C2255EB8676), UINT64_C(0x0002EEBEE04E7BD1),
2578           UINT64_C(0x00047162E07D3E1B), UINT64_C(0x00019CBB802D7D2F),
2579           UINT64_C(0x0004D5BCA1F2FE81), UINT64_C(0x000636275F6E3CD0),
2580           UINT64_C(0x000074C1065AE748), UINT64_C(0x00000ED33D724610),
2581           UINT64_C(0x000382AAE71C671F), UINT64_C(0x00050F862E56FE82)},
2582          {UINT64_C(0x000F0C6FE0519997), UINT64_C(0x0004AF7A837FAD03),
2583           UINT64_C(0x00029E2DCFC7D836), UINT64_C(0x0000D7429D3F9BC8),
2584           UINT64_C(0x0002062ED538B7FE), UINT64_C(0x00048D96CEDB79F1),
2585           UINT64_C(0x00035E77C26028A3), UINT64_C(0x0002BEBC515C0C05),
2586           UINT64_C(0x0001137EC9DBE5EA), UINT64_C(0x0004EF0306F592B4)}},
2587         {{UINT64_C(0x00045CFFCC0FA82B), UINT64_C(0x000147CD2A7BCEF8),
2588           UINT64_C(0x0004A7DF37A543F3), UINT64_C(0x0000E83C08C7DB26),
2589           UINT64_C(0x000433C19A259924), UINT64_C(0x000060A2CC17C1B7),
2590           UINT64_C(0x00048887C01708A7), UINT64_C(0x0004F7B43946A5B5),
2591           UINT64_C(0x0000318DA056D31F), UINT64_C(0x0005816FA3E55B23)},
2592          {UINT64_C(0x00028F1B6BE8EDBD), UINT64_C(0x0002FAEDDF5DD2E3),
2593           UINT64_C(0x0004F7E40BA33E35), UINT64_C(0x00065C3B855FC053),
2594           UINT64_C(0x0001874EF8C8D7C7), UINT64_C(0x0009EE69935EB5BD),
2595           UINT64_C(0x0005209285BDCD9B), UINT64_C(0x00065CD4AD193A52),
2596           UINT64_C(0x0007AF07028EFAD4), UINT64_C(0x0003D64202012D6B)}},
2597         {{UINT64_C(0x000B9243B209436A), UINT64_C(0x0004A9127BF30A58),
2598           UINT64_C(0x0006E0E94A1E2713), UINT64_C(0x0004376EAD2B248D),
2599           UINT64_C(0x000767EEA5E05823), UINT64_C(0x0009BF8F74216C3F),
2600           UINT64_C(0x00024B8202C21037), UINT64_C(0x00013B0257209206),
2601           UINT64_C(0x0002F0B8A9C57E63), UINT64_C(0x0001559540A76AA1)},
2602          {UINT64_C(0x00066AF801F7DD9E), UINT64_C(0x00075AFD2B0FB2AA),
2603           UINT64_C(0x00055CB5FD0A01A3), UINT64_C(0x000139A9A848804F),
2604           UINT64_C(0x0004DB6F2563F825), UINT64_C(0x0001293E77720431),
2605           UINT64_C(0x0005D00E9E6814E5), UINT64_C(0x00033A3B82EBAE98),
2606           UINT64_C(0x00032C37E6C66CBB), UINT64_C(0x000690013DADC456)}},
2607         {{UINT64_C(0x000272465B8B5D7D), UINT64_C(0x000720DB646ED253),
2608           UINT64_C(0x0002AB65B7565858), UINT64_C(0x00014AD6B607866E),
2609           UINT64_C(0x000598494CC47B43), UINT64_C(0x000001AE0D244024),
2610           UINT64_C(0x00029E1DE544546D), UINT64_C(0x0002D87A26EE67AB),
2611           UINT64_C(0x0002767B394A967D), UINT64_C(0x0005DD104AA8F32A)},
2612          {UINT64_C(0x00068115CF22CDAC), UINT64_C(0x0006E7DA3BE129A8),
2613           UINT64_C(0x00037A31451A8758), UINT64_C(0x00039CB3690F9258),
2614           UINT64_C(0x00069351BF30A237), UINT64_C(0x000943CB31F201C2),
2615           UINT64_C(0x00056D93FDE091B5), UINT64_C(0x0007A6DAFB6FE56C),
2616           UINT64_C(0x00076EBD371AC14C), UINT64_C(0x00022219B02515D5)}},
2617         {{UINT64_C(0x0007126658D45F84), UINT64_C(0x0005F94089210333),
2618           UINT64_C(0x0000DF0B1374230F), UINT64_C(0x0000C22084A59475),
2619           UINT64_C(0x0005B56056BEF979), UINT64_C(0x0003B18C16D005D1),
2620           UINT64_C(0x00009A3D6108A669), UINT64_C(0x0002B5446C86171D),
2621           UINT64_C(0x0003C25E4502353F), UINT64_C(0x0002AF979DDD05A1)},
2622          {UINT64_C(0x000CE57EA911389C), UINT64_C(0x00060CBCB1000CD6),
2623           UINT64_C(0x0002AEF497970566), UINT64_C(0x0003002606F34647),
2624           UINT64_C(0x0005BAC30DE7C37E), UINT64_C(0x000ACE8DDCA7F508),
2625           UINT64_C(0x0004C49914338529), UINT64_C(0x000201F520B0AA42),
2626           UINT64_C(0x0003ACEB18EE94D1), UINT64_C(0x00043292408A3327)}},
2627         {{UINT64_C(0x00071CFCF4149893), UINT64_C(0x0002FF24B716F1CF),
2628           UINT64_C(0x0002E9DD42D79E81), UINT64_C(0x0005F2E12A9D3787),
2629           UINT64_C(0x0000B67ABBDD6226), UINT64_C(0x000E14AD866F075E),
2630           UINT64_C(0x0000DF8C5452E7ED), UINT64_C(0x000179D614E61B47),
2631           UINT64_C(0x0005F5E532D764C5), UINT64_C(0x000134C30CA43904)},
2632          {UINT64_C(0x0008A3D8E0E5028B), UINT64_C(0x0002AD02FF65DB2D),
2633           UINT64_C(0x000024B54F477366), UINT64_C(0x0004DF76000BEBD4),
2634           UINT64_C(0x0001BABEBBC5B492), UINT64_C(0x000293A99B9A4E9E),
2635           UINT64_C(0x0006DA8EC81880DF), UINT64_C(0x0004D62443F19541),
2636           UINT64_C(0x0007788BC32D12B7), UINT64_C(0x00053D73A62F6A5D)}},
2637         {{UINT64_C(0x0008D1269BFE5E8B), UINT64_C(0x0000FE4C7CBD9622),
2638           UINT64_C(0x0003CF67B2F4ACFF), UINT64_C(0x0006A8A24518F03D),
2639           UINT64_C(0x000347DAE1827AD4), UINT64_C(0x000F291ACCCDE5C5),
2640           UINT64_C(0x0000C9C96024DBC2), UINT64_C(0x0006E1493787400F),
2641           UINT64_C(0x0004557C49C13B5E), UINT64_C(0x0001BBD5022E461F)},
2642          {UINT64_C(0x00029EF080397D2A), UINT64_C(0x0007D3AEFB96A5DA),
2643           UINT64_C(0x0005CE903FC41243), UINT64_C(0x0007ACF27A77BE2F),
2644           UINT64_C(0x00069367C2BB5B2D), UINT64_C(0x000EA380A0F28EC9),
2645           UINT64_C(0x0004D091094729F5), UINT64_C(0x0000568ED1C33BAF),
2646           UINT64_C(0x0006FFC9FEC1754C), UINT64_C(0x00079AF250E87C71)}},
2647         {{UINT64_C(0x0001B7181A9FE1E7), UINT64_C(0x0004BF3195C7079A),
2648           UINT64_C(0x00004C65A8623BD7), UINT64_C(0x000293D8EC50869E),
2649           UINT64_C(0x00061ECDC77A17C7), UINT64_C(0x00024A53FBCEF78C),
2650           UINT64_C(0x0006DE143AB5A0EC), UINT64_C(0x0004F508E8AD0226),
2651           UINT64_C(0x0006DB9363078A38), UINT64_C(0x0002687048D33591)},
2652          {UINT64_C(0x00002320E24E6A1C), UINT64_C(0x000313A5A33B1564),
2653           UINT64_C(0x00032A7B146533BC), UINT64_C(0x00071698E42DC91D),
2654           UINT64_C(0x00013FC72B6E6862), UINT64_C(0x000192B68047991B),
2655           UINT64_C(0x00077CB246D0CF66), UINT64_C(0x00019BF6E968E141),
2656           UINT64_C(0x00022BEFB71228A7), UINT64_C(0x0007A8BE0F3AB802)}},
2657         {{UINT64_C(0x0004ADD37A15BAF2), UINT64_C(0x0002BA4932A7035A),
2658           UINT64_C(0x0007F27F93062C33), UINT64_C(0x0001E46147E6199F),
2659           UINT64_C(0x0004849455CB21C9), UINT64_C(0x000DF6C55755F760),
2660           UINT64_C(0x00062C25D51F8005), UINT64_C(0x00018D552106AE65),
2661           UINT64_C(0x00036D4A8E15A67D), UINT64_C(0x0002EAE18E596E61)},
2662          {UINT64_C(0x000A03842DB9836A), UINT64_C(0x00048F98CEFB00D3),
2663           UINT64_C(0x0005190809ADF2BA), UINT64_C(0x0002DFB56F0A20D0),
2664           UINT64_C(0x00027970FAA41846), UINT64_C(0x000A481D0AD15C42),
2665           UINT64_C(0x000613F431F58DB3), UINT64_C(0x00007B1DF30C2753),
2666           UINT64_C(0x000724A12A33FE21), UINT64_C(0x00061257C4C8D5D9)}},
2667         {{UINT64_C(0x0006B38283640BFC), UINT64_C(0x00071A8876D2D39B),
2668           UINT64_C(0x0000F57FF4B7C4D2), UINT64_C(0x00048165C6651FA6),
2669           UINT64_C(0x000261CAB432E4D9), UINT64_C(0x0003A33A1024655B),
2670           UINT64_C(0x00016A80FB002EFE), UINT64_C(0x0007F53959DC0BF4),
2671           UINT64_C(0x000327B19C41762A), UINT64_C(0x0003AEB118550BD1)},
2672          {UINT64_C(0x000194446473FAA4), UINT64_C(0x00056252C5E6D79B),
2673           UINT64_C(0x000385407B1E32BE), UINT64_C(0x0004F62D3BA2C380),
2674           UINT64_C(0x0006709FC90E66D9), UINT64_C(0x000BF2EFEC69E52A),
2675           UINT64_C(0x00025E53D4588CB4), UINT64_C(0x000767AF079A8486),
2676           UINT64_C(0x0006B1B2BCF33774), UINT64_C(0x00054711D18A6446)}},
2677         {{UINT64_C(0x0002F65D12A437F5), UINT64_C(0x0004C193BB16BB5C),
2678           UINT64_C(0x00044CB11429B380), UINT64_C(0x000575B1D96C4371),
2679           UINT64_C(0x0004792169D089CC), UINT64_C(0x000A44E79CFC086D),
2680           UINT64_C(0x0007F7A9AA829C6C), UINT64_C(0x0000E51AD40E415B),
2681           UINT64_C(0x0003741299AE5AB0), UINT64_C(0x00034773AD27F4C8)},
2682          {UINT64_C(0x0001088846755E86), UINT64_C(0x0007C43CEE739306),
2683           UINT64_C(0x0006DFB006FC973D), UINT64_C(0x00075D11ABB97E3F),
2684           UINT64_C(0x0006CE4EAD9FD40A), UINT64_C(0x00090DE95E0B71B8),
2685           UINT64_C(0x000677FB1CA2400F), UINT64_C(0x0001D6A9EAC1F91B),
2686           UINT64_C(0x0004B5A0DEA254E4), UINT64_C(0x00031843DB8ACA4B)}},
2687     },
2688     {
2689         {{UINT64_C(0x00040F0FEE5191D7), UINT64_C(0x0007AD757B218666),
2690           UINT64_C(0x00025B684155AF20), UINT64_C(0x00029F4B5C485180),
2691           UINT64_C(0x0007D8377347091F), UINT64_C(0x000A22940AF54A77),
2692           UINT64_C(0x0003BDF6CB1B3734), UINT64_C(0x000579D05F06E011),
2693           UINT64_C(0x00032F87199B836F), UINT64_C(0x000467CDC3E7620A)},
2694          {UINT64_C(0x00099269E81CAEA9), UINT64_C(0x00060FAD5B89DD61),
2695           UINT64_C(0x0005D82009E159C4), UINT64_C(0x000543570882A388),
2696           UINT64_C(0x0005742B11F41567), UINT64_C(0x00005532CC1A04CF),
2697           UINT64_C(0x0007E7D67CA82018), UINT64_C(0x00030811921ED542),
2698           UINT64_C(0x00033B0153C0A9D2), UINT64_C(0x000027EEDE45D652)}},
2699         {{UINT64_C(0x00054628B564DD25), UINT64_C(0x000278E72161A60B),
2700           UINT64_C(0x0002875070456F4D), UINT64_C(0x0000A471C5023AE6),
2701           UINT64_C(0x00053142CC156044), UINT64_C(0x000EB689710B36EE),
2702           UINT64_C(0x000749FE221A7A5D), UINT64_C(0x0005CE289B236184),
2703           UINT64_C(0x00064A9332E96DFA), UINT64_C(0x00019F74B7F23AA6)},
2704          {UINT64_C(0x000047C80E1C6849), UINT64_C(0x00032C0409EB2702),
2705           UINT64_C(0x0005472D7A3265A6), UINT64_C(0x00007486A002948B),
2706           UINT64_C(0x0005B35D6DCD0117), UINT64_C(0x000F09583142990E),
2707           UINT64_C(0x00020994F45554BA), UINT64_C(0x0002A8A2ED9245E6),
2708           UINT64_C(0x0001FCB7F2469865), UINT64_C(0x0003ABDD4F76D182)}},
2709         {{UINT64_C(0x0007EF170E5B61C6), UINT64_C(0x00072FD9870DA526),
2710           UINT64_C(0x00052A5CE07FB8A2), UINT64_C(0x000641090CDA363A),
2711           UINT64_C(0x0001F046CD11B1C9), UINT64_C(0x000C5ACA2B42DE77),
2712           UINT64_C(0x0003FA2D3D3A78D1), UINT64_C(0x00022EE52A68BA15),
2713           UINT64_C(0x0006ED9A8FFEDB9E), UINT64_C(0x000628597175CF09)},
2714          {UINT64_C(0x0007233FAD040661), UINT64_C(0x0002DBF1724897C1),
2715           UINT64_C(0x00058AF887383FF2), UINT64_C(0x0001A82F626A8BA1),
2716           UINT64_C(0x000663B0E734D3AD), UINT64_C(0x00041A94CEBE29A8),
2717           UINT64_C(0x0000EBE98973931D), UINT64_C(0x0007653DABE4C434),
2718           UINT64_C(0x00077F080BA025B1), UINT64_C(0x0001349D8D6D5053)}},
2719         {{UINT64_C(0x000BE1C7FB3EA365), UINT64_C(0x0000DEC547480E21),
2720           UINT64_C(0x0003063031574C24), UINT64_C(0x0004A1A78E047579),
2721           UINT64_C(0x000606500AB9A488), UINT64_C(0x00027F5C522D4690),
2722           UINT64_C(0x0001EDD9FF35555F), UINT64_C(0x00027FDC2B282190),
2723           UINT64_C(0x000683CED2B98C75), UINT64_C(0x000650923C157066)},
2724          {UINT64_C(0x00092C9AF39CBACB), UINT64_C(0x0007D3858C2DD00B),
2725           UINT64_C(0x00031E676BBB7275), UINT64_C(0x0003AA2D98F4F933),
2726           UINT64_C(0x0003DCA9CE27A62B), UINT64_C(0x000A07F50B9E690F),
2727           UINT64_C(0x000051DF1C1BCD4A), UINT64_C(0x0003517B8AC99CFD),
2728           UINT64_C(0x0006367C0179F6E0), UINT64_C(0x0002CE5C968BCB6D)}},
2729         {{UINT64_C(0x000200C339FA6063), UINT64_C(0x0002D8C7E4167214),
2730           UINT64_C(0x00043F59D8D68BBE), UINT64_C(0x00020ABF6635C5FA),
2731           UINT64_C(0x000676FC3B2B32D8), UINT64_C(0x000EBE9FD818DFC0),
2732           UINT64_C(0x0006D7A4486F3794), UINT64_C(0x000684F5E2DF04E3),
2733           UINT64_C(0x00032590E104D8CA), UINT64_C(0x0007F86F511DEAF5)},
2734          {UINT64_C(0x00034E941C93C058), UINT64_C(0x00034819A8DA6A22),
2735           UINT64_C(0x000164AD4449303E), UINT64_C(0x00042BE59CA73B0D),
2736           UINT64_C(0x00014B7F6EA0A455), UINT64_C(0x00098C54814B4ED9),
2737           UINT64_C(0x0004C74E9049A134), UINT64_C(0x0001859C7C28787A),
2738           UINT64_C(0x0002BF6FCC75D79D), UINT64_C(0x0007A8E2129CEB51)}},
2739         {{UINT64_C(0x00018E8A6D68977A), UINT64_C(0x000202BA27C4F548),
2740           UINT64_C(0x000765E7CECDA47B), UINT64_C(0x000363DB05A69000),
2741           UINT64_C(0x0005F96506BEB7D3), UINT64_C(0x00089C30791266ED),
2742           UINT64_C(0x00077E5CAB5C1F29), UINT64_C(0x0006E87E942A7A13),
2743           UINT64_C(0x0001FD90D57F757B), UINT64_C(0x0007B1FF16E524CF)},
2744          {UINT64_C(0x0005EA5BBEA59591), UINT64_C(0x000427E51D91AE1C),
2745           UINT64_C(0x00070FC7F83A8541), UINT64_C(0x00069E9D31A36625),
2746           UINT64_C(0x00030C2ED2385F4C), UINT64_C(0x00095E9CEDC7EC18),
2747           UINT64_C(0x0004DF297D2AB731), UINT64_C(0x0007FD32EE0B4C2F),
2748           UINT64_C(0x0006423F55007B50), UINT64_C(0x000582AFCEAF6692)}},
2749         {{UINT64_C(0x000132229C4BE432), UINT64_C(0x000062BDAF1A965D),
2750           UINT64_C(0x0002C1A7663C1E53), UINT64_C(0x00038DAE7DCFB8CC),
2751           UINT64_C(0x00072695BB1282ED), UINT64_C(0x0006EC32706E7F8F),
2752           UINT64_C(0x0004FDED61E285BE), UINT64_C(0x0003D1D5A48B6110),
2753           UINT64_C(0x000552ACEEFD0F10), UINT64_C(0x00011D10445A68E0)},
2754          {UINT64_C(0x000CB3E30A36F50F), UINT64_C(0x0004A7B7557E35AE),
2755           UINT64_C(0x00066CFBF15B4D97), UINT64_C(0x0000508B08233B2E),
2756           UINT64_C(0x0003F31FB5C7AE10), UINT64_C(0x000E6621F3031E22),
2757           UINT64_C(0x000482990F4ECDC4), UINT64_C(0x000484D2AA8A0F24),
2758           UINT64_C(0x00009D4CF9C0A36A), UINT64_C(0x0001CC385C527853)}},
2759         {{UINT64_C(0x000A4792A9EEE2A9), UINT64_C(0x00072FA6FDF2C7C6),
2760           UINT64_C(0x0007C7826E4812BE), UINT64_C(0x0006F6D236CF8FD6),
2761           UINT64_C(0x00073F81409D27AF), UINT64_C(0x0006499E587E37BE),
2762           UINT64_C(0x0001D910B9037DCA), UINT64_C(0x00076B6BA2C2DD1C),
2763           UINT64_C(0x0000C40F587E10E9), UINT64_C(0x0003A0C39693B06A)},
2764          {UINT64_C(0x000B22437DF0A661), UINT64_C(0x000740D926C3CA81),
2765           UINT64_C(0x0004D6FC409922D3), UINT64_C(0x0006C8B0A63EBE3B),
2766           UINT64_C(0x0007A7E09C658E92), UINT64_C(0x000EE849F67956DF),
2767           UINT64_C(0x00009ACED8E8FE8F), UINT64_C(0x0001CD4640F2626A),
2768           UINT64_C(0x0000370AE99E0EF4), UINT64_C(0x000081E0D1461BE8)}},
2769         {{UINT64_C(0x00073065330BAB74), UINT64_C(0x0001574E266A5243),
2770           UINT64_C(0x0002D1F64CEC7BBF), UINT64_C(0x0005B4B35FD5F97F),
2771           UINT64_C(0x0006E328070806B7), UINT64_C(0x000194194F915C7A),
2772           UINT64_C(0x00073D3745896020), UINT64_C(0x0005E613BB39AE2A),
2773           UINT64_C(0x00011D507ABCADE1), UINT64_C(0x0002EAF0689489D1)},
2774          {UINT64_C(0x000058D096BDB2AB), UINT64_C(0x00069969F77F9CB1),
2775           UINT64_C(0x00039B6125B8F829), UINT64_C(0x00044A07AEC2D0C6),
2776           UINT64_C(0x000504B4F3946022), UINT64_C(0x00080D0DFA735E99),
2777           UINT64_C(0x0002BC6CCE0171E5), UINT64_C(0x0003D83527837207),
2778           UINT64_C(0x00066CBA871AC0F9), UINT64_C(0x00024A295AAEBA6A)}},
2779         {{UINT64_C(0x000D2B933FA0DA3A), UINT64_C(0x00079892AF905B11),
2780           UINT64_C(0x00021863855AA63A), UINT64_C(0x00052D86FEC679D3),
2781           UINT64_C(0x000791B1FDE46EBE), UINT64_C(0x000AF24DC2D97724),
2782           UINT64_C(0x000430197793B4EF), UINT64_C(0x0001355100B792D4),
2783           UINT64_C(0x00067BC1C675D49F), UINT64_C(0x00013F553362D7E5)},
2784          {UINT64_C(0x0004977612BCB0EB), UINT64_C(0x0003E50B8F31A3A8),
2785           UINT64_C(0x0007CD4AF5A9CB24), UINT64_C(0x0002D3E56A2C0F66),
2786           UINT64_C(0x0002D65C455CD2EF), UINT64_C(0x0002086963C9C7D0),
2787           UINT64_C(0x000145D5C4A9FFAE), UINT64_C(0x000619BAC8505C4A),
2788           UINT64_C(0x000027E3A7AE4A7A), UINT64_C(0x0000B67AD3689936)}},
2789         {{UINT64_C(0x000CC7D3BF4762C0), UINT64_C(0x0001F746EDBE329E),
2790           UINT64_C(0x0001DF8B85050FA2), UINT64_C(0x0003BD3B0F568385),
2791           UINT64_C(0x000180BF161ABAC6), UINT64_C(0x0000215CE0594FA0),
2792           UINT64_C(0x00047C0CB6A73218), UINT64_C(0x0000DBAEA7BF27D7),
2793           UINT64_C(0x0002F869F09063DD), UINT64_C(0x00054D9BA9522E09)},
2794          {UINT64_C(0x0002FE8D87A17CE0), UINT64_C(0x00057E4AC584E74A),
2795           UINT64_C(0x0002DAC318271EF4), UINT64_C(0x0002423F79D4DEB2),
2796           UINT64_C(0x0003E960755CCBC4), UINT64_C(0x000D266A7438DBF6),
2797           UINT64_C(0x000477E42DA16918), UINT64_C(0x0006B11A646B2B6A),
2798           UINT64_C(0x000431429BD1F7B7), UINT64_C(0x0006ED79801CF551)}},
2799         {{UINT64_C(0x000C2F5AD403D304), UINT64_C(0x00000E16E8839A82),
2800           UINT64_C(0x0006E1D15D839778), UINT64_C(0x0005F5B10106BB12),
2801           UINT64_C(0x0005C19D486DD5C6), UINT64_C(0x000719C29C1E59DF),
2802           UINT64_C(0x000659479542B834), UINT64_C(0x0007ACDE37B973BE),
2803           UINT64_C(0x0003482AD9321747), UINT64_C(0x000505ADD6521552)},
2804          {UINT64_C(0x000F913FC1522D09), UINT64_C(0x00037BFD0D4ABC49),
2805           UINT64_C(0x00001FA1DDC7C8F2), UINT64_C(0x000557253E6A7DB6),
2806           UINT64_C(0x0006E4F330384051), UINT64_C(0x000EB36BC2271684),
2807           UINT64_C(0x0006E60BC26E1F0F), UINT64_C(0x00054A6E03B188FB),
2808           UINT64_C(0x0003C21955E62B44), UINT64_C(0x00029C4483BA7D4D)}},
2809         {{UINT64_C(0x000670CC3896EBA5), UINT64_C(0x000259CFB18CBAE2),
2810           UINT64_C(0x0006699793CC03B7), UINT64_C(0x0006E571D3FF8F29),
2811           UINT64_C(0x00001EB92283238D), UINT64_C(0x000F5DE25A4C21F7),
2812           UINT64_C(0x00021DA151657372), UINT64_C(0x0005351A570D55D1),
2813           UINT64_C(0x0005E3C40430A85A), UINT64_C(0x0001A3FAEB0F9878)},
2814          {UINT64_C(0x00041F28CA0920E8), UINT64_C(0x0000528AA3286F64),
2815           UINT64_C(0x000550CD85825A5A), UINT64_C(0x0006A07132346430),
2816           UINT64_C(0x0006248B435552B3), UINT64_C(0x000C51E8492A342A),
2817           UINT64_C(0x000238B2E633EAE5), UINT64_C(0x00077EFF4FF5E3AF),
2818           UINT64_C(0x000737FE3C5938DC), UINT64_C(0x0003E7F342587F14)}},
2819         {{UINT64_C(0x0000469EA4F316A5), UINT64_C(0x0000CFF01ADFC8EC),
2820           UINT64_C(0x000752DEE0AF6B42), UINT64_C(0x0000FBD7A1DB547A),
2821           UINT64_C(0x00071529F9CBFCB7), UINT64_C(0x0002EEF2C4E55DE9),
2822           UINT64_C(0x00068B08FC158B20), UINT64_C(0x0005BA1440B0CD47),
2823           UINT64_C(0x000770690268EB1C), UINT64_C(0x0004FEA766326EEE)},
2824          {UINT64_C(0x0007E31940932215), UINT64_C(0x0006F953571E0D10),
2825           UINT64_C(0x000325DB7CA114C1), UINT64_C(0x0003346F1BDB76FF),
2826           UINT64_C(0x0004B2D608C398A0), UINT64_C(0x000880C15A6358CD),
2827           UINT64_C(0x00003A12DA7DAE1C), UINT64_C(0x00012A98295624DC),
2828           UINT64_C(0x0003F435F64DA03F), UINT64_C(0x00077E682761BD79)}},
2829         {{UINT64_C(0x000725EBE3550E60), UINT64_C(0x00009759E82357AA),
2830           UINT64_C(0x000707477FAC3456), UINT64_C(0x00056FDC23023B2E),
2831           UINT64_C(0x00051E1365B47E4D), UINT64_C(0x000B5D849F58CA94),
2832           UINT64_C(0x000685BF93742A36), UINT64_C(0x0001A1BC548F6279),
2833           UINT64_C(0x000344BB9DE268D0), UINT64_C(0x0005FDFB2BC3DEF5)},
2834          {UINT64_C(0x000848AFB0499C56), UINT64_C(0x00010DC37ABCFDEA),
2835           UINT64_C(0x0006C1811764BA4D), UINT64_C(0x0002A308A7745FCC),
2836           UINT64_C(0x00074CBB9E51FB1A), UINT64_C(0x000AC8D6F8659635),
2837           UINT64_C(0x000154D1F4F69089), UINT64_C(0x00028051B6633DBB),
2838           UINT64_C(0x0003335687BF4293), UINT64_C(0x0005ED908B0510A4)}},
2839         {{UINT64_C(0x0004904C9668E6CD), UINT64_C(0x00079071B2B92E94),
2840           UINT64_C(0x0001E7AE6FF7AF6A), UINT64_C(0x0002127FE63573CD),
2841           UINT64_C(0x0000D3D1E41CDAC6), UINT64_C(0x00011204952E81CE),
2842           UINT64_C(0x000271F8C2A453E2), UINT64_C(0x0001B69F9248DB24),
2843           UINT64_C(0x000379D0353FB400), UINT64_C(0x0001295BB193D08F)},
2844          {UINT64_C(0x000E90DA27BA514F), UINT64_C(0x0003159CBE1F9C35),
2845           UINT64_C(0x0005521CD6FEB8F3), UINT64_C(0x0005119F047F6EB1),
2846           UINT64_C(0x0004D5D0948D614B), UINT64_C(0x0006892CA0E25568),
2847           UINT64_C(0x0000FD25BBE0A6E7), UINT64_C(0x00021564372435F1),
2848           UINT64_C(0x00027D8B49CAD04C), UINT64_C(0x00007D5A2C89462D)}},
2849     },
2850     {
2851         {{UINT64_C(0x000F514B71EBBDCC), UINT64_C(0x0004035582F1B252),
2852           UINT64_C(0x0002A1C7C414989A), UINT64_C(0x0007743F23DC3274),
2853           UINT64_C(0x000791E243AE6EF8), UINT64_C(0x0009076C398D3FDA),
2854           UINT64_C(0x00055D23854865C6), UINT64_C(0x00067630F1F7A188),
2855           UINT64_C(0x0004FEF4830113F0), UINT64_C(0x0006EF4DC0128B39)},
2856          {UINT64_C(0x000AE1F76A7AB992), UINT64_C(0x0003D7ABB33C7671),
2857           UINT64_C(0x0007A82D28545FE8), UINT64_C(0x00034AB6DCB3D487),
2858           UINT64_C(0x0007701ECE7EE900), UINT64_C(0x000E400E5BC2A1A4),
2859           UINT64_C(0x000693EAE58F5DF2), UINT64_C(0x00037BBA5ED12DB3),
2860           UINT64_C(0x0005ED5B1E21C1B3), UINT64_C(0x000641DC0D967E8B)}},
2861         {{UINT64_C(0x00054C95BB0652B1), UINT64_C(0x00046F4FED58813D),
2862           UINT64_C(0x00050815BA4C242F), UINT64_C(0x0003C70A5ADB1CBD),
2863           UINT64_C(0x00018471501C557F), UINT64_C(0x00061B89E1DB46F5),
2864           UINT64_C(0x00030130047B6C15), UINT64_C(0x00024E7E179F958E),
2865           UINT64_C(0x00029B81AFD116BD), UINT64_C(0x0001F1C0E6F5B495)},
2866          {UINT64_C(0x00023C05D2947309), UINT64_C(0x000077CE6739DA7A),
2867           UINT64_C(0x0007175E6FC632C3), UINT64_C(0x00079215145A49EE),
2868           UINT64_C(0x0005582902E4AEC2), UINT64_C(0x0003D193BC0C12D2),
2869           UINT64_C(0x0005BA6F099A5DF0), UINT64_C(0x000403F8EF0B4955),
2870           UINT64_C(0x000642EB7C8A43A1), UINT64_C(0x0005D32BCC2F8B89)}},
2871         {{UINT64_C(0x00017EB1EE4CB1A1), UINT64_C(0x0006638C230FE375),
2872           UINT64_C(0x00023DCF4460C9F8), UINT64_C(0x0002497719F0A400),
2873           UINT64_C(0x00040836988B5191), UINT64_C(0x0004916DE1D1C20D),
2874           UINT64_C(0x0001141194F546D7), UINT64_C(0x00002179582ACA27),
2875           UINT64_C(0x0004DBC84C72F8E0), UINT64_C(0x00023C1DFC8EFD14)},
2876          {UINT64_C(0x00070B7F76ADAF26), UINT64_C(0x0003C6CEB8B1DA8A),
2877           UINT64_C(0x0003FD11262FDAE0), UINT64_C(0x0002770D8C7E9FB3),
2878           UINT64_C(0x0006D3BD713575D9), UINT64_C(0x0007838C17F3658C),
2879           UINT64_C(0x00077F30784494CF), UINT64_C(0x0001CE5F8562296E),
2880           UINT64_C(0x0005C03FBD4434BB), UINT64_C(0x0001FF536CDDE62E)}},
2881         {{UINT64_C(0x0001172A96A1E7D6), UINT64_C(0x0001098F9CBA5BBC),
2882           UINT64_C(0x00074F5479589BDA), UINT64_C(0x0003E78B80CE763C),
2883           UINT64_C(0x00045042B492B949), UINT64_C(0x000135B01953B25D),
2884           UINT64_C(0x000564A958658405), UINT64_C(0x00073391FC7A30CF),
2885           UINT64_C(0x00051DA995FAF2AC), UINT64_C(0x00008899D026CFE6)},
2886          {UINT64_C(0x0002EF92641119A3), UINT64_C(0x0007CFCD3D8E8348),
2887           UINT64_C(0x000251D519AA1667), UINT64_C(0x0007524C025888AD),
2888           UINT64_C(0x0002847F5CB47F5C), UINT64_C(0x0000C637101A1799),
2889           UINT64_C(0x000684496C314774), UINT64_C(0x0005DF9F71863B37),
2890           UINT64_C(0x0003099895A2F373), UINT64_C(0x0000333CA2E94544)}},
2891         {{UINT64_C(0x00070CCF02ECB2CC), UINT64_C(0x000105EF4D0A506E),
2892           UINT64_C(0x00007BF7A4DE2CA0), UINT64_C(0x0006DAB36E4422DE),
2893           UINT64_C(0x0005261AD9D05DF0), UINT64_C(0x000C9FCA9FCF1803),
2894           UINT64_C(0x00077F743B9F8F4A), UINT64_C(0x00054F8CFD871DBE),
2895           UINT64_C(0x00008369A88F23E3), UINT64_C(0x0004DE24D800793E)},
2896          {UINT64_C(0x00080D00BBD99113), UINT64_C(0x000705E433C3D50A),
2897           UINT64_C(0x0000CC78397E7790), UINT64_C(0x00033741085A403B),
2898           UINT64_C(0x0006E31F0AE64239), UINT64_C(0x0004B8AE3CC6DEFC),
2899           UINT64_C(0x0007FC3C4D4BFA22), UINT64_C(0x0005A85FF42BA85E),
2900           UINT64_C(0x0005E2879D483F75), UINT64_C(0x000111B21C595B57)}},
2901         {{UINT64_C(0x000B69E54FB31425), UINT64_C(0x0007670DB77E68C9),
2902           UINT64_C(0x000200548E67C390), UINT64_C(0x0007E58E7DA1316B),
2903           UINT64_C(0x00065C0A1A2EC1E9), UINT64_C(0x000566CC8A93BAED),
2904           UINT64_C(0x00034140BA9D29BD), UINT64_C(0x00066D8BC0434EC9),
2905           UINT64_C(0x000545F0A0BE9D95), UINT64_C(0x0005D43571D5259A)},
2906          {UINT64_C(0x000CB66450379E4A), UINT64_C(0x0002EA896E3D63C2),
2907           UINT64_C(0x0000A1CBC3C15620), UINT64_C(0x0004F3A6795DCE0B),
2908           UINT64_C(0x0007A3F6DAC83AC6), UINT64_C(0x0005EC06F01B9BAD),
2909           UINT64_C(0x0006468A896619D3), UINT64_C(0x0003C2FAACC2C60B),
2910           UINT64_C(0x0006858F9F24FF57), UINT64_C(0x00011A6265D8A36E)}},
2911         {{UINT64_C(0x00041C66E40F1A90), UINT64_C(0x0004E4F0180E78EF),
2912           UINT64_C(0x0003FB530CA47EAF), UINT64_C(0x0007ABB19E0A2FA0),
2913           UINT64_C(0x00041ABDD6CB403F), UINT64_C(0x000DAB4EEE08EF52),
2914           UINT64_C(0x00023FC4E743BC92), UINT64_C(0x0005B913456A7476),
2915           UINT64_C(0x0001C85ADE3AC4F1), UINT64_C(0x0004C1EA18C4581B)},
2916          {UINT64_C(0x000AC8C9F1F7F0A6), UINT64_C(0x0007E11A1C557ED2),
2917           UINT64_C(0x0000E1E16CCE15D8), UINT64_C(0x000132838704418A),
2918           UINT64_C(0x0002E6AFA3B1E448), UINT64_C(0x000D76FF3FBC3F61),
2919           UINT64_C(0x00015097A2812475), UINT64_C(0x0000F295A5BC66CB),
2920           UINT64_C(0x0002FF9986FD6334), UINT64_C(0x000792181517F379)}},
2921         {{UINT64_C(0x000593BFA181F4DE), UINT64_C(0x00076E78859CC727),
2922           UINT64_C(0x0000768CDCBCFB1D), UINT64_C(0x0002B147828E8906),
2923           UINT64_C(0x0004D189BBDFAF3E), UINT64_C(0x000F4188F2DE5620),
2924           UINT64_C(0x0005541E2603D86E), UINT64_C(0x00068B0163E24EF2),
2925           UINT64_C(0x000732F7A222EC67), UINT64_C(0x00030102005758D0)},
2926          {UINT64_C(0x000965B8766CC610), UINT64_C(0x0006CED5C6750EC9),
2927           UINT64_C(0x0002510890A11A94), UINT64_C(0x00050A335E380C21),
2928           UINT64_C(0x0002D3AAA4B5ABB1), UINT64_C(0x000C3DEBF83FD12E),
2929           UINT64_C(0x00042A5B613A963D), UINT64_C(0x00048A5474D5B2CC),
2930           UINT64_C(0x0006DBC324E377DF), UINT64_C(0x0004A450113CC47F)}},
2931         {{UINT64_C(0x00082FD2D666BA94), UINT64_C(0x000307B3C69374F1),
2932           UINT64_C(0x00030E4DCCADA50B), UINT64_C(0x00025121DD5AF46E),
2933           UINT64_C(0x0005DAE113DE717D), UINT64_C(0x000F540F6A242AF7),
2934           UINT64_C(0x0001984B2DEE5FE8), UINT64_C(0x000751006703C07F),
2935           UINT64_C(0x0003C4BED0C06C42), UINT64_C(0x0006834E2CFEAF97)},
2936          {UINT64_C(0x00079EF331F8BE0C), UINT64_C(0x0006C58FB2C0D852),
2937           UINT64_C(0x000642C225B2131C), UINT64_C(0x0003F1F2DD654AF1),
2938           UINT64_C(0x0003F6D400299A16), UINT64_C(0x000A1D524B709913),
2939           UINT64_C(0x0007F61D15FA8CD7), UINT64_C(0x00007D279176192A),
2940           UINT64_C(0x0004CB0573788091), UINT64_C(0x00017B43566C1463)}},
2941         {{UINT64_C(0x0007A50D58E645CD), UINT64_C(0x000717BFEFCEFD32),
2942           UINT64_C(0x00021533C2082002), UINT64_C(0x0000B6C97BE84215),
2943           UINT64_C(0x0003D9526234147F), UINT64_C(0x000736AFD37F86C3),
2944           UINT64_C(0x0001446C15A309FC), UINT64_C(0x00049F6A2E32732D),
2945           UINT64_C(0x0005A7F6B6BD0310), UINT64_C(0x00049050A86F7F6E)},
2946          {UINT64_C(0x000478A084486F70), UINT64_C(0x0004B485E454FFE6),
2947           UINT64_C(0x00005134AC546D22), UINT64_C(0x00045EC4A7C0DB13),
2948           UINT64_C(0x0003AB8CCE7A0B15), UINT64_C(0x000601A238F1B5B3),
2949           UINT64_C(0x00063D63F830D881), UINT64_C(0x0000F2D0A86F5488),
2950           UINT64_C(0x00077A07AB5A6307), UINT64_C(0x0001A0E97FE656C5)}},
2951         {{UINT64_C(0x0002B8E72C38FDE6), UINT64_C(0x0001650DDE9F2E2E),
2952           UINT64_C(0x00028EF99CEB5566), UINT64_C(0x00041C64DDA06D6A),
2953           UINT64_C(0x00005CB89B26AD37), UINT64_C(0x000A5F15A5F8AF03),
2954           UINT64_C(0x00025505F3937C0E), UINT64_C(0x000159B4CD9043F4),
2955           UINT64_C(0x000343C00F6BA0DB), UINT64_C(0x00047E9671AB1CFB)},
2956          {UINT64_C(0x0007DE9E2086ECD6), UINT64_C(0x0000A7B07155978A),
2957           UINT64_C(0x00026C99DCA72BC9), UINT64_C(0x0004F4F2C6EB2ED1),
2958           UINT64_C(0x00074C9CE7C64240), UINT64_C(0x000A4D876B2764B2),
2959           UINT64_C(0x0005394454615D25), UINT64_C(0x000481776CCE078B),
2960           UINT64_C(0x000186A538247AB1), UINT64_C(0x000333D9943B1146)}},
2961         {{UINT64_C(0x00084973CEDC2791), UINT64_C(0x0002950F48F39EEB),
2962           UINT64_C(0x0000EF6F70D1EFF2), UINT64_C(0x0004D3D6FD70FEAF),
2963           UINT64_C(0x000638ED86C3A27D), UINT64_C(0x000F9B23D52DAEF5),
2964           UINT64_C(0x0007DCA2C6212A71), UINT64_C(0x0003A72278C541D8),
2965           UINT64_C(0x0000D206D53E4F6B), UINT64_C(0x0007CC2FD213C6D8)},
2966          {UINT64_C(0x0009C9835F59129E), UINT64_C(0x0007F4A22C2FB8AC),
2967           UINT64_C(0x0000EB9FBBDAB0AF), UINT64_C(0x000397BE0B58FC49),
2968           UINT64_C(0x0000D58A5D14AA83), UINT64_C(0x000CBCDEEF3C688F),
2969           UINT64_C(0x0007F56D84202AE6), UINT64_C(0x0001AACDE92E0055),
2970           UINT64_C(0x0006A0198A5DD4EF), UINT64_C(0x00009072B8CFBB20)}},
2971         {{UINT64_C(0x000F7FEC5A5D3591), UINT64_C(0x0003CC91186CC1D7),
2972           UINT64_C(0x0000539F22D56CB3), UINT64_C(0x00014418785A7E75),
2973           UINT64_C(0x0007DD55510142B3), UINT64_C(0x00027C9298FBB5F7),
2974           UINT64_C(0x0002E6839156F4F1), UINT64_C(0x00006806E7AF3BDD),
2975           UINT64_C(0x00017FEEBFA3E11C), UINT64_C(0x0005E3B668C8CF1E)},
2976          {UINT64_C(0x0002E308DB4D3ABB), UINT64_C(0x0002519214DBB309),
2977           UINT64_C(0x00053F1D5795FB73), UINT64_C(0x00006C5A6BA835DE),
2978           UINT64_C(0x0007282B5833FF0C), UINT64_C(0x0007CA1C54F0B679),
2979           UINT64_C(0x00067F8A25FBF269), UINT64_C(0x00006A247708AB5B),
2980           UINT64_C(0x000271FDD248BDC5), UINT64_C(0x00001617D43FC96F)}},
2981         {{UINT64_C(0x000530DC05A439D4), UINT64_C(0x0002C89DF13D212F),
2982           UINT64_C(0x00006CD963D870CE), UINT64_C(0x00070E6A17E094DF),
2983           UINT64_C(0x0005335D7B440052), UINT64_C(0x0005D20A7FC5B6E6),
2984           UINT64_C(0x0000816C1BD2E991), UINT64_C(0x00015BFD4D6A50B8),
2985           UINT64_C(0x000611290ED60372), UINT64_C(0x000252141FDE02E6)},
2986          {UINT64_C(0x000EE270D2D5D91D), UINT64_C(0x00064864D00DF773),
2987           UINT64_C(0x0002CDF8C5BDD29E), UINT64_C(0x0004B4D19D843238),
2988           UINT64_C(0x0001E7349DF960FB), UINT64_C(0x000AB7E45A9B26DB),
2989           UINT64_C(0x0002D5282F6EE449), UINT64_C(0x0004F9B215872CD1),
2990           UINT64_C(0x0002F931EDC40DD7), UINT64_C(0x0004C76A77256A9F)}},
2991         {{UINT64_C(0x0006A781358C169E), UINT64_C(0x000093BAB2A31F43),
2992           UINT64_C(0x0002C0B13C7E6C0A), UINT64_C(0x00035E6DBE645073),
2993           UINT64_C(0x00027A3CF6B52BB2), UINT64_C(0x0007090F7CD7F0B6),
2994           UINT64_C(0x00049B2C3B592E30), UINT64_C(0x0002359164A5EB6A),
2995           UINT64_C(0x0004DC6C9A544458), UINT64_C(0x0007423068D875B5)},
2996          {UINT64_C(0x00059D79EBA27F83), UINT64_C(0x0005D19F0CBC111F),
2997           UINT64_C(0x000753952EB35496), UINT64_C(0x00062897B4108C18),
2998           UINT64_C(0x0006D7F09D866E46), UINT64_C(0x0005897E202402FA),
2999           UINT64_C(0x0001D12E39D2981C), UINT64_C(0x0004D1F9BD50FDDC),
3000           UINT64_C(0x00060754737FA4EC), UINT64_C(0x0004B66C109681C2)}},
3001         {{UINT64_C(0x00091EB3450A8B6F), UINT64_C(0x0006E67784D11649),
3002           UINT64_C(0x00052A0A75E83A4C), UINT64_C(0x0000C7EF54A33FAB),
3003           UINT64_C(0x0007E4B1F177CCAC), UINT64_C(0x000B1572C584C7B2),
3004           UINT64_C(0x0003F88F3DDE8AF6), UINT64_C(0x00055A76B8A9FEC4),
3005           UINT64_C(0x0004D726D797ABF3), UINT64_C(0x000063A37056B2C1)},
3006          {UINT64_C(0x000BEC5B8D4113B1), UINT64_C(0x0004AF1E78531E4F),
3007           UINT64_C(0x0003A706B01EA69E), UINT64_C(0x000114C7197A503E),
3008           UINT64_C(0x00068D6405B730D6), UINT64_C(0x00037F60FB050D8E),
3009           UINT64_C(0x0002625FCDD6414D), UINT64_C(0x0000A66900D00C7B),
3010           UINT64_C(0x0007AADE957078F1), UINT64_C(0x000708B1373BF752)}},
3011     },
3012     {
3013         {{UINT64_C(0x000C3BAB92C31CE5), UINT64_C(0x00002134ECD1DE22),
3014           UINT64_C(0x000610E7706C8F42), UINT64_C(0x0004D37D742251A7),
3015           UINT64_C(0x0003F0AD3A1A8A28), UINT64_C(0x0005B53175168302),
3016           UINT64_C(0x0007812CA56B0662), UINT64_C(0x0006DBA3FECD0E65),
3017           UINT64_C(0x000488903D3A2C5C), UINT64_C(0x000356F226A3070C)},
3018          {UINT64_C(0x000C6272379969A8), UINT64_C(0x000030E999753799),
3019           UINT64_C(0x00006FA2FD45CF73), UINT64_C(0x0005B8B69287AF76),
3020           UINT64_C(0x0005213C07A81179), UINT64_C(0x0008D822B335452D),
3021           UINT64_C(0x000011E080D0121B), UINT64_C(0x000337047AED499C),
3022           UINT64_C(0x0005F3F0DAE82068), UINT64_C(0x000287D13EDC6853)}},
3023         {{UINT64_C(0x000890BAE3CD0A60), UINT64_C(0x0007CFCB31DC10E6),
3024           UINT64_C(0x00042A0AD557A444), UINT64_C(0x0005E3E8DEDD318E),
3025           UINT64_C(0x0004B768FB3B1B2D), UINT64_C(0x000A74BE0F89CA10),
3026           UINT64_C(0x0003022817A331F0), UINT64_C(0x000398531778D3CE),
3027           UINT64_C(0x0003F92B536499CA), UINT64_C(0x00039BBC19367C44)},
3028          {UINT64_C(0x0003D17E79CF10DA), UINT64_C(0x00041C136308597C),
3029           UINT64_C(0x0001C7CFCC962C3F), UINT64_C(0x0005F7010BF5A11D),
3030           UINT64_C(0x00018E8314AB3E4C), UINT64_C(0x000B784160490F36),
3031           UINT64_C(0x00002C72D731F23C), UINT64_C(0x00059E1083EF050E),
3032           UINT64_C(0x00029D7C307711F7), UINT64_C(0x00028978EEF174D0)}},
3033         {{UINT64_C(0x0000B2EDE471ED48), UINT64_C(0x00049FF7F87A8FDE),
3034           UINT64_C(0x000407DAC8E66330), UINT64_C(0x00017A99137DCD53),
3035           UINT64_C(0x000413D5BA8A3E49), UINT64_C(0x00069E2849ED7ACF),
3036           UINT64_C(0x00011A49582E3C16), UINT64_C(0x0003EF82C8E245ED),
3037           UINT64_C(0x0002209E0B7EA09E), UINT64_C(0x000640B26788B817)},
3038          {UINT64_C(0x000FB77EC4895293), UINT64_C(0x000521EE12FEC7C5),
3039           UINT64_C(0x0006B87272F0F4BE), UINT64_C(0x000743571A70D3FA),
3040           UINT64_C(0x00012A853508E676), UINT64_C(0x000C8E90D720C744),
3041           UINT64_C(0x0004E53325BF55D5), UINT64_C(0x00022141D2FC04DE),
3042           UINT64_C(0x0002C08E37CCB8A9), UINT64_C(0x0005B2FF2928CA19)}},
3043         {{UINT64_C(0x00093112664E6955), UINT64_C(0x000318FAC599B3B0),
3044           UINT64_C(0x0004E86FFA5DC372), UINT64_C(0x00011CEA6B7ED8B5),
3045           UINT64_C(0x00032C5BB4D4B3E4), UINT64_C(0x00012FAB789556A8),
3046           UINT64_C(0x0005FD6D51C50C39), UINT64_C(0x0001F53B8DF4EB2C),
3047           UINT64_C(0x0003DC5A71DF97A9), UINT64_C(0x000202CBFD6A2695)},
3048          {UINT64_C(0x000A8D3B3805ED4E), UINT64_C(0x0006E97BF7B19A75),
3049           UINT64_C(0x000020C8EF1A157A), UINT64_C(0x0000DDAD96ECC141),
3050           UINT64_C(0x000634B69890E950), UINT64_C(0x000BCFBDA6464E18),
3051           UINT64_C(0x00057A50EC40E5E7), UINT64_C(0x000369C5C34E75A1),
3052           UINT64_C(0x0001DDDA57109D52), UINT64_C(0x000109C8DA359727)}},
3053         {{UINT64_C(0x000DC858E40E2D09), UINT64_C(0x0006583010E4FCF5),
3054           UINT64_C(0x0005616E9FBECEE8), UINT64_C(0x0004CC7EC96FFCA8),
3055           UINT64_C(0x0005436EDC94F6C0), UINT64_C(0x0001BFB47EC04EC2),
3056           UINT64_C(0x000353148F9B2046), UINT64_C(0x0002E68773E2D458),
3057           UINT64_C(0x000128904A0917E3), UINT64_C(0x0007E5A730228042)},
3058          {UINT64_C(0x000447DEFB88BB4F), UINT64_C(0x00012D87179A012D),
3059           UINT64_C(0x0002379DFC6577E4), UINT64_C(0x000646EB1BA5867E),
3060           UINT64_C(0x0004927A6707CB7F), UINT64_C(0x000F2F4B5DD2C056),
3061           UINT64_C(0x000148E5C0EB9590), UINT64_C(0x000022E829ADA8D2),
3062           UINT64_C(0x00066C299B36127A), UINT64_C(0x000208ACAE17BA18)}},
3063         {{UINT64_C(0x0003FD0BE2AFDA6A), UINT64_C(0x00079A3A05AFE09A),
3064           UINT64_C(0x00024431B9238AF6), UINT64_C(0x000196CDCEEABC5D),
3065           UINT64_C(0x0005CD6BA856B384), UINT64_C(0x0003376ABB9C7D13),
3066           UINT64_C(0x0000E28403D233B1), UINT64_C(0x0001E3E601F20B20),
3067           UINT64_C(0x000553A7F33316D7), UINT64_C(0x00077A41CF9D1895)},
3068          {UINT64_C(0x00018114833694B4), UINT64_C(0x00066ACE25DEC0AC),
3069           UINT64_C(0x000000AD04607BBE), UINT64_C(0x0001C2BBD9D88ED5),
3070           UINT64_C(0x000207EF8CDA325D), UINT64_C(0x0008C36267211FB6),
3071           UINT64_C(0x0004148ABE972485), UINT64_C(0x00032559C1C5BC5F),
3072           UINT64_C(0x0000D7CC34EB0616), UINT64_C(0x0006CFEBFC675164)}},
3073         {{UINT64_C(0x0006391786A18B11), UINT64_C(0x00072B22981C2BBC),
3074           UINT64_C(0x00064B2DCDABB7B4), UINT64_C(0x000307055034DD3A),
3075           UINT64_C(0x00051C4CAE5629B9), UINT64_C(0x0007AAF27949F035),
3076           UINT64_C(0x0002346889D53C01), UINT64_C(0x0006F67E4A19CA62),
3077           UINT64_C(0x000331666606352F), UINT64_C(0x0005374DF049C2AC)},
3078          {UINT64_C(0x0002B2B3139457D6), UINT64_C(0x000351A98E4D4EB2),
3079           UINT64_C(0x0003DC00C4EBC1E7), UINT64_C(0x00017CA9107B252F),
3080           UINT64_C(0x0007D9A4523CFBEB), UINT64_C(0x00037F677495611A),
3081           UINT64_C(0x00032ACDFB65FA6E), UINT64_C(0x000005C03EBCCAC4),
3082           UINT64_C(0x00044D67340F21A9), UINT64_C(0x0006F83F5FED3656)}},
3083         {{UINT64_C(0x000E79AA3546F16F), UINT64_C(0x0000A94AF4903B11),
3084           UINT64_C(0x0005BFBC2B88E83A), UINT64_C(0x0001616214CA6D22),
3085           UINT64_C(0x0002F33B14AC87D4), UINT64_C(0x000DC3668AC17EC3),
3086           UINT64_C(0x0003F9A5CD0FA18C), UINT64_C(0x00012136A765687B),
3087           UINT64_C(0x000477263FD5ADD5), UINT64_C(0x00047574A89B0A9F)},
3088          {UINT64_C(0x00086FD1F3EC5E19), UINT64_C(0x0001A0517754F902),
3089           UINT64_C(0x0003FBB71A4EF414), UINT64_C(0x00060C166C23D6D5),
3090           UINT64_C(0x0003CB4401A452C9), UINT64_C(0x00084139B2A26F87),
3091           UINT64_C(0x000194184853F0AF), UINT64_C(0x000725C3E883547A),
3092           UINT64_C(0x00007311B46CFE9E), UINT64_C(0x0006272C00057E36)}},
3093         {{UINT64_C(0x00091526FAFA38D9), UINT64_C(0x00013C7B17BEB483),
3094           UINT64_C(0x0005FBC53CC1E78B), UINT64_C(0x0000C1040CBB5D8E),
3095           UINT64_C(0x0003A0AF18FC9ADE), UINT64_C(0x0007BC9B9B737A51),
3096           UINT64_C(0x00058EAEC3E9FED9), UINT64_C(0x0000D346CF710790),
3097           UINT64_C(0x0003BE2B75105FA1), UINT64_C(0x0004D079255CE7B8)},
3098          {UINT64_C(0x00006C7D92D0825D), UINT64_C(0x00027A8C0386749E),
3099           UINT64_C(0x0001C5B09D0FC792), UINT64_C(0x0002C2B760A9C963),
3100           UINT64_C(0x0001524437DB7579), UINT64_C(0x0001B37F4B60ABD4),
3101           UINT64_C(0x0007FE579406D534), UINT64_C(0x0002739C0C35BD00),
3102           UINT64_C(0x00051086E45FFF04), UINT64_C(0x0003F4C9935FE354)}},
3103         {{UINT64_C(0x0004E5D268BD8A83), UINT64_C(0x000377586FC26AA0),
3104           UINT64_C(0x00030113A02CBC64), UINT64_C(0x000692EB25CA12F0),
3105           UINT64_C(0x0001A47E293F9D79), UINT64_C(0x000DD2612D416AA9),
3106           UINT64_C(0x00019FAC853D7BDD), UINT64_C(0x00001B9C4E8811EC),
3107           UINT64_C(0x000164570C0AABCB), UINT64_C(0x0002DBCACCC287E8)},
3108          {UINT64_C(0x00027EADFBCEA391), UINT64_C(0x000406BA866FB97C),
3109           UINT64_C(0x000250E70AA28457), UINT64_C(0x0000CE5D6B77F502),
3110           UINT64_C(0x0007E1FE982DC604), UINT64_C(0x00077DC8CD9AEDE3),
3111           UINT64_C(0x0006EECC4E8C56CC), UINT64_C(0x000529E001D51C07),
3112           UINT64_C(0x0000D42CF53B5E54), UINT64_C(0x00059F46F2041F90)}},
3113         {{UINT64_C(0x000A993579C46A7C), UINT64_C(0x0003FADB3C50214A),
3114           UINT64_C(0x0007552587801072), UINT64_C(0x00008E9ED9922E64),
3115           UINT64_C(0x0001D65D1FE863B0), UINT64_C(0x000B68B2D984977E),
3116           UINT64_C(0x00026F8BCC4EF71E), UINT64_C(0x0004580D2CF9C07C),
3117           UINT64_C(0x0005F7DB9F7C5608), UINT64_C(0x00039723A14ADB8F)},
3118          {UINT64_C(0x0001FC8374852517), UINT64_C(0x0004EFCD85E78688),
3119           UINT64_C(0x0005BA5C6E340E04), UINT64_C(0x0002AD5541C4F7E0),
3120           UINT64_C(0x0007AFEAD74D7911), UINT64_C(0x000772EEA94A657C),
3121           UINT64_C(0x000372BB0B3340C5), UINT64_C(0x0002DFFC3FE428C3),
3122           UINT64_C(0x0007780B19634458), UINT64_C(0x000396C2E8AD8E1B)}},
3123         {{UINT64_C(0x000A0DC2AEA8D665), UINT64_C(0x000497C1A0EAAB74),
3124           UINT64_C(0x00034918630C5E96), UINT64_C(0x00021960961A8492),
3125           UINT64_C(0x00056059C4ACA995), UINT64_C(0x000FDDE1D84A2BCA),
3126           UINT64_C(0x0003E28D6D947C37), UINT64_C(0x00059FA17EA39CB1),
3127           UINT64_C(0x0002B2B829872434), UINT64_C(0x0001AD4DAEAA9FE2)},
3128          {UINT64_C(0x000F2E4853E5AF32), UINT64_C(0x0004693D39964BD6),
3129           UINT64_C(0x0006A84B327FFE47), UINT64_C(0x0002F3C1238E197A),
3130           UINT64_C(0x0003790974398BDF), UINT64_C(0x000FF31F3581AF07),
3131           UINT64_C(0x0004C239726330EE), UINT64_C(0x0002C366AFC8A963),
3132           UINT64_C(0x0005B30D24500CBF), UINT64_C(0x0007D9C6B29592A1)}},
3133         {{UINT64_C(0x000E71DDD57E8296), UINT64_C(0x000346C03100FF87),
3134           UINT64_C(0x00046A920C6C7EF3), UINT64_C(0x00017883AE0679DA),
3135           UINT64_C(0x0007371362C409A2), UINT64_C(0x0003F3FD0398532B),
3136           UINT64_C(0x00047C47A292C97E), UINT64_C(0x0003E20A94F0DAB2),
3137           UINT64_C(0x000615A39700E27A), UINT64_C(0x0004DD4F52D80B70)},
3138          {UINT64_C(0x000D8189C3E7FF9B), UINT64_C(0x0006A323F12ACCE3),
3139           UINT64_C(0x000218561CEBE916), UINT64_C(0x000582DFFA5B6244),
3140           UINT64_C(0x00017E86803253FE), UINT64_C(0x000F6E066437E671),
3141           UINT64_C(0x00003379D07B3571), UINT64_C(0x00028E80792D0F88),
3142           UINT64_C(0x0003ADB5E00F7D48), UINT64_C(0x0004490947B64CC1)}},
3143         {{UINT64_C(0x000966BA117EB5A0), UINT64_C(0x0003EAD0F9635F78),
3144           UINT64_C(0x0001127434D7F565), UINT64_C(0x000166F7EFE73A42),
3145           UINT64_C(0x0006E1EB3EE2C95B), UINT64_C(0x0002169A44ADD28F),
3146           UINT64_C(0x0007D099F80F5E40), UINT64_C(0x00001673EEDC2717),
3147           UINT64_C(0x0006D35CE7C87042), UINT64_C(0x0001F1659FA895C4)},
3148          {UINT64_C(0x0000CDA418AFEEA2), UINT64_C(0x00022BB4CD3D78EA),
3149           UINT64_C(0x0007CCB3C8415D6C), UINT64_C(0x00072FAD0144A08F),
3150           UINT64_C(0x0006AD7BD312743A), UINT64_C(0x0009717E7E313571),
3151           UINT64_C(0x00030507C307B184), UINT64_C(0x00037E8A184867EE),
3152           UINT64_C(0x0005A0F950ED5715), UINT64_C(0x00035FB26907AA86)}},
3153         {{UINT64_C(0x00087069CFCD15C6), UINT64_C(0x0005E74CAE8DD69A),
3154           UINT64_C(0x00077415248EC6CF), UINT64_C(0x00039CFB19D98136),
3155           UINT64_C(0x0004102ADA4617F0), UINT64_C(0x00091344A9950D43),
3156           UINT64_C(0x0007F37FAA893404), UINT64_C(0x0000894C6ED07059),
3157           UINT64_C(0x0001CBD2D8C191AE), UINT64_C(0x0005E7D0A8D6C1FB)},
3158          {UINT64_C(0x000D8A6DCD86A648), UINT64_C(0x00069DFB00FAC67A),
3159           UINT64_C(0x00055E4E4A8BF53E), UINT64_C(0x00052C3F21F19F1A),
3160           UINT64_C(0x000199681E75B076), UINT64_C(0x000B461379ABA50E),
3161           UINT64_C(0x00027C35B013932E), UINT64_C(0x0003E43D98DC3C8B),
3162           UINT64_C(0x0005299D0D27C3FF), UINT64_C(0x000501003FB5C76B)}},
3163         {{UINT64_C(0x0002584D9F215747), UINT64_C(0x0007BE751EE9975B),
3164           UINT64_C(0x0006739CFFA040AB), UINT64_C(0x00021F693AB51286),
3165           UINT64_C(0x0004378F5B99BA03), UINT64_C(0x00092021DCD03E29),
3166           UINT64_C(0x00029C3D833529D1), UINT64_C(0x0003218DAA201C66),
3167           UINT64_C(0x00068DD2830252B2), UINT64_C(0x0000C547881361FE)},
3168          {UINT64_C(0x0004DA1DDF2727C5), UINT64_C(0x000141088C10F286),
3169           UINT64_C(0x00033EFA65C7AD64), UINT64_C(0x000309E225C521F2),
3170           UINT64_C(0x000165C50DA477FD), UINT64_C(0x0006A39D52AC02AF),
3171           UINT64_C(0x000583FDD7E42212), UINT64_C(0x00049409EBFF68E5),
3172           UINT64_C(0x0003F0AC36D8B5F7), UINT64_C(0x0007F9BFC22F82AF)}},
3173     },
3174     {
3175         {{UINT64_C(0x0002372DBC024334), UINT64_C(0x0003AC04780C37E6),
3176           UINT64_C(0x0000B462B14E1199), UINT64_C(0x000789AB88A9152C),
3177           UINT64_C(0x0004669A83086007), UINT64_C(0x0002875233E2BB95),
3178           UINT64_C(0x000164D14E6DD133), UINT64_C(0x0007834C96D7F2E1),
3179           UINT64_C(0x0000376AF8A1FB72), UINT64_C(0x00025E655DD42C55)},
3180          {UINT64_C(0x000BC3F8D59BD4F8), UINT64_C(0x0004295AE12759FE),
3181           UINT64_C(0x0001710B8788649D), UINT64_C(0x00063FB5252144E8),
3182           UINT64_C(0x0000FB67B48BFB15), UINT64_C(0x000EF2243C620B1A),
3183           UINT64_C(0x00043471BAB61989), UINT64_C(0x000297865EB6854C),
3184           UINT64_C(0x00041EC649B840B6), UINT64_C(0x0000DBB860FE03FD)}},
3185         {{UINT64_C(0x000F3F668337995A), UINT64_C(0x0000D23F1A076787),
3186           UINT64_C(0x000559B19C7D6F35), UINT64_C(0x0001F5D63B1D816A),
3187           UINT64_C(0x0004919133B61F8E), UINT64_C(0x00031862225D9C14),
3188           UINT64_C(0x0003C6604EA7EF2F), UINT64_C(0x00062AF2D864BE9B),
3189           UINT64_C(0x0004E75593316CB0), UINT64_C(0x0006270C9215DEE8)},
3190          {UINT64_C(0x00079DDB43AE991A), UINT64_C(0x0000D9D288C5279D),
3191           UINT64_C(0x00010A5CE9E2122D), UINT64_C(0x0006627C1899977C),
3192           UINT64_C(0x0004545C3F73568F), UINT64_C(0x00041DA4E722FDD7),
3193           UINT64_C(0x0001D1CA3BA6C0E4), UINT64_C(0x000154DDB8B11262),
3194           UINT64_C(0x00076A8BBB916CBA), UINT64_C(0x000264F61CEB449C)}},
3195         {{UINT64_C(0x000C03E88F01C0CF), UINT64_C(0x0002DE2458CBF5D8),
3196           UINT64_C(0x00059AB57877E3A8), UINT64_C(0x000022BA99E9FF36),
3197           UINT64_C(0x0006E3D7F3651BA4), UINT64_C(0x00091A76C49112C9),
3198           UINT64_C(0x00033BFF09F31D44), UINT64_C(0x00037DF6585ECCB8),
3199           UINT64_C(0x00031E08F635DFAB), UINT64_C(0x00061B6BEEA111BC)},
3200          {UINT64_C(0x000EC7C8AED31D53), UINT64_C(0x0001C2D420733AED),
3201           UINT64_C(0x00028A0A574AB6AC), UINT64_C(0x0000C07A2A7F50B8),
3202           UINT64_C(0x000146FAE597AF65), UINT64_C(0x000BFB422415D9A7),
3203           UINT64_C(0x0003B3FAF595D88B), UINT64_C(0x00016FABFA94B1DD),
3204           UINT64_C(0x00077BD9F4E1A511), UINT64_C(0x0001ED87CB724465)}},
3205         {{UINT64_C(0x000213F3A12FADCB), UINT64_C(0x00073702A45BFCC2),
3206           UINT64_C(0x00005344B6A0BE9D), UINT64_C(0x0005780B5541C989),
3207           UINT64_C(0x0004689EA1E50219), UINT64_C(0x0005B3C5CE5DF752),
3208           UINT64_C(0x000187B449599429), UINT64_C(0x0004F3F92602410B),
3209           UINT64_C(0x00008266C08FAD01), UINT64_C(0x00006449FDC76A08)},
3210          {UINT64_C(0x0001290134E207CC), UINT64_C(0x0005FC0BF00CD133),
3211           UINT64_C(0x0005093E94846544), UINT64_C(0x0001904D36A7E4E0),
3212           UINT64_C(0x0006CFB29FCB4C43), UINT64_C(0x00021A5E794AD08A),
3213           UINT64_C(0x00049AF3B74BD0CA), UINT64_C(0x0003D12DD54A42E0),
3214           UINT64_C(0x00020F8191FC6C17), UINT64_C(0x0005271ACF2BEF13)}},
3215         {{UINT64_C(0x0003973D23C5FC40), UINT64_C(0x00022C79CF716759),
3216           UINT64_C(0x000698E37C807E96), UINT64_C(0x00061499D8A20942),
3217           UINT64_C(0x0003CA6565D1591A), UINT64_C(0x000376C82319132C),
3218           UINT64_C(0x0000AB592C414D58), UINT64_C(0x00078DCD766F3A9F),
3219           UINT64_C(0x000235326903A314), UINT64_C(0x0001C533CF655AFB)},
3220          {UINT64_C(0x000417ABAE4343FF), UINT64_C(0x0000CC1BEBE8BA73),
3221           UINT64_C(0x00035CFD9C4CD9EB), UINT64_C(0x000525DDECFE78DD),
3222           UINT64_C(0x0004018B732A3EA9), UINT64_C(0x0004158841836B35),
3223           UINT64_C(0x00013A9FC11821AB), UINT64_C(0x0001A62E3E9F6760),
3224           UINT64_C(0x00019D2F382BFC5A), UINT64_C(0x00048B8C5EE1498A)}},
3225         {{UINT64_C(0x00067BC07969E710), UINT64_C(0x00056FE1647FF971),
3226           UINT64_C(0x00056B9EC60E5571), UINT64_C(0x0004FF5FF4D6D59D),
3227           UINT64_C(0x00048349FDBC6F40), UINT64_C(0x0000EDA3EDA8889B),
3228           UINT64_C(0x0000C724742965C9), UINT64_C(0x0004CA3A42627635),
3229           UINT64_C(0x00047141B8D6F392), UINT64_C(0x0003D2FEDEAA1C29)},
3230          {UINT64_C(0x000716C803508620), UINT64_C(0x0004F95142A62BB6),
3231           UINT64_C(0x000486FEE8AA4AD7), UINT64_C(0x0007AEE5F2F7D145),
3232           UINT64_C(0x00073A3D7B302EEA), UINT64_C(0x000C31B194B33CB5),
3233           UINT64_C(0x0005E8F7E9DB0F29), UINT64_C(0x00026804A1976839),
3234           UINT64_C(0x000224312A20168B), UINT64_C(0x0004C6397AFDC614)}},
3235         {{UINT64_C(0x000B366A0560CD66), UINT64_C(0x0005ACD26E6E7D4B),
3236           UINT64_C(0x0001A29126E560EF), UINT64_C(0x00077D0A85F35263),
3237           UINT64_C(0x00066BB4F7909A61), UINT64_C(0x000089487A0F6CA2),
3238           UINT64_C(0x00004201AC59EC89), UINT64_C(0x0003517D862DA268),
3239           UINT64_C(0x0004E06334DCBFC2), UINT64_C(0x000542129BF06EDC)},
3240          {UINT64_C(0x0009AC6AC40ECFAD), UINT64_C(0x0004A4A6435450F2),
3241           UINT64_C(0x0003884DC2B01CE7), UINT64_C(0x00033DFEBB566E48),
3242           UINT64_C(0x000578290964FDAC), UINT64_C(0x00023B7A353BC889),
3243           UINT64_C(0x0005060A08B7EE8B), UINT64_C(0x0007AB7A129FEBF9),
3244           UINT64_C(0x000546502F940252), UINT64_C(0x0001DBB0164F28EF)}},
3245         {{UINT64_C(0x00018A4A75F64304), UINT64_C(0x00046FFF5757186A),
3246           UINT64_C(0x000114066ED84642), UINT64_C(0x0002551CC10C6D4D),
3247           UINT64_C(0x000402FACD10897C), UINT64_C(0x00015C0E2DCC992B),
3248           UINT64_C(0x00040E8F0EBF60EE), UINT64_C(0x000060EB6563E9C6),
3249           UINT64_C(0x0003B809A3126313), UINT64_C(0x00017A66BDC55746)},
3250          {UINT64_C(0x0009062DED579427), UINT64_C(0x00044A5F128A6E10),
3251           UINT64_C(0x000151DC6DCB8F89), UINT64_C(0x000141A87B41F52E),
3252           UINT64_C(0x0000D7A6A002BD72), UINT64_C(0x000E8B9C9303AC1F),
3253           UINT64_C(0x0001834AD28690AA), UINT64_C(0x00032ADCC504A8B7),
3254           UINT64_C(0x0000A927B2B2E93B), UINT64_C(0x0002A737885EE993)}},
3255         {{UINT64_C(0x0006BCF992E8B9F6), UINT64_C(0x00040A05E593A37A),
3256           UINT64_C(0x0003A56755FA1A2F), UINT64_C(0x0003C89364FAE34E),
3257           UINT64_C(0x0007E77DBC3D88C6), UINT64_C(0x0002ED2A5FAC8E6E),
3258           UINT64_C(0x0005FAFA89C46962), UINT64_C(0x0004DBFA31641429),
3259           UINT64_C(0x0000DB79C8D1176F), UINT64_C(0x00019941D0C3522A)},
3260          {UINT64_C(0x00041A75E1C8E526), UINT64_C(0x0004C6B783802833),
3261           UINT64_C(0x0001B562BAFECB1F), UINT64_C(0x0003E09662D4B955),
3262           UINT64_C(0x00036C04E510554C), UINT64_C(0x000E4C0F87B4805F),
3263           UINT64_C(0x00073B95C41A7C5A), UINT64_C(0x00010377BD353B8C),
3264           UINT64_C(0x0000E2A301E84DD8), UINT64_C(0x0004AA08670DB7E8)}},
3265         {{UINT64_C(0x00056A0D36E91A81), UINT64_C(0x0007AE104EAE22F7),
3266           UINT64_C(0x000377C28F77E9A6), UINT64_C(0x00077E662A50D752),
3267           UINT64_C(0x0000806A44DC69B2), UINT64_C(0x0007C6E8FEC3651E),
3268           UINT64_C(0x0003B809BA19FDFE), UINT64_C(0x0002B748E1AF6B23),
3269           UINT64_C(0x00013D51330F00A4), UINT64_C(0x000054847211A69E)},
3270          {UINT64_C(0x00012FB021D29481), UINT64_C(0x0006FA2B27174477),
3271           UINT64_C(0x0003C6438378319E), UINT64_C(0x0000FFD2B056F1C6),
3272           UINT64_C(0x0004D77E75145534), UINT64_C(0x00020A7895D994A3),
3273           UINT64_C(0x0003166E20D7EAB2), UINT64_C(0x0006B6D0CB136A52),
3274           UINT64_C(0x0002B5C30551AFC3), UINT64_C(0x00068443D6142CD4)}},
3275         {{UINT64_C(0x000408A9351DFB46), UINT64_C(0x0006B998F97E7968),
3276           UINT64_C(0x0005B54EB77BAE87), UINT64_C(0x0001D1547584B3F6),
3277           UINT64_C(0x0000DEC5666F2759), UINT64_C(0x00097223408D9F44),
3278           UINT64_C(0x0004E4F55A177F66), UINT64_C(0x000008514532470B),
3279           UINT64_C(0x0000856C14AE04B3), UINT64_C(0x00061CA70F3895B4)},
3280          {UINT64_C(0x000253C057F4BB69), UINT64_C(0x0001163F0D6F162A),
3281           UINT64_C(0x00016E781BFFB4F3), UINT64_C(0x0001F13813403F57),
3282           UINT64_C(0x000720EC959BE2A5), UINT64_C(0x00004CAD26FC8BC3),
3283           UINT64_C(0x0004430E9FD18B54), UINT64_C(0x000127BC205199CF),
3284           UINT64_C(0x0006E3D5CCB5D82C), UINT64_C(0x0002C08FFC17839E)}},
3285         {{UINT64_C(0x00038FAE0545EF38), UINT64_C(0x00053E6BB230EB0F),
3286           UINT64_C(0x0003612B0393816C), UINT64_C(0x00073B82CB17AA32),
3287           UINT64_C(0x000164306BE664B8), UINT64_C(0x0007DECB1BEAB083),
3288           UINT64_C(0x0003ABA14AB6DFEF), UINT64_C(0x0006698C134B72CB),
3289           UINT64_C(0x00048700868CEFB6), UINT64_C(0x0004DC5186706827)},
3290          {UINT64_C(0x000D284BA53E67E8), UINT64_C(0x0004F1D7F1CDA504),
3291           UINT64_C(0x000763E8AAD17850), UINT64_C(0x0003EE3C7D2B43AB),
3292           UINT64_C(0x0005EDDBD6D373C5), UINT64_C(0x000F6B7396FD7F7F),
3293           UINT64_C(0x0006367A99D09B8F), UINT64_C(0x0001571A1CD21578),
3294           UINT64_C(0x0007236B9994F1FA), UINT64_C(0x00062AA7DCD740A8)}},
3295         {{UINT64_C(0x000895A1FD8F0DA1), UINT64_C(0x0000940D048284D5),
3296           UINT64_C(0x0007059173020EB7), UINT64_C(0x00034CBCC3643F29),
3297           UINT64_C(0x00054D38DFC9A9C7), UINT64_C(0x00004D0D54222865),
3298           UINT64_C(0x0007AC3D3F2E7588), UINT64_C(0x0004BD1D9A8CC40C),
3299           UINT64_C(0x0004BA573C79363A), UINT64_C(0x0003B77EA3C0F6CE)},
3300          {UINT64_C(0x0004EA2FC4B8BA7C), UINT64_C(0x0001ADDAEDBD593B),
3301           UINT64_C(0x0007B6AB6C9FFEBE), UINT64_C(0x000246C34D52441A),
3302           UINT64_C(0x000664D1C2133D2A), UINT64_C(0x0005A8FCC6F82245),
3303           UINT64_C(0x0003C821241B7620), UINT64_C(0x0007ABB29F71AC83),
3304           UINT64_C(0x0000126E955FDD3A), UINT64_C(0x000483EA750D326E)}},
3305         {{UINT64_C(0x0003FD366EBA1606), UINT64_C(0x0002D9ABAF3B8EC5),
3306           UINT64_C(0x00011FB79452ADD0), UINT64_C(0x0004D367D2541244),
3307           UINT64_C(0x00014C5A74A4D2BE), UINT64_C(0x000BD9255862125B),
3308           UINT64_C(0x00053C3CF655527E), UINT64_C(0x000040AA6D6CB56E),
3309           UINT64_C(0x0005F328C422C551), UINT64_C(0x000635823C8498F1)},
3310          {UINT64_C(0x000B8D2832D1E4F0), UINT64_C(0x0002253CC89289E1),
3311           UINT64_C(0x0004AFE460B4CFA4), UINT64_C(0x00047F33AFB8FB72),
3312           UINT64_C(0x0003147C7881EF17), UINT64_C(0x000B142D32392AC5),
3313           UINT64_C(0x0002DB71D8F10037), UINT64_C(0x000445CB1A7CD1AC),
3314           UINT64_C(0x0005320C19EF8761), UINT64_C(0x0006956661FEB75C)}},
3315         {{UINT64_C(0x0008A4F6E3E57DAD), UINT64_C(0x00052E3220306CD3),
3316           UINT64_C(0x00016C04A243039F), UINT64_C(0x0006F0BB18CACDCB),
3317           UINT64_C(0x000061BCDE864EC1), UINT64_C(0x00029F6788292DC0),
3318           UINT64_C(0x000022F1DB885727), UINT64_C(0x00058B87F88D42DB),
3319           UINT64_C(0x00067E1B4B34B7CE), UINT64_C(0x00065DB9E57B9F40)},
3320          {UINT64_C(0x000DB97A65B73FBC), UINT64_C(0x0005DDAD4615047A),
3321           UINT64_C(0x0003254BA8C48789), UINT64_C(0x0007BDDF93DDA4BB),
3322           UINT64_C(0x0002C0DF753CF13C), UINT64_C(0x000F1261EE450629),
3323           UINT64_C(0x0001AFB00BDE3B73), UINT64_C(0x0007AD40F78FD9B6),
3324           UINT64_C(0x000275243D6431D9), UINT64_C(0x000670BF2C9CC698)}},
3325         {{UINT64_C(0x0009312A3CA8CBBC), UINT64_C(0x0000D499C81D0092),
3326           UINT64_C(0x0001F9D05BE7A579), UINT64_C(0x000262C322C0431E),
3327           UINT64_C(0x00078231853C844C), UINT64_C(0x00046A359E9EA4F7),
3328           UINT64_C(0x000490A7B54A0D2C), UINT64_C(0x0005AAE046C3E758),
3329           UINT64_C(0x00059A6FF1C516DC), UINT64_C(0x0005C2CEC2165D95)},
3330          {UINT64_C(0x000912BFF9FC238B), UINT64_C(0x0007FEBB522D20DD),
3331           UINT64_C(0x00070A32C9786B85), UINT64_C(0x0003419D9DCB4F51),
3332           UINT64_C(0x0006464E7100B7D1), UINT64_C(0x0001B5E3520C4AE3),
3333           UINT64_C(0x00019B50C7D74FC7), UINT64_C(0x0003ECE80D56DEDC),
3334           UINT64_C(0x00031A0A04910717), UINT64_C(0x0002DC124F80EA68)}},
3335     },
3336     {
3337         {{UINT64_C(0x0007FC3E471A068B), UINT64_C(0x0001F9C0BD1E7FDA),
3338           UINT64_C(0x0005B816710E054C), UINT64_C(0x000641A4989CA761),
3339           UINT64_C(0x0005868FBF10DBFA), UINT64_C(0x000AB68C9F619D52),
3340           UINT64_C(0x000610CC30529BEC), UINT64_C(0x000627D1E7BB0ABB),
3341           UINT64_C(0x000312A648EFC13F), UINT64_C(0x000720DB474C9967)},
3342          {UINT64_C(0x00088A74ECFAC532), UINT64_C(0x0000CA6C465E54E3),
3343           UINT64_C(0x00063BCCC230DDCA), UINT64_C(0x000545133A54D8A3),
3344           UINT64_C(0x000289A2A21D7DAD), UINT64_C(0x00064142FD2154C0),
3345           UINT64_C(0x0000AE8DE8498437), UINT64_C(0x0000FEE6A05C9CA4),
3346           UINT64_C(0x0005A712CADD4BD3), UINT64_C(0x00073C7C0CB9DC7E)}},
3347         {{UINT64_C(0x00014BC20D8FC866), UINT64_C(0x0001B713C72B026C),
3348           UINT64_C(0x0002BB1B00DD97B0), UINT64_C(0x0003DDF6D5D77C14),
3349           UINT64_C(0x0000018D34DBE288), UINT64_C(0x000B37E4BE21CFC1),
3350           UINT64_C(0x00042460ABD75619), UINT64_C(0x00048564EF06DBBE),
3351           UINT64_C(0x0001D0F8F700CFDF), UINT64_C(0x00050BF2E57EF201)},
3352          {UINT64_C(0x0000E7551324C838), UINT64_C(0x00013E348DFFE7EF),
3353           UINT64_C(0x0005667611C90CF1), UINT64_C(0x00054F8E74F0FE54),
3354           UINT64_C(0x00046065CFEC47E4), UINT64_C(0x00020F5CA7131E31),
3355           UINT64_C(0x00056BCD632BBD22), UINT64_C(0x0004068611AE97FE),
3356           UINT64_C(0x000342E9BF1AE60D), UINT64_C(0x00059284EE40F315)}},
3357         {{UINT64_C(0x000695C423B1830F), UINT64_C(0x000061319340E99D),
3358           UINT64_C(0x00056EECAD0FDEF4), UINT64_C(0x0001851799B6AF30),
3359           UINT64_C(0x000574BFEEC6CF78), UINT64_C(0x00090695389CAC68),
3360           UINT64_C(0x0004AD41B7692D45), UINT64_C(0x00067399705E0A02),
3361           UINT64_C(0x0004D01C657BFE93), UINT64_C(0x0007AE346F356E78)},
3362          {UINT64_C(0x0005ED517D1CECA6), UINT64_C(0x0004FA192E057F98),
3363           UINT64_C(0x00028B4C280516A2), UINT64_C(0x0000F57015483B8B),
3364           UINT64_C(0x000381A2B0925CBA), UINT64_C(0x0007EC4E45D3BCA9),
3365           UINT64_C(0x0005E6AE14D94280), UINT64_C(0x00044AA8A233553A),
3366           UINT64_C(0x000188ECFCF3FD6B), UINT64_C(0x00056CD6831AF6A1)}},
3367         {{UINT64_C(0x000BAD665FBBA51D), UINT64_C(0x0005CE5627119792),
3368           UINT64_C(0x000013618EFFC45B), UINT64_C(0x00059C97725250C5),
3369           UINT64_C(0x00034D2A31C26543), UINT64_C(0x000FC7D8B33901C2),
3370           UINT64_C(0x0004049BB70B6E8C), UINT64_C(0x000298E4AB70ACB4),
3371           UINT64_C(0x00024A67CAB12D0F), UINT64_C(0x0000658DD54DD249)},
3372          {UINT64_C(0x00018A1BE3CECA73), UINT64_C(0x0007CB9EB76F08C8),
3373           UINT64_C(0x0001B277825030CD), UINT64_C(0x0005EE5C3A83FB88),
3374           UINT64_C(0x000520DD7C104236), UINT64_C(0x0000B4C8EAC628F4),
3375           UINT64_C(0x00067414680C3CBD), UINT64_C(0x000634E9A20A30CC),
3376           UINT64_C(0x0006FCA2CD50A25E), UINT64_C(0x0003207EC54AE849)}},
3377         {{UINT64_C(0x000A7C2C9FA19751), UINT64_C(0x00032EAC1838C0AE),
3378           UINT64_C(0x000704308B256AC4), UINT64_C(0x0002462B6C4B26A1),
3379           UINT64_C(0x0002E3D83A96467F), UINT64_C(0x000FE8591432EB6A),
3380           UINT64_C(0x0003FD27EAF7B31A), UINT64_C(0x00058F724E26D47B),
3381           UINT64_C(0x00076136F099E12E), UINT64_C(0x000558F5CDCDEAA6)},
3382          {UINT64_C(0x0006ED04F333B165), UINT64_C(0x000634F9F9299870),
3383           UINT64_C(0x0006E7943903D73C), UINT64_C(0x00005689249D8E40),
3384           UINT64_C(0x00043B4AC0439BF3), UINT64_C(0x000553178FDF6D63),
3385           UINT64_C(0x000439F7375523D2), UINT64_C(0x0005F10CB0346B4A),
3386           UINT64_C(0x00004E0AE314DF84), UINT64_C(0x00069471AB5DFADA)}},
3387         {{UINT64_C(0x0000E9501E9FAFE7), UINT64_C(0x0001ED4A26197388),
3388           UINT64_C(0x0005CAA03225B2DC), UINT64_C(0x0003498CF6071DD5),
3389           UINT64_C(0x00002CF8D255A84E), UINT64_C(0x000FA75C0885DE81),
3390           UINT64_C(0x00030965CE1A47CB), UINT64_C(0x00011FB194A95BB0),
3391           UINT64_C(0x0004800A95408A73), UINT64_C(0x0002EEA35FCE3212)},
3392          {UINT64_C(0x00087C5B9DE51934), UINT64_C(0x00036D95402D7411),
3393           UINT64_C(0x00037FB02C63558B), UINT64_C(0x0006A1232CBC6C08),
3394           UINT64_C(0x0005C0E468414E24), UINT64_C(0x0007F99C0CCF2D15),
3395           UINT64_C(0x000094592332F465), UINT64_C(0x0002AB96A524CF72),
3396           UINT64_C(0x0007E87F1D99C378), UINT64_C(0x0000207DD0DD808E)}},
3397         {{UINT64_C(0x000ECD9FF97D4931), UINT64_C(0x0001D4B8B850BE44),
3398           UINT64_C(0x0006C1F7D66BFB33), UINT64_C(0x000286B0E020CE70),
3399           UINT64_C(0x00057D2D930A9035), UINT64_C(0x000F70CD43EF78D8),
3400           UINT64_C(0x0005595A2E3FB21C), UINT64_C(0x0002B23212C03281),
3401           UINT64_C(0x0006BE2A6AB3CEFB), UINT64_C(0x0007B13ACF77F80E)},
3402          {UINT64_C(0x000CB860BC601AFD), UINT64_C(0x0006ACF4F99A1471),
3403           UINT64_C(0x0006698A5886492B), UINT64_C(0x000245BF72D02C00),
3404           UINT64_C(0x00067720650A5EB3), UINT64_C(0x000D9E8B3198D8BE),
3405           UINT64_C(0x00072728DEA3F720), UINT64_C(0x0000B079DF1DF966),
3406           UINT64_C(0x000764E77F92B823), UINT64_C(0x00004721437DFB0D)}},
3407         {{UINT64_C(0x0008C47E3E9972F3), UINT64_C(0x0005F6800BF3F5AC),
3408           UINT64_C(0x00040B8943EC9A82), UINT64_C(0x00018C3DE68795BC),
3409           UINT64_C(0x000798ACD9D5C188), UINT64_C(0x000626A89DFFB9C7),
3410           UINT64_C(0x0000A446A1E585FF), UINT64_C(0x00003F9D6C0F2522),
3411           UINT64_C(0x00045DA3E3E5843E), UINT64_C(0x0001DF8788F4C149)},
3412          {UINT64_C(0x00002D1EA1F1D567), UINT64_C(0x0007D2CEB46D5CF9),
3413           UINT64_C(0x0000AE8762EDBE19), UINT64_C(0x0004D34041C698A3),
3414           UINT64_C(0x0002249A52FB7AFB), UINT64_C(0x0001AA28A184F6D0),
3415           UINT64_C(0x0004AEDC54AC0233), UINT64_C(0x0001A52FA2FE3789),
3416           UINT64_C(0x000684CDB10852C6), UINT64_C(0x000006A488535FB8)}},
3417         {{UINT64_C(0x000B69CD208922BD), UINT64_C(0x000113C0A2CDC098),
3418           UINT64_C(0x00034EB1527C9342), UINT64_C(0x0002E33524A72273),
3419           UINT64_C(0x0005D54F4B29D1BB), UINT64_C(0x000935E2895D6B59),
3420           UINT64_C(0x00002467FF51247E), UINT64_C(0x00064A19BE2B9B33),
3421           UINT64_C(0x0000CA9B34B3CC48), UINT64_C(0x0001C1179DC502AF)},
3422          {UINT64_C(0x00030DD196A35DEC), UINT64_C(0x0004F43012319797),
3423           UINT64_C(0x0003AD2F85C0A8FE), UINT64_C(0x000767B8C3625127),
3424           UINT64_C(0x0007156D91446AF4), UINT64_C(0x000A52B80B684D9E),
3425           UINT64_C(0x000493C29A3C9396), UINT64_C(0x00060B66E8B18710),
3426           UINT64_C(0x00073CE5C6E23F4E), UINT64_C(0x0000C0E9CF09DBEA)}},
3427         {{UINT64_C(0x000D847204E88E6A), UINT64_C(0x00014392C2DBD5D4),
3428           UINT64_C(0x0003647F5392D642), UINT64_C(0x00005CD6B4397528),
3429           UINT64_C(0x0003CA804BE0E6E6), UINT64_C(0x000AFA2DEBF9BDF0),
3430           UINT64_C(0x0003B70844F7F77A), UINT64_C(0x00055FD54AED8423),
3431           UINT64_C(0x0001E87463CB4E23), UINT64_C(0x0001BCB9D95AA334)},
3432          {UINT64_C(0x0008AD95903A42F5), UINT64_C(0x0002B77C076B1514),
3433           UINT64_C(0x00004EA8D39728A1), UINT64_C(0x00006196D1EAC34C),
3434           UINT64_C(0x00021AD5CD908FB5), UINT64_C(0x0009231E8FBDFA13),
3435           UINT64_C(0x0006F53F72D12265), UINT64_C(0x0004EEB89634BD92),
3436           UINT64_C(0x000467E16722B0C0), UINT64_C(0x000322B4828C8354)}},
3437         {{UINT64_C(0x000749D2D2151628), UINT64_C(0x00017DB343621D73),
3438           UINT64_C(0x000165CD9CF505C3), UINT64_C(0x0006EF002B6F7508),
3439           UINT64_C(0x0006A5B3F2EBD640), UINT64_C(0x00088918A6F47361),
3440           UINT64_C(0x00024A4CC1F89F3D), UINT64_C(0x0002A883A0915ACB),
3441           UINT64_C(0x0000B430E4311864), UINT64_C(0x0002E5AFD5631755)},
3442          {UINT64_C(0x000E6600C23AF414), UINT64_C(0x0004A68A06127530),
3443           UINT64_C(0x0000119CF5DBEFF9), UINT64_C(0x00031BD59339EC9D),
3444           UINT64_C(0x0007AFB0A0652755), UINT64_C(0x0004E54D473D5D91),
3445           UINT64_C(0x0006663BBC911425), UINT64_C(0x00060CD99F4A6814),
3446           UINT64_C(0x0004D70E317492DC), UINT64_C(0x00057C676F34207B)}},
3447         {{UINT64_C(0x000FA45FEB394F79), UINT64_C(0x0002595780239750),
3448           UINT64_C(0x0006DAEAFB6AF370), UINT64_C(0x0004F71BE680332B),
3449           UINT64_C(0x0007A2B88BEC444F), UINT64_C(0x0006D282845556D8),
3450           UINT64_C(0x0003A48753C8FEB2), UINT64_C(0x0005314A5E71A50D),
3451           UINT64_C(0x00064B67D3BEDF37), UINT64_C(0x00049BB87F9AA6E0)},
3452          {UINT64_C(0x000F9E3C83D99F56), UINT64_C(0x0002AFD6DA547B1C),
3453           UINT64_C(0x000799EBA75D7647), UINT64_C(0x00017702967C6572),
3454           UINT64_C(0x00036DAA4C258B87), UINT64_C(0x0005BAA7744D42CE),
3455           UINT64_C(0x0006706FA16409C8), UINT64_C(0x0003833BD25E3852),
3456           UINT64_C(0x0005B9B25E71D72C), UINT64_C(0x0000851A32EE02B9)}},
3457         {{UINT64_C(0x00096C7F5422B60A), UINT64_C(0x0000A451DBBE6CC7),
3458           UINT64_C(0x0004DFB70D71B03F), UINT64_C(0x00047A85B6A73205),
3459           UINT64_C(0x000552D4E655E4A4), UINT64_C(0x00026F31F95A9399),
3460           UINT64_C(0x0001C446539B5383), UINT64_C(0x000544DB6B46DF8B),
3461           UINT64_C(0x0003348ADD036467), UINT64_C(0x0000AA2D0D6935D7)},
3462          {UINT64_C(0x0007D5B7A1E58219), UINT64_C(0x0004617A5AB605AC),
3463           UINT64_C(0x0006A6AF7E81B995), UINT64_C(0x00042EE78EACBEE0),
3464           UINT64_C(0x00049DD85014D117), UINT64_C(0x0009591FD9314E76),
3465           UINT64_C(0x0005DB569F458EB8), UINT64_C(0x00051D4F2503D183),
3466           UINT64_C(0x00063FBB28BA6AD3), UINT64_C(0x0006D3AC67CC821C)}},
3467         {{UINT64_C(0x000DB3F243061D75), UINT64_C(0x0006D73931E621F2),
3468           UINT64_C(0x0000B17170E27A4D), UINT64_C(0x00004483B525B3B3),
3469           UINT64_C(0x0000CEC6BF188345), UINT64_C(0x00028C93F5247B6F),
3470           UINT64_C(0x0004A6511A5DEF06), UINT64_C(0x00076B62AEAC63B1),
3471           UINT64_C(0x00074A604ED95C71), UINT64_C(0x00009EFCC184826A)},
3472          {UINT64_C(0x0008BAC2B060443D), UINT64_C(0x000344E9D3B2EEA9),
3473           UINT64_C(0x00020435D407DCEB), UINT64_C(0x00022E3643D85699),
3474           UINT64_C(0x0001A1F508400E9C), UINT64_C(0x000D7CC9B1AC0494),
3475           UINT64_C(0x0004C1AD9E2EB052), UINT64_C(0x00009FBD9B150459),
3476           UINT64_C(0x000369468497704F), UINT64_C(0x0003FF2AC90D8014)}},
3477         {{UINT64_C(0x000F26B79E392352), UINT64_C(0x0002B957BF938557),
3478           UINT64_C(0x000715D0978BD2B2), UINT64_C(0x00045531E667D86D),
3479           UINT64_C(0x00038962FCA00EDE), UINT64_C(0x000DC1791F176B3F),
3480           UINT64_C(0x000743403651C9FA), UINT64_C(0x0004ABD020A84523),
3481           UINT64_C(0x0006DECB17845C69), UINT64_C(0x0003DF12469D37F5)},
3482          {UINT64_C(0x000FA8419C8A9D27), UINT64_C(0x000768869058EE8E),
3483           UINT64_C(0x0000D174A1CB1143), UINT64_C(0x00070F67326B9037),
3484           UINT64_C(0x00026979FA59E935), UINT64_C(0x000F4AA12B6BC96F),
3485           UINT64_C(0x000606751117A342), UINT64_C(0x00047A115AF10FB7),
3486           UINT64_C(0x0006DF7816619F79), UINT64_C(0x00072158DA5671BF)}},
3487         {{UINT64_C(0x000ECAFE87CBB23D), UINT64_C(0x000512A524D4D77C),
3488           UINT64_C(0x0005FF1AF3F9CDCC), UINT64_C(0x0005A5222E7CCBCA),
3489           UINT64_C(0x00037F25D366C5D3), UINT64_C(0x000DEE9CD4A0BD44),
3490           UINT64_C(0x0001BA906B38FE5F), UINT64_C(0x0002479A4422043C),
3491           UINT64_C(0x0007F85530950F05), UINT64_C(0x00026843F9CA979A)},
3492          {UINT64_C(0x000E6EBFB1D7D79A), UINT64_C(0x0001962262421C26),
3493           UINT64_C(0x000749C75E0896B7), UINT64_C(0x00072656E0591FB4),
3494           UINT64_C(0x00048C25570B4B5D), UINT64_C(0x000C0F6689F57006),
3495           UINT64_C(0x000106B77BE98B19), UINT64_C(0x00070FD9ADA250C6),
3496           UINT64_C(0x0004B2AC835CA2CF), UINT64_C(0x0005FD38C57539D3)}},
3497     },
3498     {
3499         {{UINT64_C(0x00078CF823118058), UINT64_C(0x000084E70B90249E),
3500           UINT64_C(0x000340E63640803E), UINT64_C(0x000259F3BA46031B),
3501           UINT64_C(0x0004025A533D8FB6), UINT64_C(0x00021525975D8B46),
3502           UINT64_C(0x00016415CB875BF3), UINT64_C(0x00037D3C94CF88C2),
3503           UINT64_C(0x0001303423D046C3), UINT64_C(0x00064D6CA6CF50E4)},
3504          {UINT64_C(0x0001C4F51365236C), UINT64_C(0x00074C650114C6D7),
3505           UINT64_C(0x00030B74EB231DBC), UINT64_C(0x000108DDE7A79F07),
3506           UINT64_C(0x0005C84883DAAC53), UINT64_C(0x000F4FFFB87D65C4),
3507           UINT64_C(0x0003A077D6424776), UINT64_C(0x00074EF17A8FF930),
3508           UINT64_C(0x0001C70531DAACC1), UINT64_C(0x0004FDAB70943349)}},
3509         {{UINT64_C(0x000D10852C9532B6), UINT64_C(0x000043AAC71DC676),
3510           UINT64_C(0x0000699B3F568856), UINT64_C(0x00062AA64E24D6D0),
3511           UINT64_C(0x0000AC30CB5E809D), UINT64_C(0x0003DF891FADF9D0),
3512           UINT64_C(0x0002E8AEFD6E009D), UINT64_C(0x000763BB5C596056),
3513           UINT64_C(0x00027648417EC3B3), UINT64_C(0x00026FFF568DBEC6)},
3514          {UINT64_C(0x00046866CD52C51B), UINT64_C(0x00074EBD129DAF5E),
3515           UINT64_C(0x0007E8A44CB2D0FF), UINT64_C(0x0001754AF2E0C3E1),
3516           UINT64_C(0x00075DF74CCBA4EB), UINT64_C(0x0007015D1AC6F756),
3517           UINT64_C(0x0007CC58CB459B84), UINT64_C(0x0004431C9AFC9478),
3518           UINT64_C(0x0001496EF18E492E), UINT64_C(0x00040F52B9782D09)}},
3519         {{UINT64_C(0x0005432D2ABFAEFB), UINT64_C(0x000219E9F74B6891),
3520           UINT64_C(0x000772FBB5A56EDD), UINT64_C(0x0003F9B32B854A6E),
3521           UINT64_C(0x0000E23A82F7F4DB), UINT64_C(0x00079910F350CA56),
3522           UINT64_C(0x0002F2CBD94634FD), UINT64_C(0x00062DE8463F621C),
3523           UINT64_C(0x00018A84A27F47AC), UINT64_C(0x000492918B0A6CFC)},
3524          {UINT64_C(0x000917028ABF0C6C), UINT64_C(0x0005885BCB7EC09C),
3525           UINT64_C(0x00007B7029F86047), UINT64_C(0x0004E980E40CB14D),
3526           UINT64_C(0x0002414620471CAF), UINT64_C(0x000638833F454BE0),
3527           UINT64_C(0x0007530E1D810E0C), UINT64_C(0x00007BC1509E4C84),
3528           UINT64_C(0x000234FE03106A25), UINT64_C(0x0007B3C1744922CE)}},
3529         {{UINT64_C(0x0001D6F26560D816), UINT64_C(0x000761F53B7DED62),
3530           UINT64_C(0x0003F63729C380A1), UINT64_C(0x0000D9AABEB1F8E4),
3531           UINT64_C(0x0002FC799030E923), UINT64_C(0x00090EB9E83FC112),
3532           UINT64_C(0x000276A6C7B64189), UINT64_C(0x0005C92C57117936),
3533           UINT64_C(0x0003A76769F60AB1), UINT64_C(0x0000214C6BFF3AB2)},
3534          {UINT64_C(0x000F91FA223FB871), UINT64_C(0x00072F8E905BA3A7),
3535           UINT64_C(0x00054D9829B0E1C4), UINT64_C(0x000041AADCD2F042),
3536           UINT64_C(0x0006B33B8DBF5DAC), UINT64_C(0x0005E138CA79ABDB),
3537           UINT64_C(0x0007F91015FD64B0), UINT64_C(0x0003E42D44B48D18),
3538           UINT64_C(0x0003070F61FC98CE), UINT64_C(0x0003ECFBC333B9A7)}},
3539         {{UINT64_C(0x000A1C5F63F4003A), UINT64_C(0x00073E65E07CAEF9),
3540           UINT64_C(0x0007EE53E05454BD), UINT64_C(0x0002832BB0CB8A80),
3541           UINT64_C(0x0007F92B5F28C3C9), UINT64_C(0x000B198CFA188FC6),
3542           UINT64_C(0x0001B4972BD5EA15), UINT64_C(0x0003371055BFF265),
3543           UINT64_C(0x00040289DB496278), UINT64_C(0x000037FB8AEF99C7)},
3544          {UINT64_C(0x0003E8BA240F2657), UINT64_C(0x000507715E41F403),
3545           UINT64_C(0x00000AC5E34F938B), UINT64_C(0x00010AC246A10935),
3546           UINT64_C(0x00035E92D9586CD7), UINT64_C(0x000A927B7C112162),
3547           UINT64_C(0x0001E320A6A23B35), UINT64_C(0x0002AEA76305FB4D),
3548           UINT64_C(0x00027FC7B4E55E7B), UINT64_C(0x0007F605FDDB3012)}},
3549         {{UINT64_C(0x0007B3BEE04C4C80), UINT64_C(0x0005EC1698F3E6D0),
3550           UINT64_C(0x00058683E8514BF8), UINT64_C(0x00003490978C1C15),
3551           UINT64_C(0x0003FD63AD3797AF), UINT64_C(0x00078C4971CAD19E),
3552           UINT64_C(0x0006E7EC2A846823), UINT64_C(0x00077586A76BAADD),
3553           UINT64_C(0x00022BF1CA7743E1), UINT64_C(0x000719DBF8CE1E82)},
3554          {UINT64_C(0x000E187887A1EB86), UINT64_C(0x0006E15CE17F34FE),
3555           UINT64_C(0x000165A9C070F6B8), UINT64_C(0x000235BE0B50B7A1),
3556           UINT64_C(0x0000701631632860), UINT64_C(0x0001520CD1B97E69),
3557           UINT64_C(0x000324D126195433), UINT64_C(0x000695BD1FBD3083),
3558           UINT64_C(0x0007D0E98F84E4E6), UINT64_C(0x000076D0FD61BE2C)}},
3559         {{UINT64_C(0x0001C135C074F082), UINT64_C(0x0001B1C98964C70E),
3560           UINT64_C(0x00070F16F51C63DE), UINT64_C(0x00065C546121FD21),
3561           UINT64_C(0x0006E0EA00711AC1), UINT64_C(0x00019C4ED64CA43A),
3562           UINT64_C(0x0007B5F5DE4D83CD), UINT64_C(0x0004A3289E196D3B),
3563           UINT64_C(0x000379BD42718428), UINT64_C(0x00028B586AD8AC43)},
3564          {UINT64_C(0x00081CF90B74F2A0), UINT64_C(0x0002D685FCE339CF),
3565           UINT64_C(0x00029BACF289048F), UINT64_C(0x00031B11C9F022B9),
3566           UINT64_C(0x000723747A599137), UINT64_C(0x00008CAE4A9C10E7),
3567           UINT64_C(0x000252D22A179598), UINT64_C(0x000462BF1945C2A5),
3568           UINT64_C(0x0005E7BF4B6F8B7E), UINT64_C(0x0004A5CC544E7A94)}},
3569         {{UINT64_C(0x0002CE082C195DF7), UINT64_C(0x0000B2902F1DD4F4),
3570           UINT64_C(0x0002EBCE1E8E6C3E), UINT64_C(0x0003DBB93DD984FC),
3571           UINT64_C(0x000294BCFA46D91A), UINT64_C(0x000E47F5EB6C49F2),
3572           UINT64_C(0x00027D01A275F685), UINT64_C(0x0002A8AB31F7A7C5),
3573           UINT64_C(0x000065DEDCCEB9FE), UINT64_C(0x0007EE40D2F05D3F)},
3574          {UINT64_C(0x000AA9F92E841F87), UINT64_C(0x00025B8A866BCAA0),
3575           UINT64_C(0x000456616AD0616E), UINT64_C(0x000019C95CBF2929),
3576           UINT64_C(0x00018B84E8563743), UINT64_C(0x000D9BBA3F123075),
3577           UINT64_C(0x0003C88C52754F28), UINT64_C(0x0002A84A28E16C62),
3578           UINT64_C(0x00006C4CBF9BD1BE), UINT64_C(0x00014E2ED761883C)}},
3579         {{UINT64_C(0x000DD43327A5EC62), UINT64_C(0x00037A88C2CE8F10),
3580           UINT64_C(0x00079FB7AF273687), UINT64_C(0x0005C217AE2F9294),
3581           UINT64_C(0x0007B658E58E2D4D), UINT64_C(0x0001B9F8E201BDE2),
3582           UINT64_C(0x00003AF8B1C4F58C), UINT64_C(0x000023F0302D4943),
3583           UINT64_C(0x0000F016949D42FE), UINT64_C(0x0005DA77793E30DF)},
3584          {UINT64_C(0x0009A4A03292A077), UINT64_C(0x0005E38597159B13),
3585           UINT64_C(0x000438CD4AA3B94B), UINT64_C(0x00039E50FBBA527D),
3586           UINT64_C(0x00032E5CFA99121B), UINT64_C(0x000CE6179D42746B),
3587           UINT64_C(0x000201FC90B2780E), UINT64_C(0x0002129922687B60),
3588           UINT64_C(0x0001410E58988022), UINT64_C(0x0005E3F21AE57B91)}},
3589         {{UINT64_C(0x000EE44D178CCA07), UINT64_C(0x0002290775707084),
3590           UINT64_C(0x000256E01D88B556), UINT64_C(0x0001EF98ED0CEE11),
3591           UINT64_C(0x0003BD6824481F73), UINT64_C(0x000BAAFD1FEBD7AB),
3592           UINT64_C(0x0006C5370AC07A93), UINT64_C(0x00039FFED4B7C601),
3593           UINT64_C(0x00039A6B4153D857), UINT64_C(0x00077A6BC55E5234)},
3594          {UINT64_C(0x000816AA9A09968B), UINT64_C(0x0007BDB9C7F2EAF9),
3595           UINT64_C(0x00032ACE09E1CBDC), UINT64_C(0x000522E8C19D3EEB),
3596           UINT64_C(0x0003827A069B97BD), UINT64_C(0x0006716F9981A71A),
3597           UINT64_C(0x000554503B7BA012), UINT64_C(0x000074637BF2E394),
3598           UINT64_C(0x000615A2194548E8), UINT64_C(0x000006C523A794B4)}},
3599         {{UINT64_C(0x000A0B318735C445), UINT64_C(0x00055C3BC1A59729),
3600           UINT64_C(0x000355C87CF06A80), UINT64_C(0x0000ABBB95628B32),
3601           UINT64_C(0x00073A2D28549A3A), UINT64_C(0x000CC8F16C0B5FB6),
3602           UINT64_C(0x0005190FEF2C780C), UINT64_C(0x000485C8686725FF),
3603           UINT64_C(0x000212610F06DB7C), UINT64_C(0x000186C78ED4F0AC)},
3604          {UINT64_C(0x00051A0699ABFB29), UINT64_C(0x0004079D38322CB8),
3605           UINT64_C(0x0004E0C463922EE4), UINT64_C(0x0005EC25735A7F4C),
3606           UINT64_C(0x00030ACD8B3755D5), UINT64_C(0x0004533C09F622E8),
3607           UINT64_C(0x00065BD64578113C), UINT64_C(0x000011679C79532B),
3608           UINT64_C(0x000270C486D96F98), UINT64_C(0x00064FCDA161257D)}},
3609         {{UINT64_C(0x000A95E15137A104), UINT64_C(0x000184008DF11135),
3610           UINT64_C(0x00005609A6FCBD2E), UINT64_C(0x0004EDFE7BC6F8F9),
3611           UINT64_C(0x00053CA3D1760E75), UINT64_C(0x000EA2FB5A31F0F3),
3612           UINT64_C(0x00077ABE20D50F91), UINT64_C(0x0007C0E34B46F175),
3613           UINT64_C(0x0007A94E7592DB90), UINT64_C(0x000249BEAED5FC42)},
3614          {UINT64_C(0x000F85AF26A73A5A), UINT64_C(0x0002B83D21F3C411),
3615           UINT64_C(0x000069FD92DFF608), UINT64_C(0x000407178D3E9436),
3616           UINT64_C(0x0000D6C1A603C407), UINT64_C(0x000C556CBD53BF39),
3617           UINT64_C(0x0000802C8ABE0ADC), UINT64_C(0x00024A5E6F60B0DA),
3618           UINT64_C(0x0007DB9843929DA3), UINT64_C(0x0001FF410E9D19C7)}},
3619         {{UINT64_C(0x00094E812DBE8C32), UINT64_C(0x0006D33ED80BCDA2),
3620           UINT64_C(0x00002D936BC7580C), UINT64_C(0x00043D349744E6D4),
3621           UINT64_C(0x00020A0DEB1F77B4), UINT64_C(0x00031B3519BBF1AA),
3622           UINT64_C(0x0007A520ED4CEF61), UINT64_C(0x000043394E7A87E8),
3623           UINT64_C(0x00040764584AEB95), UINT64_C(0x0003155C9B8CCF57)},
3624          {UINT64_C(0x000C17DA9E28ADF8), UINT64_C(0x0003424BBFF78B37),
3625           UINT64_C(0x0003CC6A19FFC5FF), UINT64_C(0x0002CB497A44C566),
3626           UINT64_C(0x00022DDAD26DE223), UINT64_C(0x000AC080F18A0065),
3627           UINT64_C(0x000575057C11015D), UINT64_C(0x00078021729DE91B),
3628           UINT64_C(0x0005796ED9E76DA3), UINT64_C(0x0006FE4AB6E74734)}},
3629         {{UINT64_C(0x0005F849D235CCE0), UINT64_C(0x000436E70A0D70E1),
3630           UINT64_C(0x00035E68AA2BDD02), UINT64_C(0x0003E7FE63874EA2),
3631           UINT64_C(0x00026C88F7884563), UINT64_C(0x000FCD9BAE21D5B1),
3632           UINT64_C(0x0005C69101494E3A), UINT64_C(0x00037DB907EEE3A2),
3633           UINT64_C(0x00064C59AE199A08), UINT64_C(0x00039423CE12F5BB)},
3634          {UINT64_C(0x0000AAAF7EEE09F7), UINT64_C(0x0004C5314B2C4D75),
3635           UINT64_C(0x0003EC74B3A6D36C), UINT64_C(0x000620CA51245767),
3636           UINT64_C(0x00044F419AE83224), UINT64_C(0x00080A722E02A693),
3637           UINT64_C(0x0007A360EBC5DBD9), UINT64_C(0x000381727BCF6E58),
3638           UINT64_C(0x000617B700F3ADF6), UINT64_C(0x0000FA1A09F64950)}},
3639         {{UINT64_C(0x00096F84C0BDFF5B), UINT64_C(0x0006E5B26C5065BB),
3640           UINT64_C(0x0001952942E39562), UINT64_C(0x000653E9892230FF),
3641           UINT64_C(0x0000F763C13E4999), UINT64_C(0x0009F0784B215E56),
3642           UINT64_C(0x000270D42201B3A3), UINT64_C(0x00045740B9AF7F09),
3643           UINT64_C(0x000229B251B5D908), UINT64_C(0x000657F560FDA230)},
3644          {UINT64_C(0x00031EFD1B4B981B), UINT64_C(0x0007B1F5B3F7B1EA),
3645           UINT64_C(0x000170AF323B8DC9), UINT64_C(0x00055F77521B9F83),
3646           UINT64_C(0x0003B381A7CCCC0F), UINT64_C(0x00086767112D35DD),
3647           UINT64_C(0x0000C15A5CC603CB), UINT64_C(0x00026C0095FA28DE),
3648           UINT64_C(0x0005178C03D1D4CC), UINT64_C(0x0006A499CD28196A)}},
3649         {{UINT64_C(0x0009617A9ECA8281), UINT64_C(0x0002F03DC8FC403F),
3650           UINT64_C(0x0005A200AB22733A), UINT64_C(0x000402BA3A81D989),
3651           UINT64_C(0x0006690A4DAA9371), UINT64_C(0x0001CC8F6D90CC2C),
3652           UINT64_C(0x000293AC50B59125), UINT64_C(0x0004D1A882B9D469),
3653           UINT64_C(0x00014C4DF2707168), UINT64_C(0x0005A3C384944E0D)},
3654          {UINT64_C(0x000B2CD4D51F74FF), UINT64_C(0x00021EB289F478F1),
3655           UINT64_C(0x0004BF9CA3A7AC0A), UINT64_C(0x0003DB4F626C2310),
3656           UINT64_C(0x0005CBF13B00CCC4), UINT64_C(0x00029073A697E0B9),
3657           UINT64_C(0x0002C5D67FD6CD73), UINT64_C(0x0005D10BAA363615),
3658           UINT64_C(0x000051A608EA619E), UINT64_C(0x0004155A6B02D3FB)}},
3659     },
3660     {
3661         {{UINT64_C(0x000B63BE2E2471B6), UINT64_C(0x000793F7C56B8C12),
3662           UINT64_C(0x00003A61A28C6343), UINT64_C(0x00073E8EF4E8B82C),
3663           UINT64_C(0x000770A1A8474CE7), UINT64_C(0x000B2231CECAFDB4),
3664           UINT64_C(0x0006E5A738D66F01), UINT64_C(0x0002489688C31B78),
3665           UINT64_C(0x00060068F8F76B83), UINT64_C(0x0003D6F5D74A6F06)},
3666          {UINT64_C(0x0002EEDB0339BF8A), UINT64_C(0x0006213ECE2A8CBB),
3667           UINT64_C(0x0006876AC31EC71D), UINT64_C(0x0001ADFE07733CDB),
3668           UINT64_C(0x000192FE0B2619CE), UINT64_C(0x00000B3F7CB6D64F),
3669           UINT64_C(0x000193DD7BC97D28), UINT64_C(0x0005572F38C9E619),
3670           UINT64_C(0x000117122583880C), UINT64_C(0x0003F2E95F7AD5BD)}},
3671         {{UINT64_C(0x0005C60618A27AB4), UINT64_C(0x00041A118681EEDE),
3672           UINT64_C(0x000264B9365ED5C1), UINT64_C(0x000257E09A79B510),
3673           UINT64_C(0x0007087B4DFA9B18), UINT64_C(0x000BC4BD3F5B7665),
3674           UINT64_C(0x00047988ECDAA2B4), UINT64_C(0x00038D5A0D231327),
3675           UINT64_C(0x00061EBA028CB516), UINT64_C(0x00034DFCB32D1C33)},
3676          {UINT64_C(0x0007BF2B53E6F733), UINT64_C(0x0007363F62FE6A5D),
3677           UINT64_C(0x00009E88E9E4BBC7), UINT64_C(0x00053137DF685DF0),
3678           UINT64_C(0x0000D26EEFA89EB2), UINT64_C(0x00060E84ECFF317A),
3679           UINT64_C(0x000562FC49406706), UINT64_C(0x0004010FC39B719E),
3680           UINT64_C(0x00059BF4CE26C533), UINT64_C(0x00016B0A194ADE86)}},
3681         {{UINT64_C(0x00025D428CB55AB4), UINT64_C(0x000349C469FB2C47),
3682           UINT64_C(0x00011112758D3875), UINT64_C(0x0005BBB75049ADD3),
3683           UINT64_C(0x00013E42E4FC95BB), UINT64_C(0x00063D2C733F5E50),
3684           UINT64_C(0x00071ECB0DB2E6CD), UINT64_C(0x00047F5C9C428E03),
3685           UINT64_C(0x0000C8ACA14009B2), UINT64_C(0x0000FEBA85C091ED)},
3686          {UINT64_C(0x000319368C78D149), UINT64_C(0x0000A97A3731C17E),
3687           UINT64_C(0x0005734AA19A7BF7), UINT64_C(0x0004110947FCD175),
3688           UINT64_C(0x00027E988A2F1542), UINT64_C(0x0001405032878E0A),
3689           UINT64_C(0x00035BAF2C56A5E2), UINT64_C(0x000539BA8560A8C0),
3690           UINT64_C(0x0006BE84D2118DA9), UINT64_C(0x0005E0476ABA3F5B)}},
3691         {{UINT64_C(0x0003AA4CC1DD3F97), UINT64_C(0x00063185FB6A0D5E),
3692           UINT64_C(0x0007EAE973FA7134), UINT64_C(0x0000D566EB4BA56E),
3693           UINT64_C(0x000432A20DAAF7BF), UINT64_C(0x000C99D6D0DE97D6),
3694           UINT64_C(0x00040CD8D71B4231), UINT64_C(0x00061DBA01336D9F),
3695           UINT64_C(0x00010DC031C5661D), UINT64_C(0x0007DBFCC3C94CE7)},
3696          {UINT64_C(0x00092DCF6D493BCC), UINT64_C(0x00008741DFAF5D31),
3697           UINT64_C(0x0002E2A67554DF10), UINT64_C(0x0005119B1E5ADE23),
3698           UINT64_C(0x000501601DB80686), UINT64_C(0x00016AF164683AA7),
3699           UINT64_C(0x00013250FB11AA12), UINT64_C(0x00070A10DFF37326),
3700           UINT64_C(0x0000F9D812FF4EAB), UINT64_C(0x00002035714DCE83)}},
3701         {{UINT64_C(0x0007CA219AED5320), UINT64_C(0x0000DC5D44C110A5),
3702           UINT64_C(0x000211982529953C), UINT64_C(0x000330BE049F485C),
3703           UINT64_C(0x0006B006A9948E28), UINT64_C(0x0000B04E018D4DC0),
3704           UINT64_C(0x000215F49B9F8FF2), UINT64_C(0x00079CE3A3D8E522),
3705           UINT64_C(0x0006EDC3EA4A4987), UINT64_C(0x0006F9FD6811BC4F)},
3706          {UINT64_C(0x000FEF3CB3BE843C), UINT64_C(0x0005B9E17892CE3D),
3707           UINT64_C(0x0005168AA844E7A9), UINT64_C(0x000600B2314595D6),
3708           UINT64_C(0x000477B0AFD0F4F6), UINT64_C(0x00053D8F4E812FCD),
3709           UINT64_C(0x00049909798B2B0F), UINT64_C(0x0000B0BD698B1D5E),
3710           UINT64_C(0x000009B704E143DF), UINT64_C(0x00043C8ABB658E21)}},
3711         {{UINT64_C(0x0009311B2D0959AA), UINT64_C(0x000408C67EBE4373),
3712           UINT64_C(0x0004708398C93D1C), UINT64_C(0x0005CEEB3BA4DF18),
3713           UINT64_C(0x00059663D0C68975), UINT64_C(0x000D6F23DB87CD7A),
3714           UINT64_C(0x0007FE452E537133), UINT64_C(0x000067D1FF579E76),
3715           UINT64_C(0x000678700E4625F3), UINT64_C(0x000512B5A1BD51F9)},
3716          {UINT64_C(0x000E28A401845C37), UINT64_C(0x0005334538459412),
3717           UINT64_C(0x000415EEBEE74BD9), UINT64_C(0x00014AFBBC227A22),
3718           UINT64_C(0x000214A015E7D9E7), UINT64_C(0x000139325A047952),
3719           UINT64_C(0x00029504D6930EAE), UINT64_C(0x0005D1BCA17818E8),
3720           UINT64_C(0x0002DD22238F7A8E), UINT64_C(0x0004F8349B5B0ED3)}},
3721         {{UINT64_C(0x00034C0AE7DDF681), UINT64_C(0x0007688311AB02D5),
3722           UINT64_C(0x0002EB0E8A6E1F1D), UINT64_C(0x0005FF8BCF6AAEB8),
3723           UINT64_C(0x0002CAD1E56904C4), UINT64_C(0x000FA16935A53E47),
3724           UINT64_C(0x00002881197DC9DD), UINT64_C(0x0005C925AAAF6DA8),
3725           UINT64_C(0x0006034B84FE7D23), UINT64_C(0x0005D6AE622F2E8E)},
3726          {UINT64_C(0x00065068FCC0ACD6), UINT64_C(0x000070B371C8C2DF),
3727           UINT64_C(0x0003DA0FCB5BFD98), UINT64_C(0x0005B4F3426521A8),
3728           UINT64_C(0x000689F815FC00FE), UINT64_C(0x0002E666CEEBA0E2),
3729           UINT64_C(0x0001E39832C0990E), UINT64_C(0x000574558F79940A),
3730           UINT64_C(0x00076D485F8B12D9), UINT64_C(0x000156F30CEE05D5)}},
3731         {{UINT64_C(0x0007D87AFB920C3D), UINT64_C(0x0002A9E23A083533),
3732           UINT64_C(0x0001543E5ED3B5D9), UINT64_C(0x0000B974928CFC56),
3733           UINT64_C(0x0002CF48F5FC7EE6), UINT64_C(0x000CE1C3C95C8368),
3734           UINT64_C(0x000333FD6C3D7D3F), UINT64_C(0x00044589E3099078),
3735           UINT64_C(0x0001F34D2E96B01D), UINT64_C(0x00017EAC450F370E)},
3736          {UINT64_C(0x0001B2713A497273), UINT64_C(0x00030B002E865A54),
3737           UINT64_C(0x000182D7C612D473), UINT64_C(0x00026397A5C46946),
3738           UINT64_C(0x000187CB68D83F11), UINT64_C(0x00077ADF60174A14),
3739           UINT64_C(0x0002BC33B9BC9135), UINT64_C(0x00036AD6BE31C9F9),
3740           UINT64_C(0x0001AC5D650B5D13), UINT64_C(0x0003F43A72E4D5E3)}},
3741         {{UINT64_C(0x000EF6C11E20B6EA), UINT64_C(0x0005905102070C81),
3742           UINT64_C(0x00024652608509D4), UINT64_C(0x000205B6D7FBB6A0),
3743           UINT64_C(0x00032589FE0677BD), UINT64_C(0x00085D8055C79F1F),
3744           UINT64_C(0x00004E43893D83E7), UINT64_C(0x00013EDB219CA7D3),
3745           UINT64_C(0x0007BF9B35859660), UINT64_C(0x0005DF7DCB816251)},
3746          {UINT64_C(0x0001EF55471D4356), UINT64_C(0x000540AF79AD9A97),
3747           UINT64_C(0x00060EB528DDF6D9), UINT64_C(0x000328BCC97D7964),
3748           UINT64_C(0x000706B99B540A23), UINT64_C(0x0007753141D6BF4E),
3749           UINT64_C(0x000256E51FDE35B1), UINT64_C(0x0005324363DCFDED),
3750           UINT64_C(0x0004E0FE9820F921), UINT64_C(0x000368ECFA81C767)}},
3751         {{UINT64_C(0x000AE3882AC0F8F0), UINT64_C(0x00023952C3BBED16),
3752           UINT64_C(0x0002208B0CCB771B), UINT64_C(0x00032499978C3D1E),
3753           UINT64_C(0x0000B08DEF9DE24A), UINT64_C(0x00014733B64362CB),
3754           UINT64_C(0x00044CEB44FBCD29), UINT64_C(0x00062081D15BFA79),
3755           UINT64_C(0x000612FF02BEFFD5), UINT64_C(0x00016207454BB815)},
3756          {UINT64_C(0x000E140447F99D22), UINT64_C(0x0004415B5CE2B9E2),
3757           UINT64_C(0x000497FECE7E53B5), UINT64_C(0x0003BBA75954C646),
3758           UINT64_C(0x00075267384AD185), UINT64_C(0x000BE077D1B86BB1),
3759           UINT64_C(0x0000A186FFAE61F0), UINT64_C(0x0007E20C811F4FAE),
3760           UINT64_C(0x0004F69AD42F56BF), UINT64_C(0x00006F7B76AEA2AF)}},
3761         {{UINT64_C(0x000BEDEC2A48D51F), UINT64_C(0x00040C00234C90E7),
3762           UINT64_C(0x0003BC8777CA6ECC), UINT64_C(0x0000D79570C70B74),
3763           UINT64_C(0x000157D50E130D10), UINT64_C(0x0003932A1F3A8446),
3764           UINT64_C(0x000520C248ECB88C), UINT64_C(0x00073A8FF16D17F0),
3765           UINT64_C(0x0006B070CCE2E887), UINT64_C(0x00006F6D81DF9ECD)},
3766          {UINT64_C(0x0007C3E53178DAC6), UINT64_C(0x0000802C2D20978A),
3767           UINT64_C(0x0005CC0D9E0C57C8), UINT64_C(0x0000A2DB47B4AA42),
3768           UINT64_C(0x0000D0C16DEAE477), UINT64_C(0x00030AECB867C0D4),
3769           UINT64_C(0x0006545EF5ADABE6), UINT64_C(0x0006207530AC956A),
3770           UINT64_C(0x0004B667DB2FBFC5), UINT64_C(0x0007231A93C94578)}},
3771         {{UINT64_C(0x0006EE7B285AAF99), UINT64_C(0x000184C97496A4CA),
3772           UINT64_C(0x0000E820762561C8), UINT64_C(0x0003069976AB441A),
3773           UINT64_C(0x0002F2D34AB64E3A), UINT64_C(0x0008DA8798C4984C),
3774           UINT64_C(0x00018E10EC261ED8), UINT64_C(0x0005572CDE59EF3B),
3775           UINT64_C(0x0005243583492A31), UINT64_C(0x000553EBD5BD4F76)},
3776          {UINT64_C(0x00003CD44541889B), UINT64_C(0x0000A15FD3B46A03),
3777           UINT64_C(0x0002445DDC01C49C), UINT64_C(0x0000FF7AB524990D),
3778           UINT64_C(0x00067DD44CEF1BC4), UINT64_C(0x00011A6A854E822E),
3779           UINT64_C(0x00020922345D9089), UINT64_C(0x00004F8BE8B1C52C),
3780           UINT64_C(0x000334AD5EA9B90D), UINT64_C(0x0004E5FE9C90028A)}},
3781         {{UINT64_C(0x000068C177996387), UINT64_C(0x000019B13C995F39),
3782           UINT64_C(0x00065BFEAB3691E1), UINT64_C(0x0003CEAA9FF90919),
3783           UINT64_C(0x00070CE531ADC5B6), UINT64_C(0x000E2CEBFDBB5331),
3784           UINT64_C(0x0000D202455F41D3), UINT64_C(0x000671180605FF9D),
3785           UINT64_C(0x00011AD81B928580), UINT64_C(0x00028FC16864D6F0)},
3786          {UINT64_C(0x000A61CD60DAEB8D), UINT64_C(0x000365700D8B7834),
3787           UINT64_C(0x00057BC9FDF724EE), UINT64_C(0x0001F7A1B9F925AF),
3788           UINT64_C(0x0007AA4AEFCA0359), UINT64_C(0x00034A27F50833A0),
3789           UINT64_C(0x0000ED7927DFB95D), UINT64_C(0x0007B8F116040DEA),
3790           UINT64_C(0x000117F98382AC39), UINT64_C(0x00020171F463D451)}},
3791         {{UINT64_C(0x00059264A9F49C09), UINT64_C(0x00044F0F00815067),
3792           UINT64_C(0x000151E20E3CE2F3), UINT64_C(0x0003CB10A0F261AA),
3793           UINT64_C(0x00019DAE7938AAE9), UINT64_C(0x000FA6C983FECF4D),
3794           UINT64_C(0x0000A4A7CA460046), UINT64_C(0x00069CD684FAA9A3),
3795           UINT64_C(0x0005962FD31973AC), UINT64_C(0x0001A315E3CE66B5)},
3796          {UINT64_C(0x0001EE33900F6430), UINT64_C(0x00064BE92C2C1CDD),
3797           UINT64_C(0x00011FCA5905D7B7), UINT64_C(0x0001664E4C15055D),
3798           UINT64_C(0x000124F50846C1DD), UINT64_C(0x0005A95B64C89DD6),
3799           UINT64_C(0x000635C7B470A25B), UINT64_C(0x00044199D92D72BC),
3800           UINT64_C(0x000317D8CC4D6593), UINT64_C(0x0004A1E8E879471E)}},
3801         {{UINT64_C(0x00070F53D415523F), UINT64_C(0x00008843EE85FF0C),
3802           UINT64_C(0x0001E10C523BB14C), UINT64_C(0x0004756E413F0932),
3803           UINT64_C(0x0003DE85A220DF46), UINT64_C(0x000E272251866340),
3804           UINT64_C(0x00008C97549ABE3D), UINT64_C(0x0003998C7C359F9D),
3805           UINT64_C(0x00018EC0C21FA45C), UINT64_C(0x0007A6A308E8E50C)},
3806          {UINT64_C(0x0002370A35276C0F), UINT64_C(0x0002729B26DBEA22),
3807           UINT64_C(0x0000D95854453918), UINT64_C(0x0000FEBB57C7378F),
3808           UINT64_C(0x0002E3F0D283969D), UINT64_C(0x000875CC00175050),
3809           UINT64_C(0x00050E7B3F62B00A), UINT64_C(0x0006E1A11C5C2BEA),
3810           UINT64_C(0x0003461785DC962F), UINT64_C(0x00006A29E20D62BD)}},
3811         {{UINT64_C(0x000537C77DAC5528), UINT64_C(0x00008C1BE92F83C6),
3812           UINT64_C(0x000611D61F939CC5), UINT64_C(0x00067A47050E3CE6),
3813           UINT64_C(0x0006FC68EE4297A6), UINT64_C(0x00076CC8299AC1F1),
3814           UINT64_C(0x000798EF7F4F028F), UINT64_C(0x0003D929F2A08907),
3815           UINT64_C(0x0007F626DB8181AE), UINT64_C(0x00038C7518A169E3)},
3816          {UINT64_C(0x0003C2C303DDCFAE), UINT64_C(0x0005A51351AFA1EB),
3817           UINT64_C(0x00033D8168A6178F), UINT64_C(0x0002BAE4B7BD921A),
3818           UINT64_C(0x00079BB0E6C13360), UINT64_C(0x0002FEC8223E6E6A),
3819           UINT64_C(0x00057EB3E02985A1), UINT64_C(0x0006A5F6F23E337D),
3820           UINT64_C(0x0000B51AD9A8DF7E), UINT64_C(0x0007C85F9D74F60E)}},
3821     },
3822     {
3823         {{UINT64_C(0x000373002424FC6B), UINT64_C(0x000265A533B8CF47),
3824           UINT64_C(0x00015EAD4A0AE37C), UINT64_C(0x00022EEEA45AEA56),
3825           UINT64_C(0x0005CA0E0AF3AAE5), UINT64_C(0x000216AD75D115B7),
3826           UINT64_C(0x0002B2885E63BCC1), UINT64_C(0x00001DEB58FCEA8C),
3827           UINT64_C(0x00050D28722A0E55), UINT64_C(0x00016C1C97050E66)},
3828          {UINT64_C(0x000BACBCDEEAFAB6), UINT64_C(0x000210A7858140DE),
3829           UINT64_C(0x0006E228E5AB34EE), UINT64_C(0x00038068E28B5065),
3830           UINT64_C(0x0002BDB4015D78E6), UINT64_C(0x000E7DF0E5A47C2C),
3831           UINT64_C(0x000091791C6E0564), UINT64_C(0x00047E8BA82005E7),
3832           UINT64_C(0x0002E2976DD2714D), UINT64_C(0x00029F182BE6C8A5)}},
3833         {{UINT64_C(0x000D83B94CB40D60), UINT64_C(0x000182EE55A47AB2),
3834           UINT64_C(0x0002A9A2A11F16C0), UINT64_C(0x00050CC737555D01),
3835           UINT64_C(0x000189A2DA48966B), UINT64_C(0x000A973CE36E61C1),
3836           UINT64_C(0x0004AF3A17E7233F), UINT64_C(0x00045CB6428ED4F1),
3837           UINT64_C(0x0001768287382675), UINT64_C(0x0000C6B22C10147C)},
3838          {UINT64_C(0x000401DB5A4C6A3E), UINT64_C(0x00023EE16B73E10C),
3839           UINT64_C(0x0002FEA5C8440A34), UINT64_C(0x00018E7129952281),
3840           UINT64_C(0x0001A31C2F9C5948), UINT64_C(0x0006685938AF9BD8),
3841           UINT64_C(0x0002F4C9F4721C11), UINT64_C(0x0006D88254B2B220),
3842           UINT64_C(0x00007BC40460348E), UINT64_C(0x0001773137A2404B)}},
3843         {{UINT64_C(0x000C6B4D1144D64A), UINT64_C(0x0006D90E0E79B31D),
3844           UINT64_C(0x00068DA0056E18D5), UINT64_C(0x0005340F7E02D070),
3845           UINT64_C(0x0001D5DF828F1380), UINT64_C(0x000636F195DCDB2B),
3846           UINT64_C(0x0000E7E7E014119C), UINT64_C(0x0007B435A9FBE2C0),
3847           UINT64_C(0x00076EB85EA1EFBB), UINT64_C(0x00022AA0A0C698A1)},
3848          {UINT64_C(0x000B9CB571CA9CF0), UINT64_C(0x0004B86CE22A5E6D),
3849           UINT64_C(0x0006E4462F85131B), UINT64_C(0x0002F155E75A2EED),
3850           UINT64_C(0x00063F764F24AC73), UINT64_C(0x000FFA94474DEF2E),
3851           UINT64_C(0x0004A1B60F2E7A47), UINT64_C(0x00063EE08D47164B),
3852           UINT64_C(0x0005ECDC6B2A7E48), UINT64_C(0x00071C6910C71824)}},
3853         {{UINT64_C(0x0007813E229F97CB), UINT64_C(0x00043ADE3B460997),
3854           UINT64_C(0x0005E8C96137590A), UINT64_C(0x000484EEC3127431),
3855           UINT64_C(0x0003A512D58F34EC), UINT64_C(0x000B47722D5ECC77),
3856           UINT64_C(0x00076E35AE2C410D), UINT64_C(0x000142A4F3860A59),
3857           UINT64_C(0x0005AD2423E3E88D), UINT64_C(0x00032A4A2C6376BD)},
3858          {UINT64_C(0x0009DB45FC2C575A), UINT64_C(0x0007CF11E987B02F),
3859           UINT64_C(0x000329AE7B16D79A), UINT64_C(0x0006BA1FDDBA003F),
3860           UINT64_C(0x00072F40C3D1D0E1), UINT64_C(0x000A2168272DEAEB),
3861           UINT64_C(0x00040B3BC5E98BE4), UINT64_C(0x0005426244ED0D94),
3862           UINT64_C(0x000610D19F336894), UINT64_C(0x0001EC5B0CD24773)}},
3863         {{UINT64_C(0x000126DC95FF47CB), UINT64_C(0x0006D821C64139FD),
3864           UINT64_C(0x00036D6653EA637C), UINT64_C(0x0005A97F942DD0FF),
3865           UINT64_C(0x00000318724B076A), UINT64_C(0x000ED3C1F9BBE805),
3866           UINT64_C(0x0002E76961D49FCA), UINT64_C(0x000759A40326E7D9),
3867           UINT64_C(0x0002641EFF076C29), UINT64_C(0x00006CA5347A2017)},
3868          {UINT64_C(0x00010765B5C69CBC), UINT64_C(0x0001782241147DAD),
3869           UINT64_C(0x000104E6A5297609), UINT64_C(0x0006495BFD0C4503),
3870           UINT64_C(0x0006B9D0D10CA297), UINT64_C(0x00034803A8F4A7B8),
3871           UINT64_C(0x00069B1A0E7F94AF), UINT64_C(0x00076E9131740435),
3872           UINT64_C(0x00079E1647538E00), UINT64_C(0x000381FB07DCC831)}},
3873         {{UINT64_C(0x0000623E19A529B0), UINT64_C(0x0002A1F34419A0BA),
3874           UINT64_C(0x0007450BB7C4CEEC), UINT64_C(0x000724D0766E901A),
3875           UINT64_C(0x0006FDCF27272EFB), UINT64_C(0x000E99E1E2856702),
3876           UINT64_C(0x0006AF1B534CF0E7), UINT64_C(0x00024538A8F87630),
3877           UINT64_C(0x0002DBFF74B7F80D), UINT64_C(0x0006689E4424A84F)},
3878          {UINT64_C(0x000A25CFDE9D7DDB), UINT64_C(0x00025B06D5477447),
3879           UINT64_C(0x00040103EF10F2A9), UINT64_C(0x0000589A19B6B3E8),
3880           UINT64_C(0x0001001736EC3E24), UINT64_C(0x000B77124673C96A),
3881           UINT64_C(0x00053B0645C3104F), UINT64_C(0x00066AEE9346C15C),
3882           UINT64_C(0x000336D117178F21), UINT64_C(0x0004C8732602283A)}},
3883         {{UINT64_C(0x000B072ABBE3BA75), UINT64_C(0x00015A08F89BDB09),
3884           UINT64_C(0x00034F423F9E09E0), UINT64_C(0x0001EF27A09841EF),
3885           UINT64_C(0x00065B203436FF75), UINT64_C(0x00018864D568B13F),
3886           UINT64_C(0x00069449D057FB4C), UINT64_C(0x000005868A6A3CD5),
3887           UINT64_C(0x0007932D29BB522B), UINT64_C(0x0001069BF48AA2B7)},
3888          {UINT64_C(0x000EE21FDCDDE7C7), UINT64_C(0x0006CAF6E905C045),
3889           UINT64_C(0x00031A72930255A6), UINT64_C(0x00076FCF5F4A6F74),
3890           UINT64_C(0x00001AA0517A0131), UINT64_C(0x00040DDFF2E11FAF),
3891           UINT64_C(0x0004A5512DFF3F02), UINT64_C(0x00055F08A9212CD2),
3892           UINT64_C(0x000519761093F184), UINT64_C(0x00027B6A1B2A1EF7)}},
3893         {{UINT64_C(0x000EA5C61B6DBC4E), UINT64_C(0x00051A4DCC7D6792),
3894           UINT64_C(0x0003357B7EAF7670), UINT64_C(0x000554E802A50353),
3895           UINT64_C(0x00072BF41E70B24F), UINT64_C(0x000049E5C8DA1177),
3896           UINT64_C(0x00037C5CB7FD16BA), UINT64_C(0x0003803F2EEEF15D),
3897           UINT64_C(0x000146D4B548675B), UINT64_C(0x0000E11A2717E6B2)},
3898          {UINT64_C(0x000C794070988A0A), UINT64_C(0x0002A32EF7BCEEB5),
3899           UINT64_C(0x00050C772349C586), UINT64_C(0x0000FA8C6654583D),
3900           UINT64_C(0x000385E544F610DF), UINT64_C(0x000C27780562C065),
3901           UINT64_C(0x0004D0E5952E5D7A), UINT64_C(0x00022358D60920AE),
3902           UINT64_C(0x000647D3BCA69083), UINT64_C(0x000663401832196F)}},
3903         {{UINT64_C(0x0002E9B7160E3961), UINT64_C(0x0000CFDD2754F2C2),
3904           UINT64_C(0x000737ED6627095B), UINT64_C(0x0000907EAC442E04),
3905           UINT64_C(0x0004BFDDFD6D0E23), UINT64_C(0x0009C97A7D587EEF),
3906           UINT64_C(0x000543F2822FAFB5), UINT64_C(0x0003FDF6AF5D7A19),
3907           UINT64_C(0x0000FC963721698D), UINT64_C(0x000179F21E6577FB)},
3908          {UINT64_C(0x00025DABF637CE7B), UINT64_C(0x0000DEF29AADAC3D),
3909           UINT64_C(0x0001737E91658123), UINT64_C(0x000249402C7B4BC4),
3910           UINT64_C(0x0001F964C1BA2B35), UINT64_C(0x0006547130478601),
3911           UINT64_C(0x00004A763BB9F26E), UINT64_C(0x0002DEE0532A3ABA),
3912           UINT64_C(0x0000FB73209B3189), UINT64_C(0x000323CB18309CBF)}},
3913         {{UINT64_C(0x000F430885B15B6B), UINT64_C(0x00075D059AEC5A1E),
3914           UINT64_C(0x0004453A277EFFCE), UINT64_C(0x00064F823D9E2950),
3915           UINT64_C(0x00073827A14B9299), UINT64_C(0x0001C133BA90B752),
3916           UINT64_C(0x0002FE7DB431EADF), UINT64_C(0x0007321007818326),
3917           UINT64_C(0x00071653A5874521), UINT64_C(0x000797A5565F102D)},
3918          {UINT64_C(0x00036CFD54EEA72C), UINT64_C(0x0000808016DA4E23),
3919           UINT64_C(0x0003D2134B084DFE), UINT64_C(0x00011B5581647A89),
3920           UINT64_C(0x00052FAD726D60BB), UINT64_C(0x000DCFDB5420868A),
3921           UINT64_C(0x000750548DD329FF), UINT64_C(0x00019FE6DA0749CC),
3922           UINT64_C(0x00005B85FA39A2C1), UINT64_C(0x00023AE3BBD89F61)}},
3923         {{UINT64_C(0x000CA8883C4EF58F), UINT64_C(0x0006E759199F54FA),
3924           UINT64_C(0x00055E8867F4288D), UINT64_C(0x000225E439FE7035),
3925           UINT64_C(0x00040EE9678BC4D1), UINT64_C(0x000E0C8FEC05A2E2),
3926           UINT64_C(0x000586D8C13D487A), UINT64_C(0x00008B4A7E530498),
3927           UINT64_C(0x0001E781B4E18C6D), UINT64_C(0x00017D763BE7083C)},
3928          {UINT64_C(0x000A451105CF54F0), UINT64_C(0x000637BF27522C26),
3929           UINT64_C(0x0006042AB901CB43), UINT64_C(0x0000F3A157D77CEC),
3930           UINT64_C(0x00040B5652E5D030), UINT64_C(0x0003F395A2C01F02),
3931           UINT64_C(0x00041B950FC573CA), UINT64_C(0x0007DED4FDDEA439),
3932           UINT64_C(0x00012CAC59609158), UINT64_C(0x0000EC63DC4F41D8)}},
3933         {{UINT64_C(0x000027B04D23C68B), UINT64_C(0x000525B4F2B59AFC),
3934           UINT64_C(0x0001473B3791B81E), UINT64_C(0x0004234680C59597),
3935           UINT64_C(0x00049B5B1E7B7404), UINT64_C(0x000CA846EE9B6288),
3936           UINT64_C(0x0002F4D705212A30), UINT64_C(0x000435199A6D217F),
3937           UINT64_C(0x0002C022FF19EE1F), UINT64_C(0x0003594F8F0758A9)},
3938          {UINT64_C(0x000968170931C47A), UINT64_C(0x000621AD96C9DEDE),
3939           UINT64_C(0x0001F40DB9806854), UINT64_C(0x0006535786069F3A),
3940           UINT64_C(0x0002BAAF09744048), UINT64_C(0x000CE1A02746C6D1),
3941           UINT64_C(0x000159007061AA2D), UINT64_C(0x000679FCA2D81FCD),
3942           UINT64_C(0x000418AC9FB46B4D), UINT64_C(0x000308BE060423D1)}},
3943         {{UINT64_C(0x0000C4AC87AF9AD9), UINT64_C(0x0000CDECE641A609),
3944           UINT64_C(0x0001E12CC58F8FCD), UINT64_C(0x000510A219809940),
3945           UINT64_C(0x0006DA7CEA8384F8), UINT64_C(0x000AB5F0694566E0),
3946           UINT64_C(0x0001CC9EE803A140), UINT64_C(0x0000F9FBB28BDD1E),
3947           UINT64_C(0x0007F4EFEB56B1DE), UINT64_C(0x000277916C4688BF)},
3948          {UINT64_C(0x000D23553900C111), UINT64_C(0x0002646A893D2545),
3949           UINT64_C(0x0003F85DED9F79E4), UINT64_C(0x0003D6EBC7956C87),
3950           UINT64_C(0x00042C8421E33668), UINT64_C(0x0000CE0FCEE92113),
3951           UINT64_C(0x00062F37FB71D455), UINT64_C(0x0002B5C2D8B8E0D9),
3952           UINT64_C(0x0001F89A7B791F03), UINT64_C(0x00026E0534AAFC55)}},
3953         {{UINT64_C(0x0002995D9382FB5B), UINT64_C(0x0007C05714B2BDCD),
3954           UINT64_C(0x00055EFDFFD811CA), UINT64_C(0x0000C43B6FA2E22F),
3955           UINT64_C(0x0003930FE770F72D), UINT64_C(0x00082F4073A9EB83),
3956           UINT64_C(0x00028C90A8534165), UINT64_C(0x00020C6D2C543EAE),
3957           UINT64_C(0x0003F98A8E8F71B7), UINT64_C(0x0007B8FB4D43C48C)},
3958          {UINT64_C(0x000C54F1DA463909), UINT64_C(0x000482EC99C805E1),
3959           UINT64_C(0x000301F27ED477A1), UINT64_C(0x0005CA99320599DA),
3960           UINT64_C(0x0003F84676223EB7), UINT64_C(0x00001D5F50BC87AC),
3961           UINT64_C(0x0006D360C6473C45), UINT64_C(0x00078FE24EB5EF6D),
3962           UINT64_C(0x0003E18E1D8C918F), UINT64_C(0x0000BAAA9526A788)}},
3963         {{UINT64_C(0x0003CFAC186FC15D), UINT64_C(0x0004079422F8115B),
3964           UINT64_C(0x00015745819F82E6), UINT64_C(0x0003618BCA6799CF),
3965           UINT64_C(0x000147DCBEB05016), UINT64_C(0x0008E01C4060F0AE),
3966           UINT64_C(0x0006DD9C9ABCADD5), UINT64_C(0x00055C9418FA0C56),
3967           UINT64_C(0x0004ADEDA517CF14), UINT64_C(0x0000A4AEB8D1A937)},
3968          {UINT64_C(0x0004727D18C04C1D), UINT64_C(0x000459FEB8D4258F),
3969           UINT64_C(0x000134BF4171D346), UINT64_C(0x000686442480B1AF),
3970           UINT64_C(0x000739A7BBB7AB37), UINT64_C(0x000F61BC7DC00473),
3971           UINT64_C(0x0003746597B948CE), UINT64_C(0x000125EAB46F1D2B),
3972           UINT64_C(0x000033F4805B72AE), UINT64_C(0x000584748C0B9409)}},
3973         {{UINT64_C(0x00092A49D3069003), UINT64_C(0x0005840D8AF17ED6),
3974           UINT64_C(0x000174B6F581B1E5), UINT64_C(0x000163189D301971),
3975           UINT64_C(0x0000018D239951ED), UINT64_C(0x0009B7C92C641D5C),
3976           UINT64_C(0x000289C88DD6E0A4), UINT64_C(0x0000CE7ED79D24F4),
3977           UINT64_C(0x0007F5A09563A4B9), UINT64_C(0x0007A4A25F6B4D5C)},
3978          {UINT64_C(0x00002966A02D81D0), UINT64_C(0x00079C7EA96452D3),
3979           UINT64_C(0x0007C34AB0AA795A), UINT64_C(0x00050A1B57CC0E57),
3980           UINT64_C(0x0007DE8829195BCB), UINT64_C(0x0006242A9B8D0EC5),
3981           UINT64_C(0x0005DD50FAD307D9), UINT64_C(0x0001B700B637CA0B),
3982           UINT64_C(0x0003455689EBE7C1), UINT64_C(0x0002782C47D2932F)}},
3983     }};
3984
3985 /*-
3986  * Q := 2P, both projective, Q and P same pointers OK
3987  * Autogenerated: op3/dbl_proj.op3
3988  * https://eprint.iacr.org/2015/1060 Alg 6
3989  * ASSERT: a = -3
3990  */
3991 static void point_double(pt_prj_t *Q, const pt_prj_t *P) {
3992     /* temporary variables */
3993     fe_t t0, t1, t2, t3, t4;
3994     /* constants */
3995     const limb_t *b = const_b;
3996     /* set pointers for legacy curve arith */
3997     const limb_t *X = P->X;
3998     const limb_t *Y = P->Y;
3999     const limb_t *Z = P->Z;
4000     limb_t *X3 = Q->X;
4001     limb_t *Y3 = Q->Y;
4002     limb_t *Z3 = Q->Z;
4003
4004     /* the curve arith formula */
4005     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(t0, X);
4006     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(t1, Y);
4007     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(t2, Z);
4008     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, X, Y);
4009     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, t3, t3);
4010     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t4, Y, Z);
4011     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, X, Z);
4012     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, Z3);
4013     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, b, t2);
4014     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, Z3);
4015     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, Y3, Y3);
4016     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, X3, Y3);
4017     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, t1, Y3);
4018     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t1, Y3);
4019     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X3, Y3);
4020     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, X3, t3);
4021     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, t2, t2);
4022     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t2, t2, t3);
4023     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, b, Z3);
4024     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, Z3, t2);
4025     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, Z3, t0);
4026     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, Z3, Z3);
4027     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, t3);
4028     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, t0, t0);
4029     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t3, t0);
4030     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t0, t0, t2);
4031     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t0, t0, Z3);
4032     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, t0);
4033     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t4, t4);
4034     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t0, Z3);
4035     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, X3, Z3);
4036     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t0, t1);
4037     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, Z3);
4038     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, Z3);
4039 }
4040
4041 /*-
4042  * out1 = (arg1 == 0) ? 0 : nz
4043  * NB: this is not a "mod p equiv" 0, but literal 0
4044  * NB: this is not a real Fiat function, just named that way for consistency.
4045  */
4046 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_nonzero(limb_t *out1,
4047                                                               const fe_t arg1) {
4048     limb_t x1 = 0;
4049     int i;
4050
4051     for (i = 0; i < LIMB_CNT; i++) x1 |= arg1[i];
4052     *out1 = x1;
4053 }
4054
4055 /*-
4056  * R := Q + P where R and Q are projective, P affine.
4057  * R and Q same pointers OK
4058  * R and P same pointers not OK
4059  * Autogenerated: op3/add_mixed.op3
4060  * https://eprint.iacr.org/2015/1060 Alg 5
4061  * ASSERT: a = -3
4062  */
4063 static void point_add_mixed(pt_prj_t *R, const pt_prj_t *Q, const pt_aff_t *P) {
4064     /* temporary variables */
4065     fe_t t0, t1, t2, t3, t4;
4066     /* constants */
4067     const limb_t *b = const_b;
4068     /* set pointers for legacy curve arith */
4069     const limb_t *X1 = Q->X;
4070     const limb_t *Y1 = Q->Y;
4071     const limb_t *Z1 = Q->Z;
4072     const limb_t *X2 = P->X;
4073     const limb_t *Y2 = P->Y;
4074     fe_t X3;
4075     fe_t Y3;
4076     fe_t Z3;
4077     limb_t nz;
4078
4079     /* check P for affine inf */
4080     fiat_id_tc26_gost_3410_2012_512_paramSetA_nonzero(&nz, P->Y);
4081
4082     /* the curve arith formula */
4083     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t0, X1, X2);
4084     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, Y1, Y2);
4085     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, X2, Y2);
4086     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, X1, Y1);
4087     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, t3, t4);
4088     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, t0, t1);
4089     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t3, t3, t4);
4090     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t4, Y2, Z1);
4091     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, t4, Y1);
4092     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X2, Z1);
4093     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, X1);
4094     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, b, Z1);
4095     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, Y3, Z3);
4096     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, X3, X3);
4097     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, X3, Z3);
4098     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, t1, X3);
4099     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, t1, X3);
4100     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, b, Y3);
4101     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, Z1, Z1);
4102     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t2, t1, Z1);
4103     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t2);
4104     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t0);
4105     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, Y3, Y3);
4106     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t1, Y3);
4107     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, t0, t0);
4108     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t1, t0);
4109     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t0, t0, t2);
4110     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t4, Y3);
4111     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, t0, Y3);
4112     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X3, Z3);
4113     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, t2);
4114     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, t3, X3);
4115     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, X3, t1);
4116     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t4, Z3);
4117     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t3, t0);
4118     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, t1);
4119
4120     /* if P is inf, throw all that away and take Q */
4121     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(R->X, nz, Q->X, X3);
4122     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(R->Y, nz, Q->Y, Y3);
4123     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(R->Z, nz, Q->Z, Z3);
4124 }
4125
4126 /*-
4127  * R := Q + P all projective.
4128  * R and Q same pointers OK
4129  * R and P same pointers not OK
4130  * Autogenerated: op3/add_proj.op3
4131  * https://eprint.iacr.org/2015/1060 Alg 4
4132  * ASSERT: a = -3
4133  */
4134 static void point_add_proj(pt_prj_t *R, const pt_prj_t *Q, const pt_prj_t *P) {
4135     /* temporary variables */
4136     fe_t t0, t1, t2, t3, t4, t5;
4137     /* constants */
4138     const limb_t *b = const_b;
4139     /* set pointers for legacy curve arith */
4140     const limb_t *X1 = Q->X;
4141     const limb_t *Y1 = Q->Y;
4142     const limb_t *Z1 = Q->Z;
4143     const limb_t *X2 = P->X;
4144     const limb_t *Y2 = P->Y;
4145     const limb_t *Z2 = P->Z;
4146     limb_t *X3 = R->X;
4147     limb_t *Y3 = R->Y;
4148     limb_t *Z3 = R->Z;
4149
4150     /* the curve arith formula */
4151     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t0, X1, X2);
4152     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, Y1, Y2);
4153     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, Z1, Z2);
4154     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, X1, Y1);
4155     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, X2, Y2);
4156     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, t3, t4);
4157     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, t0, t1);
4158     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t3, t3, t4);
4159     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, Y1, Z1);
4160     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t5, Y2, Z2);
4161     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t4, t4, t5);
4162     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t5, t1, t2);
4163     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t4, t4, t5);
4164     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, X1, Z1);
4165     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, X2, Z2);
4166     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, X3, Y3);
4167     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t0, t2);
4168     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, X3, Y3);
4169     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, b, t2);
4170     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, Y3, Z3);
4171     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, X3, X3);
4172     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, X3, Z3);
4173     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, t1, X3);
4174     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, t1, X3);
4175     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, b, Y3);
4176     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, t2, t2);
4177     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t2, t1, t2);
4178     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t2);
4179     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t0);
4180     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, Y3, Y3);
4181     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t1, Y3);
4182     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, t0, t0);
4183     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t1, t0);
4184     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t0, t0, t2);
4185     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t4, Y3);
4186     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, t0, Y3);
4187     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X3, Z3);
4188     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, t2);
4189     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, t3, X3);
4190     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, X3, t1);
4191     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t4, Z3);
4192     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t3, t0);
4193     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, t1);
4194 }
4195
4196 /* constants */
4197 #define RADIX 5
4198 #define DRADIX (1 << RADIX)
4199 #define DRADIX_WNAF ((DRADIX) << 1)
4200
4201 /*-
4202  * precomp for wnaf scalar multiplication:
4203  * precomp[0] = 1P
4204  * precomp[1] = 3P
4205  * precomp[2] = 5P
4206  * precomp[3] = 7P
4207  * precomp[4] = 9P
4208  * ...
4209  */
4210 static void precomp_wnaf(pt_prj_t precomp[DRADIX / 2], const pt_aff_t *P) {
4211     int i;
4212
4213     fe_copy(precomp[0].X, P->X);
4214     fe_copy(precomp[0].Y, P->Y);
4215     fe_copy(precomp[0].Z, const_one);
4216     point_double(&precomp[DRADIX / 2 - 1], &precomp[0]);
4217
4218     for (i = 1; i < DRADIX / 2; i++)
4219         point_add_proj(&precomp[i], &precomp[DRADIX / 2 - 1], &precomp[i - 1]);
4220 }
4221
4222 /* fetch a scalar bit */
4223 static int scalar_get_bit(const unsigned char in[64], int idx) {
4224     int widx, rshift;
4225
4226     widx = idx >> 3;
4227     rshift = idx & 0x7;
4228
4229     if (idx < 0 || widx >= 64) return 0;
4230
4231     return (in[widx] >> rshift) & 0x1;
4232 }
4233
4234 /*-
4235  * Compute "regular" wnaf representation of a scalar.
4236  * See "Exponent Recoding and Regular Exponentiation Algorithms",
4237  * Tunstall et al., AfricaCrypt 2009, Alg 6.
4238  * It forces an odd scalar and outputs digits in
4239  * {\pm 1, \pm 3, \pm 5, \pm 7, \pm 9, ...}
4240  * i.e. signed odd digits with _no zeroes_ -- that makes it "regular".
4241  */
4242 static void scalar_rwnaf(char out[103], const unsigned char in[64]) {
4243     int i;
4244     char window, d;
4245
4246     window = (in[0] & (DRADIX_WNAF - 1)) | 1;
4247     for (i = 0; i < 102; i++) {
4248         d = (window & (DRADIX_WNAF - 1)) - DRADIX;
4249         out[i] = d;
4250         window = (window - d) >> RADIX;
4251         window += scalar_get_bit(in, (i + 1) * RADIX + 1) << 1;
4252         window += scalar_get_bit(in, (i + 1) * RADIX + 2) << 2;
4253         window += scalar_get_bit(in, (i + 1) * RADIX + 3) << 3;
4254         window += scalar_get_bit(in, (i + 1) * RADIX + 4) << 4;
4255         window += scalar_get_bit(in, (i + 1) * RADIX + 5) << 5;
4256     }
4257     out[i] = window;
4258 }
4259
4260 /*-
4261  * Compute "textbook" wnaf representation of a scalar.
4262  * NB: not constant time
4263  */
4264 static void scalar_wnaf(char out[513], const unsigned char in[64]) {
4265     int i;
4266     char window, d;
4267
4268     window = in[0] & (DRADIX_WNAF - 1);
4269     for (i = 0; i < 513; i++) {
4270         d = 0;
4271         if ((window & 1) && ((d = window & (DRADIX_WNAF - 1)) & DRADIX))
4272             d -= DRADIX_WNAF;
4273         out[i] = d;
4274         window = (window - d) >> 1;
4275         window += scalar_get_bit(in, i + 1 + RADIX) << RADIX;
4276     }
4277 }
4278
4279 /*-
4280  * Simulateous scalar multiplication: interleaved "textbook" wnaf.
4281  * NB: not constant time
4282  */
4283 static void var_smul_wnaf_two(pt_aff_t *out, const unsigned char a[64],
4284                               const unsigned char b[64], const pt_aff_t *P) {
4285     int i, d, is_neg, is_inf = 1, flipped = 0;
4286     char anaf[513] = {0};
4287     char bnaf[513] = {0};
4288     pt_prj_t Q;
4289     pt_prj_t precomp[DRADIX / 2];
4290
4291     precomp_wnaf(precomp, P);
4292     scalar_wnaf(anaf, a);
4293     scalar_wnaf(bnaf, b);
4294
4295     for (i = 512; i >= 0; i--) {
4296         if (!is_inf) point_double(&Q, &Q);
4297         if ((d = bnaf[i])) {
4298             if ((is_neg = d < 0) != flipped) {
4299                 fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(Q.Y, Q.Y);
4300                 flipped ^= 1;
4301             }
4302             d = (is_neg) ? (-d - 1) >> 1 : (d - 1) >> 1;
4303             if (is_inf) {
4304                 /* initialize accumulator */
4305                 fe_copy(Q.X, &precomp[d].X);
4306                 fe_copy(Q.Y, &precomp[d].Y);
4307                 fe_copy(Q.Z, &precomp[d].Z);
4308                 is_inf = 0;
4309             } else
4310                 point_add_proj(&Q, &Q, &precomp[d]);
4311         }
4312         if ((d = anaf[i])) {
4313             if ((is_neg = d < 0) != flipped) {
4314                 fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(Q.Y, Q.Y);
4315                 flipped ^= 1;
4316             }
4317             d = (is_neg) ? (-d - 1) >> 1 : (d - 1) >> 1;
4318             if (is_inf) {
4319                 /* initialize accumulator */
4320                 fe_copy(Q.X, &lut_cmb[0][d].X);
4321                 fe_copy(Q.Y, &lut_cmb[0][d].Y);
4322                 fe_copy(Q.Z, const_one);
4323                 is_inf = 0;
4324             } else
4325                 point_add_mixed(&Q, &Q, &lut_cmb[0][d]);
4326         }
4327     }
4328
4329     if (is_inf) {
4330         /* initialize accumulator to inf: all-zero scalars */
4331         fe_set_zero(Q.X);
4332         fe_copy(Q.Y, const_one);
4333         fe_set_zero(Q.Z);
4334     }
4335
4336     if (flipped) {
4337         /* correct sign */
4338         fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(Q.Y, Q.Y);
4339     }
4340
4341     /* convert to affine -- NB depends on coordinate system */
4342     fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(Q.Z, Q.Z);
4343     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->X, Q.X, Q.Z);
4344     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->Y, Q.Y, Q.Z);
4345 }
4346
4347 /*-
4348  * Variable point scalar multiplication with "regular" wnaf.
4349  */
4350 static void var_smul_rwnaf(pt_aff_t *out, const unsigned char scalar[64],
4351                            const pt_aff_t *P) {
4352     int i, j, d, diff, is_neg;
4353     char rnaf[103] = {0};
4354     pt_prj_t Q, lut;
4355     pt_prj_t precomp[DRADIX / 2];
4356
4357     precomp_wnaf(precomp, P);
4358     scalar_rwnaf(rnaf, scalar);
4359
4360 #if defined(_MSC_VER)
4361     /* result still unsigned: yes we know */
4362 #pragma warning(push)
4363 #pragma warning(disable : 4146)
4364 #endif
4365
4366     /* initialize accumulator to high digit */
4367     d = (rnaf[102] - 1) >> 1;
4368     for (j = 0; j < DRADIX / 2; j++) {
4369         diff = (1 - (-(d ^ j) >> (8 * sizeof(int) - 1))) & 1;
4370         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.X, diff, Q.X,
4371                                                             precomp[j].X);
4372         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Y, diff, Q.Y,
4373                                                             precomp[j].Y);
4374         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Z, diff, Q.Z,
4375                                                             precomp[j].Z);
4376     }
4377
4378     for (i = 101; i >= 0; i--) {
4379         for (j = 0; j < RADIX; j++) point_double(&Q, &Q);
4380         d = rnaf[i];
4381         /* is_neg = (d < 0) ? 1 : 0 */
4382         is_neg = (d >> (8 * sizeof(int) - 1)) & 1;
4383         /* d = abs(d) */
4384         d = (d ^ -is_neg) + is_neg;
4385         d = (d - 1) >> 1;
4386         for (j = 0; j < DRADIX / 2; j++) {
4387             diff = (1 - (-(d ^ j) >> (8 * sizeof(int) - 1))) & 1;
4388             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
4389                 lut.X, diff, lut.X, precomp[j].X);
4390             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
4391                 lut.Y, diff, lut.Y, precomp[j].Y);
4392             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
4393                 lut.Z, diff, lut.Z, precomp[j].Z);
4394         }
4395         /* negate lut point if digit is negative */
4396         fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(out->Y, lut.Y);
4397         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(lut.Y, is_neg,
4398                                                             lut.Y, out->Y);
4399         point_add_proj(&Q, &Q, &lut);
4400     }
4401
4402 #if defined(_MSC_VER)
4403 #pragma warning(pop)
4404 #endif
4405
4406     /* conditionally subtract P if the scalar was even */
4407     fe_copy(lut.X, precomp[0].X);
4408     fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(lut.Y, precomp[0].Y);
4409     fe_copy(lut.Z, precomp[0].Z);
4410     point_add_proj(&lut, &lut, &Q);
4411     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.X, scalar[0] & 1,
4412                                                         lut.X, Q.X);
4413     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Y, scalar[0] & 1,
4414                                                         lut.Y, Q.Y);
4415     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Z, scalar[0] & 1,
4416                                                         lut.Z, Q.Z);
4417
4418     /* convert to affine -- NB depends on coordinate system */
4419     fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(Q.Z, Q.Z);
4420     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->X, Q.X, Q.Z);
4421     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->Y, Q.Y, Q.Z);
4422 }
4423
4424 /*-
4425  * Fixed scalar multiplication: comb with interleaving.
4426  */
4427 static void fixed_smul_cmb(pt_aff_t *out, const unsigned char scalar[64]) {
4428     int i, j, k, d, diff, is_neg = 0;
4429     char rnaf[103] = {0};
4430     pt_prj_t Q, R;
4431     pt_aff_t lut;
4432
4433     scalar_rwnaf(rnaf, scalar);
4434
4435     /* initalize accumulator to inf */
4436     fe_set_zero(Q.X);
4437     fe_copy(Q.Y, const_one);
4438     fe_set_zero(Q.Z);
4439
4440 #if defined(_MSC_VER)
4441     /* result still unsigned: yes we know */
4442 #pragma warning(push)
4443 #pragma warning(disable : 4146)
4444 #endif
4445
4446     for (i = 9; i >= 0; i--) {
4447         for (j = 0; i != 9 && j < RADIX; j++) point_double(&Q, &Q);
4448         for (j = 0; j < 12; j++) {
4449             if (j * 10 + i > 102) continue;
4450             d = rnaf[j * 10 + i];
4451             /* is_neg = (d < 0) ? 1 : 0 */
4452             is_neg = (d >> (8 * sizeof(int) - 1)) & 1;
4453             /* d = abs(d) */
4454             d = (d ^ -is_neg) + is_neg;
4455             d = (d - 1) >> 1;
4456             for (k = 0; k < DRADIX / 2; k++) {
4457                 diff = (1 - (-(d ^ k) >> (8 * sizeof(int) - 1))) & 1;
4458                 fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
4459                     lut.X, diff, lut.X, lut_cmb[j][k].X);
4460                 fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
4461                     lut.Y, diff, lut.Y, lut_cmb[j][k].Y);
4462             }
4463             /* negate lut point if digit is negative */
4464             fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(out->Y, lut.Y);
4465             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(lut.Y, is_neg,
4466                                                                 lut.Y, out->Y);
4467             point_add_mixed(&Q, &Q, &lut);
4468         }
4469     }
4470
4471 #if defined(_MSC_VER)
4472 #pragma warning(pop)
4473 #endif
4474
4475     /* conditionally subtract P if the scalar was even */
4476     fe_copy(lut.X, lut_cmb[0][0].X);
4477     fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(lut.Y, lut_cmb[0][0].Y);
4478     point_add_mixed(&R, &Q, &lut);
4479     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.X, scalar[0] & 1, R.X,
4480                                                         Q.X);
4481     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Y, scalar[0] & 1, R.Y,
4482                                                         Q.Y);
4483     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Z, scalar[0] & 1, R.Z,
4484                                                         Q.Z);
4485
4486     /* convert to affine -- NB depends on coordinate system */
4487     fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(Q.Z, Q.Z);
4488     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->X, Q.X, Q.Z);
4489     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->Y, Q.Y, Q.Z);
4490 }
4491
4492 static void point_mul_two(unsigned char outx[64], unsigned char outy[64],
4493                           const unsigned char a[64], const unsigned char b[64],
4494                           const unsigned char inx[64],
4495                           const unsigned char iny[64]) {
4496     pt_aff_t P;
4497
4498     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.X, inx);
4499     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.Y, iny);
4500     /* simultaneous scalar multiplication */
4501     var_smul_wnaf_two(&P, a, b, &P);
4502
4503     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outx, P.X);
4504     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outy, P.Y);
4505 }
4506
4507 static void point_mul_g(unsigned char outx[64], unsigned char outy[64],
4508                         const unsigned char scalar[64]) {
4509     pt_aff_t P;
4510
4511     /* fixed scmul function */
4512     fixed_smul_cmb(&P, scalar);
4513     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outx, P.X);
4514     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outy, P.Y);
4515 }
4516
4517 static void point_mul(unsigned char outx[64], unsigned char outy[64],
4518                       const unsigned char scalar[64],
4519                       const unsigned char inx[64],
4520                       const unsigned char iny[64]) {
4521     pt_aff_t P;
4522
4523     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.X, inx);
4524     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.Y, iny);
4525     /* var scmul function */
4526     var_smul_rwnaf(&P, scalar, &P);
4527     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outx, P.X);
4528     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outy, P.Y);
4529 }
4530
4531 #include <openssl/ec.h>
4532
4533 static const unsigned char const_zb[64] = {0};
4534
4535     int
4536     point_mul_two_id_tc26_gost_3410_2012_512_paramSetA(
4537         const EC_GROUP *group, EC_POINT *r, const BIGNUM *n, const EC_POINT *q,
4538         const BIGNUM *m, BN_CTX *ctx) {
4539     int ret = 0;
4540     unsigned char b_x[64];
4541     unsigned char b_y[64];
4542     unsigned char b_n[64];
4543     unsigned char b_m[64];
4544     BIGNUM *x = NULL, *y = NULL;
4545
4546     BN_CTX_start(ctx);
4547     x = BN_CTX_get(ctx);
4548     if ((y = BN_CTX_get(ctx)) == NULL
4549         /* pull out coords as bytes */
4550         || !EC_POINT_get_affine_coordinates(group, q, x, y, ctx) ||
4551         BN_bn2lebinpad(x, b_x, 64) != 64 || BN_bn2lebinpad(y, b_y, 64) != 64 ||
4552         BN_bn2lebinpad(n, b_n, 64) != 64 || BN_bn2lebinpad(m, b_m, 64) != 64)
4553         goto err;
4554     /* do the simultaneous scalar multiplication */
4555     point_mul_two(b_x, b_y, b_n, b_m, b_x, b_y);
4556     /* check for infinity */
4557     if (CRYPTO_memcmp(const_zb, b_x, 64) == 0 &&
4558         CRYPTO_memcmp(const_zb, b_y, 64) == 0) {
4559         if (!EC_POINT_set_to_infinity(group, r)) goto err;
4560     } else {
4561         /* otherwise, pack the bytes into the result */
4562         if (BN_lebin2bn(b_x, 64, x) == NULL ||
4563             BN_lebin2bn(b_y, 64, y) == NULL ||
4564             !EC_POINT_set_affine_coordinates(group, r, x, y, ctx))
4565             goto err;
4566     }
4567     ret = 1;
4568 err:
4569     BN_CTX_end(ctx);
4570     return ret;
4571 }
4572
4573     int
4574     point_mul_id_tc26_gost_3410_2012_512_paramSetA(const EC_GROUP *group,
4575                                                    EC_POINT *r,
4576                                                    const EC_POINT *q,
4577                                                    const BIGNUM *m,
4578                                                    BN_CTX *ctx) {
4579     int ret = 0;
4580     unsigned char b_x[64];
4581     unsigned char b_y[64];
4582     unsigned char b_m[64];
4583     BIGNUM *x = NULL, *y = NULL;
4584
4585     BN_CTX_start(ctx);
4586     x = BN_CTX_get(ctx);
4587     if ((y = BN_CTX_get(ctx)) == NULL
4588         /* pull out coords as bytes */
4589         || !EC_POINT_get_affine_coordinates(group, q, x, y, ctx) ||
4590         BN_bn2lebinpad(x, b_x, 64) != 64 || BN_bn2lebinpad(y, b_y, 64) != 64 ||
4591         BN_bn2lebinpad(m, b_m, 64) != 64)
4592         goto err;
4593     /* do the variable scalar multiplication */
4594     point_mul(b_x, b_y, b_m, b_x, b_y);
4595     /* check for infinity */
4596     if (CRYPTO_memcmp(const_zb, b_x, 64) == 0 &&
4597         CRYPTO_memcmp(const_zb, b_y, 64) == 0) {
4598         if (!EC_POINT_set_to_infinity(group, r)) goto err;
4599     } else {
4600         /* otherwise, pack the bytes into the result */
4601         if (BN_lebin2bn(b_x, 64, x) == NULL ||
4602             BN_lebin2bn(b_y, 64, y) == NULL ||
4603             !EC_POINT_set_affine_coordinates(group, r, x, y, ctx))
4604             goto err;
4605     }
4606     ret = 1;
4607 err:
4608     BN_CTX_end(ctx);
4609     return ret;
4610 }
4611
4612     int
4613     point_mul_g_id_tc26_gost_3410_2012_512_paramSetA(const EC_GROUP *group,
4614                                                      EC_POINT *r,
4615                                                      const BIGNUM *n,
4616                                                      BN_CTX *ctx) {
4617     int ret = 0;
4618     unsigned char b_x[64];
4619     unsigned char b_y[64];
4620     unsigned char b_n[64];
4621     BIGNUM *x = NULL, *y = NULL;
4622
4623     BN_CTX_start(ctx);
4624     x = BN_CTX_get(ctx);
4625     if ((y = BN_CTX_get(ctx)) == NULL || BN_bn2lebinpad(n, b_n, 64) != 64)
4626         goto err;
4627     /* do the fixed scalar multiplication */
4628     point_mul_g(b_x, b_y, b_n);
4629     /* check for infinity */
4630     if (CRYPTO_memcmp(const_zb, b_x, 64) == 0 &&
4631         CRYPTO_memcmp(const_zb, b_y, 64) == 0) {
4632         if (!EC_POINT_set_to_infinity(group, r)) goto err;
4633     } else {
4634         /* otherwise, pack the bytes into the result */
4635         if (BN_lebin2bn(b_x, 64, x) == NULL ||
4636             BN_lebin2bn(b_y, 64, y) == NULL ||
4637             !EC_POINT_set_affine_coordinates(group, r, x, y, ctx))
4638             goto err;
4639     }
4640     ret = 1;
4641 err:
4642     BN_CTX_end(ctx);
4643     return ret;
4644 }
4645
4646
4647
4648 #else /* __SIZEOF_INT128__ */
4649
4650 #include <stdint.h>
4651 #include <string.h>
4652 #define LIMB_BITS 32
4653 #define LIMB_CNT 23
4654 /* Field elements */
4655 typedef uint32_t fe_t[LIMB_CNT];
4656 typedef uint32_t limb_t;
4657
4658 #define fe_copy(d, s) memcpy(d, s, sizeof(fe_t))
4659 #define fe_set_zero(d) memset(d, 0, sizeof(fe_t))
4660
4661 #define fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(c, a, b) \
4662     fiat_id_tc26_gost_3410_2012_512_paramSetA_add(c, a, b);          \
4663     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry(c, c)
4664 #define fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(c, a, b) \
4665     fiat_id_tc26_gost_3410_2012_512_paramSetA_sub(c, a, b);          \
4666     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry(c, c)
4667
4668 /* Projective points */
4669 typedef struct {
4670     fe_t X;
4671     fe_t Y;
4672     fe_t Z;
4673 } pt_prj_t;
4674
4675 /* Affine points */
4676 typedef struct {
4677     fe_t X;
4678     fe_t Y;
4679 } pt_aff_t;
4680
4681 /* BEGIN verbatim fiat code https://github.com/mit-plv/fiat-crypto */
4682 /*-
4683  * MIT License
4684  *
4685  * Copyright (c) 2020 the fiat-crypto authors (see the AUTHORS file)
4686  *
4687  * Permission is hereby granted, free of charge, to any person obtaining a copy
4688  * of this software and associated documentation files (the "Software"), to deal
4689  * in the Software without restriction, including without limitation the rights
4690  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
4691  * copies of the Software, and to permit persons to whom the Software is
4692  * furnished to do so, subject to the following conditions:
4693  *
4694  * The above copyright notice and this permission notice shall be included in
4695  * all copies or substantial portions of the Software.
4696  *
4697  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
4698  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
4699  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
4700  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
4701  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
4702  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
4703  * SOFTWARE.
4704  */
4705
4706 /* Autogenerated: unsaturated_solinas --static id_tc26_gost_3410_2012_512_paramSetA 32 '(auto)' '2^512 - 569' */
4707 /* curve description: id_tc26_gost_3410_2012_512_paramSetA */
4708 /* machine_wordsize = 32 (from "32") */
4709 /* requested operations: (all) */
4710 /* n = 23 (from "(auto)") */
4711 /* s-c = 2^512 - [(1, 569)] (from "2^512 - 569") */
4712 /* tight_bounds_multiplier = 1.1 (from "") */
4713 /*  */
4714 /* Computed values: */
4715 /* carry_chain = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 0, 1] */
4716 /* eval z = z[0] + (z[1] << 23) + (z[2] << 45) + (z[3] << 67) + (z[4] << 90) + (z[5] << 112) + (z[6] << 134) + (z[7] << 156) + (z[8] << 179) + (z[9] << 201) + (z[10] << 223) + (z[11] << 245) + (z[12] << 0x10c) + (z[13] << 0x122) + (z[14] << 0x138) + (z[15] << 0x14e) + (z[16] << 0x165) + (z[17] << 0x17b) + (z[18] << 0x191) + (z[19] << 0x1a7) + (z[20] << 0x1be) + (z[21] << 0x1d4) + (z[22] << 0x1ea) */
4717 /* bytes_eval z = z[0] + (z[1] << 8) + (z[2] << 16) + (z[3] << 24) + (z[4] << 32) + (z[5] << 40) + (z[6] << 48) + (z[7] << 56) + (z[8] << 64) + (z[9] << 72) + (z[10] << 80) + (z[11] << 88) + (z[12] << 96) + (z[13] << 104) + (z[14] << 112) + (z[15] << 120) + (z[16] << 128) + (z[17] << 136) + (z[18] << 144) + (z[19] << 152) + (z[20] << 160) + (z[21] << 168) + (z[22] << 176) + (z[23] << 184) + (z[24] << 192) + (z[25] << 200) + (z[26] << 208) + (z[27] << 216) + (z[28] << 224) + (z[29] << 232) + (z[30] << 240) + (z[31] << 248) + (z[32] << 256) + (z[33] << 0x108) + (z[34] << 0x110) + (z[35] << 0x118) + (z[36] << 0x120) + (z[37] << 0x128) + (z[38] << 0x130) + (z[39] << 0x138) + (z[40] << 0x140) + (z[41] << 0x148) + (z[42] << 0x150) + (z[43] << 0x158) + (z[44] << 0x160) + (z[45] << 0x168) + (z[46] << 0x170) + (z[47] << 0x178) + (z[48] << 0x180) + (z[49] << 0x188) + (z[50] << 0x190) + (z[51] << 0x198) + (z[52] << 0x1a0) + (z[53] << 0x1a8) + (z[54] << 0x1b0) + (z[55] << 0x1b8) + (z[56] << 0x1c0) + (z[57] << 0x1c8) + (z[58] << 0x1d0) + (z[59] << 0x1d8) + (z[60] << 0x1e0) + (z[61] << 0x1e8) + (z[62] << 0x1f0) + (z[63] << 0x1f8) */
4718
4719 #include <stdint.h>
4720 typedef unsigned char fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1;
4721 typedef signed char fiat_id_tc26_gost_3410_2012_512_paramSetA_int1;
4722
4723 #if (-1 & 3) != 3
4724 #error "This code only works on a two's complement system"
4725 #endif
4726
4727 /*
4728  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22 is an addition with carry.
4729  * Postconditions:
4730  *   out1 = (arg1 + arg2 + arg3) mod 2^22
4731  *   out2 = ⌊(arg1 + arg2 + arg3) / 2^22⌋
4732  *
4733  * Input Bounds:
4734  *   arg1: [0x0 ~> 0x1]
4735  *   arg2: [0x0 ~> 0x3fffff]
4736  *   arg3: [0x0 ~> 0x3fffff]
4737  * Output Bounds:
4738  *   out1: [0x0 ~> 0x3fffff]
4739  *   out2: [0x0 ~> 0x1]
4740  */
4741 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
4742     uint32_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
4743     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint32_t arg2,
4744     uint32_t arg3) {
4745     uint32_t x1;
4746     uint32_t x2;
4747     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x3;
4748     x1 = ((arg1 + arg2) + arg3);
4749     x2 = (x1 & UINT32_C(0x3fffff));
4750     x3 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x1 >> 22);
4751     *out1 = x2;
4752     *out2 = x3;
4753 }
4754
4755 /*
4756  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22 is a subtraction with borrow.
4757  * Postconditions:
4758  *   out1 = (-arg1 + arg2 + -arg3) mod 2^22
4759  *   out2 = -⌊(-arg1 + arg2 + -arg3) / 2^22⌋
4760  *
4761  * Input Bounds:
4762  *   arg1: [0x0 ~> 0x1]
4763  *   arg2: [0x0 ~> 0x3fffff]
4764  *   arg3: [0x0 ~> 0x3fffff]
4765  * Output Bounds:
4766  *   out1: [0x0 ~> 0x3fffff]
4767  *   out2: [0x0 ~> 0x1]
4768  */
4769 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
4770     uint32_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
4771     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint32_t arg2,
4772     uint32_t arg3) {
4773     int32_t x1;
4774     fiat_id_tc26_gost_3410_2012_512_paramSetA_int1 x2;
4775     uint32_t x3;
4776     x1 = ((int32_t)(arg2 - arg1) - (int32_t)arg3);
4777     x2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_int1)(x1 >> 22);
4778     x3 = (x1 & UINT32_C(0x3fffff));
4779     *out1 = x3;
4780     *out2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(0x0 - x2);
4781 }
4782
4783 /*
4784  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23 is an addition with carry.
4785  * Postconditions:
4786  *   out1 = (arg1 + arg2 + arg3) mod 2^23
4787  *   out2 = ⌊(arg1 + arg2 + arg3) / 2^23⌋
4788  *
4789  * Input Bounds:
4790  *   arg1: [0x0 ~> 0x1]
4791  *   arg2: [0x0 ~> 0x7fffff]
4792  *   arg3: [0x0 ~> 0x7fffff]
4793  * Output Bounds:
4794  *   out1: [0x0 ~> 0x7fffff]
4795  *   out2: [0x0 ~> 0x1]
4796  */
4797 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
4798     uint32_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
4799     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint32_t arg2,
4800     uint32_t arg3) {
4801     uint32_t x1;
4802     uint32_t x2;
4803     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x3;
4804     x1 = ((arg1 + arg2) + arg3);
4805     x2 = (x1 & UINT32_C(0x7fffff));
4806     x3 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x1 >> 23);
4807     *out1 = x2;
4808     *out2 = x3;
4809 }
4810
4811 /*
4812  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23 is a subtraction with borrow.
4813  * Postconditions:
4814  *   out1 = (-arg1 + arg2 + -arg3) mod 2^23
4815  *   out2 = -⌊(-arg1 + arg2 + -arg3) / 2^23⌋
4816  *
4817  * Input Bounds:
4818  *   arg1: [0x0 ~> 0x1]
4819  *   arg2: [0x0 ~> 0x7fffff]
4820  *   arg3: [0x0 ~> 0x7fffff]
4821  * Output Bounds:
4822  *   out1: [0x0 ~> 0x7fffff]
4823  *   out2: [0x0 ~> 0x1]
4824  */
4825 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
4826     uint32_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 *out2,
4827     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1, uint32_t arg2,
4828     uint32_t arg3) {
4829     int32_t x1;
4830     fiat_id_tc26_gost_3410_2012_512_paramSetA_int1 x2;
4831     uint32_t x3;
4832     x1 = ((int32_t)(arg2 - arg1) - (int32_t)arg3);
4833     x2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_int1)(x1 >> 23);
4834     x3 = (x1 & UINT32_C(0x7fffff));
4835     *out1 = x3;
4836     *out2 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(0x0 - x2);
4837 }
4838
4839 /*
4840  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32 is a single-word conditional move.
4841  * Postconditions:
4842  *   out1 = (if arg1 = 0 then arg2 else arg3)
4843  *
4844  * Input Bounds:
4845  *   arg1: [0x0 ~> 0x1]
4846  *   arg2: [0x0 ~> 0xffffffff]
4847  *   arg3: [0x0 ~> 0xffffffff]
4848  * Output Bounds:
4849  *   out1: [0x0 ~> 0xffffffff]
4850  */
4851 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
4852     uint32_t *out1, fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1,
4853     uint32_t arg2, uint32_t arg3) {
4854     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x1;
4855     uint32_t x2;
4856     uint32_t x3;
4857     x1 = (!(!arg1));
4858     x2 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_int1)(0x0 - x1) &
4859           UINT32_C(0xffffffff));
4860     x3 = ((x2 & arg3) | ((~x2) & arg2));
4861     *out1 = x3;
4862 }
4863
4864 /*
4865  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul multiplies two field elements and reduces the result.
4866  * Postconditions:
4867  *   eval out1 mod m = (eval arg1 * eval arg2) mod m
4868  *
4869  * Input Bounds:
4870  *   arg1: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
4871  *   arg2: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
4872  * Output Bounds:
4873  *   out1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
4874  */
4875 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(
4876     uint32_t out1[23], const uint32_t arg1[23], const uint32_t arg2[23]) {
4877     uint64_t x1;
4878     uint64_t x2;
4879     uint64_t x3;
4880     uint64_t x4;
4881     uint64_t x5;
4882     uint64_t x6;
4883     uint64_t x7;
4884     uint64_t x8;
4885     uint64_t x9;
4886     uint64_t x10;
4887     uint64_t x11;
4888     uint64_t x12;
4889     uint64_t x13;
4890     uint64_t x14;
4891     uint64_t x15;
4892     uint64_t x16;
4893     uint64_t x17;
4894     uint64_t x18;
4895     uint64_t x19;
4896     uint64_t x20;
4897     uint64_t x21;
4898     uint64_t x22;
4899     uint64_t x23;
4900     uint64_t x24;
4901     uint64_t x25;
4902     uint64_t x26;
4903     uint64_t x27;
4904     uint64_t x28;
4905     uint64_t x29;
4906     uint64_t x30;
4907     uint64_t x31;
4908     uint64_t x32;
4909     uint64_t x33;
4910     uint64_t x34;
4911     uint64_t x35;
4912     uint64_t x36;
4913     uint64_t x37;
4914     uint64_t x38;
4915     uint64_t x39;
4916     uint64_t x40;
4917     uint64_t x41;
4918     uint64_t x42;
4919     uint64_t x43;
4920     uint64_t x44;
4921     uint64_t x45;
4922     uint64_t x46;
4923     uint64_t x47;
4924     uint64_t x48;
4925     uint64_t x49;
4926     uint64_t x50;
4927     uint64_t x51;
4928     uint64_t x52;
4929     uint64_t x53;
4930     uint64_t x54;
4931     uint64_t x55;
4932     uint64_t x56;
4933     uint64_t x57;
4934     uint64_t x58;
4935     uint64_t x59;
4936     uint64_t x60;
4937     uint64_t x61;
4938     uint64_t x62;
4939     uint64_t x63;
4940     uint64_t x64;
4941     uint64_t x65;
4942     uint64_t x66;
4943     uint64_t x67;
4944     uint64_t x68;
4945     uint64_t x69;
4946     uint64_t x70;
4947     uint64_t x71;
4948     uint64_t x72;
4949     uint64_t x73;
4950     uint64_t x74;
4951     uint64_t x75;
4952     uint64_t x76;
4953     uint64_t x77;
4954     uint64_t x78;
4955     uint64_t x79;
4956     uint64_t x80;
4957     uint64_t x81;
4958     uint64_t x82;
4959     uint64_t x83;
4960     uint64_t x84;
4961     uint64_t x85;
4962     uint64_t x86;
4963     uint64_t x87;
4964     uint64_t x88;
4965     uint64_t x89;
4966     uint64_t x90;
4967     uint64_t x91;
4968     uint64_t x92;
4969     uint64_t x93;
4970     uint64_t x94;
4971     uint64_t x95;
4972     uint64_t x96;
4973     uint64_t x97;
4974     uint64_t x98;
4975     uint64_t x99;
4976     uint64_t x100;
4977     uint64_t x101;
4978     uint64_t x102;
4979     uint64_t x103;
4980     uint64_t x104;
4981     uint64_t x105;
4982     uint64_t x106;
4983     uint64_t x107;
4984     uint64_t x108;
4985     uint64_t x109;
4986     uint64_t x110;
4987     uint64_t x111;
4988     uint64_t x112;
4989     uint64_t x113;
4990     uint64_t x114;
4991     uint64_t x115;
4992     uint64_t x116;
4993     uint64_t x117;
4994     uint64_t x118;
4995     uint64_t x119;
4996     uint64_t x120;
4997     uint64_t x121;
4998     uint64_t x122;
4999     uint64_t x123;
5000     uint64_t x124;
5001     uint64_t x125;
5002     uint64_t x126;
5003     uint64_t x127;
5004     uint64_t x128;
5005     uint64_t x129;
5006     uint64_t x130;
5007     uint64_t x131;
5008     uint64_t x132;
5009     uint64_t x133;
5010     uint64_t x134;
5011     uint64_t x135;
5012     uint64_t x136;
5013     uint64_t x137;
5014     uint64_t x138;
5015     uint64_t x139;
5016     uint64_t x140;
5017     uint64_t x141;
5018     uint64_t x142;
5019     uint64_t x143;
5020     uint64_t x144;
5021     uint64_t x145;
5022     uint64_t x146;
5023     uint64_t x147;
5024     uint64_t x148;
5025     uint64_t x149;
5026     uint64_t x150;
5027     uint64_t x151;
5028     uint64_t x152;
5029     uint64_t x153;
5030     uint64_t x154;
5031     uint64_t x155;
5032     uint64_t x156;
5033     uint64_t x157;
5034     uint64_t x158;
5035     uint64_t x159;
5036     uint64_t x160;
5037     uint64_t x161;
5038     uint64_t x162;
5039     uint64_t x163;
5040     uint64_t x164;
5041     uint64_t x165;
5042     uint64_t x166;
5043     uint64_t x167;
5044     uint64_t x168;
5045     uint64_t x169;
5046     uint64_t x170;
5047     uint64_t x171;
5048     uint64_t x172;
5049     uint64_t x173;
5050     uint64_t x174;
5051     uint64_t x175;
5052     uint64_t x176;
5053     uint64_t x177;
5054     uint64_t x178;
5055     uint64_t x179;
5056     uint64_t x180;
5057     uint64_t x181;
5058     uint64_t x182;
5059     uint64_t x183;
5060     uint64_t x184;
5061     uint64_t x185;
5062     uint64_t x186;
5063     uint64_t x187;
5064     uint64_t x188;
5065     uint64_t x189;
5066     uint64_t x190;
5067     uint64_t x191;
5068     uint64_t x192;
5069     uint64_t x193;
5070     uint64_t x194;
5071     uint64_t x195;
5072     uint64_t x196;
5073     uint64_t x197;
5074     uint64_t x198;
5075     uint64_t x199;
5076     uint64_t x200;
5077     uint64_t x201;
5078     uint64_t x202;
5079     uint64_t x203;
5080     uint64_t x204;
5081     uint64_t x205;
5082     uint64_t x206;
5083     uint64_t x207;
5084     uint64_t x208;
5085     uint64_t x209;
5086     uint64_t x210;
5087     uint64_t x211;
5088     uint64_t x212;
5089     uint64_t x213;
5090     uint64_t x214;
5091     uint64_t x215;
5092     uint64_t x216;
5093     uint64_t x217;
5094     uint64_t x218;
5095     uint64_t x219;
5096     uint64_t x220;
5097     uint64_t x221;
5098     uint64_t x222;
5099     uint64_t x223;
5100     uint64_t x224;
5101     uint64_t x225;
5102     uint64_t x226;
5103     uint64_t x227;
5104     uint64_t x228;
5105     uint64_t x229;
5106     uint64_t x230;
5107     uint64_t x231;
5108     uint64_t x232;
5109     uint64_t x233;
5110     uint64_t x234;
5111     uint64_t x235;
5112     uint64_t x236;
5113     uint64_t x237;
5114     uint64_t x238;
5115     uint64_t x239;
5116     uint64_t x240;
5117     uint64_t x241;
5118     uint64_t x242;
5119     uint64_t x243;
5120     uint64_t x244;
5121     uint64_t x245;
5122     uint64_t x246;
5123     uint64_t x247;
5124     uint64_t x248;
5125     uint64_t x249;
5126     uint64_t x250;
5127     uint64_t x251;
5128     uint64_t x252;
5129     uint64_t x253;
5130     uint64_t x254;
5131     uint64_t x255;
5132     uint64_t x256;
5133     uint64_t x257;
5134     uint64_t x258;
5135     uint64_t x259;
5136     uint64_t x260;
5137     uint64_t x261;
5138     uint64_t x262;
5139     uint64_t x263;
5140     uint64_t x264;
5141     uint64_t x265;
5142     uint64_t x266;
5143     uint64_t x267;
5144     uint64_t x268;
5145     uint64_t x269;
5146     uint64_t x270;
5147     uint64_t x271;
5148     uint64_t x272;
5149     uint64_t x273;
5150     uint64_t x274;
5151     uint64_t x275;
5152     uint64_t x276;
5153     uint64_t x277;
5154     uint64_t x278;
5155     uint64_t x279;
5156     uint64_t x280;
5157     uint64_t x281;
5158     uint64_t x282;
5159     uint64_t x283;
5160     uint64_t x284;
5161     uint64_t x285;
5162     uint64_t x286;
5163     uint64_t x287;
5164     uint64_t x288;
5165     uint64_t x289;
5166     uint64_t x290;
5167     uint64_t x291;
5168     uint64_t x292;
5169     uint64_t x293;
5170     uint64_t x294;
5171     uint64_t x295;
5172     uint64_t x296;
5173     uint64_t x297;
5174     uint64_t x298;
5175     uint64_t x299;
5176     uint64_t x300;
5177     uint64_t x301;
5178     uint64_t x302;
5179     uint64_t x303;
5180     uint64_t x304;
5181     uint64_t x305;
5182     uint64_t x306;
5183     uint64_t x307;
5184     uint64_t x308;
5185     uint64_t x309;
5186     uint64_t x310;
5187     uint64_t x311;
5188     uint64_t x312;
5189     uint64_t x313;
5190     uint64_t x314;
5191     uint64_t x315;
5192     uint64_t x316;
5193     uint64_t x317;
5194     uint64_t x318;
5195     uint64_t x319;
5196     uint64_t x320;
5197     uint64_t x321;
5198     uint64_t x322;
5199     uint64_t x323;
5200     uint64_t x324;
5201     uint64_t x325;
5202     uint64_t x326;
5203     uint64_t x327;
5204     uint64_t x328;
5205     uint64_t x329;
5206     uint64_t x330;
5207     uint64_t x331;
5208     uint64_t x332;
5209     uint64_t x333;
5210     uint64_t x334;
5211     uint64_t x335;
5212     uint64_t x336;
5213     uint64_t x337;
5214     uint64_t x338;
5215     uint64_t x339;
5216     uint64_t x340;
5217     uint64_t x341;
5218     uint64_t x342;
5219     uint64_t x343;
5220     uint64_t x344;
5221     uint64_t x345;
5222     uint64_t x346;
5223     uint64_t x347;
5224     uint64_t x348;
5225     uint64_t x349;
5226     uint64_t x350;
5227     uint64_t x351;
5228     uint64_t x352;
5229     uint64_t x353;
5230     uint64_t x354;
5231     uint64_t x355;
5232     uint64_t x356;
5233     uint64_t x357;
5234     uint64_t x358;
5235     uint64_t x359;
5236     uint64_t x360;
5237     uint64_t x361;
5238     uint64_t x362;
5239     uint64_t x363;
5240     uint64_t x364;
5241     uint64_t x365;
5242     uint64_t x366;
5243     uint64_t x367;
5244     uint64_t x368;
5245     uint64_t x369;
5246     uint64_t x370;
5247     uint64_t x371;
5248     uint64_t x372;
5249     uint64_t x373;
5250     uint64_t x374;
5251     uint64_t x375;
5252     uint64_t x376;
5253     uint64_t x377;
5254     uint64_t x378;
5255     uint64_t x379;
5256     uint64_t x380;
5257     uint64_t x381;
5258     uint64_t x382;
5259     uint64_t x383;
5260     uint64_t x384;
5261     uint64_t x385;
5262     uint64_t x386;
5263     uint64_t x387;
5264     uint64_t x388;
5265     uint64_t x389;
5266     uint64_t x390;
5267     uint64_t x391;
5268     uint64_t x392;
5269     uint64_t x393;
5270     uint64_t x394;
5271     uint64_t x395;
5272     uint64_t x396;
5273     uint64_t x397;
5274     uint64_t x398;
5275     uint64_t x399;
5276     uint64_t x400;
5277     uint64_t x401;
5278     uint64_t x402;
5279     uint64_t x403;
5280     uint64_t x404;
5281     uint64_t x405;
5282     uint64_t x406;
5283     uint64_t x407;
5284     uint64_t x408;
5285     uint64_t x409;
5286     uint64_t x410;
5287     uint64_t x411;
5288     uint64_t x412;
5289     uint64_t x413;
5290     uint64_t x414;
5291     uint64_t x415;
5292     uint64_t x416;
5293     uint64_t x417;
5294     uint64_t x418;
5295     uint64_t x419;
5296     uint64_t x420;
5297     uint64_t x421;
5298     uint64_t x422;
5299     uint64_t x423;
5300     uint64_t x424;
5301     uint64_t x425;
5302     uint64_t x426;
5303     uint64_t x427;
5304     uint64_t x428;
5305     uint64_t x429;
5306     uint64_t x430;
5307     uint64_t x431;
5308     uint64_t x432;
5309     uint64_t x433;
5310     uint64_t x434;
5311     uint64_t x435;
5312     uint64_t x436;
5313     uint64_t x437;
5314     uint64_t x438;
5315     uint64_t x439;
5316     uint64_t x440;
5317     uint64_t x441;
5318     uint64_t x442;
5319     uint64_t x443;
5320     uint64_t x444;
5321     uint64_t x445;
5322     uint64_t x446;
5323     uint64_t x447;
5324     uint64_t x448;
5325     uint64_t x449;
5326     uint64_t x450;
5327     uint64_t x451;
5328     uint64_t x452;
5329     uint64_t x453;
5330     uint64_t x454;
5331     uint64_t x455;
5332     uint64_t x456;
5333     uint64_t x457;
5334     uint64_t x458;
5335     uint64_t x459;
5336     uint64_t x460;
5337     uint64_t x461;
5338     uint64_t x462;
5339     uint64_t x463;
5340     uint64_t x464;
5341     uint64_t x465;
5342     uint64_t x466;
5343     uint64_t x467;
5344     uint64_t x468;
5345     uint64_t x469;
5346     uint64_t x470;
5347     uint64_t x471;
5348     uint64_t x472;
5349     uint64_t x473;
5350     uint64_t x474;
5351     uint64_t x475;
5352     uint64_t x476;
5353     uint64_t x477;
5354     uint64_t x478;
5355     uint64_t x479;
5356     uint64_t x480;
5357     uint64_t x481;
5358     uint64_t x482;
5359     uint64_t x483;
5360     uint64_t x484;
5361     uint64_t x485;
5362     uint64_t x486;
5363     uint64_t x487;
5364     uint64_t x488;
5365     uint64_t x489;
5366     uint64_t x490;
5367     uint64_t x491;
5368     uint64_t x492;
5369     uint64_t x493;
5370     uint64_t x494;
5371     uint64_t x495;
5372     uint64_t x496;
5373     uint64_t x497;
5374     uint64_t x498;
5375     uint64_t x499;
5376     uint64_t x500;
5377     uint64_t x501;
5378     uint64_t x502;
5379     uint64_t x503;
5380     uint64_t x504;
5381     uint64_t x505;
5382     uint64_t x506;
5383     uint64_t x507;
5384     uint64_t x508;
5385     uint64_t x509;
5386     uint64_t x510;
5387     uint64_t x511;
5388     uint64_t x512;
5389     uint64_t x513;
5390     uint64_t x514;
5391     uint64_t x515;
5392     uint64_t x516;
5393     uint64_t x517;
5394     uint64_t x518;
5395     uint64_t x519;
5396     uint64_t x520;
5397     uint64_t x521;
5398     uint64_t x522;
5399     uint64_t x523;
5400     uint64_t x524;
5401     uint64_t x525;
5402     uint64_t x526;
5403     uint64_t x527;
5404     uint64_t x528;
5405     uint64_t x529;
5406     uint64_t x530;
5407     uint64_t x531;
5408     uint32_t x532;
5409     uint64_t x533;
5410     uint64_t x534;
5411     uint64_t x535;
5412     uint64_t x536;
5413     uint64_t x537;
5414     uint64_t x538;
5415     uint64_t x539;
5416     uint64_t x540;
5417     uint64_t x541;
5418     uint64_t x542;
5419     uint64_t x543;
5420     uint64_t x544;
5421     uint64_t x545;
5422     uint64_t x546;
5423     uint64_t x547;
5424     uint64_t x548;
5425     uint64_t x549;
5426     uint64_t x550;
5427     uint64_t x551;
5428     uint64_t x552;
5429     uint64_t x553;
5430     uint64_t x554;
5431     uint64_t x555;
5432     uint64_t x556;
5433     uint32_t x557;
5434     uint64_t x558;
5435     uint64_t x559;
5436     uint32_t x560;
5437     uint64_t x561;
5438     uint64_t x562;
5439     uint32_t x563;
5440     uint64_t x564;
5441     uint64_t x565;
5442     uint32_t x566;
5443     uint64_t x567;
5444     uint64_t x568;
5445     uint32_t x569;
5446     uint64_t x570;
5447     uint64_t x571;
5448     uint32_t x572;
5449     uint64_t x573;
5450     uint64_t x574;
5451     uint32_t x575;
5452     uint64_t x576;
5453     uint64_t x577;
5454     uint32_t x578;
5455     uint64_t x579;
5456     uint64_t x580;
5457     uint32_t x581;
5458     uint64_t x582;
5459     uint64_t x583;
5460     uint32_t x584;
5461     uint64_t x585;
5462     uint64_t x586;
5463     uint32_t x587;
5464     uint64_t x588;
5465     uint64_t x589;
5466     uint32_t x590;
5467     uint64_t x591;
5468     uint64_t x592;
5469     uint32_t x593;
5470     uint64_t x594;
5471     uint64_t x595;
5472     uint32_t x596;
5473     uint64_t x597;
5474     uint64_t x598;
5475     uint32_t x599;
5476     uint64_t x600;
5477     uint64_t x601;
5478     uint32_t x602;
5479     uint64_t x603;
5480     uint64_t x604;
5481     uint32_t x605;
5482     uint64_t x606;
5483     uint64_t x607;
5484     uint32_t x608;
5485     uint64_t x609;
5486     uint64_t x610;
5487     uint32_t x611;
5488     uint64_t x612;
5489     uint64_t x613;
5490     uint32_t x614;
5491     uint64_t x615;
5492     uint64_t x616;
5493     uint32_t x617;
5494     uint64_t x618;
5495     uint32_t x619;
5496     uint32_t x620;
5497     uint64_t x621;
5498     uint64_t x622;
5499     uint32_t x623;
5500     uint32_t x624;
5501     uint32_t x625;
5502     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x626;
5503     uint32_t x627;
5504     uint32_t x628;
5505     x1 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[22])));
5506     x2 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[21])));
5507     x3 = (UINT16_C(0x239) * (((uint64_t)(arg1[22]) * (arg2[20])) * 0x2));
5508     x4 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[19])));
5509     x5 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[18])));
5510     x6 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[17])));
5511     x7 = (UINT16_C(0x239) * (((uint64_t)(arg1[22]) * (arg2[16])) * 0x2));
5512     x8 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[15])));
5513     x9 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[14])));
5514     x10 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[13])));
5515     x11 = (UINT16_C(0x239) * (((uint64_t)(arg1[22]) * (arg2[12])) * 0x2));
5516     x12 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[11])));
5517     x13 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[10])));
5518     x14 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[9])));
5519     x15 = (UINT16_C(0x239) * (((uint64_t)(arg1[22]) * (arg2[8])) * 0x2));
5520     x16 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[7])));
5521     x17 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[6])));
5522     x18 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[5])));
5523     x19 = (UINT16_C(0x239) * (((uint64_t)(arg1[22]) * (arg2[4])) * 0x2));
5524     x20 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[3])));
5525     x21 = (UINT16_C(0x239) * ((uint64_t)(arg1[22]) * (arg2[2])));
5526     x22 = (UINT16_C(0x239) * (((uint64_t)(arg1[22]) * (arg2[1])) * 0x2));
5527     x23 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[22])));
5528     x24 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[21])) * 0x2));
5529     x25 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[20])) * 0x2));
5530     x26 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[19])));
5531     x27 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[18])));
5532     x28 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[17])) * 0x2));
5533     x29 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[16])) * 0x2));
5534     x30 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[15])));
5535     x31 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[14])));
5536     x32 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[13])) * 0x2));
5537     x33 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[12])) * 0x2));
5538     x34 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[11])));
5539     x35 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[10])));
5540     x36 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[9])) * 0x2));
5541     x37 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[8])) * 0x2));
5542     x38 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[7])));
5543     x39 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[6])));
5544     x40 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[5])) * 0x2));
5545     x41 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[4])) * 0x2));
5546     x42 = (UINT16_C(0x239) * ((uint64_t)(arg1[21]) * (arg2[3])));
5547     x43 = (UINT16_C(0x239) * (((uint64_t)(arg1[21]) * (arg2[2])) * 0x2));
5548     x44 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[22])) * 0x2));
5549     x45 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[21])) * 0x2));
5550     x46 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[20])) * 0x2));
5551     x47 = (UINT16_C(0x239) * ((uint64_t)(arg1[20]) * (arg2[19])));
5552     x48 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[18])) * 0x2));
5553     x49 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[17])) * 0x2));
5554     x50 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[16])) * 0x2));
5555     x51 = (UINT16_C(0x239) * ((uint64_t)(arg1[20]) * (arg2[15])));
5556     x52 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[14])) * 0x2));
5557     x53 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[13])) * 0x2));
5558     x54 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[12])) * 0x2));
5559     x55 = (UINT16_C(0x239) * ((uint64_t)(arg1[20]) * (arg2[11])));
5560     x56 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[10])) * 0x2));
5561     x57 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[9])) * 0x2));
5562     x58 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[8])) * 0x2));
5563     x59 = (UINT16_C(0x239) * ((uint64_t)(arg1[20]) * (arg2[7])));
5564     x60 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[6])) * 0x2));
5565     x61 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[5])) * 0x2));
5566     x62 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[4])) * 0x2));
5567     x63 = (UINT16_C(0x239) * (((uint64_t)(arg1[20]) * (arg2[3])) * 0x2));
5568     x64 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[22])));
5569     x65 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[21])));
5570     x66 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[20])));
5571     x67 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[19])));
5572     x68 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[18])));
5573     x69 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[17])));
5574     x70 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[16])));
5575     x71 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[15])));
5576     x72 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[14])));
5577     x73 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[13])));
5578     x74 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[12])));
5579     x75 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[11])));
5580     x76 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[10])));
5581     x77 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[9])));
5582     x78 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[8])));
5583     x79 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[7])));
5584     x80 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[6])));
5585     x81 = (UINT16_C(0x239) * ((uint64_t)(arg1[19]) * (arg2[5])));
5586     x82 = (UINT16_C(0x239) * (((uint64_t)(arg1[19]) * (arg2[4])) * 0x2));
5587     x83 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[22])));
5588     x84 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[21])));
5589     x85 = (UINT16_C(0x239) * (((uint64_t)(arg1[18]) * (arg2[20])) * 0x2));
5590     x86 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[19])));
5591     x87 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[18])));
5592     x88 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[17])));
5593     x89 = (UINT16_C(0x239) * (((uint64_t)(arg1[18]) * (arg2[16])) * 0x2));
5594     x90 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[15])));
5595     x91 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[14])));
5596     x92 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[13])));
5597     x93 = (UINT16_C(0x239) * (((uint64_t)(arg1[18]) * (arg2[12])) * 0x2));
5598     x94 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[11])));
5599     x95 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[10])));
5600     x96 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[9])));
5601     x97 = (UINT16_C(0x239) * (((uint64_t)(arg1[18]) * (arg2[8])) * 0x2));
5602     x98 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[7])));
5603     x99 = (UINT16_C(0x239) * ((uint64_t)(arg1[18]) * (arg2[6])));
5604     x100 = (UINT16_C(0x239) * (((uint64_t)(arg1[18]) * (arg2[5])) * 0x2));
5605     x101 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[22])));
5606     x102 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[21])) * 0x2));
5607     x103 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[20])) * 0x2));
5608     x104 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[19])));
5609     x105 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[18])));
5610     x106 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[17])) * 0x2));
5611     x107 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[16])) * 0x2));
5612     x108 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[15])));
5613     x109 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[14])));
5614     x110 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[13])) * 0x2));
5615     x111 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[12])) * 0x2));
5616     x112 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[11])));
5617     x113 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[10])));
5618     x114 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[9])) * 0x2));
5619     x115 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[8])) * 0x2));
5620     x116 = (UINT16_C(0x239) * ((uint64_t)(arg1[17]) * (arg2[7])));
5621     x117 = (UINT16_C(0x239) * (((uint64_t)(arg1[17]) * (arg2[6])) * 0x2));
5622     x118 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[22])) * 0x2));
5623     x119 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[21])) * 0x2));
5624     x120 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[20])) * 0x2));
5625     x121 = (UINT16_C(0x239) * ((uint64_t)(arg1[16]) * (arg2[19])));
5626     x122 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[18])) * 0x2));
5627     x123 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[17])) * 0x2));
5628     x124 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[16])) * 0x2));
5629     x125 = (UINT16_C(0x239) * ((uint64_t)(arg1[16]) * (arg2[15])));
5630     x126 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[14])) * 0x2));
5631     x127 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[13])) * 0x2));
5632     x128 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[12])) * 0x2));
5633     x129 = (UINT16_C(0x239) * ((uint64_t)(arg1[16]) * (arg2[11])));
5634     x130 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[10])) * 0x2));
5635     x131 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[9])) * 0x2));
5636     x132 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[8])) * 0x2));
5637     x133 = (UINT16_C(0x239) * (((uint64_t)(arg1[16]) * (arg2[7])) * 0x2));
5638     x134 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[22])));
5639     x135 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[21])));
5640     x136 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[20])));
5641     x137 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[19])));
5642     x138 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[18])));
5643     x139 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[17])));
5644     x140 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[16])));
5645     x141 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[15])));
5646     x142 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[14])));
5647     x143 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[13])));
5648     x144 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[12])));
5649     x145 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[11])));
5650     x146 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[10])));
5651     x147 = (UINT16_C(0x239) * ((uint64_t)(arg1[15]) * (arg2[9])));
5652     x148 = (UINT16_C(0x239) * (((uint64_t)(arg1[15]) * (arg2[8])) * 0x2));
5653     x149 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[22])));
5654     x150 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[21])));
5655     x151 = (UINT16_C(0x239) * (((uint64_t)(arg1[14]) * (arg2[20])) * 0x2));
5656     x152 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[19])));
5657     x153 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[18])));
5658     x154 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[17])));
5659     x155 = (UINT16_C(0x239) * (((uint64_t)(arg1[14]) * (arg2[16])) * 0x2));
5660     x156 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[15])));
5661     x157 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[14])));
5662     x158 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[13])));
5663     x159 = (UINT16_C(0x239) * (((uint64_t)(arg1[14]) * (arg2[12])) * 0x2));
5664     x160 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[11])));
5665     x161 = (UINT16_C(0x239) * ((uint64_t)(arg1[14]) * (arg2[10])));
5666     x162 = (UINT16_C(0x239) * (((uint64_t)(arg1[14]) * (arg2[9])) * 0x2));
5667     x163 = (UINT16_C(0x239) * ((uint64_t)(arg1[13]) * (arg2[22])));
5668     x164 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[21])) * 0x2));
5669     x165 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[20])) * 0x2));
5670     x166 = (UINT16_C(0x239) * ((uint64_t)(arg1[13]) * (arg2[19])));
5671     x167 = (UINT16_C(0x239) * ((uint64_t)(arg1[13]) * (arg2[18])));
5672     x168 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[17])) * 0x2));
5673     x169 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[16])) * 0x2));
5674     x170 = (UINT16_C(0x239) * ((uint64_t)(arg1[13]) * (arg2[15])));
5675     x171 = (UINT16_C(0x239) * ((uint64_t)(arg1[13]) * (arg2[14])));
5676     x172 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[13])) * 0x2));
5677     x173 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[12])) * 0x2));
5678     x174 = (UINT16_C(0x239) * ((uint64_t)(arg1[13]) * (arg2[11])));
5679     x175 = (UINT16_C(0x239) * (((uint64_t)(arg1[13]) * (arg2[10])) * 0x2));
5680     x176 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[22])) * 0x2));
5681     x177 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[21])) * 0x2));
5682     x178 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[20])) * 0x2));
5683     x179 = (UINT16_C(0x239) * ((uint64_t)(arg1[12]) * (arg2[19])));
5684     x180 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[18])) * 0x2));
5685     x181 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[17])) * 0x2));
5686     x182 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[16])) * 0x2));
5687     x183 = (UINT16_C(0x239) * ((uint64_t)(arg1[12]) * (arg2[15])));
5688     x184 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[14])) * 0x2));
5689     x185 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[13])) * 0x2));
5690     x186 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[12])) * 0x2));
5691     x187 = (UINT16_C(0x239) * (((uint64_t)(arg1[12]) * (arg2[11])) * 0x2));
5692     x188 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[22])));
5693     x189 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[21])));
5694     x190 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[20])));
5695     x191 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[19])));
5696     x192 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[18])));
5697     x193 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[17])));
5698     x194 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[16])));
5699     x195 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[15])));
5700     x196 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[14])));
5701     x197 = (UINT16_C(0x239) * ((uint64_t)(arg1[11]) * (arg2[13])));
5702     x198 = (UINT16_C(0x239) * (((uint64_t)(arg1[11]) * (arg2[12])) * 0x2));
5703     x199 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[22])));
5704     x200 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[21])));
5705     x201 = (UINT16_C(0x239) * (((uint64_t)(arg1[10]) * (arg2[20])) * 0x2));
5706     x202 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[19])));
5707     x203 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[18])));
5708     x204 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[17])));
5709     x205 = (UINT16_C(0x239) * (((uint64_t)(arg1[10]) * (arg2[16])) * 0x2));
5710     x206 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[15])));
5711     x207 = (UINT16_C(0x239) * ((uint64_t)(arg1[10]) * (arg2[14])));
5712     x208 = (UINT16_C(0x239) * (((uint64_t)(arg1[10]) * (arg2[13])) * 0x2));
5713     x209 = (UINT16_C(0x239) * ((uint64_t)(arg1[9]) * (arg2[22])));
5714     x210 = (UINT16_C(0x239) * (((uint64_t)(arg1[9]) * (arg2[21])) * 0x2));
5715     x211 = (UINT16_C(0x239) * (((uint64_t)(arg1[9]) * (arg2[20])) * 0x2));
5716     x212 = (UINT16_C(0x239) * ((uint64_t)(arg1[9]) * (arg2[19])));
5717     x213 = (UINT16_C(0x239) * ((uint64_t)(arg1[9]) * (arg2[18])));
5718     x214 = (UINT16_C(0x239) * (((uint64_t)(arg1[9]) * (arg2[17])) * 0x2));
5719     x215 = (UINT16_C(0x239) * (((uint64_t)(arg1[9]) * (arg2[16])) * 0x2));
5720     x216 = (UINT16_C(0x239) * ((uint64_t)(arg1[9]) * (arg2[15])));
5721     x217 = (UINT16_C(0x239) * (((uint64_t)(arg1[9]) * (arg2[14])) * 0x2));
5722     x218 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[22])) * 0x2));
5723     x219 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[21])) * 0x2));
5724     x220 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[20])) * 0x2));
5725     x221 = (UINT16_C(0x239) * ((uint64_t)(arg1[8]) * (arg2[19])));
5726     x222 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[18])) * 0x2));
5727     x223 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[17])) * 0x2));
5728     x224 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[16])) * 0x2));
5729     x225 = (UINT16_C(0x239) * (((uint64_t)(arg1[8]) * (arg2[15])) * 0x2));
5730     x226 = (UINT16_C(0x239) * ((uint64_t)(arg1[7]) * (arg2[22])));
5731     x227 = (UINT16_C(0x239) * ((uint64_t)(arg1[7]) * (arg2[21])));
5732     x228 = (UINT16_C(0x239) * ((uint64_t)(arg1[7]) * (arg2[20])));
5733     x229 = (UINT16_C(0x239) * ((uint64_t)(arg1[7]) * (arg2[19])));
5734     x230 = (UINT16_C(0x239) * ((uint64_t)(arg1[7]) * (arg2[18])));
5735     x231 = (UINT16_C(0x239) * ((uint64_t)(arg1[7]) * (arg2[17])));
5736     x232 = (UINT16_C(0x239) * (((uint64_t)(arg1[7]) * (arg2[16])) * 0x2));
5737     x233 = (UINT16_C(0x239) * ((uint64_t)(arg1[6]) * (arg2[22])));
5738     x234 = (UINT16_C(0x239) * ((uint64_t)(arg1[6]) * (arg2[21])));
5739     x235 = (UINT16_C(0x239) * (((uint64_t)(arg1[6]) * (arg2[20])) * 0x2));
5740     x236 = (UINT16_C(0x239) * ((uint64_t)(arg1[6]) * (arg2[19])));
5741     x237 = (UINT16_C(0x239) * ((uint64_t)(arg1[6]) * (arg2[18])));
5742     x238 = (UINT16_C(0x239) * (((uint64_t)(arg1[6]) * (arg2[17])) * 0x2));
5743     x239 = (UINT16_C(0x239) * ((uint64_t)(arg1[5]) * (arg2[22])));
5744     x240 = (UINT16_C(0x239) * (((uint64_t)(arg1[5]) * (arg2[21])) * 0x2));
5745     x241 = (UINT16_C(0x239) * (((uint64_t)(arg1[5]) * (arg2[20])) * 0x2));
5746     x242 = (UINT16_C(0x239) * ((uint64_t)(arg1[5]) * (arg2[19])));
5747     x243 = (UINT16_C(0x239) * (((uint64_t)(arg1[5]) * (arg2[18])) * 0x2));
5748     x244 = (UINT16_C(0x239) * (((uint64_t)(arg1[4]) * (arg2[22])) * 0x2));
5749     x245 = (UINT16_C(0x239) * (((uint64_t)(arg1[4]) * (arg2[21])) * 0x2));
5750     x246 = (UINT16_C(0x239) * (((uint64_t)(arg1[4]) * (arg2[20])) * 0x2));
5751     x247 = (UINT16_C(0x239) * (((uint64_t)(arg1[4]) * (arg2[19])) * 0x2));
5752     x248 = (UINT16_C(0x239) * ((uint64_t)(arg1[3]) * (arg2[22])));
5753     x249 = (UINT16_C(0x239) * ((uint64_t)(arg1[3]) * (arg2[21])));
5754     x250 = (UINT16_C(0x239) * (((uint64_t)(arg1[3]) * (arg2[20])) * 0x2));
5755     x251 = (UINT16_C(0x239) * ((uint64_t)(arg1[2]) * (arg2[22])));
5756     x252 = (UINT16_C(0x239) * (((uint64_t)(arg1[2]) * (arg2[21])) * 0x2));
5757     x253 = (UINT16_C(0x239) * (((uint64_t)(arg1[1]) * (arg2[22])) * 0x2));
5758     x254 = ((uint64_t)(arg1[22]) * (arg2[0]));
5759     x255 = ((uint64_t)(arg1[21]) * ((arg2[1]) * 0x2));
5760     x256 = ((uint64_t)(arg1[21]) * (arg2[0]));
5761     x257 = ((uint64_t)(arg1[20]) * ((arg2[2]) * 0x2));
5762     x258 = ((uint64_t)(arg1[20]) * ((arg2[1]) * 0x2));
5763     x259 = ((uint64_t)(arg1[20]) * (arg2[0]));
5764     x260 = ((uint64_t)(arg1[19]) * (arg2[3]));
5765     x261 = ((uint64_t)(arg1[19]) * (arg2[2]));
5766     x262 = ((uint64_t)(arg1[19]) * (arg2[1]));
5767     x263 = ((uint64_t)(arg1[19]) * (arg2[0]));
5768     x264 = ((uint64_t)(arg1[18]) * ((arg2[4]) * 0x2));
5769     x265 = ((uint64_t)(arg1[18]) * (arg2[3]));
5770     x266 = ((uint64_t)(arg1[18]) * (arg2[2]));
5771     x267 = ((uint64_t)(arg1[18]) * ((arg2[1]) * 0x2));
5772     x268 = ((uint64_t)(arg1[18]) * (arg2[0]));
5773     x269 = ((uint64_t)(arg1[17]) * ((arg2[5]) * 0x2));
5774     x270 = ((uint64_t)(arg1[17]) * ((arg2[4]) * 0x2));
5775     x271 = ((uint64_t)(arg1[17]) * (arg2[3]));
5776     x272 = ((uint64_t)(arg1[17]) * ((arg2[2]) * 0x2));
5777     x273 = ((uint64_t)(arg1[17]) * ((arg2[1]) * 0x2));
5778     x274 = ((uint64_t)(arg1[17]) * (arg2[0]));
5779     x275 = ((uint64_t)(arg1[16]) * ((arg2[6]) * 0x2));
5780     x276 = ((uint64_t)(arg1[16]) * ((arg2[5]) * 0x2));
5781     x277 = ((uint64_t)(arg1[16]) * ((arg2[4]) * 0x2));
5782     x278 = ((uint64_t)(arg1[16]) * ((arg2[3]) * 0x2));
5783     x279 = ((uint64_t)(arg1[16]) * ((arg2[2]) * 0x2));
5784     x280 = ((uint64_t)(arg1[16]) * ((arg2[1]) * 0x2));
5785     x281 = ((uint64_t)(arg1[16]) * (arg2[0]));
5786     x282 = ((uint64_t)(arg1[15]) * (arg2[7]));
5787     x283 = ((uint64_t)(arg1[15]) * (arg2[6]));
5788     x284 = ((uint64_t)(arg1[15]) * (arg2[5]));
5789     x285 = ((uint64_t)(arg1[15]) * ((arg2[4]) * 0x2));
5790     x286 = ((uint64_t)(arg1[15]) * (arg2[3]));
5791     x287 = ((uint64_t)(arg1[15]) * (arg2[2]));
5792     x288 = ((uint64_t)(arg1[15]) * (arg2[1]));
5793     x289 = ((uint64_t)(arg1[15]) * (arg2[0]));
5794     x290 = ((uint64_t)(arg1[14]) * ((arg2[8]) * 0x2));
5795     x291 = ((uint64_t)(arg1[14]) * (arg2[7]));
5796     x292 = ((uint64_t)(arg1[14]) * (arg2[6]));
5797     x293 = ((uint64_t)(arg1[14]) * ((arg2[5]) * 0x2));
5798     x294 = ((uint64_t)(arg1[14]) * ((arg2[4]) * 0x2));
5799     x295 = ((uint64_t)(arg1[14]) * (arg2[3]));
5800     x296 = ((uint64_t)(arg1[14]) * (arg2[2]));
5801     x297 = ((uint64_t)(arg1[14]) * ((arg2[1]) * 0x2));
5802     x298 = ((uint64_t)(arg1[14]) * (arg2[0]));
5803     x299 = ((uint64_t)(arg1[13]) * ((arg2[9]) * 0x2));
5804     x300 = ((uint64_t)(arg1[13]) * ((arg2[8]) * 0x2));
5805     x301 = ((uint64_t)(arg1[13]) * (arg2[7]));
5806     x302 = ((uint64_t)(arg1[13]) * ((arg2[6]) * 0x2));
5807     x303 = ((uint64_t)(arg1[13]) * ((arg2[5]) * 0x2));
5808     x304 = ((uint64_t)(arg1[13]) * ((arg2[4]) * 0x2));
5809     x305 = ((uint64_t)(arg1[13]) * (arg2[3]));
5810     x306 = ((uint64_t)(arg1[13]) * ((arg2[2]) * 0x2));
5811     x307 = ((uint64_t)(arg1[13]) * ((arg2[1]) * 0x2));
5812     x308 = ((uint64_t)(arg1[13]) * (arg2[0]));
5813     x309 = ((uint64_t)(arg1[12]) * ((arg2[10]) * 0x2));
5814     x310 = ((uint64_t)(arg1[12]) * ((arg2[9]) * 0x2));
5815     x311 = ((uint64_t)(arg1[12]) * ((arg2[8]) * 0x2));
5816     x312 = ((uint64_t)(arg1[12]) * ((arg2[7]) * 0x2));
5817     x313 = ((uint64_t)(arg1[12]) * ((arg2[6]) * 0x2));
5818     x314 = ((uint64_t)(arg1[12]) * ((arg2[5]) * 0x2));
5819     x315 = ((uint64_t)(arg1[12]) * ((arg2[4]) * 0x2));
5820     x316 = ((uint64_t)(arg1[12]) * ((arg2[3]) * 0x2));
5821     x317 = ((uint64_t)(arg1[12]) * ((arg2[2]) * 0x2));
5822     x318 = ((uint64_t)(arg1[12]) * ((arg2[1]) * 0x2));
5823     x319 = ((uint64_t)(arg1[12]) * (arg2[0]));
5824     x320 = ((uint64_t)(arg1[11]) * (arg2[11]));
5825     x321 = ((uint64_t)(arg1[11]) * (arg2[10]));
5826     x322 = ((uint64_t)(arg1[11]) * (arg2[9]));
5827     x323 = ((uint64_t)(arg1[11]) * ((arg2[8]) * 0x2));
5828     x324 = ((uint64_t)(arg1[11]) * (arg2[7]));
5829     x325 = ((uint64_t)(arg1[11]) * (arg2[6]));
5830     x326 = ((uint64_t)(arg1[11]) * (arg2[5]));
5831     x327 = ((uint64_t)(arg1[11]) * ((arg2[4]) * 0x2));
5832     x328 = ((uint64_t)(arg1[11]) * (arg2[3]));
5833     x329 = ((uint64_t)(arg1[11]) * (arg2[2]));
5834     x330 = ((uint64_t)(arg1[11]) * (arg2[1]));
5835     x331 = ((uint64_t)(arg1[11]) * (arg2[0]));
5836     x332 = ((uint64_t)(arg1[10]) * ((arg2[12]) * 0x2));
5837     x333 = ((uint64_t)(arg1[10]) * (arg2[11]));
5838     x334 = ((uint64_t)(arg1[10]) * (arg2[10]));
5839     x335 = ((uint64_t)(arg1[10]) * ((arg2[9]) * 0x2));
5840     x336 = ((uint64_t)(arg1[10]) * ((arg2[8]) * 0x2));
5841     x337 = ((uint64_t)(arg1[10]) * (arg2[7]));
5842     x338 = ((uint64_t)(arg1[10]) * (arg2[6]));
5843     x339 = ((uint64_t)(arg1[10]) * ((arg2[5]) * 0x2));
5844     x340 = ((uint64_t)(arg1[10]) * ((arg2[4]) * 0x2));
5845     x341 = ((uint64_t)(arg1[10]) * (arg2[3]));
5846     x342 = ((uint64_t)(arg1[10]) * (arg2[2]));
5847     x343 = ((uint64_t)(arg1[10]) * ((arg2[1]) * 0x2));
5848     x344 = ((uint64_t)(arg1[10]) * (arg2[0]));
5849     x345 = ((uint64_t)(arg1[9]) * ((arg2[13]) * 0x2));
5850     x346 = ((uint64_t)(arg1[9]) * ((arg2[12]) * 0x2));
5851     x347 = ((uint64_t)(arg1[9]) * (arg2[11]));
5852     x348 = ((uint64_t)(arg1[9]) * ((arg2[10]) * 0x2));
5853     x349 = ((uint64_t)(arg1[9]) * ((arg2[9]) * 0x2));
5854     x350 = ((uint64_t)(arg1[9]) * ((arg2[8]) * 0x2));
5855     x351 = ((uint64_t)(arg1[9]) * (arg2[7]));
5856     x352 = ((uint64_t)(arg1[9]) * ((arg2[6]) * 0x2));
5857     x353 = ((uint64_t)(arg1[9]) * ((arg2[5]) * 0x2));
5858     x354 = ((uint64_t)(arg1[9]) * ((arg2[4]) * 0x2));
5859     x355 = ((uint64_t)(arg1[9]) * (arg2[3]));
5860     x356 = ((uint64_t)(arg1[9]) * ((arg2[2]) * 0x2));
5861     x357 = ((uint64_t)(arg1[9]) * ((arg2[1]) * 0x2));
5862     x358 = ((uint64_t)(arg1[9]) * (arg2[0]));
5863     x359 = ((uint64_t)(arg1[8]) * ((arg2[14]) * 0x2));
5864     x360 = ((uint64_t)(arg1[8]) * ((arg2[13]) * 0x2));
5865     x361 = ((uint64_t)(arg1[8]) * ((arg2[12]) * 0x2));
5866     x362 = ((uint64_t)(arg1[8]) * ((arg2[11]) * 0x2));
5867     x363 = ((uint64_t)(arg1[8]) * ((arg2[10]) * 0x2));
5868     x364 = ((uint64_t)(arg1[8]) * ((arg2[9]) * 0x2));
5869     x365 = ((uint64_t)(arg1[8]) * ((arg2[8]) * 0x2));
5870     x366 = ((uint64_t)(arg1[8]) * ((arg2[7]) * 0x2));
5871     x367 = ((uint64_t)(arg1[8]) * ((arg2[6]) * 0x2));
5872     x368 = ((uint64_t)(arg1[8]) * ((arg2[5]) * 0x2));
5873     x369 = ((uint64_t)(arg1[8]) * ((arg2[4]) * 0x2));
5874     x370 = ((uint64_t)(arg1[8]) * ((arg2[3]) * 0x2));
5875     x371 = ((uint64_t)(arg1[8]) * ((arg2[2]) * 0x2));
5876     x372 = ((uint64_t)(arg1[8]) * ((arg2[1]) * 0x2));
5877     x373 = ((uint64_t)(arg1[8]) * (arg2[0]));
5878     x374 = ((uint64_t)(arg1[7]) * (arg2[15]));
5879     x375 = ((uint64_t)(arg1[7]) * (arg2[14]));
5880     x376 = ((uint64_t)(arg1[7]) * (arg2[13]));
5881     x377 = ((uint64_t)(arg1[7]) * ((arg2[12]) * 0x2));
5882     x378 = ((uint64_t)(arg1[7]) * (arg2[11]));
5883     x379 = ((uint64_t)(arg1[7]) * (arg2[10]));
5884     x380 = ((uint64_t)(arg1[7]) * (arg2[9]));
5885     x381 = ((uint64_t)(arg1[7]) * ((arg2[8]) * 0x2));
5886     x382 = ((uint64_t)(arg1[7]) * (arg2[7]));
5887     x383 = ((uint64_t)(arg1[7]) * (arg2[6]));
5888     x384 = ((uint64_t)(arg1[7]) * (arg2[5]));
5889     x385 = ((uint64_t)(arg1[7]) * ((arg2[4]) * 0x2));
5890     x386 = ((uint64_t)(arg1[7]) * (arg2[3]));
5891     x387 = ((uint64_t)(arg1[7]) * (arg2[2]));
5892     x388 = ((uint64_t)(arg1[7]) * (arg2[1]));
5893     x389 = ((uint64_t)(arg1[7]) * (arg2[0]));
5894     x390 = ((uint64_t)(arg1[6]) * ((arg2[16]) * 0x2));
5895     x391 = ((uint64_t)(arg1[6]) * (arg2[15]));
5896     x392 = ((uint64_t)(arg1[6]) * (arg2[14]));
5897     x393 = ((uint64_t)(arg1[6]) * ((arg2[13]) * 0x2));
5898     x394 = ((uint64_t)(arg1[6]) * ((arg2[12]) * 0x2));
5899     x395 = ((uint64_t)(arg1[6]) * (arg2[11]));
5900     x396 = ((uint64_t)(arg1[6]) * (arg2[10]));
5901     x397 = ((uint64_t)(arg1[6]) * ((arg2[9]) * 0x2));
5902     x398 = ((uint64_t)(arg1[6]) * ((arg2[8]) * 0x2));
5903     x399 = ((uint64_t)(arg1[6]) * (arg2[7]));
5904     x400 = ((uint64_t)(arg1[6]) * (arg2[6]));
5905     x401 = ((uint64_t)(arg1[6]) * ((arg2[5]) * 0x2));
5906     x402 = ((uint64_t)(arg1[6]) * ((arg2[4]) * 0x2));
5907     x403 = ((uint64_t)(arg1[6]) * (arg2[3]));
5908     x404 = ((uint64_t)(arg1[6]) * (arg2[2]));
5909     x405 = ((uint64_t)(arg1[6]) * ((arg2[1]) * 0x2));
5910     x406 = ((uint64_t)(arg1[6]) * (arg2[0]));
5911     x407 = ((uint64_t)(arg1[5]) * ((arg2[17]) * 0x2));
5912     x408 = ((uint64_t)(arg1[5]) * ((arg2[16]) * 0x2));
5913     x409 = ((uint64_t)(arg1[5]) * (arg2[15]));
5914     x410 = ((uint64_t)(arg1[5]) * ((arg2[14]) * 0x2));
5915     x411 = ((uint64_t)(arg1[5]) * ((arg2[13]) * 0x2));
5916     x412 = ((uint64_t)(arg1[5]) * ((arg2[12]) * 0x2));
5917     x413 = ((uint64_t)(arg1[5]) * (arg2[11]));
5918     x414 = ((uint64_t)(arg1[5]) * ((arg2[10]) * 0x2));
5919     x415 = ((uint64_t)(arg1[5]) * ((arg2[9]) * 0x2));
5920     x416 = ((uint64_t)(arg1[5]) * ((arg2[8]) * 0x2));
5921     x417 = ((uint64_t)(arg1[5]) * (arg2[7]));
5922     x418 = ((uint64_t)(arg1[5]) * ((arg2[6]) * 0x2));
5923     x419 = ((uint64_t)(arg1[5]) * ((arg2[5]) * 0x2));
5924     x420 = ((uint64_t)(arg1[5]) * ((arg2[4]) * 0x2));
5925     x421 = ((uint64_t)(arg1[5]) * (arg2[3]));
5926     x422 = ((uint64_t)(arg1[5]) * ((arg2[2]) * 0x2));
5927     x423 = ((uint64_t)(arg1[5]) * ((arg2[1]) * 0x2));
5928     x424 = ((uint64_t)(arg1[5]) * (arg2[0]));
5929     x425 = ((uint64_t)(arg1[4]) * ((arg2[18]) * 0x2));
5930     x426 = ((uint64_t)(arg1[4]) * ((arg2[17]) * 0x2));
5931     x427 = ((uint64_t)(arg1[4]) * ((arg2[16]) * 0x2));
5932     x428 = ((uint64_t)(arg1[4]) * ((arg2[15]) * 0x2));
5933     x429 = ((uint64_t)(arg1[4]) * ((arg2[14]) * 0x2));
5934     x430 = ((uint64_t)(arg1[4]) * ((arg2[13]) * 0x2));
5935     x431 = ((uint64_t)(arg1[4]) * ((arg2[12]) * 0x2));
5936     x432 = ((uint64_t)(arg1[4]) * ((arg2[11]) * 0x2));
5937     x433 = ((uint64_t)(arg1[4]) * ((arg2[10]) * 0x2));
5938     x434 = ((uint64_t)(arg1[4]) * ((arg2[9]) * 0x2));
5939     x435 = ((uint64_t)(arg1[4]) * ((arg2[8]) * 0x2));
5940     x436 = ((uint64_t)(arg1[4]) * ((arg2[7]) * 0x2));
5941     x437 = ((uint64_t)(arg1[4]) * ((arg2[6]) * 0x2));
5942     x438 = ((uint64_t)(arg1[4]) * ((arg2[5]) * 0x2));
5943     x439 = ((uint64_t)(arg1[4]) * ((arg2[4]) * 0x2));
5944     x440 = ((uint64_t)(arg1[4]) * ((arg2[3]) * 0x2));
5945     x441 = ((uint64_t)(arg1[4]) * ((arg2[2]) * 0x2));
5946     x442 = ((uint64_t)(arg1[4]) * ((arg2[1]) * 0x2));
5947     x443 = ((uint64_t)(arg1[4]) * (arg2[0]));
5948     x444 = ((uint64_t)(arg1[3]) * (arg2[19]));
5949     x445 = ((uint64_t)(arg1[3]) * (arg2[18]));
5950     x446 = ((uint64_t)(arg1[3]) * (arg2[17]));
5951     x447 = ((uint64_t)(arg1[3]) * ((arg2[16]) * 0x2));
5952     x448 = ((uint64_t)(arg1[3]) * (arg2[15]));
5953     x449 = ((uint64_t)(arg1[3]) * (arg2[14]));
5954     x450 = ((uint64_t)(arg1[3]) * (arg2[13]));
5955     x451 = ((uint64_t)(arg1[3]) * ((arg2[12]) * 0x2));
5956     x452 = ((uint64_t)(arg1[3]) * (arg2[11]));
5957     x453 = ((uint64_t)(arg1[3]) * (arg2[10]));
5958     x454 = ((uint64_t)(arg1[3]) * (arg2[9]));
5959     x455 = ((uint64_t)(arg1[3]) * ((arg2[8]) * 0x2));
5960     x456 = ((uint64_t)(arg1[3]) * (arg2[7]));
5961     x457 = ((uint64_t)(arg1[3]) * (arg2[6]));
5962     x458 = ((uint64_t)(arg1[3]) * (arg2[5]));
5963     x459 = ((uint64_t)(arg1[3]) * ((arg2[4]) * 0x2));
5964     x460 = ((uint64_t)(arg1[3]) * (arg2[3]));
5965     x461 = ((uint64_t)(arg1[3]) * (arg2[2]));
5966     x462 = ((uint64_t)(arg1[3]) * (arg2[1]));
5967     x463 = ((uint64_t)(arg1[3]) * (arg2[0]));
5968     x464 = ((uint64_t)(arg1[2]) * ((arg2[20]) * 0x2));
5969     x465 = ((uint64_t)(arg1[2]) * (arg2[19]));
5970     x466 = ((uint64_t)(arg1[2]) * (arg2[18]));
5971     x467 = ((uint64_t)(arg1[2]) * ((arg2[17]) * 0x2));
5972     x468 = ((uint64_t)(arg1[2]) * ((arg2[16]) * 0x2));
5973     x469 = ((uint64_t)(arg1[2]) * (arg2[15]));
5974     x470 = ((uint64_t)(arg1[2]) * (arg2[14]));
5975     x471 = ((uint64_t)(arg1[2]) * ((arg2[13]) * 0x2));
5976     x472 = ((uint64_t)(arg1[2]) * ((arg2[12]) * 0x2));
5977     x473 = ((uint64_t)(arg1[2]) * (arg2[11]));
5978     x474 = ((uint64_t)(arg1[2]) * (arg2[10]));
5979     x475 = ((uint64_t)(arg1[2]) * ((arg2[9]) * 0x2));
5980     x476 = ((uint64_t)(arg1[2]) * ((arg2[8]) * 0x2));
5981     x477 = ((uint64_t)(arg1[2]) * (arg2[7]));
5982     x478 = ((uint64_t)(arg1[2]) * (arg2[6]));
5983     x479 = ((uint64_t)(arg1[2]) * ((arg2[5]) * 0x2));
5984     x480 = ((uint64_t)(arg1[2]) * ((arg2[4]) * 0x2));
5985     x481 = ((uint64_t)(arg1[2]) * (arg2[3]));
5986     x482 = ((uint64_t)(arg1[2]) * (arg2[2]));
5987     x483 = ((uint64_t)(arg1[2]) * ((arg2[1]) * 0x2));
5988     x484 = ((uint64_t)(arg1[2]) * (arg2[0]));
5989     x485 = ((uint64_t)(arg1[1]) * ((arg2[21]) * 0x2));
5990     x486 = ((uint64_t)(arg1[1]) * ((arg2[20]) * 0x2));
5991     x487 = ((uint64_t)(arg1[1]) * (arg2[19]));
5992     x488 = ((uint64_t)(arg1[1]) * ((arg2[18]) * 0x2));
5993     x489 = ((uint64_t)(arg1[1]) * ((arg2[17]) * 0x2));
5994     x490 = ((uint64_t)(arg1[1]) * ((arg2[16]) * 0x2));
5995     x491 = ((uint64_t)(arg1[1]) * (arg2[15]));
5996     x492 = ((uint64_t)(arg1[1]) * ((arg2[14]) * 0x2));
5997     x493 = ((uint64_t)(arg1[1]) * ((arg2[13]) * 0x2));
5998     x494 = ((uint64_t)(arg1[1]) * ((arg2[12]) * 0x2));
5999     x495 = ((uint64_t)(arg1[1]) * (arg2[11]));
6000     x496 = ((uint64_t)(arg1[1]) * ((arg2[10]) * 0x2));
6001     x497 = ((uint64_t)(arg1[1]) * ((arg2[9]) * 0x2));
6002     x498 = ((uint64_t)(arg1[1]) * ((arg2[8]) * 0x2));
6003     x499 = ((uint64_t)(arg1[1]) * (arg2[7]));
6004     x500 = ((uint64_t)(arg1[1]) * ((arg2[6]) * 0x2));
6005     x501 = ((uint64_t)(arg1[1]) * ((arg2[5]) * 0x2));
6006     x502 = ((uint64_t)(arg1[1]) * ((arg2[4]) * 0x2));
6007     x503 = ((uint64_t)(arg1[1]) * (arg2[3]));
6008     x504 = ((uint64_t)(arg1[1]) * ((arg2[2]) * 0x2));
6009     x505 = ((uint64_t)(arg1[1]) * ((arg2[1]) * 0x2));
6010     x506 = ((uint64_t)(arg1[1]) * (arg2[0]));
6011     x507 = ((uint64_t)(arg1[0]) * (arg2[22]));
6012     x508 = ((uint64_t)(arg1[0]) * (arg2[21]));
6013     x509 = ((uint64_t)(arg1[0]) * (arg2[20]));
6014     x510 = ((uint64_t)(arg1[0]) * (arg2[19]));
6015     x511 = ((uint64_t)(arg1[0]) * (arg2[18]));
6016     x512 = ((uint64_t)(arg1[0]) * (arg2[17]));
6017     x513 = ((uint64_t)(arg1[0]) * (arg2[16]));
6018     x514 = ((uint64_t)(arg1[0]) * (arg2[15]));
6019     x515 = ((uint64_t)(arg1[0]) * (arg2[14]));
6020     x516 = ((uint64_t)(arg1[0]) * (arg2[13]));
6021     x517 = ((uint64_t)(arg1[0]) * (arg2[12]));
6022     x518 = ((uint64_t)(arg1[0]) * (arg2[11]));
6023     x519 = ((uint64_t)(arg1[0]) * (arg2[10]));
6024     x520 = ((uint64_t)(arg1[0]) * (arg2[9]));
6025     x521 = ((uint64_t)(arg1[0]) * (arg2[8]));
6026     x522 = ((uint64_t)(arg1[0]) * (arg2[7]));
6027     x523 = ((uint64_t)(arg1[0]) * (arg2[6]));
6028     x524 = ((uint64_t)(arg1[0]) * (arg2[5]));
6029     x525 = ((uint64_t)(arg1[0]) * (arg2[4]));
6030     x526 = ((uint64_t)(arg1[0]) * (arg2[3]));
6031     x527 = ((uint64_t)(arg1[0]) * (arg2[2]));
6032     x528 = ((uint64_t)(arg1[0]) * (arg2[1]));
6033     x529 = ((uint64_t)(arg1[0]) * (arg2[0]));
6034     x530 = (x529 +
6035             (x253 +
6036              (x252 +
6037               (x250 +
6038                (x247 +
6039                 (x243 +
6040                  (x238 +
6041                   (x232 +
6042                    (x225 +
6043                     (x217 +
6044                      (x208 +
6045                       (x198 +
6046                        (x187 +
6047                         (x175 +
6048                          (x162 +
6049                           (x148 +
6050                            (x133 +
6051                             (x117 +
6052                              (x100 +
6053                               (x82 + (x63 + (x43 + x22))))))))))))))))))))));
6054     x531 = (x530 >> 23);
6055     x532 = (uint32_t)(x530 & UINT32_C(0x7fffff));
6056     x533 =
6057         (x507 +
6058          (x485 +
6059           (x464 +
6060            (x444 +
6061             (x425 +
6062              (x407 +
6063               (x390 +
6064                (x374 +
6065                 (x359 +
6066                  (x345 +
6067                   (x332 +
6068                    (x320 +
6069                     (x309 +
6070                      (x299 +
6071                       (x290 +
6072                        (x282 +
6073                         (x275 +
6074                          (x269 +
6075                           (x264 +
6076                            (x260 + (x257 + (x255 + x254))))))))))))))))))))));
6077     x534 = (x508 +
6078             (x486 +
6079              (x465 +
6080               (x445 +
6081                (x426 +
6082                 (x408 +
6083                  (x391 +
6084                   (x375 +
6085                    (x360 +
6086                     (x346 +
6087                      (x333 +
6088                       (x321 +
6089                        (x310 +
6090                         (x300 +
6091                          (x291 +
6092                           (x283 +
6093                            (x276 +
6094                             (x270 +
6095                              (x265 +
6096                               (x261 + (x258 + (x256 + x1))))))))))))))))))))));
6097     x535 = (x509 +
6098             (x487 +
6099              (x466 +
6100               (x446 +
6101                (x427 +
6102                 (x409 +
6103                  (x392 +
6104                   (x376 +
6105                    (x361 +
6106                     (x347 +
6107                      (x334 +
6108                       (x322 +
6109                        (x311 +
6110                         (x301 +
6111                          (x292 +
6112                           (x284 +
6113                            (x277 +
6114                             (x271 +
6115                              (x266 +
6116                               (x262 + (x259 + (x23 + x2))))))))))))))))))))));
6117     x536 = (x510 +
6118             (x488 +
6119              (x467 +
6120               (x447 +
6121                (x428 +
6122                 (x410 +
6123                  (x393 +
6124                   (x377 +
6125                    (x362 +
6126                     (x348 +
6127                      (x335 +
6128                       (x323 +
6129                        (x312 +
6130                         (x302 +
6131                          (x293 +
6132                           (x285 +
6133                            (x278 +
6134                             (x272 +
6135                              (x267 +
6136                               (x263 + (x44 + (x24 + x3))))))))))))))))))))));
6137     x537 =
6138         (x511 +
6139          (x489 +
6140           (x468 +
6141            (x448 +
6142             (x429 +
6143              (x411 +
6144               (x394 +
6145                (x378 +
6146                 (x363 +
6147                  (x349 +
6148                   (x336 +
6149                    (x324 +
6150                     (x313 +
6151                      (x303 +
6152                       (x294 +
6153                        (x286 +
6154                         (x279 +
6155                          (x273 +
6156                           (x268 + (x64 + (x45 + (x25 + x4))))))))))))))))))))));
6157     x538 =
6158         (x512 +
6159          (x490 +
6160           (x469 +
6161            (x449 +
6162             (x430 +
6163              (x412 +
6164               (x395 +
6165                (x379 +
6166                 (x364 +
6167                  (x350 +
6168                   (x337 +
6169                    (x325 +
6170                     (x314 +
6171                      (x304 +
6172                       (x295 +
6173                        (x287 +
6174                         (x280 +
6175                          (x274 +
6176                           (x83 + (x65 + (x46 + (x26 + x5))))))))))))))))))))));
6177     x539 =
6178         (x513 +
6179          (x491 +
6180           (x470 +
6181            (x450 +
6182             (x431 +
6183              (x413 +
6184               (x396 +
6185                (x380 +
6186                 (x365 +
6187                  (x351 +
6188                   (x338 +
6189                    (x326 +
6190                     (x315 +
6191                      (x305 +
6192                       (x296 +
6193                        (x288 +
6194                         (x281 +
6195                          (x101 +
6196                           (x84 + (x66 + (x47 + (x27 + x6))))))))))))))))))))));
6197     x540 =
6198         (x514 +
6199          (x492 +
6200           (x471 +
6201            (x451 +
6202             (x432 +
6203              (x414 +
6204               (x397 +
6205                (x381 +
6206                 (x366 +
6207                  (x352 +
6208                   (x339 +
6209                    (x327 +
6210                     (x316 +
6211                      (x306 +
6212                       (x297 +
6213                        (x289 +
6214                         (x118 +
6215                          (x102 +
6216                           (x85 + (x67 + (x48 + (x28 + x7))))))))))))))))))))));
6217     x541 =
6218         (x515 +
6219          (x493 +
6220           (x472 +
6221            (x452 +
6222             (x433 +
6223              (x415 +
6224               (x398 +
6225                (x382 +
6226                 (x367 +
6227                  (x353 +
6228                   (x340 +
6229                    (x328 +
6230                     (x317 +
6231                      (x307 +
6232                       (x298 +
6233                        (x134 +
6234                         (x119 +
6235                          (x103 +
6236                           (x86 + (x68 + (x49 + (x29 + x8))))))))))))))))))))));
6237     x542 =
6238         (x516 +
6239          (x494 +
6240           (x473 +
6241            (x453 +
6242             (x434 +
6243              (x416 +
6244               (x399 +
6245                (x383 +
6246                 (x368 +
6247                  (x354 +
6248                   (x341 +
6249                    (x329 +
6250                     (x318 +
6251                      (x308 +
6252                       (x149 +
6253                        (x135 +
6254                         (x120 +
6255                          (x104 +
6256                           (x87 + (x69 + (x50 + (x30 + x9))))))))))))))))))))));
6257     x543 =
6258         (x517 +
6259          (x495 +
6260           (x474 +
6261            (x454 +
6262             (x435 +
6263              (x417 +
6264               (x400 +
6265                (x384 +
6266                 (x369 +
6267                  (x355 +
6268                   (x342 +
6269                    (x330 +
6270                     (x319 +
6271                      (x163 +
6272                       (x150 +
6273                        (x136 +
6274                         (x121 +
6275                          (x105 +
6276                           (x88 + (x70 + (x51 + (x31 + x10))))))))))))))))))))));
6277     x544 =
6278         (x518 +
6279          (x496 +
6280           (x475 +
6281            (x455 +
6282             (x436 +
6283              (x418 +
6284               (x401 +
6285                (x385 +
6286                 (x370 +
6287                  (x356 +
6288                   (x343 +
6289                    (x331 +
6290                     (x176 +
6291                      (x164 +
6292                       (x151 +
6293                        (x137 +
6294                         (x122 +
6295                          (x106 +
6296                           (x89 + (x71 + (x52 + (x32 + x11))))))))))))))))))))));
6297     x545 =
6298         (x519 +
6299          (x497 +
6300           (x476 +
6301            (x456 +
6302             (x437 +
6303              (x419 +
6304               (x402 +
6305                (x386 +
6306                 (x371 +
6307                  (x357 +
6308                   (x344 +
6309                    (x188 +
6310                     (x177 +
6311                      (x165 +
6312                       (x152 +
6313                        (x138 +
6314                         (x123 +
6315                          (x107 +
6316                           (x90 + (x72 + (x53 + (x33 + x12))))))))))))))))))))));
6317     x546 =
6318         (x520 +
6319          (x498 +
6320           (x477 +
6321            (x457 +
6322             (x438 +
6323              (x420 +
6324               (x403 +
6325                (x387 +
6326                 (x372 +
6327                  (x358 +
6328                   (x199 +
6329                    (x189 +
6330                     (x178 +
6331                      (x166 +
6332                       (x153 +
6333                        (x139 +
6334                         (x124 +
6335                          (x108 +
6336                           (x91 + (x73 + (x54 + (x34 + x13))))))))))))))))))))));
6337     x547 =
6338         (x521 +
6339          (x499 +
6340           (x478 +
6341            (x458 +
6342             (x439 +
6343              (x421 +
6344               (x404 +
6345                (x388 +
6346                 (x373 +
6347                  (x209 +
6348                   (x200 +
6349                    (x190 +
6350                     (x179 +
6351                      (x167 +
6352                       (x154 +
6353                        (x140 +
6354                         (x125 +
6355                          (x109 +
6356                           (x92 + (x74 + (x55 + (x35 + x14))))))))))))))))))))));
6357     x548 =
6358         (x522 +
6359          (x500 +
6360           (x479 +
6361            (x459 +
6362             (x440 +
6363              (x422 +
6364               (x405 +
6365                (x389 +
6366                 (x218 +
6367                  (x210 +
6368                   (x201 +
6369                    (x191 +
6370                     (x180 +
6371                      (x168 +
6372                       (x155 +
6373                        (x141 +
6374                         (x126 +
6375                          (x110 +
6376                           (x93 + (x75 + (x56 + (x36 + x15))))))))))))))))))))));
6377     x549 =
6378         (x523 +
6379          (x501 +
6380           (x480 +
6381            (x460 +
6382             (x441 +
6383              (x423 +
6384               (x406 +
6385                (x226 +
6386                 (x219 +
6387                  (x211 +
6388                   (x202 +
6389                    (x192 +
6390                     (x181 +
6391                      (x169 +
6392                       (x156 +
6393                        (x142 +
6394                         (x127 +
6395                          (x111 +
6396                           (x94 + (x76 + (x57 + (x37 + x16))))))))))))))))))))));
6397     x550 =
6398         (x524 +
6399          (x502 +
6400           (x481 +
6401            (x461 +
6402             (x442 +
6403              (x424 +
6404               (x233 +
6405                (x227 +
6406                 (x220 +
6407                  (x212 +
6408                   (x203 +
6409                    (x193 +
6410                     (x182 +
6411                      (x170 +
6412                       (x157 +
6413                        (x143 +
6414                         (x128 +
6415                          (x112 +
6416                           (x95 + (x77 + (x58 + (x38 + x17))))))))))))))))))))));
6417     x551 =
6418         (x525 +
6419          (x503 +
6420           (x482 +
6421            (x462 +
6422             (x443 +
6423              (x239 +
6424               (x234 +
6425                (x228 +
6426                 (x221 +
6427                  (x213 +
6428                   (x204 +
6429                    (x194 +
6430                     (x183 +
6431                      (x171 +
6432                       (x158 +
6433                        (x144 +
6434                         (x129 +
6435                          (x113 +
6436                           (x96 + (x78 + (x59 + (x39 + x18))))))))))))))))))))));
6437     x552 =
6438         (x526 +
6439          (x504 +
6440           (x483 +
6441            (x463 +
6442             (x244 +
6443              (x240 +
6444               (x235 +
6445                (x229 +
6446                 (x222 +
6447                  (x214 +
6448                   (x205 +
6449                    (x195 +
6450                     (x184 +
6451                      (x172 +
6452                       (x159 +
6453                        (x145 +
6454                         (x130 +
6455                          (x114 +
6456                           (x97 + (x79 + (x60 + (x40 + x19))))))))))))))))))))));
6457     x553 =
6458         (x527 +
6459          (x505 +
6460           (x484 +
6461            (x248 +
6462             (x245 +
6463              (x241 +
6464               (x236 +
6465                (x230 +
6466                 (x223 +
6467                  (x215 +
6468                   (x206 +
6469                    (x196 +
6470                     (x185 +
6471                      (x173 +
6472                       (x160 +
6473                        (x146 +
6474                         (x131 +
6475                          (x115 +
6476                           (x98 + (x80 + (x61 + (x41 + x20))))))))))))))))))))));
6477     x554 =
6478         (x528 +
6479          (x506 +
6480           (x251 +
6481            (x249 +
6482             (x246 +
6483              (x242 +
6484               (x237 +
6485                (x231 +
6486                 (x224 +
6487                  (x216 +
6488                   (x207 +
6489                    (x197 +
6490                     (x186 +
6491                      (x174 +
6492                       (x161 +
6493                        (x147 +
6494                         (x132 +
6495                          (x116 +
6496                           (x99 + (x81 + (x62 + (x42 + x21))))))))))))))))))))));
6497     x555 = (x531 + x554);
6498     x556 = (x555 >> 22);
6499     x557 = (uint32_t)(x555 & UINT32_C(0x3fffff));
6500     x558 = (x556 + x553);
6501     x559 = (x558 >> 22);
6502     x560 = (uint32_t)(x558 & UINT32_C(0x3fffff));
6503     x561 = (x559 + x552);
6504     x562 = (x561 >> 23);
6505     x563 = (uint32_t)(x561 & UINT32_C(0x7fffff));
6506     x564 = (x562 + x551);
6507     x565 = (x564 >> 22);
6508     x566 = (uint32_t)(x564 & UINT32_C(0x3fffff));
6509     x567 = (x565 + x550);
6510     x568 = (x567 >> 22);
6511     x569 = (uint32_t)(x567 & UINT32_C(0x3fffff));
6512     x570 = (x568 + x549);
6513     x571 = (x570 >> 22);
6514     x572 = (uint32_t)(x570 & UINT32_C(0x3fffff));
6515     x573 = (x571 + x548);
6516     x574 = (x573 >> 23);
6517     x575 = (uint32_t)(x573 & UINT32_C(0x7fffff));
6518     x576 = (x574 + x547);
6519     x577 = (x576 >> 22);
6520     x578 = (uint32_t)(x576 & UINT32_C(0x3fffff));
6521     x579 = (x577 + x546);
6522     x580 = (x579 >> 22);
6523     x581 = (uint32_t)(x579 & UINT32_C(0x3fffff));
6524     x582 = (x580 + x545);
6525     x583 = (x582 >> 22);
6526     x584 = (uint32_t)(x582 & UINT32_C(0x3fffff));
6527     x585 = (x583 + x544);
6528     x586 = (x585 >> 23);
6529     x587 = (uint32_t)(x585 & UINT32_C(0x7fffff));
6530     x588 = (x586 + x543);
6531     x589 = (x588 >> 22);
6532     x590 = (uint32_t)(x588 & UINT32_C(0x3fffff));
6533     x591 = (x589 + x542);
6534     x592 = (x591 >> 22);
6535     x593 = (uint32_t)(x591 & UINT32_C(0x3fffff));
6536     x594 = (x592 + x541);
6537     x595 = (x594 >> 22);
6538     x596 = (uint32_t)(x594 & UINT32_C(0x3fffff));
6539     x597 = (x595 + x540);
6540     x598 = (x597 >> 23);
6541     x599 = (uint32_t)(x597 & UINT32_C(0x7fffff));
6542     x600 = (x598 + x539);
6543     x601 = (x600 >> 22);
6544     x602 = (uint32_t)(x600 & UINT32_C(0x3fffff));
6545     x603 = (x601 + x538);
6546     x604 = (x603 >> 22);
6547     x605 = (uint32_t)(x603 & UINT32_C(0x3fffff));
6548     x606 = (x604 + x537);
6549     x607 = (x606 >> 22);
6550     x608 = (uint32_t)(x606 & UINT32_C(0x3fffff));
6551     x609 = (x607 + x536);
6552     x610 = (x609 >> 23);
6553     x611 = (uint32_t)(x609 & UINT32_C(0x7fffff));
6554     x612 = (x610 + x535);
6555     x613 = (x612 >> 22);
6556     x614 = (uint32_t)(x612 & UINT32_C(0x3fffff));
6557     x615 = (x613 + x534);
6558     x616 = (x615 >> 22);
6559     x617 = (uint32_t)(x615 & UINT32_C(0x3fffff));
6560     x618 = (x616 + x533);
6561     x619 = (uint32_t)(x618 >> 22);
6562     x620 = (uint32_t)(x618 & UINT32_C(0x3fffff));
6563     x621 = ((uint64_t)UINT16_C(0x239) * x619);
6564     x622 = (x532 + x621);
6565     x623 = (uint32_t)(x622 >> 23);
6566     x624 = (uint32_t)(x622 & UINT32_C(0x7fffff));
6567     x625 = (x623 + x557);
6568     x626 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x625 >> 22);
6569     x627 = (x625 & UINT32_C(0x3fffff));
6570     x628 = (x626 + x560);
6571     out1[0] = x624;
6572     out1[1] = x627;
6573     out1[2] = x628;
6574     out1[3] = x563;
6575     out1[4] = x566;
6576     out1[5] = x569;
6577     out1[6] = x572;
6578     out1[7] = x575;
6579     out1[8] = x578;
6580     out1[9] = x581;
6581     out1[10] = x584;
6582     out1[11] = x587;
6583     out1[12] = x590;
6584     out1[13] = x593;
6585     out1[14] = x596;
6586     out1[15] = x599;
6587     out1[16] = x602;
6588     out1[17] = x605;
6589     out1[18] = x608;
6590     out1[19] = x611;
6591     out1[20] = x614;
6592     out1[21] = x617;
6593     out1[22] = x620;
6594 }
6595
6596 /*
6597  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square squares a field element and reduces the result.
6598  * Postconditions:
6599  *   eval out1 mod m = (eval arg1 * eval arg1) mod m
6600  *
6601  * Input Bounds:
6602  *   arg1: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
6603  * Output Bounds:
6604  *   out1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
6605  */
6606 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(
6607     uint32_t out1[23], const uint32_t arg1[23]) {
6608     uint64_t x1;
6609     uint64_t x2;
6610     uint32_t x3;
6611     uint64_t x4;
6612     uint64_t x5;
6613     uint32_t x6;
6614     uint64_t x7;
6615     uint64_t x8;
6616     uint32_t x9;
6617     uint64_t x10;
6618     uint64_t x11;
6619     uint32_t x12;
6620     uint64_t x13;
6621     uint64_t x14;
6622     uint32_t x15;
6623     uint64_t x16;
6624     uint64_t x17;
6625     uint32_t x18;
6626     uint64_t x19;
6627     uint64_t x20;
6628     uint32_t x21;
6629     uint64_t x22;
6630     uint64_t x23;
6631     uint32_t x24;
6632     uint64_t x25;
6633     uint64_t x26;
6634     uint32_t x27;
6635     uint64_t x28;
6636     uint64_t x29;
6637     uint32_t x30;
6638     uint64_t x31;
6639     uint64_t x32;
6640     uint32_t x33;
6641     uint32_t x34;
6642     uint32_t x35;
6643     uint32_t x36;
6644     uint32_t x37;
6645     uint32_t x38;
6646     uint32_t x39;
6647     uint32_t x40;
6648     uint32_t x41;
6649     uint32_t x42;
6650     uint32_t x43;
6651     uint32_t x44;
6652     uint64_t x45;
6653     uint64_t x46;
6654     uint64_t x47;
6655     uint64_t x48;
6656     uint64_t x49;
6657     uint64_t x50;
6658     uint64_t x51;
6659     uint64_t x52;
6660     uint64_t x53;
6661     uint64_t x54;
6662     uint64_t x55;
6663     uint64_t x56;
6664     uint64_t x57;
6665     uint64_t x58;
6666     uint64_t x59;
6667     uint64_t x60;
6668     uint64_t x61;
6669     uint64_t x62;
6670     uint64_t x63;
6671     uint64_t x64;
6672     uint64_t x65;
6673     uint64_t x66;
6674     uint64_t x67;
6675     uint64_t x68;
6676     uint64_t x69;
6677     uint64_t x70;
6678     uint64_t x71;
6679     uint64_t x72;
6680     uint64_t x73;
6681     uint64_t x74;
6682     uint64_t x75;
6683     uint64_t x76;
6684     uint64_t x77;
6685     uint64_t x78;
6686     uint64_t x79;
6687     uint64_t x80;
6688     uint64_t x81;
6689     uint64_t x82;
6690     uint64_t x83;
6691     uint64_t x84;
6692     uint64_t x85;
6693     uint64_t x86;
6694     uint64_t x87;
6695     uint64_t x88;
6696     uint64_t x89;
6697     uint64_t x90;
6698     uint64_t x91;
6699     uint64_t x92;
6700     uint64_t x93;
6701     uint64_t x94;
6702     uint64_t x95;
6703     uint64_t x96;
6704     uint64_t x97;
6705     uint64_t x98;
6706     uint64_t x99;
6707     uint64_t x100;
6708     uint64_t x101;
6709     uint64_t x102;
6710     uint64_t x103;
6711     uint64_t x104;
6712     uint64_t x105;
6713     uint64_t x106;
6714     uint64_t x107;
6715     uint64_t x108;
6716     uint64_t x109;
6717     uint64_t x110;
6718     uint64_t x111;
6719     uint64_t x112;
6720     uint64_t x113;
6721     uint64_t x114;
6722     uint64_t x115;
6723     uint64_t x116;
6724     uint64_t x117;
6725     uint64_t x118;
6726     uint64_t x119;
6727     uint64_t x120;
6728     uint64_t x121;
6729     uint64_t x122;
6730     uint64_t x123;
6731     uint64_t x124;
6732     uint64_t x125;
6733     uint64_t x126;
6734     uint64_t x127;
6735     uint64_t x128;
6736     uint64_t x129;
6737     uint64_t x130;
6738     uint64_t x131;
6739     uint64_t x132;
6740     uint64_t x133;
6741     uint64_t x134;
6742     uint64_t x135;
6743     uint64_t x136;
6744     uint64_t x137;
6745     uint64_t x138;
6746     uint64_t x139;
6747     uint64_t x140;
6748     uint64_t x141;
6749     uint64_t x142;
6750     uint64_t x143;
6751     uint64_t x144;
6752     uint64_t x145;
6753     uint64_t x146;
6754     uint64_t x147;
6755     uint64_t x148;
6756     uint64_t x149;
6757     uint64_t x150;
6758     uint64_t x151;
6759     uint64_t x152;
6760     uint64_t x153;
6761     uint64_t x154;
6762     uint64_t x155;
6763     uint64_t x156;
6764     uint64_t x157;
6765     uint64_t x158;
6766     uint64_t x159;
6767     uint64_t x160;
6768     uint64_t x161;
6769     uint64_t x162;
6770     uint64_t x163;
6771     uint64_t x164;
6772     uint64_t x165;
6773     uint64_t x166;
6774     uint64_t x167;
6775     uint64_t x168;
6776     uint64_t x169;
6777     uint64_t x170;
6778     uint64_t x171;
6779     uint64_t x172;
6780     uint64_t x173;
6781     uint64_t x174;
6782     uint64_t x175;
6783     uint64_t x176;
6784     uint64_t x177;
6785     uint64_t x178;
6786     uint64_t x179;
6787     uint64_t x180;
6788     uint64_t x181;
6789     uint64_t x182;
6790     uint64_t x183;
6791     uint64_t x184;
6792     uint64_t x185;
6793     uint64_t x186;
6794     uint64_t x187;
6795     uint64_t x188;
6796     uint64_t x189;
6797     uint64_t x190;
6798     uint64_t x191;
6799     uint64_t x192;
6800     uint64_t x193;
6801     uint64_t x194;
6802     uint64_t x195;
6803     uint64_t x196;
6804     uint64_t x197;
6805     uint64_t x198;
6806     uint64_t x199;
6807     uint64_t x200;
6808     uint64_t x201;
6809     uint64_t x202;
6810     uint64_t x203;
6811     uint64_t x204;
6812     uint64_t x205;
6813     uint64_t x206;
6814     uint64_t x207;
6815     uint64_t x208;
6816     uint64_t x209;
6817     uint64_t x210;
6818     uint64_t x211;
6819     uint64_t x212;
6820     uint64_t x213;
6821     uint64_t x214;
6822     uint64_t x215;
6823     uint64_t x216;
6824     uint64_t x217;
6825     uint64_t x218;
6826     uint64_t x219;
6827     uint64_t x220;
6828     uint64_t x221;
6829     uint64_t x222;
6830     uint64_t x223;
6831     uint64_t x224;
6832     uint64_t x225;
6833     uint64_t x226;
6834     uint64_t x227;
6835     uint64_t x228;
6836     uint64_t x229;
6837     uint64_t x230;
6838     uint64_t x231;
6839     uint64_t x232;
6840     uint64_t x233;
6841     uint64_t x234;
6842     uint64_t x235;
6843     uint64_t x236;
6844     uint64_t x237;
6845     uint64_t x238;
6846     uint64_t x239;
6847     uint64_t x240;
6848     uint64_t x241;
6849     uint64_t x242;
6850     uint64_t x243;
6851     uint64_t x244;
6852     uint64_t x245;
6853     uint64_t x246;
6854     uint64_t x247;
6855     uint64_t x248;
6856     uint64_t x249;
6857     uint64_t x250;
6858     uint64_t x251;
6859     uint64_t x252;
6860     uint64_t x253;
6861     uint64_t x254;
6862     uint64_t x255;
6863     uint64_t x256;
6864     uint64_t x257;
6865     uint64_t x258;
6866     uint64_t x259;
6867     uint64_t x260;
6868     uint64_t x261;
6869     uint64_t x262;
6870     uint64_t x263;
6871     uint64_t x264;
6872     uint64_t x265;
6873     uint64_t x266;
6874     uint64_t x267;
6875     uint64_t x268;
6876     uint64_t x269;
6877     uint64_t x270;
6878     uint64_t x271;
6879     uint64_t x272;
6880     uint64_t x273;
6881     uint64_t x274;
6882     uint64_t x275;
6883     uint64_t x276;
6884     uint64_t x277;
6885     uint64_t x278;
6886     uint64_t x279;
6887     uint64_t x280;
6888     uint64_t x281;
6889     uint64_t x282;
6890     uint64_t x283;
6891     uint64_t x284;
6892     uint64_t x285;
6893     uint64_t x286;
6894     uint64_t x287;
6895     uint64_t x288;
6896     uint64_t x289;
6897     uint64_t x290;
6898     uint64_t x291;
6899     uint64_t x292;
6900     uint64_t x293;
6901     uint64_t x294;
6902     uint64_t x295;
6903     uint64_t x296;
6904     uint64_t x297;
6905     uint64_t x298;
6906     uint64_t x299;
6907     uint64_t x300;
6908     uint64_t x301;
6909     uint64_t x302;
6910     uint64_t x303;
6911     uint64_t x304;
6912     uint64_t x305;
6913     uint64_t x306;
6914     uint64_t x307;
6915     uint64_t x308;
6916     uint64_t x309;
6917     uint64_t x310;
6918     uint64_t x311;
6919     uint64_t x312;
6920     uint64_t x313;
6921     uint64_t x314;
6922     uint64_t x315;
6923     uint64_t x316;
6924     uint64_t x317;
6925     uint64_t x318;
6926     uint64_t x319;
6927     uint64_t x320;
6928     uint64_t x321;
6929     uint64_t x322;
6930     uint32_t x323;
6931     uint64_t x324;
6932     uint64_t x325;
6933     uint64_t x326;
6934     uint64_t x327;
6935     uint64_t x328;
6936     uint64_t x329;
6937     uint64_t x330;
6938     uint64_t x331;
6939     uint64_t x332;
6940     uint64_t x333;
6941     uint64_t x334;
6942     uint64_t x335;
6943     uint64_t x336;
6944     uint64_t x337;
6945     uint64_t x338;
6946     uint64_t x339;
6947     uint64_t x340;
6948     uint64_t x341;
6949     uint64_t x342;
6950     uint64_t x343;
6951     uint64_t x344;
6952     uint64_t x345;
6953     uint64_t x346;
6954     uint64_t x347;
6955     uint32_t x348;
6956     uint64_t x349;
6957     uint64_t x350;
6958     uint32_t x351;
6959     uint64_t x352;
6960     uint64_t x353;
6961     uint32_t x354;
6962     uint64_t x355;
6963     uint64_t x356;
6964     uint32_t x357;
6965     uint64_t x358;
6966     uint64_t x359;
6967     uint32_t x360;
6968     uint64_t x361;
6969     uint64_t x362;
6970     uint32_t x363;
6971     uint64_t x364;
6972     uint64_t x365;
6973     uint32_t x366;
6974     uint64_t x367;
6975     uint64_t x368;
6976     uint32_t x369;
6977     uint64_t x370;
6978     uint64_t x371;
6979     uint32_t x372;
6980     uint64_t x373;
6981     uint64_t x374;
6982     uint32_t x375;
6983     uint64_t x376;
6984     uint64_t x377;
6985     uint32_t x378;
6986     uint64_t x379;
6987     uint64_t x380;
6988     uint32_t x381;
6989     uint64_t x382;
6990     uint64_t x383;
6991     uint32_t x384;
6992     uint64_t x385;
6993     uint64_t x386;
6994     uint32_t x387;
6995     uint64_t x388;
6996     uint64_t x389;
6997     uint32_t x390;
6998     uint64_t x391;
6999     uint64_t x392;
7000     uint32_t x393;
7001     uint64_t x394;
7002     uint64_t x395;
7003     uint32_t x396;
7004     uint64_t x397;
7005     uint64_t x398;
7006     uint32_t x399;
7007     uint64_t x400;
7008     uint64_t x401;
7009     uint32_t x402;
7010     uint64_t x403;
7011     uint64_t x404;
7012     uint32_t x405;
7013     uint64_t x406;
7014     uint64_t x407;
7015     uint32_t x408;
7016     uint64_t x409;
7017     uint32_t x410;
7018     uint32_t x411;
7019     uint64_t x412;
7020     uint64_t x413;
7021     uint32_t x414;
7022     uint32_t x415;
7023     uint32_t x416;
7024     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x417;
7025     uint32_t x418;
7026     uint32_t x419;
7027     x1 = ((uint64_t)(arg1[22]) * UINT16_C(0x239));
7028     x2 = (x1 * 0x2);
7029     x3 = ((arg1[22]) * 0x2);
7030     x4 = ((uint64_t)(arg1[21]) * UINT16_C(0x239));
7031     x5 = (x4 * 0x2);
7032     x6 = ((arg1[21]) * 0x2);
7033     x7 = ((uint64_t)(arg1[20]) * UINT16_C(0x239));
7034     x8 = (x7 * 0x2);
7035     x9 = ((arg1[20]) * 0x2);
7036     x10 = ((uint64_t)(arg1[19]) * UINT16_C(0x239));
7037     x11 = (x10 * 0x2);
7038     x12 = ((arg1[19]) * 0x2);
7039     x13 = ((uint64_t)(arg1[18]) * UINT16_C(0x239));
7040     x14 = (x13 * 0x2);
7041     x15 = ((arg1[18]) * 0x2);
7042     x16 = ((uint64_t)(arg1[17]) * UINT16_C(0x239));
7043     x17 = (x16 * 0x2);
7044     x18 = ((arg1[17]) * 0x2);
7045     x19 = ((uint64_t)(arg1[16]) * UINT16_C(0x239));
7046     x20 = (x19 * 0x2);
7047     x21 = ((arg1[16]) * 0x2);
7048     x22 = ((uint64_t)(arg1[15]) * UINT16_C(0x239));
7049     x23 = (x22 * 0x2);
7050     x24 = ((arg1[15]) * 0x2);
7051     x25 = ((uint64_t)(arg1[14]) * UINT16_C(0x239));
7052     x26 = (x25 * 0x2);
7053     x27 = ((arg1[14]) * 0x2);
7054     x28 = ((uint64_t)(arg1[13]) * UINT16_C(0x239));
7055     x29 = (x28 * 0x2);
7056     x30 = ((arg1[13]) * 0x2);
7057     x31 = ((uint64_t)(arg1[12]) * UINT16_C(0x239));
7058     x32 = (x31 * 0x2);
7059     x33 = ((arg1[12]) * 0x2);
7060     x34 = ((arg1[11]) * 0x2);
7061     x35 = ((arg1[10]) * 0x2);
7062     x36 = ((arg1[9]) * 0x2);
7063     x37 = ((arg1[8]) * 0x2);
7064     x38 = ((arg1[7]) * 0x2);
7065     x39 = ((arg1[6]) * 0x2);
7066     x40 = ((arg1[5]) * 0x2);
7067     x41 = ((arg1[4]) * 0x2);
7068     x42 = ((arg1[3]) * 0x2);
7069     x43 = ((arg1[2]) * 0x2);
7070     x44 = ((arg1[1]) * 0x2);
7071     x45 = ((arg1[22]) * x1);
7072     x46 = ((arg1[21]) * x2);
7073     x47 = ((arg1[21]) * (x4 * 0x2));
7074     x48 = ((arg1[20]) * (x2 * 0x2));
7075     x49 = ((arg1[20]) * (x5 * 0x2));
7076     x50 = ((arg1[20]) * (x7 * 0x2));
7077     x51 = ((arg1[19]) * x2);
7078     x52 = ((arg1[19]) * x5);
7079     x53 = ((arg1[19]) * x8);
7080     x54 = ((arg1[19]) * x10);
7081     x55 = ((arg1[18]) * x2);
7082     x56 = ((arg1[18]) * x5);
7083     x57 = ((arg1[18]) * (x8 * 0x2));
7084     x58 = ((arg1[18]) * x11);
7085     x59 = ((arg1[18]) * x13);
7086     x60 = ((arg1[17]) * x2);
7087     x61 = ((arg1[17]) * (x5 * 0x2));
7088     x62 = ((arg1[17]) * (x8 * 0x2));
7089     x63 = ((arg1[17]) * x11);
7090     x64 = ((arg1[17]) * x14);
7091     x65 = ((arg1[17]) * (x16 * 0x2));
7092     x66 = ((arg1[16]) * (x2 * 0x2));
7093     x67 = ((arg1[16]) * (x5 * 0x2));
7094     x68 = ((arg1[16]) * (x8 * 0x2));
7095     x69 = ((arg1[16]) * x11);
7096     x70 = ((arg1[16]) * (x14 * 0x2));
7097     x71 = ((arg1[16]) * (x17 * 0x2));
7098     x72 = ((arg1[16]) * (x19 * 0x2));
7099     x73 = ((arg1[15]) * x2);
7100     x74 = ((arg1[15]) * x5);
7101     x75 = ((arg1[15]) * x8);
7102     x76 = ((arg1[15]) * x11);
7103     x77 = ((arg1[15]) * x14);
7104     x78 = ((arg1[15]) * x17);
7105     x79 = ((arg1[15]) * x20);
7106     x80 = ((arg1[15]) * x22);
7107     x81 = ((arg1[14]) * x2);
7108     x82 = ((arg1[14]) * x5);
7109     x83 = ((arg1[14]) * (x8 * 0x2));
7110     x84 = ((arg1[14]) * x11);
7111     x85 = ((arg1[14]) * x14);
7112     x86 = ((arg1[14]) * x17);
7113     x87 = ((arg1[14]) * (x20 * 0x2));
7114     x88 = ((arg1[14]) * x23);
7115     x89 = ((arg1[14]) * x25);
7116     x90 = ((arg1[13]) * x2);
7117     x91 = ((arg1[13]) * (x5 * 0x2));
7118     x92 = ((arg1[13]) * (x8 * 0x2));
7119     x93 = ((arg1[13]) * x11);
7120     x94 = ((arg1[13]) * x14);
7121     x95 = ((arg1[13]) * (x17 * 0x2));
7122     x96 = ((arg1[13]) * (x20 * 0x2));
7123     x97 = ((arg1[13]) * x23);
7124     x98 = ((arg1[13]) * x26);
7125     x99 = ((arg1[13]) * (x28 * 0x2));
7126     x100 = ((arg1[12]) * (x2 * 0x2));
7127     x101 = ((arg1[12]) * (x5 * 0x2));
7128     x102 = ((arg1[12]) * (x8 * 0x2));
7129     x103 = ((arg1[12]) * x11);
7130     x104 = ((arg1[12]) * (x14 * 0x2));
7131     x105 = ((arg1[12]) * (x17 * 0x2));
7132     x106 = ((arg1[12]) * (x20 * 0x2));
7133     x107 = ((arg1[12]) * x23);
7134     x108 = ((arg1[12]) * (x26 * 0x2));
7135     x109 = ((arg1[12]) * (x29 * 0x2));
7136     x110 = ((arg1[12]) * (x31 * 0x2));
7137     x111 = ((arg1[11]) * x2);
7138     x112 = ((arg1[11]) * x5);
7139     x113 = ((arg1[11]) * x8);
7140     x114 = ((arg1[11]) * x11);
7141     x115 = ((arg1[11]) * x14);
7142     x116 = ((arg1[11]) * x17);
7143     x117 = ((arg1[11]) * x20);
7144     x118 = ((arg1[11]) * x23);
7145     x119 = ((arg1[11]) * x26);
7146     x120 = ((arg1[11]) * x29);
7147     x121 = ((arg1[11]) * (x32 * 0x2));
7148     x122 = ((uint64_t)(arg1[11]) * (arg1[11]));
7149     x123 = ((arg1[10]) * x2);
7150     x124 = ((arg1[10]) * x5);
7151     x125 = ((arg1[10]) * (x8 * 0x2));
7152     x126 = ((arg1[10]) * x11);
7153     x127 = ((arg1[10]) * x14);
7154     x128 = ((arg1[10]) * x17);
7155     x129 = ((arg1[10]) * (x20 * 0x2));
7156     x130 = ((arg1[10]) * x23);
7157     x131 = ((arg1[10]) * x26);
7158     x132 = ((arg1[10]) * (x29 * 0x2));
7159     x133 = ((uint64_t)(arg1[10]) * (x33 * 0x2));
7160     x134 = ((uint64_t)(arg1[10]) * x34);
7161     x135 = ((uint64_t)(arg1[10]) * (arg1[10]));
7162     x136 = ((arg1[9]) * x2);
7163     x137 = ((arg1[9]) * (x5 * 0x2));
7164     x138 = ((arg1[9]) * (x8 * 0x2));
7165     x139 = ((arg1[9]) * x11);
7166     x140 = ((arg1[9]) * x14);
7167     x141 = ((arg1[9]) * (x17 * 0x2));
7168     x142 = ((arg1[9]) * (x20 * 0x2));
7169     x143 = ((arg1[9]) * x23);
7170     x144 = ((arg1[9]) * (x26 * 0x2));
7171     x145 = ((uint64_t)(arg1[9]) * (x30 * 0x2));
7172     x146 = ((uint64_t)(arg1[9]) * (x33 * 0x2));
7173     x147 = ((uint64_t)(arg1[9]) * x34);
7174     x148 = ((uint64_t)(arg1[9]) * (x35 * 0x2));
7175     x149 = ((uint64_t)(arg1[9]) * ((arg1[9]) * 0x2));
7176     x150 = ((arg1[8]) * (x2 * 0x2));
7177     x151 = ((arg1[8]) * (x5 * 0x2));
7178     x152 = ((arg1[8]) * (x8 * 0x2));
7179     x153 = ((arg1[8]) * x11);
7180     x154 = ((arg1[8]) * (x14 * 0x2));
7181     x155 = ((arg1[8]) * (x17 * 0x2));
7182     x156 = ((arg1[8]) * (x20 * 0x2));
7183     x157 = ((arg1[8]) * (x23 * 0x2));
7184     x158 = ((uint64_t)(arg1[8]) * (x27 * 0x2));
7185     x159 = ((uint64_t)(arg1[8]) * (x30 * 0x2));
7186     x160 = ((uint64_t)(arg1[8]) * (x33 * 0x2));
7187     x161 = ((uint64_t)(arg1[8]) * (x34 * 0x2));
7188     x162 = ((uint64_t)(arg1[8]) * (x35 * 0x2));
7189     x163 = ((uint64_t)(arg1[8]) * (x36 * 0x2));
7190     x164 = ((uint64_t)(arg1[8]) * ((arg1[8]) * 0x2));
7191     x165 = ((arg1[7]) * x2);
7192     x166 = ((arg1[7]) * x5);
7193     x167 = ((arg1[7]) * x8);
7194     x168 = ((arg1[7]) * x11);
7195     x169 = ((arg1[7]) * x14);
7196     x170 = ((arg1[7]) * x17);
7197     x171 = ((arg1[7]) * (x20 * 0x2));
7198     x172 = ((uint64_t)(arg1[7]) * x24);
7199     x173 = ((uint64_t)(arg1[7]) * x27);
7200     x174 = ((uint64_t)(arg1[7]) * x30);
7201     x175 = ((uint64_t)(arg1[7]) * (x33 * 0x2));
7202     x176 = ((uint64_t)(arg1[7]) * x34);
7203     x177 = ((uint64_t)(arg1[7]) * x35);
7204     x178 = ((uint64_t)(arg1[7]) * x36);
7205     x179 = ((uint64_t)(arg1[7]) * (x37 * 0x2));
7206     x180 = ((uint64_t)(arg1[7]) * (arg1[7]));
7207     x181 = ((arg1[6]) * x2);
7208     x182 = ((arg1[6]) * x5);
7209     x183 = ((arg1[6]) * (x8 * 0x2));
7210     x184 = ((arg1[6]) * x11);
7211     x185 = ((arg1[6]) * x14);
7212     x186 = ((arg1[6]) * (x17 * 0x2));
7213     x187 = ((uint64_t)(arg1[6]) * (x21 * 0x2));
7214     x188 = ((uint64_t)(arg1[6]) * x24);
7215     x189 = ((uint64_t)(arg1[6]) * x27);
7216     x190 = ((uint64_t)(arg1[6]) * (x30 * 0x2));
7217     x191 = ((uint64_t)(arg1[6]) * (x33 * 0x2));
7218     x192 = ((uint64_t)(arg1[6]) * x34);
7219     x193 = ((uint64_t)(arg1[6]) * x35);
7220     x194 = ((uint64_t)(arg1[6]) * (x36 * 0x2));
7221     x195 = ((uint64_t)(arg1[6]) * (x37 * 0x2));
7222     x196 = ((uint64_t)(arg1[6]) * x38);
7223     x197 = ((uint64_t)(arg1[6]) * (arg1[6]));
7224     x198 = ((arg1[5]) * x2);
7225     x199 = ((arg1[5]) * (x5 * 0x2));
7226     x200 = ((arg1[5]) * (x8 * 0x2));
7227     x201 = ((arg1[5]) * x11);
7228     x202 = ((arg1[5]) * (x14 * 0x2));
7229     x203 = ((uint64_t)(arg1[5]) * (x18 * 0x2));
7230     x204 = ((uint64_t)(arg1[5]) * (x21 * 0x2));
7231     x205 = ((uint64_t)(arg1[5]) * x24);
7232     x206 = ((uint64_t)(arg1[5]) * (x27 * 0x2));
7233     x207 = ((uint64_t)(arg1[5]) * (x30 * 0x2));
7234     x208 = ((uint64_t)(arg1[5]) * (x33 * 0x2));
7235     x209 = ((uint64_t)(arg1[5]) * x34);
7236     x210 = ((uint64_t)(arg1[5]) * (x35 * 0x2));
7237     x211 = ((uint64_t)(arg1[5]) * (x36 * 0x2));
7238     x212 = ((uint64_t)(arg1[5]) * (x37 * 0x2));
7239     x213 = ((uint64_t)(arg1[5]) * x38);
7240     x214 = ((uint64_t)(arg1[5]) * (x39 * 0x2));
7241     x215 = ((uint64_t)(arg1[5]) * ((arg1[5]) * 0x2));
7242     x216 = ((arg1[4]) * (x2 * 0x2));
7243     x217 = ((arg1[4]) * (x5 * 0x2));
7244     x218 = ((arg1[4]) * (x8 * 0x2));
7245     x219 = ((arg1[4]) * (x11 * 0x2));
7246     x220 = ((uint64_t)(arg1[4]) * (x15 * 0x2));
7247     x221 = ((uint64_t)(arg1[4]) * (x18 * 0x2));
7248     x222 = ((uint64_t)(arg1[4]) * (x21 * 0x2));
7249     x223 = ((uint64_t)(arg1[4]) * (x24 * 0x2));
7250     x224 = ((uint64_t)(arg1[4]) * (x27 * 0x2));
7251     x225 = ((uint64_t)(arg1[4]) * (x30 * 0x2));
7252     x226 = ((uint64_t)(arg1[4]) * (x33 * 0x2));
7253     x227 = ((uint64_t)(arg1[4]) * (x34 * 0x2));
7254     x228 = ((uint64_t)(arg1[4]) * (x35 * 0x2));
7255     x229 = ((uint64_t)(arg1[4]) * (x36 * 0x2));
7256     x230 = ((uint64_t)(arg1[4]) * (x37 * 0x2));
7257     x231 = ((uint64_t)(arg1[4]) * (x38 * 0x2));
7258     x232 = ((uint64_t)(arg1[4]) * (x39 * 0x2));
7259     x233 = ((uint64_t)(arg1[4]) * (x40 * 0x2));
7260     x234 = ((uint64_t)(arg1[4]) * ((arg1[4]) * 0x2));
7261     x235 = ((arg1[3]) * x2);
7262     x236 = ((arg1[3]) * x5);
7263     x237 = ((arg1[3]) * (x8 * 0x2));
7264     x238 = ((uint64_t)(arg1[3]) * x12);
7265     x239 = ((uint64_t)(arg1[3]) * x15);
7266     x240 = ((uint64_t)(arg1[3]) * x18);
7267     x241 = ((uint64_t)(arg1[3]) * (x21 * 0x2));
7268     x242 = ((uint64_t)(arg1[3]) * x24);
7269     x243 = ((uint64_t)(arg1[3]) * x27);
7270     x244 = ((uint64_t)(arg1[3]) * x30);
7271     x245 = ((uint64_t)(arg1[3]) * (x33 * 0x2));
7272     x246 = ((uint64_t)(arg1[3]) * x34);
7273     x247 = ((uint64_t)(arg1[3]) * x35);
7274     x248 = ((uint64_t)(arg1[3]) * x36);
7275     x249 = ((uint64_t)(arg1[3]) * (x37 * 0x2));
7276     x250 = ((uint64_t)(arg1[3]) * x38);
7277     x251 = ((uint64_t)(arg1[3]) * x39);
7278     x252 = ((uint64_t)(arg1[3]) * x40);
7279     x253 = ((uint64_t)(arg1[3]) * (x41 * 0x2));
7280     x254 = ((uint64_t)(arg1[3]) * (arg1[3]));
7281     x255 = ((arg1[2]) * x2);
7282     x256 = ((arg1[2]) * (x5 * 0x2));
7283     x257 = ((uint64_t)(arg1[2]) * (x9 * 0x2));
7284     x258 = ((uint64_t)(arg1[2]) * x12);
7285     x259 = ((uint64_t)(arg1[2]) * x15);
7286     x260 = ((uint64_t)(arg1[2]) * (x18 * 0x2));
7287     x261 = ((uint64_t)(arg1[2]) * (x21 * 0x2));
7288     x262 = ((uint64_t)(arg1[2]) * x24);
7289     x263 = ((uint64_t)(arg1[2]) * x27);
7290     x264 = ((uint64_t)(arg1[2]) * (x30 * 0x2));
7291     x265 = ((uint64_t)(arg1[2]) * (x33 * 0x2));
7292     x266 = ((uint64_t)(arg1[2]) * x34);
7293     x267 = ((uint64_t)(arg1[2]) * x35);
7294     x268 = ((uint64_t)(arg1[2]) * (x36 * 0x2));
7295     x269 = ((uint64_t)(arg1[2]) * (x37 * 0x2));
7296     x270 = ((uint64_t)(arg1[2]) * x38);
7297     x271 = ((uint64_t)(arg1[2]) * x39);
7298     x272 = ((uint64_t)(arg1[2]) * (x40 * 0x2));
7299     x273 = ((uint64_t)(arg1[2]) * (x41 * 0x2));
7300     x274 = ((uint64_t)(arg1[2]) * x42);
7301     x275 = ((uint64_t)(arg1[2]) * (arg1[2]));
7302     x276 = ((arg1[1]) * (x2 * 0x2));
7303     x277 = ((uint64_t)(arg1[1]) * (x6 * 0x2));
7304     x278 = ((uint64_t)(arg1[1]) * (x9 * 0x2));
7305     x279 = ((uint64_t)(arg1[1]) * x12);
7306     x280 = ((uint64_t)(arg1[1]) * (x15 * 0x2));
7307     x281 = ((uint64_t)(arg1[1]) * (x18 * 0x2));
7308     x282 = ((uint64_t)(arg1[1]) * (x21 * 0x2));
7309     x283 = ((uint64_t)(arg1[1]) * x24);
7310     x284 = ((uint64_t)(arg1[1]) * (x27 * 0x2));
7311     x285 = ((uint64_t)(arg1[1]) * (x30 * 0x2));
7312     x286 = ((uint64_t)(arg1[1]) * (x33 * 0x2));
7313     x287 = ((uint64_t)(arg1[1]) * x34);
7314     x288 = ((uint64_t)(arg1[1]) * (x35 * 0x2));
7315     x289 = ((uint64_t)(arg1[1]) * (x36 * 0x2));
7316     x290 = ((uint64_t)(arg1[1]) * (x37 * 0x2));
7317     x291 = ((uint64_t)(arg1[1]) * x38);
7318     x292 = ((uint64_t)(arg1[1]) * (x39 * 0x2));
7319     x293 = ((uint64_t)(arg1[1]) * (x40 * 0x2));
7320     x294 = ((uint64_t)(arg1[1]) * (x41 * 0x2));
7321     x295 = ((uint64_t)(arg1[1]) * x42);
7322     x296 = ((uint64_t)(arg1[1]) * (x43 * 0x2));
7323     x297 = ((uint64_t)(arg1[1]) * ((arg1[1]) * 0x2));
7324     x298 = ((uint64_t)(arg1[0]) * x3);
7325     x299 = ((uint64_t)(arg1[0]) * x6);
7326     x300 = ((uint64_t)(arg1[0]) * x9);
7327     x301 = ((uint64_t)(arg1[0]) * x12);
7328     x302 = ((uint64_t)(arg1[0]) * x15);
7329     x303 = ((uint64_t)(arg1[0]) * x18);
7330     x304 = ((uint64_t)(arg1[0]) * x21);
7331     x305 = ((uint64_t)(arg1[0]) * x24);
7332     x306 = ((uint64_t)(arg1[0]) * x27);
7333     x307 = ((uint64_t)(arg1[0]) * x30);
7334     x308 = ((uint64_t)(arg1[0]) * x33);
7335     x309 = ((uint64_t)(arg1[0]) * x34);
7336     x310 = ((uint64_t)(arg1[0]) * x35);
7337     x311 = ((uint64_t)(arg1[0]) * x36);
7338     x312 = ((uint64_t)(arg1[0]) * x37);
7339     x313 = ((uint64_t)(arg1[0]) * x38);
7340     x314 = ((uint64_t)(arg1[0]) * x39);
7341     x315 = ((uint64_t)(arg1[0]) * x40);
7342     x316 = ((uint64_t)(arg1[0]) * x41);
7343     x317 = ((uint64_t)(arg1[0]) * x42);
7344     x318 = ((uint64_t)(arg1[0]) * x43);
7345     x319 = ((uint64_t)(arg1[0]) * x44);
7346     x320 = ((uint64_t)(arg1[0]) * (arg1[0]));
7347     x321 = (x320 +
7348             (x276 +
7349              (x256 +
7350               (x237 +
7351                (x219 +
7352                 (x202 + (x186 + (x171 + (x157 + (x144 + (x132 + x121)))))))))));
7353     x322 = (x321 >> 23);
7354     x323 = (uint32_t)(x321 & UINT32_C(0x7fffff));
7355     x324 = (x298 +
7356             (x277 +
7357              (x257 +
7358               (x238 +
7359                (x220 +
7360                 (x203 + (x187 + (x172 + (x158 + (x145 + (x133 + x122)))))))))));
7361     x325 = (x299 +
7362             (x278 +
7363              (x258 +
7364               (x239 +
7365                (x221 +
7366                 (x204 + (x188 + (x173 + (x159 + (x146 + (x134 + x45)))))))))));
7367     x326 = (x300 +
7368             (x279 +
7369              (x259 +
7370               (x240 +
7371                (x222 +
7372                 (x205 + (x189 + (x174 + (x160 + (x147 + (x135 + x46)))))))))));
7373     x327 = (x301 +
7374             (x280 +
7375              (x260 +
7376               (x241 +
7377                (x223 +
7378                 (x206 + (x190 + (x175 + (x161 + (x148 + (x48 + x47)))))))))));
7379     x328 = (x302 +
7380             (x281 +
7381              (x261 +
7382               (x242 +
7383                (x224 +
7384                 (x207 + (x191 + (x176 + (x162 + (x149 + (x51 + x49)))))))))));
7385     x329 = (x303 +
7386             (x282 +
7387              (x262 +
7388               (x243 +
7389                (x225 +
7390                 (x208 + (x192 + (x177 + (x163 + (x55 + (x52 + x50)))))))))));
7391     x330 = (x304 +
7392             (x283 +
7393              (x263 +
7394               (x244 +
7395                (x226 +
7396                 (x209 + (x193 + (x178 + (x164 + (x60 + (x56 + x53)))))))))));
7397     x331 =
7398         (x305 +
7399          (x284 +
7400           (x264 +
7401            (x245 +
7402             (x227 + (x210 + (x194 + (x179 + (x66 + (x61 + (x57 + x54)))))))))));
7403     x332 =
7404         (x306 +
7405          (x285 +
7406           (x265 +
7407            (x246 +
7408             (x228 + (x211 + (x195 + (x180 + (x73 + (x67 + (x62 + x58)))))))))));
7409     x333 =
7410         (x307 +
7411          (x286 +
7412           (x266 +
7413            (x247 +
7414             (x229 + (x212 + (x196 + (x81 + (x74 + (x68 + (x63 + x59)))))))))));
7415     x334 =
7416         (x308 +
7417          (x287 +
7418           (x267 +
7419            (x248 +
7420             (x230 + (x213 + (x197 + (x90 + (x82 + (x75 + (x69 + x64)))))))))));
7421     x335 =
7422         (x309 +
7423          (x288 +
7424           (x268 +
7425            (x249 +
7426             (x231 + (x214 + (x100 + (x91 + (x83 + (x76 + (x70 + x65)))))))))));
7427     x336 =
7428         (x310 +
7429          (x289 +
7430           (x269 +
7431            (x250 +
7432             (x232 + (x215 + (x111 + (x101 + (x92 + (x84 + (x77 + x71)))))))))));
7433     x337 =
7434         (x311 +
7435          (x290 +
7436           (x270 +
7437            (x251 +
7438             (x233 + (x123 + (x112 + (x102 + (x93 + (x85 + (x78 + x72)))))))))));
7439     x338 = (x312 +
7440             (x291 +
7441              (x271 +
7442               (x252 +
7443                (x234 +
7444                 (x136 + (x124 + (x113 + (x103 + (x94 + (x86 + x79)))))))))));
7445     x339 = (x313 +
7446             (x292 +
7447              (x272 +
7448               (x253 +
7449                (x150 +
7450                 (x137 + (x125 + (x114 + (x104 + (x95 + (x87 + x80)))))))))));
7451     x340 = (x314 +
7452             (x293 +
7453              (x273 +
7454               (x254 +
7455                (x165 +
7456                 (x151 + (x138 + (x126 + (x115 + (x105 + (x96 + x88)))))))))));
7457     x341 = (x315 +
7458             (x294 +
7459              (x274 +
7460               (x181 +
7461                (x166 +
7462                 (x152 + (x139 + (x127 + (x116 + (x106 + (x97 + x89)))))))))));
7463     x342 = (x316 +
7464             (x295 +
7465              (x275 +
7466               (x198 +
7467                (x182 +
7468                 (x167 + (x153 + (x140 + (x128 + (x117 + (x107 + x98)))))))))));
7469     x343 = (x317 +
7470             (x296 +
7471              (x216 +
7472               (x199 +
7473                (x183 +
7474                 (x168 + (x154 + (x141 + (x129 + (x118 + (x108 + x99)))))))))));
7475     x344 = (x318 +
7476             (x297 +
7477              (x235 +
7478               (x217 +
7479                (x200 +
7480                 (x184 + (x169 + (x155 + (x142 + (x130 + (x119 + x109)))))))))));
7481     x345 = (x319 +
7482             (x255 +
7483              (x236 +
7484               (x218 +
7485                (x201 +
7486                 (x185 + (x170 + (x156 + (x143 + (x131 + (x120 + x110)))))))))));
7487     x346 = (x322 + x345);
7488     x347 = (x346 >> 22);
7489     x348 = (uint32_t)(x346 & UINT32_C(0x3fffff));
7490     x349 = (x347 + x344);
7491     x350 = (x349 >> 22);
7492     x351 = (uint32_t)(x349 & UINT32_C(0x3fffff));
7493     x352 = (x350 + x343);
7494     x353 = (x352 >> 23);
7495     x354 = (uint32_t)(x352 & UINT32_C(0x7fffff));
7496     x355 = (x353 + x342);
7497     x356 = (x355 >> 22);
7498     x357 = (uint32_t)(x355 & UINT32_C(0x3fffff));
7499     x358 = (x356 + x341);
7500     x359 = (x358 >> 22);
7501     x360 = (uint32_t)(x358 & UINT32_C(0x3fffff));
7502     x361 = (x359 + x340);
7503     x362 = (x361 >> 22);
7504     x363 = (uint32_t)(x361 & UINT32_C(0x3fffff));
7505     x364 = (x362 + x339);
7506     x365 = (x364 >> 23);
7507     x366 = (uint32_t)(x364 & UINT32_C(0x7fffff));
7508     x367 = (x365 + x338);
7509     x368 = (x367 >> 22);
7510     x369 = (uint32_t)(x367 & UINT32_C(0x3fffff));
7511     x370 = (x368 + x337);
7512     x371 = (x370 >> 22);
7513     x372 = (uint32_t)(x370 & UINT32_C(0x3fffff));
7514     x373 = (x371 + x336);
7515     x374 = (x373 >> 22);
7516     x375 = (uint32_t)(x373 & UINT32_C(0x3fffff));
7517     x376 = (x374 + x335);
7518     x377 = (x376 >> 23);
7519     x378 = (uint32_t)(x376 & UINT32_C(0x7fffff));
7520     x379 = (x377 + x334);
7521     x380 = (x379 >> 22);
7522     x381 = (uint32_t)(x379 & UINT32_C(0x3fffff));
7523     x382 = (x380 + x333);
7524     x383 = (x382 >> 22);
7525     x384 = (uint32_t)(x382 & UINT32_C(0x3fffff));
7526     x385 = (x383 + x332);
7527     x386 = (x385 >> 22);
7528     x387 = (uint32_t)(x385 & UINT32_C(0x3fffff));
7529     x388 = (x386 + x331);
7530     x389 = (x388 >> 23);
7531     x390 = (uint32_t)(x388 & UINT32_C(0x7fffff));
7532     x391 = (x389 + x330);
7533     x392 = (x391 >> 22);
7534     x393 = (uint32_t)(x391 & UINT32_C(0x3fffff));
7535     x394 = (x392 + x329);
7536     x395 = (x394 >> 22);
7537     x396 = (uint32_t)(x394 & UINT32_C(0x3fffff));
7538     x397 = (x395 + x328);
7539     x398 = (x397 >> 22);
7540     x399 = (uint32_t)(x397 & UINT32_C(0x3fffff));
7541     x400 = (x398 + x327);
7542     x401 = (x400 >> 23);
7543     x402 = (uint32_t)(x400 & UINT32_C(0x7fffff));
7544     x403 = (x401 + x326);
7545     x404 = (x403 >> 22);
7546     x405 = (uint32_t)(x403 & UINT32_C(0x3fffff));
7547     x406 = (x404 + x325);
7548     x407 = (x406 >> 22);
7549     x408 = (uint32_t)(x406 & UINT32_C(0x3fffff));
7550     x409 = (x407 + x324);
7551     x410 = (uint32_t)(x409 >> 22);
7552     x411 = (uint32_t)(x409 & UINT32_C(0x3fffff));
7553     x412 = ((uint64_t)UINT16_C(0x239) * x410);
7554     x413 = (x323 + x412);
7555     x414 = (uint32_t)(x413 >> 23);
7556     x415 = (uint32_t)(x413 & UINT32_C(0x7fffff));
7557     x416 = (x414 + x348);
7558     x417 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x416 >> 22);
7559     x418 = (x416 & UINT32_C(0x3fffff));
7560     x419 = (x417 + x351);
7561     out1[0] = x415;
7562     out1[1] = x418;
7563     out1[2] = x419;
7564     out1[3] = x354;
7565     out1[4] = x357;
7566     out1[5] = x360;
7567     out1[6] = x363;
7568     out1[7] = x366;
7569     out1[8] = x369;
7570     out1[9] = x372;
7571     out1[10] = x375;
7572     out1[11] = x378;
7573     out1[12] = x381;
7574     out1[13] = x384;
7575     out1[14] = x387;
7576     out1[15] = x390;
7577     out1[16] = x393;
7578     out1[17] = x396;
7579     out1[18] = x399;
7580     out1[19] = x402;
7581     out1[20] = x405;
7582     out1[21] = x408;
7583     out1[22] = x411;
7584 }
7585
7586 /*
7587  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_carry reduces a field element.
7588  * Postconditions:
7589  *   eval out1 mod m = eval arg1 mod m
7590  *
7591  * Input Bounds:
7592  *   arg1: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
7593  * Output Bounds:
7594  *   out1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
7595  */
7596 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_carry(
7597     uint32_t out1[23], const uint32_t arg1[23]) {
7598     uint32_t x1;
7599     uint32_t x2;
7600     uint32_t x3;
7601     uint32_t x4;
7602     uint32_t x5;
7603     uint32_t x6;
7604     uint32_t x7;
7605     uint32_t x8;
7606     uint32_t x9;
7607     uint32_t x10;
7608     uint32_t x11;
7609     uint32_t x12;
7610     uint32_t x13;
7611     uint32_t x14;
7612     uint32_t x15;
7613     uint32_t x16;
7614     uint32_t x17;
7615     uint32_t x18;
7616     uint32_t x19;
7617     uint32_t x20;
7618     uint32_t x21;
7619     uint32_t x22;
7620     uint32_t x23;
7621     uint32_t x24;
7622     uint32_t x25;
7623     uint32_t x26;
7624     uint32_t x27;
7625     uint32_t x28;
7626     uint32_t x29;
7627     uint32_t x30;
7628     uint32_t x31;
7629     uint32_t x32;
7630     uint32_t x33;
7631     uint32_t x34;
7632     uint32_t x35;
7633     uint32_t x36;
7634     uint32_t x37;
7635     uint32_t x38;
7636     uint32_t x39;
7637     uint32_t x40;
7638     uint32_t x41;
7639     uint32_t x42;
7640     uint32_t x43;
7641     uint32_t x44;
7642     uint32_t x45;
7643     uint32_t x46;
7644     uint32_t x47;
7645     uint32_t x48;
7646     x1 = (arg1[0]);
7647     x2 = ((x1 >> 23) + (arg1[1]));
7648     x3 = ((x2 >> 22) + (arg1[2]));
7649     x4 = ((x3 >> 22) + (arg1[3]));
7650     x5 = ((x4 >> 23) + (arg1[4]));
7651     x6 = ((x5 >> 22) + (arg1[5]));
7652     x7 = ((x6 >> 22) + (arg1[6]));
7653     x8 = ((x7 >> 22) + (arg1[7]));
7654     x9 = ((x8 >> 23) + (arg1[8]));
7655     x10 = ((x9 >> 22) + (arg1[9]));
7656     x11 = ((x10 >> 22) + (arg1[10]));
7657     x12 = ((x11 >> 22) + (arg1[11]));
7658     x13 = ((x12 >> 23) + (arg1[12]));
7659     x14 = ((x13 >> 22) + (arg1[13]));
7660     x15 = ((x14 >> 22) + (arg1[14]));
7661     x16 = ((x15 >> 22) + (arg1[15]));
7662     x17 = ((x16 >> 23) + (arg1[16]));
7663     x18 = ((x17 >> 22) + (arg1[17]));
7664     x19 = ((x18 >> 22) + (arg1[18]));
7665     x20 = ((x19 >> 22) + (arg1[19]));
7666     x21 = ((x20 >> 23) + (arg1[20]));
7667     x22 = ((x21 >> 22) + (arg1[21]));
7668     x23 = ((x22 >> 22) + (arg1[22]));
7669     x24 = ((x1 & UINT32_C(0x7fffff)) + (UINT16_C(0x239) * (x23 >> 22)));
7670     x25 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x24 >> 23) +
7671            (x2 & UINT32_C(0x3fffff)));
7672     x26 = (x24 & UINT32_C(0x7fffff));
7673     x27 = (x25 & UINT32_C(0x3fffff));
7674     x28 = ((fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x25 >> 22) +
7675            (x3 & UINT32_C(0x3fffff)));
7676     x29 = (x4 & UINT32_C(0x7fffff));
7677     x30 = (x5 & UINT32_C(0x3fffff));
7678     x31 = (x6 & UINT32_C(0x3fffff));
7679     x32 = (x7 & UINT32_C(0x3fffff));
7680     x33 = (x8 & UINT32_C(0x7fffff));
7681     x34 = (x9 & UINT32_C(0x3fffff));
7682     x35 = (x10 & UINT32_C(0x3fffff));
7683     x36 = (x11 & UINT32_C(0x3fffff));
7684     x37 = (x12 & UINT32_C(0x7fffff));
7685     x38 = (x13 & UINT32_C(0x3fffff));
7686     x39 = (x14 & UINT32_C(0x3fffff));
7687     x40 = (x15 & UINT32_C(0x3fffff));
7688     x41 = (x16 & UINT32_C(0x7fffff));
7689     x42 = (x17 & UINT32_C(0x3fffff));
7690     x43 = (x18 & UINT32_C(0x3fffff));
7691     x44 = (x19 & UINT32_C(0x3fffff));
7692     x45 = (x20 & UINT32_C(0x7fffff));
7693     x46 = (x21 & UINT32_C(0x3fffff));
7694     x47 = (x22 & UINT32_C(0x3fffff));
7695     x48 = (x23 & UINT32_C(0x3fffff));
7696     out1[0] = x26;
7697     out1[1] = x27;
7698     out1[2] = x28;
7699     out1[3] = x29;
7700     out1[4] = x30;
7701     out1[5] = x31;
7702     out1[6] = x32;
7703     out1[7] = x33;
7704     out1[8] = x34;
7705     out1[9] = x35;
7706     out1[10] = x36;
7707     out1[11] = x37;
7708     out1[12] = x38;
7709     out1[13] = x39;
7710     out1[14] = x40;
7711     out1[15] = x41;
7712     out1[16] = x42;
7713     out1[17] = x43;
7714     out1[18] = x44;
7715     out1[19] = x45;
7716     out1[20] = x46;
7717     out1[21] = x47;
7718     out1[22] = x48;
7719 }
7720
7721 /*
7722  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_add adds two field elements.
7723  * Postconditions:
7724  *   eval out1 mod m = (eval arg1 + eval arg2) mod m
7725  *
7726  * Input Bounds:
7727  *   arg1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
7728  *   arg2: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
7729  * Output Bounds:
7730  *   out1: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
7731  */
7732 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_add(
7733     uint32_t out1[23], const uint32_t arg1[23], const uint32_t arg2[23]) {
7734     uint32_t x1;
7735     uint32_t x2;
7736     uint32_t x3;
7737     uint32_t x4;
7738     uint32_t x5;
7739     uint32_t x6;
7740     uint32_t x7;
7741     uint32_t x8;
7742     uint32_t x9;
7743     uint32_t x10;
7744     uint32_t x11;
7745     uint32_t x12;
7746     uint32_t x13;
7747     uint32_t x14;
7748     uint32_t x15;
7749     uint32_t x16;
7750     uint32_t x17;
7751     uint32_t x18;
7752     uint32_t x19;
7753     uint32_t x20;
7754     uint32_t x21;
7755     uint32_t x22;
7756     uint32_t x23;
7757     x1 = ((arg1[0]) + (arg2[0]));
7758     x2 = ((arg1[1]) + (arg2[1]));
7759     x3 = ((arg1[2]) + (arg2[2]));
7760     x4 = ((arg1[3]) + (arg2[3]));
7761     x5 = ((arg1[4]) + (arg2[4]));
7762     x6 = ((arg1[5]) + (arg2[5]));
7763     x7 = ((arg1[6]) + (arg2[6]));
7764     x8 = ((arg1[7]) + (arg2[7]));
7765     x9 = ((arg1[8]) + (arg2[8]));
7766     x10 = ((arg1[9]) + (arg2[9]));
7767     x11 = ((arg1[10]) + (arg2[10]));
7768     x12 = ((arg1[11]) + (arg2[11]));
7769     x13 = ((arg1[12]) + (arg2[12]));
7770     x14 = ((arg1[13]) + (arg2[13]));
7771     x15 = ((arg1[14]) + (arg2[14]));
7772     x16 = ((arg1[15]) + (arg2[15]));
7773     x17 = ((arg1[16]) + (arg2[16]));
7774     x18 = ((arg1[17]) + (arg2[17]));
7775     x19 = ((arg1[18]) + (arg2[18]));
7776     x20 = ((arg1[19]) + (arg2[19]));
7777     x21 = ((arg1[20]) + (arg2[20]));
7778     x22 = ((arg1[21]) + (arg2[21]));
7779     x23 = ((arg1[22]) + (arg2[22]));
7780     out1[0] = x1;
7781     out1[1] = x2;
7782     out1[2] = x3;
7783     out1[3] = x4;
7784     out1[4] = x5;
7785     out1[5] = x6;
7786     out1[6] = x7;
7787     out1[7] = x8;
7788     out1[8] = x9;
7789     out1[9] = x10;
7790     out1[10] = x11;
7791     out1[11] = x12;
7792     out1[12] = x13;
7793     out1[13] = x14;
7794     out1[14] = x15;
7795     out1[15] = x16;
7796     out1[16] = x17;
7797     out1[17] = x18;
7798     out1[18] = x19;
7799     out1[19] = x20;
7800     out1[20] = x21;
7801     out1[21] = x22;
7802     out1[22] = x23;
7803 }
7804
7805 /*
7806  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_sub subtracts two field elements.
7807  * Postconditions:
7808  *   eval out1 mod m = (eval arg1 - eval arg2) mod m
7809  *
7810  * Input Bounds:
7811  *   arg1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
7812  *   arg2: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
7813  * Output Bounds:
7814  *   out1: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
7815  */
7816 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_sub(
7817     uint32_t out1[23], const uint32_t arg1[23], const uint32_t arg2[23]) {
7818     uint32_t x1;
7819     uint32_t x2;
7820     uint32_t x3;
7821     uint32_t x4;
7822     uint32_t x5;
7823     uint32_t x6;
7824     uint32_t x7;
7825     uint32_t x8;
7826     uint32_t x9;
7827     uint32_t x10;
7828     uint32_t x11;
7829     uint32_t x12;
7830     uint32_t x13;
7831     uint32_t x14;
7832     uint32_t x15;
7833     uint32_t x16;
7834     uint32_t x17;
7835     uint32_t x18;
7836     uint32_t x19;
7837     uint32_t x20;
7838     uint32_t x21;
7839     uint32_t x22;
7840     uint32_t x23;
7841     x1 = ((UINT32_C(0xfffb8e) + (arg1[0])) - (arg2[0]));
7842     x2 = ((UINT32_C(0x7ffffe) + (arg1[1])) - (arg2[1]));
7843     x3 = ((UINT32_C(0x7ffffe) + (arg1[2])) - (arg2[2]));
7844     x4 = ((UINT32_C(0xfffffe) + (arg1[3])) - (arg2[3]));
7845     x5 = ((UINT32_C(0x7ffffe) + (arg1[4])) - (arg2[4]));
7846     x6 = ((UINT32_C(0x7ffffe) + (arg1[5])) - (arg2[5]));
7847     x7 = ((UINT32_C(0x7ffffe) + (arg1[6])) - (arg2[6]));
7848     x8 = ((UINT32_C(0xfffffe) + (arg1[7])) - (arg2[7]));
7849     x9 = ((UINT32_C(0x7ffffe) + (arg1[8])) - (arg2[8]));
7850     x10 = ((UINT32_C(0x7ffffe) + (arg1[9])) - (arg2[9]));
7851     x11 = ((UINT32_C(0x7ffffe) + (arg1[10])) - (arg2[10]));
7852     x12 = ((UINT32_C(0xfffffe) + (arg1[11])) - (arg2[11]));
7853     x13 = ((UINT32_C(0x7ffffe) + (arg1[12])) - (arg2[12]));
7854     x14 = ((UINT32_C(0x7ffffe) + (arg1[13])) - (arg2[13]));
7855     x15 = ((UINT32_C(0x7ffffe) + (arg1[14])) - (arg2[14]));
7856     x16 = ((UINT32_C(0xfffffe) + (arg1[15])) - (arg2[15]));
7857     x17 = ((UINT32_C(0x7ffffe) + (arg1[16])) - (arg2[16]));
7858     x18 = ((UINT32_C(0x7ffffe) + (arg1[17])) - (arg2[17]));
7859     x19 = ((UINT32_C(0x7ffffe) + (arg1[18])) - (arg2[18]));
7860     x20 = ((UINT32_C(0xfffffe) + (arg1[19])) - (arg2[19]));
7861     x21 = ((UINT32_C(0x7ffffe) + (arg1[20])) - (arg2[20]));
7862     x22 = ((UINT32_C(0x7ffffe) + (arg1[21])) - (arg2[21]));
7863     x23 = ((UINT32_C(0x7ffffe) + (arg1[22])) - (arg2[22]));
7864     out1[0] = x1;
7865     out1[1] = x2;
7866     out1[2] = x3;
7867     out1[3] = x4;
7868     out1[4] = x5;
7869     out1[5] = x6;
7870     out1[6] = x7;
7871     out1[7] = x8;
7872     out1[8] = x9;
7873     out1[9] = x10;
7874     out1[10] = x11;
7875     out1[11] = x12;
7876     out1[12] = x13;
7877     out1[13] = x14;
7878     out1[14] = x15;
7879     out1[15] = x16;
7880     out1[16] = x17;
7881     out1[17] = x18;
7882     out1[18] = x19;
7883     out1[19] = x20;
7884     out1[20] = x21;
7885     out1[21] = x22;
7886     out1[22] = x23;
7887 }
7888
7889 /*
7890  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_opp negates a field element.
7891  * Postconditions:
7892  *   eval out1 mod m = -eval arg1 mod m
7893  *
7894  * Input Bounds:
7895  *   arg1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
7896  * Output Bounds:
7897  *   out1: [[0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0x1a66664], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332], [0x0 ~> 0xd33332]]
7898  */
7899 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(
7900     uint32_t out1[23], const uint32_t arg1[23]) {
7901     uint32_t x1;
7902     uint32_t x2;
7903     uint32_t x3;
7904     uint32_t x4;
7905     uint32_t x5;
7906     uint32_t x6;
7907     uint32_t x7;
7908     uint32_t x8;
7909     uint32_t x9;
7910     uint32_t x10;
7911     uint32_t x11;
7912     uint32_t x12;
7913     uint32_t x13;
7914     uint32_t x14;
7915     uint32_t x15;
7916     uint32_t x16;
7917     uint32_t x17;
7918     uint32_t x18;
7919     uint32_t x19;
7920     uint32_t x20;
7921     uint32_t x21;
7922     uint32_t x22;
7923     uint32_t x23;
7924     x1 = (UINT32_C(0xfffb8e) - (arg1[0]));
7925     x2 = (UINT32_C(0x7ffffe) - (arg1[1]));
7926     x3 = (UINT32_C(0x7ffffe) - (arg1[2]));
7927     x4 = (UINT32_C(0xfffffe) - (arg1[3]));
7928     x5 = (UINT32_C(0x7ffffe) - (arg1[4]));
7929     x6 = (UINT32_C(0x7ffffe) - (arg1[5]));
7930     x7 = (UINT32_C(0x7ffffe) - (arg1[6]));
7931     x8 = (UINT32_C(0xfffffe) - (arg1[7]));
7932     x9 = (UINT32_C(0x7ffffe) - (arg1[8]));
7933     x10 = (UINT32_C(0x7ffffe) - (arg1[9]));
7934     x11 = (UINT32_C(0x7ffffe) - (arg1[10]));
7935     x12 = (UINT32_C(0xfffffe) - (arg1[11]));
7936     x13 = (UINT32_C(0x7ffffe) - (arg1[12]));
7937     x14 = (UINT32_C(0x7ffffe) - (arg1[13]));
7938     x15 = (UINT32_C(0x7ffffe) - (arg1[14]));
7939     x16 = (UINT32_C(0xfffffe) - (arg1[15]));
7940     x17 = (UINT32_C(0x7ffffe) - (arg1[16]));
7941     x18 = (UINT32_C(0x7ffffe) - (arg1[17]));
7942     x19 = (UINT32_C(0x7ffffe) - (arg1[18]));
7943     x20 = (UINT32_C(0xfffffe) - (arg1[19]));
7944     x21 = (UINT32_C(0x7ffffe) - (arg1[20]));
7945     x22 = (UINT32_C(0x7ffffe) - (arg1[21]));
7946     x23 = (UINT32_C(0x7ffffe) - (arg1[22]));
7947     out1[0] = x1;
7948     out1[1] = x2;
7949     out1[2] = x3;
7950     out1[3] = x4;
7951     out1[4] = x5;
7952     out1[5] = x6;
7953     out1[6] = x7;
7954     out1[7] = x8;
7955     out1[8] = x9;
7956     out1[9] = x10;
7957     out1[10] = x11;
7958     out1[11] = x12;
7959     out1[12] = x13;
7960     out1[13] = x14;
7961     out1[14] = x15;
7962     out1[15] = x16;
7963     out1[16] = x17;
7964     out1[17] = x18;
7965     out1[18] = x19;
7966     out1[19] = x20;
7967     out1[20] = x21;
7968     out1[21] = x22;
7969     out1[22] = x23;
7970 }
7971
7972 /*
7973  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz is a multi-limb conditional select.
7974  * Postconditions:
7975  *   eval out1 = (if arg1 = 0 then eval arg2 else eval arg3)
7976  *
7977  * Input Bounds:
7978  *   arg1: [0x0 ~> 0x1]
7979  *   arg2: [[0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff]]
7980  *   arg3: [[0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff]]
7981  * Output Bounds:
7982  *   out1: [[0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff], [0x0 ~> 0xffffffff]]
7983  */
7984 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
7985     uint32_t out1[23], fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 arg1,
7986     const uint32_t arg2[23], const uint32_t arg3[23]) {
7987     uint32_t x1;
7988     uint32_t x2;
7989     uint32_t x3;
7990     uint32_t x4;
7991     uint32_t x5;
7992     uint32_t x6;
7993     uint32_t x7;
7994     uint32_t x8;
7995     uint32_t x9;
7996     uint32_t x10;
7997     uint32_t x11;
7998     uint32_t x12;
7999     uint32_t x13;
8000     uint32_t x14;
8001     uint32_t x15;
8002     uint32_t x16;
8003     uint32_t x17;
8004     uint32_t x18;
8005     uint32_t x19;
8006     uint32_t x20;
8007     uint32_t x21;
8008     uint32_t x22;
8009     uint32_t x23;
8010     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x1, arg1, (arg2[0]),
8011                                                           (arg3[0]));
8012     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x2, arg1, (arg2[1]),
8013                                                           (arg3[1]));
8014     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x3, arg1, (arg2[2]),
8015                                                           (arg3[2]));
8016     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x4, arg1, (arg2[3]),
8017                                                           (arg3[3]));
8018     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x5, arg1, (arg2[4]),
8019                                                           (arg3[4]));
8020     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x6, arg1, (arg2[5]),
8021                                                           (arg3[5]));
8022     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x7, arg1, (arg2[6]),
8023                                                           (arg3[6]));
8024     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x8, arg1, (arg2[7]),
8025                                                           (arg3[7]));
8026     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x9, arg1, (arg2[8]),
8027                                                           (arg3[8]));
8028     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x10, arg1, (arg2[9]),
8029                                                           (arg3[9]));
8030     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8031         &x11, arg1, (arg2[10]), (arg3[10]));
8032     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8033         &x12, arg1, (arg2[11]), (arg3[11]));
8034     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8035         &x13, arg1, (arg2[12]), (arg3[12]));
8036     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8037         &x14, arg1, (arg2[13]), (arg3[13]));
8038     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8039         &x15, arg1, (arg2[14]), (arg3[14]));
8040     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8041         &x16, arg1, (arg2[15]), (arg3[15]));
8042     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8043         &x17, arg1, (arg2[16]), (arg3[16]));
8044     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8045         &x18, arg1, (arg2[17]), (arg3[17]));
8046     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8047         &x19, arg1, (arg2[18]), (arg3[18]));
8048     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8049         &x20, arg1, (arg2[19]), (arg3[19]));
8050     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8051         &x21, arg1, (arg2[20]), (arg3[20]));
8052     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8053         &x22, arg1, (arg2[21]), (arg3[21]));
8054     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(
8055         &x23, arg1, (arg2[22]), (arg3[22]));
8056     out1[0] = x1;
8057     out1[1] = x2;
8058     out1[2] = x3;
8059     out1[3] = x4;
8060     out1[4] = x5;
8061     out1[5] = x6;
8062     out1[6] = x7;
8063     out1[7] = x8;
8064     out1[8] = x9;
8065     out1[9] = x10;
8066     out1[10] = x11;
8067     out1[11] = x12;
8068     out1[12] = x13;
8069     out1[13] = x14;
8070     out1[14] = x15;
8071     out1[15] = x16;
8072     out1[16] = x17;
8073     out1[17] = x18;
8074     out1[18] = x19;
8075     out1[19] = x20;
8076     out1[20] = x21;
8077     out1[21] = x22;
8078     out1[22] = x23;
8079 }
8080
8081 /*
8082  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes serializes a field element to bytes in little-endian order.
8083  * Postconditions:
8084  *   out1 = map (λ x, ⌊((eval arg1 mod m) mod 2^(8 * (x + 1))) / 2^(8 * x)⌋) [0..63]
8085  *
8086  * Input Bounds:
8087  *   arg1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
8088  * Output Bounds:
8089  *   out1: [[0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff]]
8090  */
8091 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(
8092     uint8_t out1[64], const uint32_t arg1[23]) {
8093     uint32_t x1;
8094     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x2;
8095     uint32_t x3;
8096     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x4;
8097     uint32_t x5;
8098     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x6;
8099     uint32_t x7;
8100     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x8;
8101     uint32_t x9;
8102     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x10;
8103     uint32_t x11;
8104     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x12;
8105     uint32_t x13;
8106     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x14;
8107     uint32_t x15;
8108     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x16;
8109     uint32_t x17;
8110     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x18;
8111     uint32_t x19;
8112     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x20;
8113     uint32_t x21;
8114     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x22;
8115     uint32_t x23;
8116     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x24;
8117     uint32_t x25;
8118     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x26;
8119     uint32_t x27;
8120     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x28;
8121     uint32_t x29;
8122     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x30;
8123     uint32_t x31;
8124     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x32;
8125     uint32_t x33;
8126     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x34;
8127     uint32_t x35;
8128     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x36;
8129     uint32_t x37;
8130     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x38;
8131     uint32_t x39;
8132     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x40;
8133     uint32_t x41;
8134     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x42;
8135     uint32_t x43;
8136     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x44;
8137     uint32_t x45;
8138     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x46;
8139     uint32_t x47;
8140     uint32_t x48;
8141     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x49;
8142     uint32_t x50;
8143     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x51;
8144     uint32_t x52;
8145     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x53;
8146     uint32_t x54;
8147     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x55;
8148     uint32_t x56;
8149     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x57;
8150     uint32_t x58;
8151     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x59;
8152     uint32_t x60;
8153     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x61;
8154     uint32_t x62;
8155     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x63;
8156     uint32_t x64;
8157     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x65;
8158     uint32_t x66;
8159     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x67;
8160     uint32_t x68;
8161     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x69;
8162     uint32_t x70;
8163     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x71;
8164     uint32_t x72;
8165     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x73;
8166     uint32_t x74;
8167     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x75;
8168     uint32_t x76;
8169     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x77;
8170     uint32_t x78;
8171     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x79;
8172     uint32_t x80;
8173     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x81;
8174     uint32_t x82;
8175     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x83;
8176     uint32_t x84;
8177     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x85;
8178     uint32_t x86;
8179     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x87;
8180     uint32_t x88;
8181     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x89;
8182     uint32_t x90;
8183     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x91;
8184     uint32_t x92;
8185     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x93;
8186     uint32_t x94;
8187     uint32_t x95;
8188     uint32_t x96;
8189     uint32_t x97;
8190     uint32_t x98;
8191     uint32_t x99;
8192     uint32_t x100;
8193     uint32_t x101;
8194     uint32_t x102;
8195     uint32_t x103;
8196     uint32_t x104;
8197     uint32_t x105;
8198     uint32_t x106;
8199     uint32_t x107;
8200     uint32_t x108;
8201     uint32_t x109;
8202     uint32_t x110;
8203     uint32_t x111;
8204     uint32_t x112;
8205     uint32_t x113;
8206     uint32_t x114;
8207     uint8_t x115;
8208     uint8_t x116;
8209     uint8_t x117;
8210     uint32_t x118;
8211     uint32_t x119;
8212     uint8_t x120;
8213     uint32_t x121;
8214     uint8_t x122;
8215     uint8_t x123;
8216     uint8_t x124;
8217     uint32_t x125;
8218     uint32_t x126;
8219     uint8_t x127;
8220     uint32_t x128;
8221     uint8_t x129;
8222     uint8_t x130;
8223     uint8_t x131;
8224     uint32_t x132;
8225     uint32_t x133;
8226     uint8_t x134;
8227     uint32_t x135;
8228     uint8_t x136;
8229     uint8_t x137;
8230     uint8_t x138;
8231     uint32_t x139;
8232     uint32_t x140;
8233     uint8_t x141;
8234     uint8_t x142;
8235     uint8_t x143;
8236     uint8_t x144;
8237     uint32_t x145;
8238     uint8_t x146;
8239     uint8_t x147;
8240     uint8_t x148;
8241     uint32_t x149;
8242     uint32_t x150;
8243     uint8_t x151;
8244     uint32_t x152;
8245     uint8_t x153;
8246     uint8_t x154;
8247     uint8_t x155;
8248     uint32_t x156;
8249     uint32_t x157;
8250     uint8_t x158;
8251     uint32_t x159;
8252     uint8_t x160;
8253     uint8_t x161;
8254     uint8_t x162;
8255     uint32_t x163;
8256     uint32_t x164;
8257     uint8_t x165;
8258     uint32_t x166;
8259     uint8_t x167;
8260     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x168;
8261     uint8_t x169;
8262     uint32_t x170;
8263     uint32_t x171;
8264     uint8_t x172;
8265     uint8_t x173;
8266     uint8_t x174;
8267     uint32_t x175;
8268     uint32_t x176;
8269     uint8_t x177;
8270     uint32_t x178;
8271     uint8_t x179;
8272     uint8_t x180;
8273     uint8_t x181;
8274     uint32_t x182;
8275     uint32_t x183;
8276     uint8_t x184;
8277     uint32_t x185;
8278     uint8_t x186;
8279     uint8_t x187;
8280     uint8_t x188;
8281     uint32_t x189;
8282     uint32_t x190;
8283     uint8_t x191;
8284     uint32_t x192;
8285     uint8_t x193;
8286     uint8_t x194;
8287     uint8_t x195;
8288     uint32_t x196;
8289     uint32_t x197;
8290     uint8_t x198;
8291     uint8_t x199;
8292     uint8_t x200;
8293     uint8_t x201;
8294     uint32_t x202;
8295     uint8_t x203;
8296     uint8_t x204;
8297     uint8_t x205;
8298     uint32_t x206;
8299     uint32_t x207;
8300     uint8_t x208;
8301     uint32_t x209;
8302     uint8_t x210;
8303     uint8_t x211;
8304     uint8_t x212;
8305     uint32_t x213;
8306     uint32_t x214;
8307     uint8_t x215;
8308     uint32_t x216;
8309     uint8_t x217;
8310     uint8_t x218;
8311     uint8_t x219;
8312     uint32_t x220;
8313     uint32_t x221;
8314     uint8_t x222;
8315     uint32_t x223;
8316     uint8_t x224;
8317     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x225;
8318     uint8_t x226;
8319     uint32_t x227;
8320     uint32_t x228;
8321     uint8_t x229;
8322     uint8_t x230;
8323     uint8_t x231;
8324     uint32_t x232;
8325     uint32_t x233;
8326     uint8_t x234;
8327     uint32_t x235;
8328     uint8_t x236;
8329     uint8_t x237;
8330     uint8_t x238;
8331     uint32_t x239;
8332     uint32_t x240;
8333     uint8_t x241;
8334     uint32_t x242;
8335     uint8_t x243;
8336     uint8_t x244;
8337     uint8_t x245;
8338     uint32_t x246;
8339     uint32_t x247;
8340     uint8_t x248;
8341     uint32_t x249;
8342     uint8_t x250;
8343     uint8_t x251;
8344     uint8_t x252;
8345     uint32_t x253;
8346     uint32_t x254;
8347     uint8_t x255;
8348     uint8_t x256;
8349     uint8_t x257;
8350     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
8351         &x1, &x2, 0x0, (arg1[0]), UINT32_C(0x7ffdc7));
8352     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8353         &x3, &x4, x2, (arg1[1]), UINT32_C(0x3fffff));
8354     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8355         &x5, &x6, x4, (arg1[2]), UINT32_C(0x3fffff));
8356     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
8357         &x7, &x8, x6, (arg1[3]), UINT32_C(0x7fffff));
8358     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8359         &x9, &x10, x8, (arg1[4]), UINT32_C(0x3fffff));
8360     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8361         &x11, &x12, x10, (arg1[5]), UINT32_C(0x3fffff));
8362     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8363         &x13, &x14, x12, (arg1[6]), UINT32_C(0x3fffff));
8364     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
8365         &x15, &x16, x14, (arg1[7]), UINT32_C(0x7fffff));
8366     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8367         &x17, &x18, x16, (arg1[8]), UINT32_C(0x3fffff));
8368     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8369         &x19, &x20, x18, (arg1[9]), UINT32_C(0x3fffff));
8370     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8371         &x21, &x22, x20, (arg1[10]), UINT32_C(0x3fffff));
8372     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
8373         &x23, &x24, x22, (arg1[11]), UINT32_C(0x7fffff));
8374     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8375         &x25, &x26, x24, (arg1[12]), UINT32_C(0x3fffff));
8376     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8377         &x27, &x28, x26, (arg1[13]), UINT32_C(0x3fffff));
8378     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8379         &x29, &x30, x28, (arg1[14]), UINT32_C(0x3fffff));
8380     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
8381         &x31, &x32, x30, (arg1[15]), UINT32_C(0x7fffff));
8382     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8383         &x33, &x34, x32, (arg1[16]), UINT32_C(0x3fffff));
8384     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8385         &x35, &x36, x34, (arg1[17]), UINT32_C(0x3fffff));
8386     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8387         &x37, &x38, x36, (arg1[18]), UINT32_C(0x3fffff));
8388     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u23(
8389         &x39, &x40, x38, (arg1[19]), UINT32_C(0x7fffff));
8390     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8391         &x41, &x42, x40, (arg1[20]), UINT32_C(0x3fffff));
8392     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8393         &x43, &x44, x42, (arg1[21]), UINT32_C(0x3fffff));
8394     fiat_id_tc26_gost_3410_2012_512_paramSetA_subborrowx_u22(
8395         &x45, &x46, x44, (arg1[22]), UINT32_C(0x3fffff));
8396     fiat_id_tc26_gost_3410_2012_512_paramSetA_cmovznz_u32(&x47, x46, 0x0,
8397                                                           UINT32_C(0xffffffff));
8398     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
8399         &x48, &x49, 0x0, x1, (x47 & UINT32_C(0x7ffdc7)));
8400     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8401         &x50, &x51, x49, x3, (x47 & UINT32_C(0x3fffff)));
8402     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8403         &x52, &x53, x51, x5, (x47 & UINT32_C(0x3fffff)));
8404     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
8405         &x54, &x55, x53, x7, (x47 & UINT32_C(0x7fffff)));
8406     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8407         &x56, &x57, x55, x9, (x47 & UINT32_C(0x3fffff)));
8408     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8409         &x58, &x59, x57, x11, (x47 & UINT32_C(0x3fffff)));
8410     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8411         &x60, &x61, x59, x13, (x47 & UINT32_C(0x3fffff)));
8412     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
8413         &x62, &x63, x61, x15, (x47 & UINT32_C(0x7fffff)));
8414     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8415         &x64, &x65, x63, x17, (x47 & UINT32_C(0x3fffff)));
8416     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8417         &x66, &x67, x65, x19, (x47 & UINT32_C(0x3fffff)));
8418     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8419         &x68, &x69, x67, x21, (x47 & UINT32_C(0x3fffff)));
8420     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
8421         &x70, &x71, x69, x23, (x47 & UINT32_C(0x7fffff)));
8422     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8423         &x72, &x73, x71, x25, (x47 & UINT32_C(0x3fffff)));
8424     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8425         &x74, &x75, x73, x27, (x47 & UINT32_C(0x3fffff)));
8426     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8427         &x76, &x77, x75, x29, (x47 & UINT32_C(0x3fffff)));
8428     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
8429         &x78, &x79, x77, x31, (x47 & UINT32_C(0x7fffff)));
8430     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8431         &x80, &x81, x79, x33, (x47 & UINT32_C(0x3fffff)));
8432     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8433         &x82, &x83, x81, x35, (x47 & UINT32_C(0x3fffff)));
8434     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8435         &x84, &x85, x83, x37, (x47 & UINT32_C(0x3fffff)));
8436     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u23(
8437         &x86, &x87, x85, x39, (x47 & UINT32_C(0x7fffff)));
8438     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8439         &x88, &x89, x87, x41, (x47 & UINT32_C(0x3fffff)));
8440     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8441         &x90, &x91, x89, x43, (x47 & UINT32_C(0x3fffff)));
8442     fiat_id_tc26_gost_3410_2012_512_paramSetA_addcarryx_u22(
8443         &x92, &x93, x91, x45, (x47 & UINT32_C(0x3fffff)));
8444     x94 = (x92 << 2);
8445     x95 = (x90 << 4);
8446     x96 = (x88 << 6);
8447     x97 = (x86 << 7);
8448     x98 = (x84 * (uint32_t)0x2);
8449     x99 = (x82 << 3);
8450     x100 = (x80 << 5);
8451     x101 = (x78 << 6);
8452     x102 = (x74 << 2);
8453     x103 = (x72 << 4);
8454     x104 = (x70 << 5);
8455     x105 = (x68 << 7);
8456     x106 = (x66 * (uint32_t)0x2);
8457     x107 = (x64 << 3);
8458     x108 = (x62 << 4);
8459     x109 = (x60 << 6);
8460     x110 = (x56 << 2);
8461     x111 = (x54 << 3);
8462     x112 = (x52 << 5);
8463     x113 = (x50 << 7);
8464     x114 = (x48 >> 8);
8465     x115 = (uint8_t)(x48 & UINT8_C(0xff));
8466     x116 = (uint8_t)(x114 >> 8);
8467     x117 = (uint8_t)(x114 & UINT8_C(0xff));
8468     x118 = (x116 + x113);
8469     x119 = (x118 >> 8);
8470     x120 = (uint8_t)(x118 & UINT8_C(0xff));
8471     x121 = (x119 >> 8);
8472     x122 = (uint8_t)(x119 & UINT8_C(0xff));
8473     x123 = (uint8_t)(x121 >> 8);
8474     x124 = (uint8_t)(x121 & UINT8_C(0xff));
8475     x125 = (x123 + x112);
8476     x126 = (x125 >> 8);
8477     x127 = (uint8_t)(x125 & UINT8_C(0xff));
8478     x128 = (x126 >> 8);
8479     x129 = (uint8_t)(x126 & UINT8_C(0xff));
8480     x130 = (uint8_t)(x128 >> 8);
8481     x131 = (uint8_t)(x128 & UINT8_C(0xff));
8482     x132 = (x130 + x111);
8483     x133 = (x132 >> 8);
8484     x134 = (uint8_t)(x132 & UINT8_C(0xff));
8485     x135 = (x133 >> 8);
8486     x136 = (uint8_t)(x133 & UINT8_C(0xff));
8487     x137 = (uint8_t)(x135 >> 8);
8488     x138 = (uint8_t)(x135 & UINT8_C(0xff));
8489     x139 = (x137 + x110);
8490     x140 = (x139 >> 8);
8491     x141 = (uint8_t)(x139 & UINT8_C(0xff));
8492     x142 = (uint8_t)(x140 >> 8);
8493     x143 = (uint8_t)(x140 & UINT8_C(0xff));
8494     x144 = (uint8_t)(x142 & UINT8_C(0xff));
8495     x145 = (x58 >> 8);
8496     x146 = (uint8_t)(x58 & UINT8_C(0xff));
8497     x147 = (uint8_t)(x145 >> 8);
8498     x148 = (uint8_t)(x145 & UINT8_C(0xff));
8499     x149 = (x147 + x109);
8500     x150 = (x149 >> 8);
8501     x151 = (uint8_t)(x149 & UINT8_C(0xff));
8502     x152 = (x150 >> 8);
8503     x153 = (uint8_t)(x150 & UINT8_C(0xff));
8504     x154 = (uint8_t)(x152 >> 8);
8505     x155 = (uint8_t)(x152 & UINT8_C(0xff));
8506     x156 = (x154 + x108);
8507     x157 = (x156 >> 8);
8508     x158 = (uint8_t)(x156 & UINT8_C(0xff));
8509     x159 = (x157 >> 8);
8510     x160 = (uint8_t)(x157 & UINT8_C(0xff));
8511     x161 = (uint8_t)(x159 >> 8);
8512     x162 = (uint8_t)(x159 & UINT8_C(0xff));
8513     x163 = (x161 + x107);
8514     x164 = (x163 >> 8);
8515     x165 = (uint8_t)(x163 & UINT8_C(0xff));
8516     x166 = (x164 >> 8);
8517     x167 = (uint8_t)(x164 & UINT8_C(0xff));
8518     x168 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x166 >> 8);
8519     x169 = (uint8_t)(x166 & UINT8_C(0xff));
8520     x170 = (x168 + x106);
8521     x171 = (x170 >> 8);
8522     x172 = (uint8_t)(x170 & UINT8_C(0xff));
8523     x173 = (uint8_t)(x171 >> 8);
8524     x174 = (uint8_t)(x171 & UINT8_C(0xff));
8525     x175 = (x173 + x105);
8526     x176 = (x175 >> 8);
8527     x177 = (uint8_t)(x175 & UINT8_C(0xff));
8528     x178 = (x176 >> 8);
8529     x179 = (uint8_t)(x176 & UINT8_C(0xff));
8530     x180 = (uint8_t)(x178 >> 8);
8531     x181 = (uint8_t)(x178 & UINT8_C(0xff));
8532     x182 = (x180 + x104);
8533     x183 = (x182 >> 8);
8534     x184 = (uint8_t)(x182 & UINT8_C(0xff));
8535     x185 = (x183 >> 8);
8536     x186 = (uint8_t)(x183 & UINT8_C(0xff));
8537     x187 = (uint8_t)(x185 >> 8);
8538     x188 = (uint8_t)(x185 & UINT8_C(0xff));
8539     x189 = (x187 + x103);
8540     x190 = (x189 >> 8);
8541     x191 = (uint8_t)(x189 & UINT8_C(0xff));
8542     x192 = (x190 >> 8);
8543     x193 = (uint8_t)(x190 & UINT8_C(0xff));
8544     x194 = (uint8_t)(x192 >> 8);
8545     x195 = (uint8_t)(x192 & UINT8_C(0xff));
8546     x196 = (x194 + x102);
8547     x197 = (x196 >> 8);
8548     x198 = (uint8_t)(x196 & UINT8_C(0xff));
8549     x199 = (uint8_t)(x197 >> 8);
8550     x200 = (uint8_t)(x197 & UINT8_C(0xff));
8551     x201 = (uint8_t)(x199 & UINT8_C(0xff));
8552     x202 = (x76 >> 8);
8553     x203 = (uint8_t)(x76 & UINT8_C(0xff));
8554     x204 = (uint8_t)(x202 >> 8);
8555     x205 = (uint8_t)(x202 & UINT8_C(0xff));
8556     x206 = (x204 + x101);
8557     x207 = (x206 >> 8);
8558     x208 = (uint8_t)(x206 & UINT8_C(0xff));
8559     x209 = (x207 >> 8);
8560     x210 = (uint8_t)(x207 & UINT8_C(0xff));
8561     x211 = (uint8_t)(x209 >> 8);
8562     x212 = (uint8_t)(x209 & UINT8_C(0xff));
8563     x213 = (x211 + x100);
8564     x214 = (x213 >> 8);
8565     x215 = (uint8_t)(x213 & UINT8_C(0xff));
8566     x216 = (x214 >> 8);
8567     x217 = (uint8_t)(x214 & UINT8_C(0xff));
8568     x218 = (uint8_t)(x216 >> 8);
8569     x219 = (uint8_t)(x216 & UINT8_C(0xff));
8570     x220 = (x218 + x99);
8571     x221 = (x220 >> 8);
8572     x222 = (uint8_t)(x220 & UINT8_C(0xff));
8573     x223 = (x221 >> 8);
8574     x224 = (uint8_t)(x221 & UINT8_C(0xff));
8575     x225 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x223 >> 8);
8576     x226 = (uint8_t)(x223 & UINT8_C(0xff));
8577     x227 = (x225 + x98);
8578     x228 = (x227 >> 8);
8579     x229 = (uint8_t)(x227 & UINT8_C(0xff));
8580     x230 = (uint8_t)(x228 >> 8);
8581     x231 = (uint8_t)(x228 & UINT8_C(0xff));
8582     x232 = (x230 + x97);
8583     x233 = (x232 >> 8);
8584     x234 = (uint8_t)(x232 & UINT8_C(0xff));
8585     x235 = (x233 >> 8);
8586     x236 = (uint8_t)(x233 & UINT8_C(0xff));
8587     x237 = (uint8_t)(x235 >> 8);
8588     x238 = (uint8_t)(x235 & UINT8_C(0xff));
8589     x239 = (x237 + x96);
8590     x240 = (x239 >> 8);
8591     x241 = (uint8_t)(x239 & UINT8_C(0xff));
8592     x242 = (x240 >> 8);
8593     x243 = (uint8_t)(x240 & UINT8_C(0xff));
8594     x244 = (uint8_t)(x242 >> 8);
8595     x245 = (uint8_t)(x242 & UINT8_C(0xff));
8596     x246 = (x244 + x95);
8597     x247 = (x246 >> 8);
8598     x248 = (uint8_t)(x246 & UINT8_C(0xff));
8599     x249 = (x247 >> 8);
8600     x250 = (uint8_t)(x247 & UINT8_C(0xff));
8601     x251 = (uint8_t)(x249 >> 8);
8602     x252 = (uint8_t)(x249 & UINT8_C(0xff));
8603     x253 = (x251 + x94);
8604     x254 = (x253 >> 8);
8605     x255 = (uint8_t)(x253 & UINT8_C(0xff));
8606     x256 = (uint8_t)(x254 >> 8);
8607     x257 = (uint8_t)(x254 & UINT8_C(0xff));
8608     out1[0] = x115;
8609     out1[1] = x117;
8610     out1[2] = x120;
8611     out1[3] = x122;
8612     out1[4] = x124;
8613     out1[5] = x127;
8614     out1[6] = x129;
8615     out1[7] = x131;
8616     out1[8] = x134;
8617     out1[9] = x136;
8618     out1[10] = x138;
8619     out1[11] = x141;
8620     out1[12] = x143;
8621     out1[13] = x144;
8622     out1[14] = x146;
8623     out1[15] = x148;
8624     out1[16] = x151;
8625     out1[17] = x153;
8626     out1[18] = x155;
8627     out1[19] = x158;
8628     out1[20] = x160;
8629     out1[21] = x162;
8630     out1[22] = x165;
8631     out1[23] = x167;
8632     out1[24] = x169;
8633     out1[25] = x172;
8634     out1[26] = x174;
8635     out1[27] = x177;
8636     out1[28] = x179;
8637     out1[29] = x181;
8638     out1[30] = x184;
8639     out1[31] = x186;
8640     out1[32] = x188;
8641     out1[33] = x191;
8642     out1[34] = x193;
8643     out1[35] = x195;
8644     out1[36] = x198;
8645     out1[37] = x200;
8646     out1[38] = x201;
8647     out1[39] = x203;
8648     out1[40] = x205;
8649     out1[41] = x208;
8650     out1[42] = x210;
8651     out1[43] = x212;
8652     out1[44] = x215;
8653     out1[45] = x217;
8654     out1[46] = x219;
8655     out1[47] = x222;
8656     out1[48] = x224;
8657     out1[49] = x226;
8658     out1[50] = x229;
8659     out1[51] = x231;
8660     out1[52] = x234;
8661     out1[53] = x236;
8662     out1[54] = x238;
8663     out1[55] = x241;
8664     out1[56] = x243;
8665     out1[57] = x245;
8666     out1[58] = x248;
8667     out1[59] = x250;
8668     out1[60] = x252;
8669     out1[61] = x255;
8670     out1[62] = x257;
8671     out1[63] = x256;
8672 }
8673
8674 /*
8675  * The function fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes deserializes a field element from bytes in little-endian order.
8676  * Postconditions:
8677  *   eval out1 mod m = bytes_eval arg1 mod m
8678  *
8679  * Input Bounds:
8680  *   arg1: [[0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff], [0x0 ~> 0xff]]
8681  * Output Bounds:
8682  *   out1: [[0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x8ccccc], [0x0 ~> 0x466666], [0x0 ~> 0x466666], [0x0 ~> 0x466666]]
8683  */
8684 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(
8685     uint32_t out1[23], const uint8_t arg1[64]) {
8686     uint32_t x1;
8687     uint32_t x2;
8688     uint32_t x3;
8689     uint32_t x4;
8690     uint32_t x5;
8691     uint32_t x6;
8692     uint32_t x7;
8693     uint32_t x8;
8694     uint32_t x9;
8695     uint32_t x10;
8696     uint32_t x11;
8697     uint32_t x12;
8698     uint32_t x13;
8699     uint32_t x14;
8700     uint32_t x15;
8701     uint32_t x16;
8702     uint32_t x17;
8703     uint32_t x18;
8704     uint32_t x19;
8705     uint32_t x20;
8706     uint32_t x21;
8707     uint32_t x22;
8708     uint32_t x23;
8709     uint32_t x24;
8710     uint8_t x25;
8711     uint32_t x26;
8712     uint32_t x27;
8713     uint32_t x28;
8714     uint32_t x29;
8715     uint32_t x30;
8716     uint32_t x31;
8717     uint32_t x32;
8718     uint32_t x33;
8719     uint32_t x34;
8720     uint32_t x35;
8721     uint32_t x36;
8722     uint32_t x37;
8723     uint32_t x38;
8724     uint32_t x39;
8725     uint32_t x40;
8726     uint32_t x41;
8727     uint32_t x42;
8728     uint32_t x43;
8729     uint32_t x44;
8730     uint32_t x45;
8731     uint32_t x46;
8732     uint32_t x47;
8733     uint32_t x48;
8734     uint32_t x49;
8735     uint8_t x50;
8736     uint32_t x51;
8737     uint32_t x52;
8738     uint32_t x53;
8739     uint32_t x54;
8740     uint32_t x55;
8741     uint32_t x56;
8742     uint32_t x57;
8743     uint32_t x58;
8744     uint32_t x59;
8745     uint32_t x60;
8746     uint32_t x61;
8747     uint32_t x62;
8748     uint32_t x63;
8749     uint8_t x64;
8750     uint32_t x65;
8751     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x66;
8752     uint32_t x67;
8753     uint32_t x68;
8754     uint32_t x69;
8755     uint32_t x70;
8756     uint32_t x71;
8757     uint32_t x72;
8758     uint32_t x73;
8759     uint32_t x74;
8760     uint32_t x75;
8761     uint32_t x76;
8762     uint32_t x77;
8763     uint32_t x78;
8764     uint32_t x79;
8765     uint32_t x80;
8766     uint32_t x81;
8767     uint32_t x82;
8768     uint32_t x83;
8769     uint32_t x84;
8770     uint32_t x85;
8771     uint32_t x86;
8772     uint32_t x87;
8773     uint32_t x88;
8774     uint32_t x89;
8775     uint32_t x90;
8776     uint8_t x91;
8777     uint32_t x92;
8778     uint32_t x93;
8779     uint8_t x94;
8780     uint32_t x95;
8781     uint32_t x96;
8782     uint8_t x97;
8783     uint32_t x98;
8784     uint32_t x99;
8785     uint32_t x100;
8786     uint8_t x101;
8787     uint32_t x102;
8788     uint32_t x103;
8789     uint8_t x104;
8790     uint32_t x105;
8791     uint32_t x106;
8792     uint8_t x107;
8793     uint32_t x108;
8794     uint32_t x109;
8795     uint8_t x110;
8796     uint32_t x111;
8797     uint32_t x112;
8798     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x113;
8799     uint32_t x114;
8800     uint32_t x115;
8801     uint8_t x116;
8802     uint32_t x117;
8803     uint32_t x118;
8804     uint8_t x119;
8805     uint32_t x120;
8806     uint32_t x121;
8807     uint8_t x122;
8808     uint32_t x123;
8809     uint32_t x124;
8810     uint32_t x125;
8811     uint8_t x126;
8812     uint32_t x127;
8813     uint32_t x128;
8814     uint8_t x129;
8815     uint32_t x130;
8816     uint32_t x131;
8817     uint8_t x132;
8818     uint32_t x133;
8819     uint32_t x134;
8820     uint8_t x135;
8821     uint32_t x136;
8822     uint32_t x137;
8823     fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1 x138;
8824     uint32_t x139;
8825     uint32_t x140;
8826     uint8_t x141;
8827     uint32_t x142;
8828     uint32_t x143;
8829     uint8_t x144;
8830     uint32_t x145;
8831     uint32_t x146;
8832     uint8_t x147;
8833     uint32_t x148;
8834     uint32_t x149;
8835     x1 = ((uint32_t)(arg1[63]) << 14);
8836     x2 = ((uint32_t)(arg1[62]) << 6);
8837     x3 = ((uint32_t)(arg1[61]) << 20);
8838     x4 = ((uint32_t)(arg1[60]) << 12);
8839     x5 = ((uint32_t)(arg1[59]) << 4);
8840     x6 = ((uint32_t)(arg1[58]) << 18);
8841     x7 = ((uint32_t)(arg1[57]) << 10);
8842     x8 = ((uint32_t)(arg1[56]) << 2);
8843     x9 = ((uint32_t)(arg1[55]) << 17);
8844     x10 = ((uint32_t)(arg1[54]) << 9);
8845     x11 = ((uint32_t)(arg1[53]) * 0x2);
8846     x12 = ((uint32_t)(arg1[52]) << 15);
8847     x13 = ((uint32_t)(arg1[51]) << 7);
8848     x14 = ((uint32_t)(arg1[50]) << 21);
8849     x15 = ((uint32_t)(arg1[49]) << 13);
8850     x16 = ((uint32_t)(arg1[48]) << 5);
8851     x17 = ((uint32_t)(arg1[47]) << 19);
8852     x18 = ((uint32_t)(arg1[46]) << 11);
8853     x19 = ((uint32_t)(arg1[45]) << 3);
8854     x20 = ((uint32_t)(arg1[44]) << 18);
8855     x21 = ((uint32_t)(arg1[43]) << 10);
8856     x22 = ((uint32_t)(arg1[42]) << 2);
8857     x23 = ((uint32_t)(arg1[41]) << 16);
8858     x24 = ((uint32_t)(arg1[40]) << 8);
8859     x25 = (arg1[39]);
8860     x26 = ((uint32_t)(arg1[38]) << 14);
8861     x27 = ((uint32_t)(arg1[37]) << 6);
8862     x28 = ((uint32_t)(arg1[36]) << 20);
8863     x29 = ((uint32_t)(arg1[35]) << 12);
8864     x30 = ((uint32_t)(arg1[34]) << 4);
8865     x31 = ((uint32_t)(arg1[33]) << 19);
8866     x32 = ((uint32_t)(arg1[32]) << 11);
8867     x33 = ((uint32_t)(arg1[31]) << 3);
8868     x34 = ((uint32_t)(arg1[30]) << 17);
8869     x35 = ((uint32_t)(arg1[29]) << 9);
8870     x36 = ((uint32_t)(arg1[28]) * 0x2);
8871     x37 = ((uint32_t)(arg1[27]) << 15);
8872     x38 = ((uint32_t)(arg1[26]) << 7);
8873     x39 = ((uint32_t)(arg1[25]) << 21);
8874     x40 = ((uint32_t)(arg1[24]) << 13);
8875     x41 = ((uint32_t)(arg1[23]) << 5);
8876     x42 = ((uint32_t)(arg1[22]) << 20);
8877     x43 = ((uint32_t)(arg1[21]) << 12);
8878     x44 = ((uint32_t)(arg1[20]) << 4);
8879     x45 = ((uint32_t)(arg1[19]) << 18);
8880     x46 = ((uint32_t)(arg1[18]) << 10);
8881     x47 = ((uint32_t)(arg1[17]) << 2);
8882     x48 = ((uint32_t)(arg1[16]) << 16);
8883     x49 = ((uint32_t)(arg1[15]) << 8);
8884     x50 = (arg1[14]);
8885     x51 = ((uint32_t)(arg1[13]) << 14);
8886     x52 = ((uint32_t)(arg1[12]) << 6);
8887     x53 = ((uint32_t)(arg1[11]) << 21);
8888     x54 = ((uint32_t)(arg1[10]) << 13);
8889     x55 = ((uint32_t)(arg1[9]) << 5);
8890     x56 = ((uint32_t)(arg1[8]) << 19);
8891     x57 = ((uint32_t)(arg1[7]) << 11);
8892     x58 = ((uint32_t)(arg1[6]) << 3);
8893     x59 = ((uint32_t)(arg1[5]) << 17);
8894     x60 = ((uint32_t)(arg1[4]) << 9);
8895     x61 = ((uint32_t)(arg1[3]) * 0x2);
8896     x62 = ((uint32_t)(arg1[2]) << 16);
8897     x63 = ((uint32_t)(arg1[1]) << 8);
8898     x64 = (arg1[0]);
8899     x65 = (x64 + (x63 + x62));
8900     x66 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x65 >> 23);
8901     x67 = (x65 & UINT32_C(0x7fffff));
8902     x68 = (x2 + x1);
8903     x69 = (x5 + (x4 + x3));
8904     x70 = (x8 + (x7 + x6));
8905     x71 = (x11 + (x10 + x9));
8906     x72 = (x13 + x12);
8907     x73 = (x16 + (x15 + x14));
8908     x74 = (x19 + (x18 + x17));
8909     x75 = (x22 + (x21 + x20));
8910     x76 = (x25 + (x24 + x23));
8911     x77 = (x27 + x26);
8912     x78 = (x30 + (x29 + x28));
8913     x79 = (x33 + (x32 + x31));
8914     x80 = (x36 + (x35 + x34));
8915     x81 = (x38 + x37);
8916     x82 = (x41 + (x40 + x39));
8917     x83 = (x44 + (x43 + x42));
8918     x84 = (x47 + (x46 + x45));
8919     x85 = (x50 + (x49 + x48));
8920     x86 = (x52 + x51);
8921     x87 = (x55 + (x54 + x53));
8922     x88 = (x58 + (x57 + x56));
8923     x89 = (x61 + (x60 + x59));
8924     x90 = (x66 + x89);
8925     x91 = (uint8_t)(x90 >> 22);
8926     x92 = (x90 & UINT32_C(0x3fffff));
8927     x93 = (x91 + x88);
8928     x94 = (uint8_t)(x93 >> 22);
8929     x95 = (x93 & UINT32_C(0x3fffff));
8930     x96 = (x94 + x87);
8931     x97 = (uint8_t)(x96 >> 23);
8932     x98 = (x96 & UINT32_C(0x7fffff));
8933     x99 = (x97 + x86);
8934     x100 = (x99 & UINT32_C(0x3fffff));
8935     x101 = (uint8_t)(x85 >> 22);
8936     x102 = (x85 & UINT32_C(0x3fffff));
8937     x103 = (x101 + x84);
8938     x104 = (uint8_t)(x103 >> 22);
8939     x105 = (x103 & UINT32_C(0x3fffff));
8940     x106 = (x104 + x83);
8941     x107 = (uint8_t)(x106 >> 23);
8942     x108 = (x106 & UINT32_C(0x7fffff));
8943     x109 = (x107 + x82);
8944     x110 = (uint8_t)(x109 >> 22);
8945     x111 = (x109 & UINT32_C(0x3fffff));
8946     x112 = (x110 + x81);
8947     x113 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x112 >> 22);
8948     x114 = (x112 & UINT32_C(0x3fffff));
8949     x115 = (x113 + x80);
8950     x116 = (uint8_t)(x115 >> 22);
8951     x117 = (x115 & UINT32_C(0x3fffff));
8952     x118 = (x116 + x79);
8953     x119 = (uint8_t)(x118 >> 23);
8954     x120 = (x118 & UINT32_C(0x7fffff));
8955     x121 = (x119 + x78);
8956     x122 = (uint8_t)(x121 >> 22);
8957     x123 = (x121 & UINT32_C(0x3fffff));
8958     x124 = (x122 + x77);
8959     x125 = (x124 & UINT32_C(0x3fffff));
8960     x126 = (uint8_t)(x76 >> 22);
8961     x127 = (x76 & UINT32_C(0x3fffff));
8962     x128 = (x126 + x75);
8963     x129 = (uint8_t)(x128 >> 23);
8964     x130 = (x128 & UINT32_C(0x7fffff));
8965     x131 = (x129 + x74);
8966     x132 = (uint8_t)(x131 >> 22);
8967     x133 = (x131 & UINT32_C(0x3fffff));
8968     x134 = (x132 + x73);
8969     x135 = (uint8_t)(x134 >> 22);
8970     x136 = (x134 & UINT32_C(0x3fffff));
8971     x137 = (x135 + x72);
8972     x138 = (fiat_id_tc26_gost_3410_2012_512_paramSetA_uint1)(x137 >> 22);
8973     x139 = (x137 & UINT32_C(0x3fffff));
8974     x140 = (x138 + x71);
8975     x141 = (uint8_t)(x140 >> 23);
8976     x142 = (x140 & UINT32_C(0x7fffff));
8977     x143 = (x141 + x70);
8978     x144 = (uint8_t)(x143 >> 22);
8979     x145 = (x143 & UINT32_C(0x3fffff));
8980     x146 = (x144 + x69);
8981     x147 = (uint8_t)(x146 >> 22);
8982     x148 = (x146 & UINT32_C(0x3fffff));
8983     x149 = (x147 + x68);
8984     out1[0] = x67;
8985     out1[1] = x92;
8986     out1[2] = x95;
8987     out1[3] = x98;
8988     out1[4] = x100;
8989     out1[5] = x102;
8990     out1[6] = x105;
8991     out1[7] = x108;
8992     out1[8] = x111;
8993     out1[9] = x114;
8994     out1[10] = x117;
8995     out1[11] = x120;
8996     out1[12] = x123;
8997     out1[13] = x125;
8998     out1[14] = x127;
8999     out1[15] = x130;
9000     out1[16] = x133;
9001     out1[17] = x136;
9002     out1[18] = x139;
9003     out1[19] = x142;
9004     out1[20] = x145;
9005     out1[21] = x148;
9006     out1[22] = x149;
9007 }
9008
9009 /* END verbatim fiat code */
9010
9011 /*-
9012  * Finite field inversion via FLT.
9013  * NB: this is not a real Fiat function, just named that way for consistency.
9014  * Autogenerated: ecp/id_tc26_gost_3410_2012_512_paramSetA/fe_inv.op3
9015  * custom repunit addition chain
9016  */
9017 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(fe_t output,
9018                                                           const fe_t t1) {
9019     int i;
9020     /* temporary variables */
9021     fe_t acc, t102, t12, t198, t2, t200, t24, t3, t400, t48, t502, t6, t96;
9022
9023     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t1);
9024     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, acc, t1);
9025     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t2);
9026     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, acc, t1);
9027     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t3);
9028     for (i = 0; i < 2; i++)
9029         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9030     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t6, acc, t3);
9031     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t6);
9032     for (i = 0; i < 5; i++)
9033         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9034     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t12, acc, t6);
9035     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t12);
9036     for (i = 0; i < 11; i++)
9037         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9038     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t24, acc, t12);
9039     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t24);
9040     for (i = 0; i < 23; i++)
9041         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9042     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t48, acc, t24);
9043     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t48);
9044     for (i = 0; i < 47; i++)
9045         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9046     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t96, acc, t48);
9047     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t96);
9048     for (i = 0; i < 5; i++)
9049         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9050     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t102, acc, t6);
9051     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t102);
9052     for (i = 0; i < 95; i++)
9053         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9054     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t198, acc, t96);
9055     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t198);
9056     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9057     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t200, acc, t2);
9058     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t200);
9059     for (i = 0; i < 199; i++)
9060         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9061     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t400, acc, t200);
9062     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t400);
9063     for (i = 0; i < 101; i++)
9064         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9065     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t502, acc, t102);
9066     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, t502);
9067     for (i = 0; i < 3; i++)
9068         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9069     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(acc, acc, t3);
9070     for (i = 0; i < 4; i++)
9071         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9072     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(acc, acc, t1);
9073     for (i = 0; i < 2; i++)
9074         fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(acc, acc);
9075     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(output, acc, t1);
9076 }
9077
9078 /* curve coefficient constants */
9079
9080 static const limb_t const_one[23] = {
9081     UINT32_C(0x00000001), UINT32_C(0x00000000), UINT32_C(0x00000000),
9082     UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9083     UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9084     UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9085     UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9086     UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9087     UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9088     UINT32_C(0x00000000), UINT32_C(0x00000000)};
9089
9090 static const limb_t const_b[23] = {
9091     UINT32_C(0x0071C760), UINT32_C(0x0020F0B4), UINT32_C(0x000A818C),
9092     UINT32_C(0x007DC8EC), UINT32_C(0x003E753A), UINT32_C(0x001D862E),
9093     UINT32_C(0x00036A43), UINT32_C(0x00457401), UINT32_C(0x002C2996),
9094     UINT32_C(0x00398693), UINT32_C(0x00396121), UINT32_C(0x00132F71),
9095     UINT32_C(0x000FD0B6), UINT32_C(0x002F4207), UINT32_C(0x0030E879),
9096     UINT32_C(0x0051D872), UINT32_C(0x0025C12B), UINT32_C(0x003E3B46),
9097     UINT32_C(0x0015B333), UINT32_C(0x00037A16), UINT32_C(0x00321B77),
9098     UINT32_C(0x0005DEDF), UINT32_C(0x003A3094)};
9099
9100 /* LUT for scalar multiplication by comb interleaving */
9101 static const pt_aff_t lut_cmb[11][16] = {
9102     {
9103         {{UINT32_C(0x00000003), UINT32_C(0x00000000), UINT32_C(0x00000000),
9104           UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9105           UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9106           UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9107           UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9108           UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9109           UINT32_C(0x00000000), UINT32_C(0x00000000), UINT32_C(0x00000000),
9110           UINT32_C(0x00000000), UINT32_C(0x00000000)},
9111          {UINT32_C(0x0015F2A4), UINT32_C(0x001396A4), UINT32_C(0x00044D2C),
9112           UINT32_C(0x0046BEB7), UINT32_C(0x003F97F0), UINT32_C(0x00298028),
9113           UINT32_C(0x0038E907), UINT32_C(0x005E6A50), UINT32_C(0x001D27AE),
9114           UINT32_C(0x0027E81B), UINT32_C(0x002C4D7C), UINT32_C(0x00490EF8),
9115           UINT32_C(0x001CBEFA), UINT32_C(0x0020193F), UINT32_C(0x002BC177),
9116           UINT32_C(0x004EB3C6), UINT32_C(0x0032F0E4), UINT32_C(0x000A1CD9),
9117           UINT32_C(0x000B712A), UINT32_C(0x004C3710), UINT32_C(0x000DAB8E),
9118           UINT32_C(0x003E87A8), UINT32_C(0x001D40F3)}},
9119         {{UINT32_C(0x004B87C3), UINT32_C(0x0028D0F9), UINT32_C(0x0020B709),
9120           UINT32_C(0x000A89D0), UINT32_C(0x0033EE84), UINT32_C(0x003AEC55),
9121           UINT32_C(0x000C2241), UINT32_C(0x0032F57B), UINT32_C(0x002BAEC9),
9122           UINT32_C(0x002696E9), UINT32_C(0x00250816), UINT32_C(0x005D2A1E),
9123           UINT32_C(0x001F488F), UINT32_C(0x0010A475), UINT32_C(0x0028A117),
9124           UINT32_C(0x00302585), UINT32_C(0x002D8AB6), UINT32_C(0x002CFF09),
9125           UINT32_C(0x002EDAD2), UINT32_C(0x006A726B), UINT32_C(0x002899FA),
9126           UINT32_C(0x002B2712), UINT32_C(0x00287FC6)},
9127          {UINT32_C(0x000D90D6), UINT32_C(0x002FD8A3), UINT32_C(0x003892E6),
9128           UINT32_C(0x0049F6D8), UINT32_C(0x001BDC46), UINT32_C(0x0014C636),
9129           UINT32_C(0x002531B7), UINT32_C(0x007AC2FE), UINT32_C(0x002DDD59),
9130           UINT32_C(0x0033E260), UINT32_C(0x00275EFC), UINT32_C(0x0075988E),
9131           UINT32_C(0x003333F7), UINT32_C(0x0020678F), UINT32_C(0x000FBFA3),
9132           UINT32_C(0x00235FE1), UINT32_C(0x0020F1D2), UINT32_C(0x00373098),
9133           UINT32_C(0x000C4DDA), UINT32_C(0x00606E9E), UINT32_C(0x00118DFC),
9134           UINT32_C(0x000417EC), UINT32_C(0x000F2D71)}},
9135         {{UINT32_C(0x007F1E5F), UINT32_C(0x001419C8), UINT32_C(0x002CF1D7),
9136           UINT32_C(0x000E5B8F), UINT32_C(0x00025B6A), UINT32_C(0x00099E5B),
9137           UINT32_C(0x001804DC), UINT32_C(0x002F7572), UINT32_C(0x002A640E),
9138           UINT32_C(0x000FB103), UINT32_C(0x00291840), UINT32_C(0x007FD916),
9139           UINT32_C(0x0005B8C9), UINT32_C(0x00131C59), UINT32_C(0x0031C148),
9140           UINT32_C(0x002BF81B), UINT32_C(0x00139B07), UINT32_C(0x002FF2FF),
9141           UINT32_C(0x00049C2D), UINT32_C(0x0011BB6C), UINT32_C(0x002B0A64),
9142           UINT32_C(0x001D12B8), UINT32_C(0x0015A2A0)},
9143          {UINT32_C(0x0006CBC6), UINT32_C(0x0027724E), UINT32_C(0x00302B5D),
9144           UINT32_C(0x001BC2F1), UINT32_C(0x003F55C0), UINT32_C(0x003AA25F),
9145           UINT32_C(0x00232F00), UINT32_C(0x0074A629), UINT32_C(0x00037B4E),
9146           UINT32_C(0x0024E8BE), UINT32_C(0x002A188A), UINT32_C(0x002CB205),
9147           UINT32_C(0x0003ED36), UINT32_C(0x001C4269), UINT32_C(0x002BD5C1),
9148           UINT32_C(0x0026AD6C), UINT32_C(0x001235FE), UINT32_C(0x001CF2C0),
9149           UINT32_C(0x0024E745), UINT32_C(0x0068766F), UINT32_C(0x002BE51F),
9150           UINT32_C(0x001B57A0), UINT32_C(0x001E35B3)}},
9151         {{UINT32_C(0x005256E0), UINT32_C(0x003F836F), UINT32_C(0x00373455),
9152           UINT32_C(0x0075BA3A), UINT32_C(0x002108B7), UINT32_C(0x001C82BE),
9153           UINT32_C(0x00267DD8), UINT32_C(0x004ECEBF), UINT32_C(0x002F62E6),
9154           UINT32_C(0x000A8F9E), UINT32_C(0x000CDAFA), UINT32_C(0x0043A073),
9155           UINT32_C(0x00313659), UINT32_C(0x00154A30), UINT32_C(0x0016402E),
9156           UINT32_C(0x001175DB), UINT32_C(0x000E2798), UINT32_C(0x001F5060),
9157           UINT32_C(0x0033E5EC), UINT32_C(0x001D0B54), UINT32_C(0x001ADD71),
9158           UINT32_C(0x0023DAD9), UINT32_C(0x001E1CA5)},
9159          {UINT32_C(0x00755E5A), UINT32_C(0x00183470), UINT32_C(0x0023F0D4),
9160           UINT32_C(0x00313928), UINT32_C(0x002DD729), UINT32_C(0x001D3E91),
9161           UINT32_C(0x0035AE71), UINT32_C(0x005318A6), UINT32_C(0x002F3EDB),
9162           UINT32_C(0x00289630), UINT32_C(0x0038D891), UINT32_C(0x007CF062),
9163           UINT32_C(0x0038EE6A), UINT32_C(0x0013AFF2), UINT32_C(0x002E68F8),
9164           UINT32_C(0x0064FAA0), UINT32_C(0x003BF0E8), UINT32_C(0x000AA0E7),
9165           UINT32_C(0x0002840F), UINT32_C(0x003DE33E), UINT32_C(0x0022D493),
9166           UINT32_C(0x003F570B), UINT32_C(0x002197B3)}},
9167         {{UINT32_C(0x003642A2), UINT32_C(0x00299DCA), UINT32_C(0x003D77E1),
9168           UINT32_C(0x00489D30), UINT32_C(0x0027522E), UINT32_C(0x00240D64),
9169           UINT32_C(0x002F9F74), UINT32_C(0x0019C938), UINT32_C(0x00296297),
9170           UINT32_C(0x001E1814), UINT32_C(0x0004E1B7), UINT32_C(0x0023D69C),
9171           UINT32_C(0x0003213C), UINT32_C(0x0004FF86), UINT32_C(0x001C3786),
9172           UINT32_C(0x00304EA3), UINT32_C(0x0014189F), UINT32_C(0x0006EA0F),
9173           UINT32_C(0x00069315), UINT32_C(0x0011E349), UINT32_C(0x00397B6C),
9174           UINT32_C(0x0000F3CD), UINT32_C(0x002183EC)},
9175          {UINT32_C(0x002E3C8E), UINT32_C(0x00250F3A), UINT32_C(0x003F23C0),
9176           UINT32_C(0x000E6089), UINT32_C(0x001AA647), UINT32_C(0x001449A0),
9177           UINT32_C(0x001EE430), UINT32_C(0x006EFFDC), UINT32_C(0x002D388D),
9178           UINT32_C(0x0019E36B), UINT32_C(0x001D016D), UINT32_C(0x000829C5),
9179           UINT32_C(0x00391C21), UINT32_C(0x00271FC6), UINT32_C(0x002F3A60),
9180           UINT32_C(0x0019B88F), UINT32_C(0x001CF454), UINT32_C(0x002B6D5C),
9181           UINT32_C(0x001DAE4B), UINT32_C(0x0014A040), UINT32_C(0x002920C3),
9182           UINT32_C(0x0017BC1F), UINT32_C(0x0019D5E3)}},
9183         {{UINT32_C(0x00135C5B), UINT32_C(0x001DC3CE), UINT32_C(0x0004C781),
9184           UINT32_C(0x00080E30), UINT32_C(0x0009851D), UINT32_C(0x00350569),
9185           UINT32_C(0x002E8442), UINT32_C(0x001051D8), UINT32_C(0x0004FD70),
9186           UINT32_C(0x00134424), UINT32_C(0x000F2B29), UINT32_C(0x00685F52),
9187           UINT32_C(0x002DDECE), UINT32_C(0x00008902), UINT32_C(0x002F4764),
9188           UINT32_C(0x000E5C3D), UINT32_C(0x0032A0B9), UINT32_C(0x001A6033),
9189           UINT32_C(0x0012A3E6), UINT32_C(0x006BF5EC), UINT32_C(0x003D93F8),
9190           UINT32_C(0x00360B6E), UINT32_C(0x0018B3FC)},
9191          {UINT32_C(0x004ECF79), UINT32_C(0x0000B2AA), UINT32_C(0x003FB9C2),
9192           UINT32_C(0x0078CE6D), UINT32_C(0x001215D4), UINT32_C(0x0038E3DD),
9193           UINT32_C(0x000C3346), UINT32_C(0x004C9060), UINT32_C(0x003D3143),
9194           UINT32_C(0x00243B10), UINT32_C(0x00259423), UINT32_C(0x006A2B73),
9195           UINT32_C(0x0028505D), UINT32_C(0x000AE48C), UINT32_C(0x0000C6EE),
9196           UINT32_C(0x00572490), UINT32_C(0x0027D956), UINT32_C(0x0014406A),
9197           UINT32_C(0x0033BE99), UINT32_C(0x0018C2FA), UINT32_C(0x002F3AF0),
9198           UINT32_C(0x001405C5), UINT32_C(0x00064B19)}},
9199         {{UINT32_C(0x001F2EBD), UINT32_C(0x000510C7), UINT32_C(0x0019AE41),
9200           UINT32_C(0x007CB53E), UINT32_C(0x003AB38E), UINT32_C(0x003266F9),
9201           UINT32_C(0x00208EB6), UINT32_C(0x006D10F3), UINT32_C(0x001D6C3A),
9202           UINT32_C(0x002D7D80), UINT32_C(0x000B3C9D), UINT32_C(0x0048BDA2),
9203           UINT32_C(0x0014CC2E), UINT32_C(0x00156682), UINT32_C(0x000BAEBC),
9204           UINT32_C(0x0032A9C9), UINT32_C(0x001FD4D5), UINT32_C(0x00323040),
9205           UINT32_C(0x00282E72), UINT32_C(0x003CE90A), UINT32_C(0x0007C3A6),
9206           UINT32_C(0x0004F672), UINT32_C(0x0019034A)},
9207          {UINT32_C(0x004DEA72), UINT32_C(0x00355CF9), UINT32_C(0x002BBD82),
9208           UINT32_C(0x004625D7), UINT32_C(0x0035A89F), UINT32_C(0x002CE049),
9209           UINT32_C(0x001D8906), UINT32_C(0x0000050C), UINT32_C(0x00357091),
9210           UINT32_C(0x001D1A1C), UINT32_C(0x001A15E2), UINT32_C(0x002C9AA7),
9211           UINT32_C(0x001B1721), UINT32_C(0x003B7772), UINT32_C(0x003075BA),
9212           UINT32_C(0x003ACE9C), UINT32_C(0x0018B5B9), UINT32_C(0x001483A0),
9213           UINT32_C(0x002B8443), UINT32_C(0x000D0833), UINT32_C(0x0011414E),
9214           UINT32_C(0x00377005), UINT32_C(0x001FE0BC)}},
9215         {{UINT32_C(0x00614D45), UINT32_C(0x000FACE1), UINT32_C(0x002E03FD),
9216           UINT32_C(0x00104582), UINT32_C(0x0027B6D8), UINT32_C(0x002E45CA),
9217           UINT32_C(0x003DC391), UINT32_C(0x000278F0), UINT32_C(0x00150F86),
9218           UINT32_C(0x002EDE47), UINT32_C(0x0025399C), UINT32_C(0x004DCCC4),
9219           UINT32_C(0x00186E7C), UINT32_C(0x000987AE), UINT32_C(0x00082ECC),
9220           UINT32_C(0x007B6EE3), UINT32_C(0x00097785), UINT32_C(0x003E0986),
9221           UINT32_C(0x001C91ED), UINT32_C(0x0061A3C8), UINT32_C(0x00291652),
9222           UINT32_C(0x00089F6C), UINT32_C(0x000C0F4E)},
9223          {UINT32_C(0x00341422), UINT32_C(0x0016F7F9), UINT32_C(0x002A2213),
9224           UINT32_C(0x000CC4C8), UINT32_C(0x002A5108), UINT32_C(0x0014C3FF),
9225           UINT32_C(0x002A84FF), UINT32_C(0x007C98C9), UINT32_C(0x001C8206),
9226           UINT32_C(0x0031B7CB), UINT32_C(0x0037BB04), UINT32_C(0x003E3334),
9227           UINT32_C(0x0029AEB3), UINT32_C(0x003E65DA), UINT32_C(0x0020EE26),
9228           UINT32_C(0x00779AF6), UINT32_C(0x00288AFE), UINT32_C(0x000D4B8D),
9229           UINT32_C(0x001DB51B), UINT32_C(0x003BF6A3), UINT32_C(0x00381A92),
9230           UINT32_C(0x0011D531), UINT32_C(0x00247F4E)}},
9231         {{UINT32_C(0x00709AE6), UINT32_C(0x00252549), UINT32_C(0x0007EE34),
9232           UINT32_C(0x005D8045), UINT32_C(0x0038367B), UINT32_C(0x0035CCF0),
9233           UINT32_C(0x0005CD45), UINT32_C(0x0072DFB7), UINT32_C(0x00059B58),
9234           UINT32_C(0x002BB6E5), UINT32_C(0x003546BA), UINT32_C(0x001567C4),
9235           UINT32_C(0x003C5F98), UINT32_C(0x002503E9), UINT32_C(0x003AB5A8),
9236           UINT32_C(0x002858EB), UINT32_C(0x001535BC), UINT32_C(0x002DC366),
9237           UINT32_C(0x0034ED0D), UINT32_C(0x00277DED), UINT32_C(0x00016E7E),
9238           UINT32_C(0x001A35D9), UINT32_C(0x00234EA3)},
9239          {UINT32_C(0x0003CF55), UINT32_C(0x0026EE0D), UINT32_C(0x0025529F),
9240           UINT32_C(0x0031335F), UINT32_C(0x00305D60), UINT32_C(0x00148F61),
9241           UINT32_C(0x00343772), UINT32_C(0x004BD619), UINT32_C(0x0012E0C0),
9242           UINT32_C(0x0013EA6E), UINT32_C(0x001A3BC0), UINT32_C(0x0069B10D),
9243           UINT32_C(0x002CCEED), UINT32_C(0x002B62B5), UINT32_C(0x003456E2),
9244           UINT32_C(0x0005151D), UINT32_C(0x00374FB6), UINT32_C(0x000F4CCC),
9245           UINT32_C(0x001978D4), UINT32_C(0x003FA7E6), UINT32_C(0x00266D24),
9246           UINT32_C(0x00248D2B), UINT32_C(0x00161AD6)}},
9247         {{UINT32_C(0x0032C9A3), UINT32_C(0x002C7C77), UINT32_C(0x000E3F02),
9248           UINT32_C(0x003E504E), UINT32_C(0x001351CC), UINT32_C(0x00177427),
9249           UINT32_C(0x0020C8E9), UINT32_C(0x0019A4C7), UINT32_C(0x000B0C5D),
9250           UINT32_C(0x001F549F), UINT32_C(0x003B0C1B), UINT32_C(0x0021F5DE),
9251           UINT32_C(0x000075B2), UINT32_C(0x0036927D), UINT32_C(0x00185855),
9252           UINT32_C(0x004BD125), UINT32_C(0x0014BBC7), UINT32_C(0x001C0CC6),
9253           UINT32_C(0x0022540C), UINT32_C(0x00552107), UINT32_C(0x002283DD),
9254           UINT32_C(0x0006BA78), UINT32_C(0x0013823D)},
9255          {UINT32_C(0x001F97DE), UINT32_C(0x0028B5D5), UINT32_C(0x0030F546),
9256           UINT32_C(0x0001A0B0), UINT32_C(0x0010CC6D), UINT32_C(0x001610C3),
9257           UINT32_C(0x00245BEB), UINT32_C(0x003016D1), UINT32_C(0x001B8316),
9258           UINT32_C(0x0016BA74), UINT32_C(0x002C99F7), UINT32_C(0x001CC511),
9259           UINT32_C(0x0017550A), UINT32_C(0x0002060A), UINT32_C(0x00256CB7),
9260           UINT32_C(0x0040BF9E), UINT32_C(0x0016677B), UINT32_C(0x0007D673),
9261           UINT32_C(0x00182B4F), UINT32_C(0x002E8ADB), UINT32_C(0x001CBED4),
9262           UINT32_C(0x002D048B), UINT32_C(0x000C037A)}},
9263         {{UINT32_C(0x005B2170), UINT32_C(0x002A20E5), UINT32_C(0x003A2CC9),
9264           UINT32_C(0x002D459D), UINT32_C(0x001DECC6), UINT32_C(0x0031C1FE),
9265           UINT32_C(0x000CE89C), UINT32_C(0x0028CB4A), UINT32_C(0x00228929),
9266           UINT32_C(0x000C455B), UINT32_C(0x00288443), UINT32_C(0x0019205F),
9267           UINT32_C(0x0023421A), UINT32_C(0x00352E01), UINT32_C(0x001E5137),
9268           UINT32_C(0x0074C0C9), UINT32_C(0x0003A0D7), UINT32_C(0x003A7F32),
9269           UINT32_C(0x002BDAAB), UINT32_C(0x0038CE1E), UINT32_C(0x000991A9),
9270           UINT32_C(0x0031AAF9), UINT32_C(0x0036FF6B)},
9271          {UINT32_C(0x006C89E0), UINT32_C(0x00256380), UINT32_C(0x001F7866),
9272           UINT32_C(0x000F7CD3), UINT32_C(0x001E0162), UINT32_C(0x001A7772),
9273           UINT32_C(0x000474B0), UINT32_C(0x001B3366), UINT32_C(0x0024C27D),
9274           UINT32_C(0x0033397C), UINT32_C(0x002DDFF7), UINT32_C(0x0003D06F),
9275           UINT32_C(0x003CE689), UINT32_C(0x00087AFA), UINT32_C(0x00135BED),
9276           UINT32_C(0x001E1302), UINT32_C(0x003FD153), UINT32_C(0x003F3F3D),
9277           UINT32_C(0x0005DB43), UINT32_C(0x006193C9), UINT32_C(0x00174036),
9278           UINT32_C(0x00258D52), UINT32_C(0x00046F1F)}},
9279         {{UINT32_C(0x0049FC14), UINT32_C(0x00007614), UINT32_C(0x001F7037),
9280           UINT32_C(0x00592750), UINT32_C(0x00290B61), UINT32_C(0x000960A8),
9281           UINT32_C(0x00194FF1), UINT32_C(0x00139CAC), UINT32_C(0x003E0952),
9282           UINT32_C(0x00270EC5), UINT32_C(0x00088B6C), UINT32_C(0x004C78F1),
9283           UINT32_C(0x001D53F4), UINT32_C(0x003170C1), UINT32_C(0x001BD840),
9284           UINT32_C(0x00705662), UINT32_C(0x0020DE92), UINT32_C(0x00128651),
9285           UINT32_C(0x003E0D7F), UINT32_C(0x007F2363), UINT32_C(0x00029F44),
9286           UINT32_C(0x001B5FCC), UINT32_C(0x0012DCB6)},
9287          {UINT32_C(0x00715C01), UINT32_C(0x003BA447), UINT32_C(0x0014B2CF),
9288           UINT32_C(0x000D0598), UINT32_C(0x0021BD5E), UINT32_C(0x003B2771),
9289           UINT32_C(0x001C4456), UINT32_C(0x000B7702), UINT32_C(0x0034AD46),
9290           UINT32_C(0x0020B4D4), UINT32_C(0x0034C10F), UINT32_C(0x00211BEE),
9291           UINT32_C(0x00229380), UINT32_C(0x000F7D2E), UINT32_C(0x001DCFEE),
9292           UINT32_C(0x00667394), UINT32_C(0x00181E9B), UINT32_C(0x000423C4),
9293           UINT32_C(0x001ECE77), UINT32_C(0x00170479), UINT32_C(0x0032353F),
9294           UINT32_C(0x00164DF6), UINT32_C(0x0016F1DE)}},
9295         {{UINT32_C(0x0075C5F8), UINT32_C(0x000385BF), UINT32_C(0x0031DD89),
9296           UINT32_C(0x006E52CD), UINT32_C(0x0007AB18), UINT32_C(0x001DB7D7),
9297           UINT32_C(0x00181DB9), UINT32_C(0x003116D9), UINT32_C(0x002F42C8),
9298           UINT32_C(0x001008A8), UINT32_C(0x000955A8), UINT32_C(0x0016157F),
9299           UINT32_C(0x00366962), UINT32_C(0x00374B18), UINT32_C(0x003DA6A4),
9300           UINT32_C(0x004DD8AE), UINT32_C(0x00303056), UINT32_C(0x000814A3),
9301           UINT32_C(0x001FD98E), UINT32_C(0x0054633B), UINT32_C(0x00196306),
9302           UINT32_C(0x0036BE52), UINT32_C(0x001CFF52)},
9303          {UINT32_C(0x006F6BD4), UINT32_C(0x00363198), UINT32_C(0x0027A4A2),
9304           UINT32_C(0x002E0CC3), UINT32_C(0x003815C9), UINT32_C(0x003F3192),
9305           UINT32_C(0x0037B67C), UINT32_C(0x0030F20C), UINT32_C(0x002A1B35),
9306           UINT32_C(0x0016C2B1), UINT32_C(0x0010040B), UINT32_C(0x006D50BA),
9307           UINT32_C(0x0015627B), UINT32_C(0x00236233), UINT32_C(0x002BD95D),
9308           UINT32_C(0x0068647C), UINT32_C(0x003DB8B8), UINT32_C(0x00090EB1),
9309           UINT32_C(0x001829ED), UINT32_C(0x003AA621), UINT32_C(0x00281854),
9310           UINT32_C(0x000579E2), UINT32_C(0x0027CDA0)}},
9311         {{UINT32_C(0x0056E4C3), UINT32_C(0x000E21FF), UINT32_C(0x0024F3B1),
9312           UINT32_C(0x002D126D), UINT32_C(0x00125D7C), UINT32_C(0x0011EF67),
9313           UINT32_C(0x000BD798), UINT32_C(0x00018629), UINT32_C(0x001299FE),
9314           UINT32_C(0x0016DCCD), UINT32_C(0x001DB60A), UINT32_C(0x002AB062),
9315           UINT32_C(0x003E7DDD), UINT32_C(0x002F1BF6), UINT32_C(0x000F1421),
9316           UINT32_C(0x007DDEFC), UINT32_C(0x0022F932), UINT32_C(0x00327FBB),
9317           UINT32_C(0x001E3684), UINT32_C(0x000F04E8), UINT32_C(0x0028B9F5),
9318           UINT32_C(0x0000AC17), UINT32_C(0x001B586E)},
9319          {UINT32_C(0x0029C581), UINT32_C(0x001F0CDD), UINT32_C(0x000C57C8),
9320           UINT32_C(0x005909C4), UINT32_C(0x003A26ED), UINT32_C(0x0032886A),
9321           UINT32_C(0x0002D003), UINT32_C(0x0047BC86), UINT32_C(0x0004B488),
9322           UINT32_C(0x0028EAC9), UINT32_C(0x00007E5F), UINT32_C(0x002AFB2F),
9323           UINT32_C(0x0029FDA2), UINT32_C(0x00161194), UINT32_C(0x0003E7BC),
9324           UINT32_C(0x000F8369), UINT32_C(0x000E94CC), UINT32_C(0x0037E9AD),
9325           UINT32_C(0x0007994D), UINT32_C(0x00620DA2), UINT32_C(0x001C54F1),
9326           UINT32_C(0x0003054F), UINT32_C(0x000F164E)}},
9327         {{UINT32_C(0x00485A6F), UINT32_C(0x0004577D), UINT32_C(0x003E3EB4),
9328           UINT32_C(0x006C4E40), UINT32_C(0x00032DFF), UINT32_C(0x0036D9C3),
9329           UINT32_C(0x003133C3), UINT32_C(0x003BD1C9), UINT32_C(0x002755D5),
9330           UINT32_C(0x00118134), UINT32_C(0x001160F0), UINT32_C(0x00059163),
9331           UINT32_C(0x003EB8FC), UINT32_C(0x00056FC9), UINT32_C(0x0028AED8),
9332           UINT32_C(0x003179B5), UINT32_C(0x003FBF05), UINT32_C(0x00011E59),
9333           UINT32_C(0x00011744), UINT32_C(0x003470B0), UINT32_C(0x00135BDE),
9334           UINT32_C(0x00158952), UINT32_C(0x0000E6DB)},
9335          {UINT32_C(0x00532F1F), UINT32_C(0x003906A8), UINT32_C(0x002A32FC),
9336           UINT32_C(0x00227E49), UINT32_C(0x00058EDF), UINT32_C(0x003D7DB2),
9337           UINT32_C(0x0023DC29), UINT32_C(0x0070553D), UINT32_C(0x0004329B),
9338           UINT32_C(0x003549B6), UINT32_C(0x003EC868), UINT32_C(0x000D7C98),
9339           UINT32_C(0x00368C50), UINT32_C(0x000F57E5), UINT32_C(0x00126458),
9340           UINT32_C(0x004D62F6), UINT32_C(0x0031CEF3), UINT32_C(0x00204DE0),
9341           UINT32_C(0x00072E81), UINT32_C(0x007DA6C8), UINT32_C(0x003D4C1E),
9342           UINT32_C(0x003FAAA5), UINT32_C(0x0018B7EB)}},
9343         {{UINT32_C(0x005B2BEF), UINT32_C(0x002EEA64), UINT32_C(0x0035ADEF),
9344           UINT32_C(0x00037B6A), UINT32_C(0x003D7F26), UINT32_C(0x003F7AE8),
9345           UINT32_C(0x0016082B), UINT32_C(0x004D0845), UINT32_C(0x003213FD),
9346           UINT32_C(0x002B907C), UINT32_C(0x0009D773), UINT32_C(0x0032EB9F),
9347           UINT32_C(0x000B9447), UINT32_C(0x000FF14B), UINT32_C(0x002CC862),
9348           UINT32_C(0x000EE902), UINT32_C(0x001A1E93), UINT32_C(0x003B5022),
9349           UINT32_C(0x0007EC85), UINT32_C(0x00773A1A), UINT32_C(0x001E3782),
9350           UINT32_C(0x001F2F23), UINT32_C(0x00371A25)},
9351          {UINT32_C(0x00500C90), UINT32_C(0x00012947), UINT32_C(0x00276B35),
9352           UINT32_C(0x00055EB4), UINT32_C(0x000B22A3), UINT32_C(0x001C3032),
9353           UINT32_C(0x0034B27D), UINT32_C(0x0058FC68), UINT32_C(0x001DB835),
9354           UINT32_C(0x0000E22D), UINT32_C(0x0026AF65), UINT32_C(0x005F11AC),
9355           UINT32_C(0x002AB077), UINT32_C(0x0016A2BF), UINT32_C(0x002DE969),
9356           UINT32_C(0x0014F0F9), UINT32_C(0x00142DA0), UINT32_C(0x00197B6C),
9357           UINT32_C(0x00098CD4), UINT32_C(0x0076AB0A), UINT32_C(0x003EDF05),
9358           UINT32_C(0x00165EF4), UINT32_C(0x002E8B63)}},
9359     },
9360     {
9361         {{UINT32_C(0x0043FF72), UINT32_C(0x00371016), UINT32_C(0x00088C3D),
9362           UINT32_C(0x003D3831), UINT32_C(0x0029E105), UINT32_C(0x000874C9),
9363           UINT32_C(0x0028AD35), UINT32_C(0x0050A745), UINT32_C(0x00129E17),
9364           UINT32_C(0x0006826F), UINT32_C(0x0003A7E7), UINT32_C(0x005A9957),
9365           UINT32_C(0x003F5A11), UINT32_C(0x001E0D75), UINT32_C(0x00132E4A),
9366           UINT32_C(0x001CACF1), UINT32_C(0x00106741), UINT32_C(0x0035B4A8),
9367           UINT32_C(0x0038B784), UINT32_C(0x007346F0), UINT32_C(0x003DB373),
9368           UINT32_C(0x001CED8B), UINT32_C(0x003B3CAB)},
9369          {UINT32_C(0x0005ACA1), UINT32_C(0x0003F976), UINT32_C(0x000C0B13),
9370           UINT32_C(0x007066AA), UINT32_C(0x0037D80F), UINT32_C(0x00150B30),
9371           UINT32_C(0x0022F326), UINT32_C(0x0034AEAA), UINT32_C(0x0008FECE),
9372           UINT32_C(0x0038E83F), UINT32_C(0x003A6384), UINT32_C(0x0015A868),
9373           UINT32_C(0x000D1591), UINT32_C(0x00111853), UINT32_C(0x0007CCDC),
9374           UINT32_C(0x00088671), UINT32_C(0x000325D9), UINT32_C(0x0030192A),
9375           UINT32_C(0x0001A7CA), UINT32_C(0x00363760), UINT32_C(0x001F97E8),
9376           UINT32_C(0x002C79F3), UINT32_C(0x001B4F8F)}},
9377         {{UINT32_C(0x006A80D4), UINT32_C(0x0039A871), UINT32_C(0x001DED13),
9378           UINT32_C(0x003F5D25), UINT32_C(0x0009BD11), UINT32_C(0x0015E36E),
9379           UINT32_C(0x000EE574), UINT32_C(0x006F2527), UINT32_C(0x0004BD44),
9380           UINT32_C(0x003A9039), UINT32_C(0x00158327), UINT32_C(0x0007B459),
9381           UINT32_C(0x002C3FC0), UINT32_C(0x002902E4), UINT32_C(0x002368B3),
9382           UINT32_C(0x0054306B), UINT32_C(0x002E6771), UINT32_C(0x0000025A),
9383           UINT32_C(0x00359E84), UINT32_C(0x00753A6D), UINT32_C(0x001F1043),
9384           UINT32_C(0x00198B2D), UINT32_C(0x001D7912)},
9385          {UINT32_C(0x007E5CCB), UINT32_C(0x000738A9), UINT32_C(0x00164BE0),
9386           UINT32_C(0x001D6B62), UINT32_C(0x000EF92E), UINT32_C(0x00280CB8),
9387           UINT32_C(0x0037C2AD), UINT32_C(0x00569D4A), UINT32_C(0x00279D0C),
9388           UINT32_C(0x002F59F7), UINT32_C(0x003DAC74), UINT32_C(0x0042978C),
9389           UINT32_C(0x0010DA80), UINT32_C(0x00217A9D), UINT32_C(0x00336498),
9390           UINT32_C(0x00239BFB), UINT32_C(0x00367CF4), UINT32_C(0x00002665),
9391           UINT32_C(0x0012FC23), UINT32_C(0x006B55F4), UINT32_C(0x0008389E),
9392           UINT32_C(0x0010C55C), UINT32_C(0x003917A5)}},
9393         {{UINT32_C(0x000B001B), UINT32_C(0x0036253F), UINT32_C(0x00364099),
9394           UINT32_C(0x00403910), UINT32_C(0x002FD274), UINT32_C(0x00240152),
9395           UINT32_C(0x002222A5), UINT32_C(0x00038A33), UINT32_C(0x0015B0C3),
9396           UINT32_C(0x001BA804), UINT32_C(0x000B91C9), UINT32_C(0x001E1D50),
9397           UINT32_C(0x002C6A3F), UINT32_C(0x0002DA6D), UINT32_C(0x0031CDE7),
9398           UINT32_C(0x005F8ABA), UINT32_C(0x0032F16C), UINT32_C(0x0005F59E),
9399           UINT32_C(0x0027FB7F), UINT32_C(0x003F4395), UINT32_C(0x0005567B),
9400           UINT32_C(0x00037388), UINT32_C(0x0031BC7C)},
9401          {UINT32_C(0x0021EB64), UINT32_C(0x000F56D8), UINT32_C(0x00063940),
9402           UINT32_C(0x007222D6), UINT32_C(0x002072C6), UINT32_C(0x002E61E2),
9403           UINT32_C(0x0016F379), UINT32_C(0x0027EADF), UINT32_C(0x003A6BD2),
9404           UINT32_C(0x002F0B3A), UINT32_C(0x002FFAE6), UINT32_C(0x007DBBB0),
9405           UINT32_C(0x00003399), UINT32_C(0x0015CF91), UINT32_C(0x00284363),
9406           UINT32_C(0x003DC09B), UINT32_C(0x00305937), UINT32_C(0x001A75E2),
9407           UINT32_C(0x0028D44C), UINT32_C(0x0052188E), UINT32_C(0x003F5117),
9408           UINT32_C(0x002A7B19), UINT32_C(0x000F38A9)}},
9409         {{UINT32_C(0x0068B2E0), UINT32_C(0x0017FFC5), UINT32_C(0x0027AFC3),
9410           UINT32_C(0x000A45A1), UINT32_C(0x001227B7), UINT32_C(0x000976FE),
9411           UINT32_C(0x003CC399), UINT32_C(0x00111C12), UINT32_C(0x0021CDEC),
9412           UINT32_C(0x000290FA), UINT32_C(0x000E0DC4), UINT32_C(0x004B8791),
9413           UINT32_C(0x003123B8), UINT32_C(0x00257E85), UINT32_C(0x0031095C),
9414           UINT32_C(0x00009042), UINT32_C(0x002E0671), UINT32_C(0x002EDE50),
9415           UINT32_C(0x002522AF), UINT32_C(0x002113DA), UINT32_C(0x002136C8),
9416           UINT32_C(0x003A4426), UINT32_C(0x00375E38)},
9417          {UINT32_C(0x004B72D7), UINT32_C(0x00317636), UINT32_C(0x002C6B14),
9418           UINT32_C(0x0023C200), UINT32_C(0x00229CA0), UINT32_C(0x0018AB4E),
9419           UINT32_C(0x0038DE7C), UINT32_C(0x0071C6F7), UINT32_C(0x0006D850),
9420           UINT32_C(0x0007F5A9), UINT32_C(0x001ADEAD), UINT32_C(0x00171F68),
9421           UINT32_C(0x0018927F), UINT32_C(0x001A4C5E), UINT32_C(0x0000DDCC),
9422           UINT32_C(0x0038263E), UINT32_C(0x003C1F7F), UINT32_C(0x001B3C9A),
9423           UINT32_C(0x003488F3), UINT32_C(0x0023C421), UINT32_C(0x002F2417),
9424           UINT32_C(0x00068EDA), UINT32_C(0x00073EC6)}},
9425         {{UINT32_C(0x00740829), UINT32_C(0x003BBE8D), UINT32_C(0x00073E98),
9426           UINT32_C(0x00356FAD), UINT32_C(0x003B7DDB), UINT32_C(0x002DC94B),
9427           UINT32_C(0x0030C9A3), UINT32_C(0x001B8A3C), UINT32_C(0x0023BCCD),
9428           UINT32_C(0x0003F076), UINT32_C(0x003A8A39), UINT32_C(0x0067C926),
9429           UINT32_C(0x00057C86), UINT32_C(0x0027A91E), UINT32_C(0x0006BFD0),
9430           UINT32_C(0x00268025), UINT32_C(0x0026C695), UINT32_C(0x0030F65C),
9431           UINT32_C(0x0007A146), UINT32_C(0x001C03BD), UINT32_C(0x001A48A6),
9432           UINT32_C(0x00327209), UINT32_C(0x00331030)},
9433          {UINT32_C(0x004BBAF6), UINT32_C(0x0014ED13), UINT32_C(0x00201E53),
9434           UINT32_C(0x0019209B), UINT32_C(0x0018CD1E), UINT32_C(0x000DEF6D),
9435           UINT32_C(0x00038012), UINT32_C(0x0045882E), UINT32_C(0x003736AB),
9436           UINT32_C(0x001E713A), UINT32_C(0x002C4DFB), UINT32_C(0x003F0EEF),
9437           UINT32_C(0x002CFF2D), UINT32_C(0x003250F5), UINT32_C(0x00078ABA),
9438           UINT32_C(0x00678753), UINT32_C(0x00056E90), UINT32_C(0x00198BB5),
9439           UINT32_C(0x003CE0AD), UINT32_C(0x007FA3C4), UINT32_C(0x00393AC2),
9440           UINT32_C(0x00207404), UINT32_C(0x001C83C6)}},
9441         {{UINT32_C(0x0006EF83), UINT32_C(0x0015F1B3), UINT32_C(0x0012AA0F),
9442           UINT32_C(0x0014518C), UINT32_C(0x002839B7), UINT32_C(0x000D1D3A),
9443           UINT32_C(0x0004C1BA), UINT32_C(0x005F75C2), UINT32_C(0x000D10B9),
9444           UINT32_C(0x0013D894), UINT32_C(0x000DB952), UINT32_C(0x000B1478),
9445           UINT32_C(0x000CB9AA), UINT32_C(0x0011AD2E), UINT32_C(0x002894C3),
9446           UINT32_C(0x0011DD4E), UINT32_C(0x000303E2), UINT32_C(0x001EEC21),
9447           UINT32_C(0x001A194B), UINT32_C(0x005970C2), UINT32_C(0x00271263),
9448           UINT32_C(0x0037CD83), UINT32_C(0x0000E91B)},
9449          {UINT32_C(0x0002F7FB), UINT32_C(0x0037D3D0), UINT32_C(0x00167E4D),
9450           UINT32_C(0x002B340E), UINT32_C(0x0029810C), UINT32_C(0x000F2744),
9451           UINT32_C(0x000500A9), UINT32_C(0x0077B334), UINT32_C(0x0033BBF3),
9452           UINT32_C(0x0035F681), UINT32_C(0x002A089F), UINT32_C(0x0005BD0A),
9453           UINT32_C(0x0034B55C), UINT32_C(0x001C94F6), UINT32_C(0x003E80FE),
9454           UINT32_C(0x0012E6AD), UINT32_C(0x002E5578), UINT32_C(0x000FCD23),
9455           UINT32_C(0x003D81BB), UINT32_C(0x000E9FC4), UINT32_C(0x002DCA2E),
9456           UINT32_C(0x00163735), UINT32_C(0x00331F02)}},
9457         {{UINT32_C(0x006924AC), UINT32_C(0x0035ADA0), UINT32_C(0x001100A8),
9458           UINT32_C(0x00267DEA), UINT32_C(0x00271C3D), UINT32_C(0x0028011C),
9459           UINT32_C(0x0033F146), UINT32_C(0x00380BD9), UINT32_C(0x001E9B99),
9460           UINT32_C(0x0038A9B3), UINT32_C(0x0023055C), UINT32_C(0x00402C40),
9461           UINT32_C(0x000E057B), UINT32_C(0x002F5047), UINT32_C(0x0030ABB8),
9462           UINT32_C(0x00177283), UINT32_C(0x00151E5A), UINT32_C(0x0026A491),
9463           UINT32_C(0x00346A9D), UINT32_C(0x006A2686), UINT32_C(0x0010AE09),
9464           UINT32_C(0x0031479F), UINT32_C(0x003F9361)},
9465          {UINT32_C(0x0022A729), UINT32_C(0x001A0AB6), UINT32_C(0x003A1834),
9466           UINT32_C(0x004ADEAE), UINT32_C(0x0025C51B), UINT32_C(0x00380B76),
9467           UINT32_C(0x00109BCA), UINT32_C(0x00326C1B), UINT32_C(0x002680D8),
9468           UINT32_C(0x003F48F6), UINT32_C(0x000DCE07), UINT32_C(0x000D0CDC),
9469           UINT32_C(0x0024513C), UINT32_C(0x001AAF42), UINT32_C(0x000F88A1),
9470           UINT32_C(0x007680CC), UINT32_C(0x00032E52), UINT32_C(0x00028B7A),
9471           UINT32_C(0x0028F444), UINT32_C(0x0013B5EA), UINT32_C(0x000BE2FE),
9472           UINT32_C(0x00382F79), UINT32_C(0x0026D469)}},
9473         {{UINT32_C(0x002EF810), UINT32_C(0x003D7CA9), UINT32_C(0x0012A7CA),
9474           UINT32_C(0x0066ED19), UINT32_C(0x003B6782), UINT32_C(0x001A688B),
9475           UINT32_C(0x00057236), UINT32_C(0x003AB1DD), UINT32_C(0x002DCA9F),
9476           UINT32_C(0x00318D65), UINT32_C(0x002C3201), UINT32_C(0x002651F2),
9477           UINT32_C(0x0002585A), UINT32_C(0x00110B33), UINT32_C(0x002FC48F),
9478           UINT32_C(0x0027FF7F), UINT32_C(0x000C314B), UINT32_C(0x00306B0F),
9479           UINT32_C(0x002BCD62), UINT32_C(0x000E5451), UINT32_C(0x00372C81),
9480           UINT32_C(0x0008B694), UINT32_C(0x001640E1)},
9481          {UINT32_C(0x005D5544), UINT32_C(0x00050CE4), UINT32_C(0x0017634F),
9482           UINT32_C(0x0013A04A), UINT32_C(0x00106FDB), UINT32_C(0x001DFA5D),
9483           UINT32_C(0x002B04EB), UINT32_C(0x0049FF7C), UINT32_C(0x0026E744),
9484           UINT32_C(0x003D42A5), UINT32_C(0x002B0FD6), UINT32_C(0x0076FAC0),
9485           UINT32_C(0x003ACF9E), UINT32_C(0x000B293A), UINT32_C(0x00120F10),
9486           UINT32_C(0x0056D4D7), UINT32_C(0x003229A1), UINT32_C(0x001C7884),
9487           UINT32_C(0x003CE57D), UINT32_C(0x003C86A7), UINT32_C(0x001588C1),
9488           UINT32_C(0x0000D548), UINT32_C(0x0011BB4A)}},
9489         {{UINT32_C(0x0036250B), UINT32_C(0x00274CE1), UINT32_C(0x003F5FE8),
9490           UINT32_C(0x00112AFF), UINT32_C(0x0004D6DD), UINT32_C(0x0037A903),
9491           UINT32_C(0x00211DC3), UINT32_C(0x0030C9D5), UINT32_C(0x003F5472),
9492           UINT32_C(0x00198593), UINT32_C(0x000093E8), UINT32_C(0x001F8BFF),
9493           UINT32_C(0x0000C9FF), UINT32_C(0x003D63D2), UINT32_C(0x00003D23),
9494           UINT32_C(0x00153CAB), UINT32_C(0x003CA8E7), UINT32_C(0x000F7F9C),
9495           UINT32_C(0x0017381E), UINT32_C(0x003B2121), UINT32_C(0x0006A36E),
9496           UINT32_C(0x0020DF0D), UINT32_C(0x002DCC34)},
9497          {UINT32_C(0x001DDE59), UINT32_C(0x00100B9E), UINT32_C(0x001387EC),
9498           UINT32_C(0x001F5F47), UINT32_C(0x0037E7AF), UINT32_C(0x00193274),
9499           UINT32_C(0x002F43DE), UINT32_C(0x0018E845), UINT32_C(0x002C7EEB),
9500           UINT32_C(0x0031E7AD), UINT32_C(0x0003754D), UINT32_C(0x00107B6F),
9501           UINT32_C(0x0006C7A7), UINT32_C(0x002EFA28), UINT32_C(0x00230679),
9502           UINT32_C(0x003BA29A), UINT32_C(0x003EB83E), UINT32_C(0x000E3477),
9503           UINT32_C(0x00312658), UINT32_C(0x006C10E6), UINT32_C(0x00372B67),
9504           UINT32_C(0x000F6596), UINT32_C(0x00380597)}},
9505         {{UINT32_C(0x00555AFE), UINT32_C(0x000C7849), UINT32_C(0x00042F9D),
9506           UINT32_C(0x0007EDFA), UINT32_C(0x000C752B), UINT32_C(0x00137CA0),
9507           UINT32_C(0x002A9FBE), UINT32_C(0x00565768), UINT32_C(0x00015078),
9508           UINT32_C(0x0037865E), UINT32_C(0x0022585A), UINT32_C(0x005C7329),
9509           UINT32_C(0x00230050), UINT32_C(0x002EAD2B), UINT32_C(0x001FFAB6),
9510           UINT32_C(0x007012D8), UINT32_C(0x00118E18), UINT32_C(0x0031CBE8),
9511           UINT32_C(0x0034B659), UINT32_C(0x000C9258), UINT32_C(0x00123325),
9512           UINT32_C(0x001F45F2), UINT32_C(0x002B0B5E)},
9513          {UINT32_C(0x0063E131), UINT32_C(0x002CEABB), UINT32_C(0x0003CF06),
9514           UINT32_C(0x005C2801), UINT32_C(0x0014448A), UINT32_C(0x001F4570),
9515           UINT32_C(0x001DE032), UINT32_C(0x007965E9), UINT32_C(0x001C2619),
9516           UINT32_C(0x001A84C4), UINT32_C(0x003CA51E), UINT32_C(0x005F8927),
9517           UINT32_C(0x001ED00E), UINT32_C(0x0018ABCE), UINT32_C(0x00282492),
9518           UINT32_C(0x002A4526), UINT32_C(0x001D6653), UINT32_C(0x000D9615),
9519           UINT32_C(0x0011E6F0), UINT32_C(0x00671D54), UINT32_C(0x00340830),
9520           UINT32_C(0x001EF0D7), UINT32_C(0x002FBB7B)}},
9521         {{UINT32_C(0x00348880), UINT32_C(0x0032B440), UINT32_C(0x003867FD),
9522           UINT32_C(0x0041325C), UINT32_C(0x000CDBC2), UINT32_C(0x00065444),
9523           UINT32_C(0x0028F475), UINT32_C(0x001DA4B4), UINT32_C(0x00109841),
9524           UINT32_C(0x003B0866), UINT32_C(0x001E6A77), UINT32_C(0x005D249E),
9525           UINT32_C(0x0039C59B), UINT32_C(0x003A6F13), UINT32_C(0x0038A7E4),
9526           UINT32_C(0x005AE286), UINT32_C(0x002F9473), UINT32_C(0x00023261),
9527           UINT32_C(0x003A0DB2), UINT32_C(0x001E7F01), UINT32_C(0x0036BF40),
9528           UINT32_C(0x000E2AEC), UINT32_C(0x000C8DE1)},
9529          {UINT32_C(0x0053791C), UINT32_C(0x0025ADBE), UINT32_C(0x001DF305),
9530           UINT32_C(0x005CB9A7), UINT32_C(0x002A8658), UINT32_C(0x00101F47),
9531           UINT32_C(0x00329A71), UINT32_C(0x006E7F78), UINT32_C(0x003CB686),
9532           UINT32_C(0x002818C0), UINT32_C(0x0013DEA8), UINT32_C(0x0001AD5E),
9533           UINT32_C(0x002F79EF), UINT32_C(0x002D66C0), UINT32_C(0x001DABD2),
9534           UINT32_C(0x00602B71), UINT32_C(0x002903C7), UINT32_C(0x00385466),
9535           UINT32_C(0x001CDB64), UINT32_C(0x0075CE9A), UINT32_C(0x002430BD),
9536           UINT32_C(0x00176946), UINT32_C(0x000E2BC5)}},
9537         {{UINT32_C(0x007C9263), UINT32_C(0x002D6DC4), UINT32_C(0x003D3ACD),
9538           UINT32_C(0x003EBF76), UINT32_C(0x003E1EFB), UINT32_C(0x002E4716),
9539           UINT32_C(0x000F0DD6), UINT32_C(0x003B4748), UINT32_C(0x00073A35),
9540           UINT32_C(0x003EB153), UINT32_C(0x003DBAE5), UINT32_C(0x00091752),
9541           UINT32_C(0x00152A69), UINT32_C(0x003A6B6D), UINT32_C(0x00190CE0),
9542           UINT32_C(0x000C4F96), UINT32_C(0x002AEE5B), UINT32_C(0x002D6E94),
9543           UINT32_C(0x00298B92), UINT32_C(0x002FC509), UINT32_C(0x000EA268),
9544           UINT32_C(0x000701E4), UINT32_C(0x003CBD22)},
9545          {UINT32_C(0x0068BB5F), UINT32_C(0x003E426A), UINT32_C(0x000ABA98),
9546           UINT32_C(0x0063696E), UINT32_C(0x000CA3AE), UINT32_C(0x0030D3D9),
9547           UINT32_C(0x000E9E5C), UINT32_C(0x0046B796), UINT32_C(0x00098D02),
9548           UINT32_C(0x001C097A), UINT32_C(0x00322587), UINT32_C(0x004192A0),
9549           UINT32_C(0x00117CF5), UINT32_C(0x0019B330), UINT32_C(0x001C614E),
9550           UINT32_C(0x007DC495), UINT32_C(0x0010F1B4), UINT32_C(0x00303802),
9551           UINT32_C(0x0039F211), UINT32_C(0x00330A82), UINT32_C(0x002DD8DA),
9552           UINT32_C(0x002D36F2), UINT32_C(0x00017BC2)}},
9553         {{UINT32_C(0x0049325F), UINT32_C(0x003DB33B), UINT32_C(0x0029EBF5),
9554           UINT32_C(0x001C7997), UINT32_C(0x0033F6E9), UINT32_C(0x0030C1AD),
9555           UINT32_C(0x00361DDF), UINT32_C(0x0034088E), UINT32_C(0x002A26DB),
9556           UINT32_C(0x00050A8F), UINT32_C(0x002D5CB6), UINT32_C(0x002B3ACD),
9557           UINT32_C(0x002F102C), UINT32_C(0x001D8F3E), UINT32_C(0x0036E06F),
9558           UINT32_C(0x005F6B74), UINT32_C(0x0003DC5F), UINT32_C(0x003135D7),
9559           UINT32_C(0x0038E39F), UINT32_C(0x007B5A1E), UINT32_C(0x000355D0),
9560           UINT32_C(0x0016256E), UINT32_C(0x00091FAA)},
9561          {UINT32_C(0x004EEA23), UINT32_C(0x002F50B1), UINT32_C(0x001CBFB6),
9562           UINT32_C(0x0077CA4A), UINT32_C(0x002E434E), UINT32_C(0x003F8B6D),
9563           UINT32_C(0x0033265D), UINT32_C(0x006DC04A), UINT32_C(0x0017B7FE),
9564           UINT32_C(0x00156470), UINT32_C(0x001C0AB3), UINT32_C(0x002B82A3),
9565           UINT32_C(0x0025ED15), UINT32_C(0x00345415), UINT32_C(0x00006AE3),
9566           UINT32_C(0x006A18D6), UINT32_C(0x000651B4), UINT32_C(0x00324AF0),
9567           UINT32_C(0x0019FD45), UINT32_C(0x00756504), UINT32_C(0x000D0EB8),
9568           UINT32_C(0x001080DF), UINT32_C(0x00117135)}},
9569         {{UINT32_C(0x0002201B), UINT32_C(0x002573D3), UINT32_C(0x002B796D),
9570           UINT32_C(0x000F77C6), UINT32_C(0x001FA05B), UINT32_C(0x0004EA6D),
9571           UINT32_C(0x003790D1), UINT32_C(0x004517CB), UINT32_C(0x003D97B6),
9572           UINT32_C(0x0015B191), UINT32_C(0x00311E57), UINT32_C(0x0037CE58),
9573           UINT32_C(0x00151409), UINT32_C(0x000D6BCF), UINT32_C(0x000C5CA5),
9574           UINT32_C(0x0063737A), UINT32_C(0x00299B77), UINT32_C(0x000C37E1),
9575           UINT32_C(0x000F27AA), UINT32_C(0x0057C9C2), UINT32_C(0x0030EDD0),
9576           UINT32_C(0x003C12B9), UINT32_C(0x003AE308)},
9577          {UINT32_C(0x00154AEB), UINT32_C(0x0008F6CC), UINT32_C(0x001668D8),
9578           UINT32_C(0x004663DD), UINT32_C(0x000D8D93), UINT32_C(0x001CE5F0),
9579           UINT32_C(0x0021BF83), UINT32_C(0x006BAE95), UINT32_C(0x002855B3),
9580           UINT32_C(0x00335B55), UINT32_C(0x001408AA), UINT32_C(0x0004E3E5),
9581           UINT32_C(0x0028E855), UINT32_C(0x0014E502), UINT32_C(0x0008E67D),
9582           UINT32_C(0x006EDAAA), UINT32_C(0x001D9F0F), UINT32_C(0x0009DC94),
9583           UINT32_C(0x003A18E2), UINT32_C(0x0007FA8E), UINT32_C(0x003E00BB),
9584           UINT32_C(0x002A56FF), UINT32_C(0x00038554)}},
9585         {{UINT32_C(0x007A0037), UINT32_C(0x003D491D), UINT32_C(0x003C391C),
9586           UINT32_C(0x006294C3), UINT32_C(0x00303F10), UINT32_C(0x0026A8E1),
9587           UINT32_C(0x0028D44A), UINT32_C(0x004CD241), UINT32_C(0x001AC12E),
9588           UINT32_C(0x0032802C), UINT32_C(0x0017518C), UINT32_C(0x004B7FF7),
9589           UINT32_C(0x00184785), UINT32_C(0x000C137F), UINT32_C(0x0020C5E6),
9590           UINT32_C(0x002E88CB), UINT32_C(0x00109C0D), UINT32_C(0x003AF23C),
9591           UINT32_C(0x0037A943), UINT32_C(0x00209953), UINT32_C(0x0015B4E0),
9592           UINT32_C(0x00069845), UINT32_C(0x00093EA8)},
9593          {UINT32_C(0x0004A991), UINT32_C(0x003F0551), UINT32_C(0x000D6C31),
9594           UINT32_C(0x006F47D6), UINT32_C(0x00007E9B), UINT32_C(0x0027E38C),
9595           UINT32_C(0x0033BB37), UINT32_C(0x0013496D), UINT32_C(0x001A3F2A),
9596           UINT32_C(0x0014FCBA), UINT32_C(0x002722F6), UINT32_C(0x005676F1),
9597           UINT32_C(0x00213E52), UINT32_C(0x003DF1C7), UINT32_C(0x00228B30),
9598           UINT32_C(0x006856C0), UINT32_C(0x0022A73D), UINT32_C(0x0000B650),
9599           UINT32_C(0x000EABEB), UINT32_C(0x00714726), UINT32_C(0x00128875),
9600           UINT32_C(0x000EB41C), UINT32_C(0x0018CA4B)}},
9601         {{UINT32_C(0x007BD9EC), UINT32_C(0x001763E0), UINT32_C(0x003A0DDC),
9602           UINT32_C(0x00731C43), UINT32_C(0x00293989), UINT32_C(0x00347EFA),
9603           UINT32_C(0x00115B21), UINT32_C(0x003B45B4), UINT32_C(0x000DA37F),
9604           UINT32_C(0x002C87D5), UINT32_C(0x001C53C2), UINT32_C(0x007822F8),
9605           UINT32_C(0x0008496E), UINT32_C(0x003D3CB7), UINT32_C(0x0008A383),
9606           UINT32_C(0x00735A84), UINT32_C(0x000876BD), UINT32_C(0x00141FF0),
9607           UINT32_C(0x003567B3), UINT32_C(0x00785465), UINT32_C(0x0030D346),
9608           UINT32_C(0x0032C983), UINT32_C(0x0016542B)},
9609          {UINT32_C(0x00175998), UINT32_C(0x00105962), UINT32_C(0x0027690D),
9610           UINT32_C(0x0053CEA1), UINT32_C(0x0027FE4A), UINT32_C(0x000377CE),
9611           UINT32_C(0x00029F12), UINT32_C(0x00791342), UINT32_C(0x001CD5D3),
9612           UINT32_C(0x0024804D), UINT32_C(0x00318CBD), UINT32_C(0x000AC20C),
9613           UINT32_C(0x002261A2), UINT32_C(0x00017C07), UINT32_C(0x0006AED6),
9614           UINT32_C(0x0001AE5E), UINT32_C(0x00230EA0), UINT32_C(0x00390D91),
9615           UINT32_C(0x0009C7FB), UINT32_C(0x002F102A), UINT32_C(0x00291350),
9616           UINT32_C(0x003DA578), UINT32_C(0x0013E6DE)}},
9617     },
9618     {
9619         {{UINT32_C(0x005C8DD6), UINT32_C(0x002A3738), UINT32_C(0x00365D8C),
9620           UINT32_C(0x0063DB9C), UINT32_C(0x00113081), UINT32_C(0x002F34E7),
9621           UINT32_C(0x003E646D), UINT32_C(0x0019B42D), UINT32_C(0x0006CC4B),
9622           UINT32_C(0x0037967A), UINT32_C(0x0037B63A), UINT32_C(0x00346973),
9623           UINT32_C(0x00175BB7), UINT32_C(0x001BAEA5), UINT32_C(0x002D90D6),
9624           UINT32_C(0x00235EC5), UINT32_C(0x0022B7D3), UINT32_C(0x0006C0A7),
9625           UINT32_C(0x000D9373), UINT32_C(0x003362B4), UINT32_C(0x00167362),
9626           UINT32_C(0x00228FA8), UINT32_C(0x002DC7CC)},
9627          {UINT32_C(0x00772F9B), UINT32_C(0x00383B30), UINT32_C(0x001FE31B),
9628           UINT32_C(0x0039283D), UINT32_C(0x0030E99D), UINT32_C(0x0019398C),
9629           UINT32_C(0x000E05D7), UINT32_C(0x001CB0B3), UINT32_C(0x0031A3E1),
9630           UINT32_C(0x00335E57), UINT32_C(0x003D185F), UINT32_C(0x004F30A8),
9631           UINT32_C(0x002CC2DA), UINT32_C(0x003CB4EE), UINT32_C(0x000D7F61),
9632           UINT32_C(0x006B8EDA), UINT32_C(0x0020C99D), UINT32_C(0x00342D58),
9633           UINT32_C(0x003BCF21), UINT32_C(0x00043EE8), UINT32_C(0x003937C7),
9634           UINT32_C(0x002B2687), UINT32_C(0x003099B7)}},
9635         {{UINT32_C(0x006F3863), UINT32_C(0x00216888), UINT32_C(0x00117F80),
9636           UINT32_C(0x003AECB0), UINT32_C(0x003CB3C3), UINT32_C(0x0009172C),
9637           UINT32_C(0x00351EE1), UINT32_C(0x000AD459), UINT32_C(0x00342449),
9638           UINT32_C(0x000A95A1), UINT32_C(0x00362F69), UINT32_C(0x0044683C),
9639           UINT32_C(0x0012100A), UINT32_C(0x000038C6), UINT32_C(0x0003DA8C),
9640           UINT32_C(0x004920F7), UINT32_C(0x001F5E72), UINT32_C(0x003F8B01),
9641           UINT32_C(0x001B2E28), UINT32_C(0x007828AE), UINT32_C(0x003B1AA3),
9642           UINT32_C(0x002304AF), UINT32_C(0x002983E5)},
9643          {UINT32_C(0x0059F3AD), UINT32_C(0x0005EBDB), UINT32_C(0x0038F715),
9644           UINT32_C(0x007427DF), UINT32_C(0x0035EE7F), UINT32_C(0x001A4B0D),
9645           UINT32_C(0x0014E6C7), UINT32_C(0x00699A32), UINT32_C(0x00015674),
9646           UINT32_C(0x003DC67D), UINT32_C(0x0001CDA8), UINT32_C(0x003C45B2),
9647           UINT32_C(0x001BE065), UINT32_C(0x000C2772), UINT32_C(0x002184E2),
9648           UINT32_C(0x005C0469), UINT32_C(0x0024F0B3), UINT32_C(0x002374A4),
9649           UINT32_C(0x0031DE85), UINT32_C(0x006B53DE), UINT32_C(0x000F651C),
9650           UINT32_C(0x003071EB), UINT32_C(0x0029A433)}},
9651         {{UINT32_C(0x0030A82F), UINT32_C(0x000EF962), UINT32_C(0x00227761),
9652           UINT32_C(0x006D7F9E), UINT32_C(0x000081BE), UINT32_C(0x000FEE69),
9653           UINT32_C(0x000752C8), UINT32_C(0x00748DEE), UINT32_C(0x00387116),
9654           UINT32_C(0x00287C41), UINT32_C(0x00027434), UINT32_C(0x00664A85),
9655           UINT32_C(0x001D3DE1), UINT32_C(0x003D565F), UINT32_C(0x003B7ED9),
9656           UINT32_C(0x0065C3BB), UINT32_C(0x0023180A), UINT32_C(0x000E41D1),
9657           UINT32_C(0x001016CD), UINT32_C(0x0065F0C5), UINT32_C(0x0017A834),
9658           UINT32_C(0x0000A4AB), UINT32_C(0x001FC477)},
9659          {UINT32_C(0x004855D4), UINT32_C(0x001D815B), UINT32_C(0x00366682),
9660           UINT32_C(0x004FEE42), UINT32_C(0x001DD612), UINT32_C(0x0025BA93),
9661           UINT32_C(0x000E1804), UINT32_C(0x0007B46D), UINT32_C(0x00079E19),
9662           UINT32_C(0x00263779), UINT32_C(0x001FDFA2), UINT32_C(0x0078741F),
9663           UINT32_C(0x0037B69E), UINT32_C(0x0018E0A2), UINT32_C(0x0037F5D9),
9664           UINT32_C(0x000C71E4), UINT32_C(0x001F6109), UINT32_C(0x0002A965),
9665           UINT32_C(0x00358A62), UINT32_C(0x00790CBB), UINT32_C(0x001FC664),
9666           UINT32_C(0x00027F06), UINT32_C(0x0026A40A)}},
9667         {{UINT32_C(0x0060807F), UINT32_C(0x003DF3AE), UINT32_C(0x000BE26F),
9668           UINT32_C(0x005110E1), UINT32_C(0x003B1A48), UINT32_C(0x00326EEB),
9669           UINT32_C(0x001E337A), UINT32_C(0x0030A675), UINT32_C(0x003F5F8B),
9670           UINT32_C(0x000CD0BA), UINT32_C(0x002297FB), UINT32_C(0x000379BD),
9671           UINT32_C(0x0015C430), UINT32_C(0x003FE28A), UINT32_C(0x00280CE2),
9672           UINT32_C(0x0010A09A), UINT32_C(0x000BB43D), UINT32_C(0x003BF3E8),
9673           UINT32_C(0x000D2A25), UINT32_C(0x00553C3D), UINT32_C(0x003A4814),
9674           UINT32_C(0x0023D406), UINT32_C(0x00130434)},
9675          {UINT32_C(0x00012725), UINT32_C(0x00034675), UINT32_C(0x0030625E),
9676           UINT32_C(0x0068204C), UINT32_C(0x00007FF0), UINT32_C(0x000353D6),
9677           UINT32_C(0x00374D41), UINT32_C(0x002B0AEC), UINT32_C(0x002D4C90),
9678           UINT32_C(0x0023B516), UINT32_C(0x003D5FE1), UINT32_C(0x001BF1AF),
9679           UINT32_C(0x0026188F), UINT32_C(0x000277E9), UINT32_C(0x0009EDC0),
9680           UINT32_C(0x00419F60), UINT32_C(0x003B901E), UINT32_C(0x00036C9A),
9681           UINT32_C(0x001C2868), UINT32_C(0x0039BD67), UINT32_C(0x001E1FAC),
9682           UINT32_C(0x0018E5C8), UINT32_C(0x000D5B85)}},
9683         {{UINT32_C(0x000B4E46), UINT32_C(0x001C91BB), UINT32_C(0x000E149E),
9684           UINT32_C(0x000CF26B), UINT32_C(0x00239A61), UINT32_C(0x001413C1),
9685           UINT32_C(0x0039D982), UINT32_C(0x0031DC48), UINT32_C(0x000CB5E3),
9686           UINT32_C(0x00177633), UINT32_C(0x003594BF), UINT32_C(0x00220B88),
9687           UINT32_C(0x003EE0E1), UINT32_C(0x0001C29C), UINT32_C(0x00332288),
9688           UINT32_C(0x001AC903), UINT32_C(0x002EA788), UINT32_C(0x002CF324),
9689           UINT32_C(0x000A068A), UINT32_C(0x00192C4F), UINT32_C(0x003620B1),
9690           UINT32_C(0x003A15B7), UINT32_C(0x001846FF)},
9691          {UINT32_C(0x0037EA0F), UINT32_C(0x000E365F), UINT32_C(0x000AB7DB),
9692           UINT32_C(0x0073FC69), UINT32_C(0x0030E576), UINT32_C(0x001F51C5),
9693           UINT32_C(0x003E4C0F), UINT32_C(0x007734A2), UINT32_C(0x000B6D61),
9694           UINT32_C(0x0007F20A), UINT32_C(0x0016676C), UINT32_C(0x000742AB),
9695           UINT32_C(0x0024CACD), UINT32_C(0x00263F7C), UINT32_C(0x001FBB60),
9696           UINT32_C(0x005126DE), UINT32_C(0x001B0843), UINT32_C(0x0027E640),
9697           UINT32_C(0x002B6416), UINT32_C(0x000E461C), UINT32_C(0x0035712F),
9698           UINT32_C(0x00021FD4), UINT32_C(0x003DFB53)}},
9699         {{UINT32_C(0x0078AFC0), UINT32_C(0x00344524), UINT32_C(0x00032570),
9700           UINT32_C(0x005274D4), UINT32_C(0x001BE8C7), UINT32_C(0x0000F7FC),
9701           UINT32_C(0x003A3CD2), UINT32_C(0x00224B02), UINT32_C(0x003CB849),
9702           UINT32_C(0x00318F23), UINT32_C(0x000B31C5), UINT32_C(0x00172883),
9703           UINT32_C(0x000E290F), UINT32_C(0x00058FCA), UINT32_C(0x0029D5B9),
9704           UINT32_C(0x000EE887), UINT32_C(0x0008C23A), UINT32_C(0x000B4641),
9705           UINT32_C(0x0019F308), UINT32_C(0x00368406), UINT32_C(0x003235C5),
9706           UINT32_C(0x000F6048), UINT32_C(0x00334FC7)},
9707          {UINT32_C(0x00721229), UINT32_C(0x0028E47C), UINT32_C(0x0006F2DC),
9708           UINT32_C(0x006E7CFF), UINT32_C(0x00184C72), UINT32_C(0x003AF41E),
9709           UINT32_C(0x000EC9A0), UINT32_C(0x0008E682), UINT32_C(0x00294028),
9710           UINT32_C(0x0010CBE0), UINT32_C(0x00325E8D), UINT32_C(0x00229C6E),
9711           UINT32_C(0x0007AE13), UINT32_C(0x0012B92A), UINT32_C(0x001A6F8B),
9712           UINT32_C(0x00445E9E), UINT32_C(0x0038E62B), UINT32_C(0x000CCE4E),
9713           UINT32_C(0x0016D227), UINT32_C(0x005AEC2B), UINT32_C(0x002CB9C3),
9714           UINT32_C(0x000E9EE2), UINT32_C(0x00151064)}},
9715         {{UINT32_C(0x00219F11), UINT32_C(0x000EEE99), UINT32_C(0x000F0E81),
9716           UINT32_C(0x0014202D), UINT32_C(0x0017D47D), UINT32_C(0x0013E996),
9717           UINT32_C(0x001FC4D3), UINT32_C(0x007153BF), UINT32_C(0x003B0646),
9718           UINT32_C(0x003CCDA8), UINT32_C(0x002DB80C), UINT32_C(0x005A6567),
9719           UINT32_C(0x00301938), UINT32_C(0x000B2A1D), UINT32_C(0x002C1CD4),
9720           UINT32_C(0x0036D153), UINT32_C(0x00002DE7), UINT32_C(0x001C0718),
9721           UINT32_C(0x001398D4), UINT32_C(0x001C18B0), UINT32_C(0x000531C6),
9722           UINT32_C(0x00270891), UINT32_C(0x001D12C0)},
9723          {UINT32_C(0x006BF552), UINT32_C(0x00379C8C), UINT32_C(0x00124703),
9724           UINT32_C(0x001685D6), UINT32_C(0x000B4D76), UINT32_C(0x00354333),
9725           UINT32_C(0x003FD16E), UINT32_C(0x0078F567), UINT32_C(0x00228610),
9726           UINT32_C(0x002410D3), UINT32_C(0x0037EE2A), UINT32_C(0x002FF2A5),
9727           UINT32_C(0x001EA65B), UINT32_C(0x003FE56C), UINT32_C(0x00086D94),
9728           UINT32_C(0x0016F8D9), UINT32_C(0x00253D0C), UINT32_C(0x00110729),
9729           UINT32_C(0x00251056), UINT32_C(0x00771AF9), UINT32_C(0x00330BB2),
9730           UINT32_C(0x0030D723), UINT32_C(0x0010B52C)}},
9731         {{UINT32_C(0x0059EEDD), UINT32_C(0x00224DDB), UINT32_C(0x00224843),
9732           UINT32_C(0x00062307), UINT32_C(0x001C385D), UINT32_C(0x00214646),
9733           UINT32_C(0x002E9EF9), UINT32_C(0x00069FC2), UINT32_C(0x0034E86C),
9734           UINT32_C(0x002DE7F8), UINT32_C(0x0011547F), UINT32_C(0x00592112),
9735           UINT32_C(0x003BA86D), UINT32_C(0x003E5946), UINT32_C(0x001999D6),
9736           UINT32_C(0x0019972E), UINT32_C(0x000BEC90), UINT32_C(0x001A2575),
9737           UINT32_C(0x000C3FB3), UINT32_C(0x0016B2B8), UINT32_C(0x000F91C3),
9738           UINT32_C(0x003BE22B), UINT32_C(0x00259437)},
9739          {UINT32_C(0x00511BD4), UINT32_C(0x00114679), UINT32_C(0x003320B0),
9740           UINT32_C(0x006912DE), UINT32_C(0x00209607), UINT32_C(0x0010EA82),
9741           UINT32_C(0x001756FD), UINT32_C(0x0067C9A7), UINT32_C(0x00386F00),
9742           UINT32_C(0x0019C5A2), UINT32_C(0x000C1F54), UINT32_C(0x0060CBC7),
9743           UINT32_C(0x001DA7B9), UINT32_C(0x00063F18), UINT32_C(0x003D8253),
9744           UINT32_C(0x006757E9), UINT32_C(0x001F28E4), UINT32_C(0x003F4512),
9745           UINT32_C(0x0015BA1B), UINT32_C(0x00296BBE), UINT32_C(0x001E7448),
9746           UINT32_C(0x0027173C), UINT32_C(0x00385C41)}},
9747         {{UINT32_C(0x001A30EE), UINT32_C(0x003F8DAD), UINT32_C(0x000A157B),
9748           UINT32_C(0x002E76B6), UINT32_C(0x0003B33B), UINT32_C(0x00067B4F),
9749           UINT32_C(0x00338572), UINT32_C(0x004A7886), UINT32_C(0x000AF814),
9750           UINT32_C(0x00231F5B), UINT32_C(0x003A7866), UINT32_C(0x001BC9D8),
9751           UINT32_C(0x002EC718), UINT32_C(0x000F7210), UINT32_C(0x0038A200),
9752           UINT32_C(0x0024BD8B), UINT32_C(0x0025403D), UINT32_C(0x002338A0),
9753           UINT32_C(0x00197FC8), UINT32_C(0x007EFFC4), UINT32_C(0x002C8ED2),
9754           UINT32_C(0x002F359C), UINT32_C(0x0007199C)},
9755          {UINT32_C(0x003AA840), UINT32_C(0x001FEBA5), UINT32_C(0x00204035),
9756           UINT32_C(0x001437DE), UINT32_C(0x0030877E), UINT32_C(0x001DC9D8),
9757           UINT32_C(0x0022F529), UINT32_C(0x004AA308), UINT32_C(0x0008CF16),
9758           UINT32_C(0x00227F26), UINT32_C(0x0030EA93), UINT32_C(0x00444D20),
9759           UINT32_C(0x000FC049), UINT32_C(0x0025FECC), UINT32_C(0x00366A3B),
9760           UINT32_C(0x0075F2C6), UINT32_C(0x002D58DE), UINT32_C(0x00037A47),
9761           UINT32_C(0x001143E7), UINT32_C(0x0066F889), UINT32_C(0x001AA585),
9762           UINT32_C(0x0008637C), UINT32_C(0x00285D24)}},
9763         {{UINT32_C(0x001684FD), UINT32_C(0x0026202E), UINT32_C(0x00229298),
9764           UINT32_C(0x0038BA17), UINT32_C(0x001143E4), UINT32_C(0x0004C67B),
9765           UINT32_C(0x0009A1D3), UINT32_C(0x00359003), UINT32_C(0x0000CF20),
9766           UINT32_C(0x003C8E67), UINT32_C(0x0025DDF6), UINT32_C(0x00167020),
9767           UINT32_C(0x000C3320), UINT32_C(0x0032FD4F), UINT32_C(0x001D4DDD),
9768           UINT32_C(0x002ABE07), UINT32_C(0x0015D694), UINT32_C(0x002025E4),
9769           UINT32_C(0x0024B490), UINT32_C(0x00237C45), UINT32_C(0x000F2232),
9770           UINT32_C(0x00172623), UINT32_C(0x003F2420)},
9771          {UINT32_C(0x0031C43A), UINT32_C(0x002504F9), UINT32_C(0x002A5346),
9772           UINT32_C(0x00085709), UINT32_C(0x00181464), UINT32_C(0x0016AE98),
9773           UINT32_C(0x0005937D), UINT32_C(0x007E227E), UINT32_C(0x0021E344),
9774           UINT32_C(0x002D37F2), UINT32_C(0x003BABA8), UINT32_C(0x0076BA1E),
9775           UINT32_C(0x001E9354), UINT32_C(0x001FB1CD), UINT32_C(0x002FA365),
9776           UINT32_C(0x0037F2A0), UINT32_C(0x00150FF4), UINT32_C(0x0001D5DC),
9777           UINT32_C(0x003D537E), UINT32_C(0x003F0F28), UINT32_C(0x002C7BEA),
9778           UINT32_C(0x003C8613), UINT32_C(0x0032181B)}},
9779         {{UINT32_C(0x004FDBFF), UINT32_C(0x00279110), UINT32_C(0x0014218E),
9780           UINT32_C(0x006FF570), UINT32_C(0x000BEE6D), UINT32_C(0x001AC4BF),
9781           UINT32_C(0x00168284), UINT32_C(0x00204FD9), UINT32_C(0x0009E49A),
9782           UINT32_C(0x00375F6C), UINT32_C(0x00188591), UINT32_C(0x00711953),
9783           UINT32_C(0x003F4432), UINT32_C(0x00196529), UINT32_C(0x00394538),
9784           UINT32_C(0x0018F2F6), UINT32_C(0x002CA7B0), UINT32_C(0x00013757),
9785           UINT32_C(0x001F2763), UINT32_C(0x001F675A), UINT32_C(0x002051A1),
9786           UINT32_C(0x003E27EB), UINT32_C(0x001862D5)},
9787          {UINT32_C(0x00762CA4), UINT32_C(0x0008C476), UINT32_C(0x00324E43),
9788           UINT32_C(0x002A5BED), UINT32_C(0x002FCB16), UINT32_C(0x003A2EC2),
9789           UINT32_C(0x000DAC89), UINT32_C(0x001B1EA8), UINT32_C(0x00270A0C),
9790           UINT32_C(0x000F92C4), UINT32_C(0x00137059), UINT32_C(0x0002C67B),
9791           UINT32_C(0x001DE35A), UINT32_C(0x0003AEB0), UINT32_C(0x0032086D),
9792           UINT32_C(0x00622727), UINT32_C(0x003663F6), UINT32_C(0x00143F44),
9793           UINT32_C(0x0007E1A6), UINT32_C(0x0052B971), UINT32_C(0x002A4520),
9794           UINT32_C(0x003B35C1), UINT32_C(0x000E5F13)}},
9795         {{UINT32_C(0x00377631), UINT32_C(0x00160066), UINT32_C(0x003F8625),
9796           UINT32_C(0x0008A975), UINT32_C(0x0011C7DC), UINT32_C(0x002AC5AE),
9797           UINT32_C(0x001D6AD4), UINT32_C(0x00457D6D), UINT32_C(0x000D9162),
9798           UINT32_C(0x0029BE2C), UINT32_C(0x0023E49C), UINT32_C(0x003CE982),
9799           UINT32_C(0x0029BD3F), UINT32_C(0x002FA98A), UINT32_C(0x000AAF8F),
9800           UINT32_C(0x0051BA4C), UINT32_C(0x000AAA3A), UINT32_C(0x00035AC4),
9801           UINT32_C(0x00326C9D), UINT32_C(0x0001BBF9), UINT32_C(0x00259EE8),
9802           UINT32_C(0x00363291), UINT32_C(0x00354D7C)},
9803          {UINT32_C(0x0004BACF), UINT32_C(0x00021298), UINT32_C(0x000BD9F4),
9804           UINT32_C(0x0043D1FD), UINT32_C(0x00144099), UINT32_C(0x0031DC66),
9805           UINT32_C(0x0038FF58), UINT32_C(0x001EDFDE), UINT32_C(0x000CDE37),
9806           UINT32_C(0x0011D4F2), UINT32_C(0x001830F3), UINT32_C(0x0066B396),
9807           UINT32_C(0x002B5740), UINT32_C(0x0000FE1B), UINT32_C(0x0018CA75),
9808           UINT32_C(0x000543A1), UINT32_C(0x0001F8BB), UINT32_C(0x003AD189),
9809           UINT32_C(0x002324CF), UINT32_C(0x004D2C11), UINT32_C(0x002F4CEB),
9810           UINT32_C(0x00158CE7), UINT32_C(0x000CC8E6)}},
9811         {{UINT32_C(0x0001F545), UINT32_C(0x000BAFC9), UINT32_C(0x00256984),
9812           UINT32_C(0x005BA1BD), UINT32_C(0x00186CC4), UINT32_C(0x00354258),
9813           UINT32_C(0x002C995A), UINT32_C(0x00634432), UINT32_C(0x001C8DFD),
9814           UINT32_C(0x0006A9F8), UINT32_C(0x003413FA), UINT32_C(0x00407583),
9815           UINT32_C(0x00364359), UINT32_C(0x00360343), UINT32_C(0x0004E81D),
9816           UINT32_C(0x0023B9E2), UINT32_C(0x00044AAC), UINT32_C(0x003E4F02),
9817           UINT32_C(0x000253E4), UINT32_C(0x004E1D95), UINT32_C(0x0008B230),
9818           UINT32_C(0x00045AB3), UINT32_C(0x00036815)},
9819          {UINT32_C(0x003912F5), UINT32_C(0x0038574B), UINT32_C(0x0004AD86),
9820           UINT32_C(0x00463316), UINT32_C(0x000037D8), UINT32_C(0x001023FC),
9821           UINT32_C(0x00031DE0), UINT32_C(0x007EC789), UINT32_C(0x000081EF),
9822           UINT32_C(0x002ABA70), UINT32_C(0x00355BFB), UINT32_C(0x00306CB6),
9823           UINT32_C(0x00146C52), UINT32_C(0x000D5AD0), UINT32_C(0x003681F1),
9824           UINT32_C(0x0063A37A), UINT32_C(0x001B646E), UINT32_C(0x000A931F),
9825           UINT32_C(0x0023DD86), UINT32_C(0x006F9AFA), UINT32_C(0x0008A0BB),
9826           UINT32_C(0x0011BD6F), UINT32_C(0x00169519)}},
9827         {{UINT32_C(0x00183D98), UINT32_C(0x003953F2), UINT32_C(0x00003F5C),
9828           UINT32_C(0x001D61CC), UINT32_C(0x0029E894), UINT32_C(0x0008FD62),
9829           UINT32_C(0x00124F02), UINT32_C(0x005D5510), UINT32_C(0x002CBB48),
9830           UINT32_C(0x0027C8EC), UINT32_C(0x002DA8A4), UINT32_C(0x00506092),
9831           UINT32_C(0x000D2ECA), UINT32_C(0x00080CB3), UINT32_C(0x00370B1F),
9832           UINT32_C(0x00264230), UINT32_C(0x00254B5D), UINT32_C(0x0030D35B),
9833           UINT32_C(0x00237E95), UINT32_C(0x003D3219), UINT32_C(0x000F1EE0),
9834           UINT32_C(0x0016F356), UINT32_C(0x000433B4)},
9835          {UINT32_C(0x002EDDFD), UINT32_C(0x0028836F), UINT32_C(0x0004B480),
9836           UINT32_C(0x00268786), UINT32_C(0x002F536C), UINT32_C(0x002AF788),
9837           UINT32_C(0x003B32BC), UINT32_C(0x003B16D5), UINT32_C(0x002C983E),
9838           UINT32_C(0x00009C26), UINT32_C(0x00267D08), UINT32_C(0x0020E60C),
9839           UINT32_C(0x000ECF45), UINT32_C(0x00278142), UINT32_C(0x001746F3),
9840           UINT32_C(0x0054A790), UINT32_C(0x0035C6AA), UINT32_C(0x00272DAC),
9841           UINT32_C(0x002BA52D), UINT32_C(0x0038B5A4), UINT32_C(0x003725B3),
9842           UINT32_C(0x003565DC), UINT32_C(0x001FF559)}},
9843         {{UINT32_C(0x0065D9D6), UINT32_C(0x00344FC2), UINT32_C(0x0000870B),
9844           UINT32_C(0x00699985), UINT32_C(0x002A5C08), UINT32_C(0x002D5249),
9845           UINT32_C(0x002CB5FE), UINT32_C(0x007C94CD), UINT32_C(0x001208B8),
9846           UINT32_C(0x00034BB9), UINT32_C(0x000F21F9), UINT32_C(0x0010B487),
9847           UINT32_C(0x001D773A), UINT32_C(0x0037E3B0), UINT32_C(0x002176D0),
9848           UINT32_C(0x0052166E), UINT32_C(0x002F70E0), UINT32_C(0x001BED82),
9849           UINT32_C(0x00286120), UINT32_C(0x007331ED), UINT32_C(0x001507E2),
9850           UINT32_C(0x003FD862), UINT32_C(0x000A5BC5)},
9851          {UINT32_C(0x00763783), UINT32_C(0x0011EC7B), UINT32_C(0x0006ECDB),
9852           UINT32_C(0x00596D37), UINT32_C(0x002D6D59), UINT32_C(0x001FB1F1),
9853           UINT32_C(0x0010DD1F), UINT32_C(0x003F277E), UINT32_C(0x00091B7A),
9854           UINT32_C(0x003FFE47), UINT32_C(0x0003D49D), UINT32_C(0x0071AF1E),
9855           UINT32_C(0x00173FA2), UINT32_C(0x001B76EC), UINT32_C(0x001D5248),
9856           UINT32_C(0x0059BE83), UINT32_C(0x003F4D6A), UINT32_C(0x001CE0D3),
9857           UINT32_C(0x003FDBAF), UINT32_C(0x00554CAA), UINT32_C(0x002FAF76),
9858           UINT32_C(0x0004DD7D), UINT32_C(0x0025BFE6)}},
9859         {{UINT32_C(0x0078E507), UINT32_C(0x003B0516), UINT32_C(0x00239513),
9860           UINT32_C(0x0026B945), UINT32_C(0x002F7EA4), UINT32_C(0x00258DAA),
9861           UINT32_C(0x002CA54E), UINT32_C(0x0038F70D), UINT32_C(0x0000EA33),
9862           UINT32_C(0x002CC019), UINT32_C(0x00322C57), UINT32_C(0x007E5F7D),
9863           UINT32_C(0x001BD5E1), UINT32_C(0x002300D9), UINT32_C(0x000A82FB),
9864           UINT32_C(0x007B959B), UINT32_C(0x00200D1E), UINT32_C(0x001F252C),
9865           UINT32_C(0x0021984A), UINT32_C(0x0015C036), UINT32_C(0x0016A72F),
9866           UINT32_C(0x00003E13), UINT32_C(0x0015AA73)},
9867          {UINT32_C(0x007C9D6A), UINT32_C(0x003E1441), UINT32_C(0x0011A00F),
9868           UINT32_C(0x0079A490), UINT32_C(0x0012D007), UINT32_C(0x003C8625),
9869           UINT32_C(0x001E5649), UINT32_C(0x004491D7), UINT32_C(0x00076136),
9870           UINT32_C(0x003E7528), UINT32_C(0x00353C0B), UINT32_C(0x0008E4BD),
9871           UINT32_C(0x003422E8), UINT32_C(0x00338BFD), UINT32_C(0x0027F2D6),
9872           UINT32_C(0x00772362), UINT32_C(0x00359B33), UINT32_C(0x003A501D),
9873           UINT32_C(0x00154AFF), UINT32_C(0x0049526D), UINT32_C(0x002761DE),
9874           UINT32_C(0x00309735), UINT32_C(0x00060B95)}},
9875     },
9876     {
9877         {{UINT32_C(0x00523B9F), UINT32_C(0x001A6BE6), UINT32_C(0x00036EDD),
9878           UINT32_C(0x0076AA2F), UINT32_C(0x003FD0E2), UINT32_C(0x00385A57),
9879           UINT32_C(0x00098667), UINT32_C(0x0013DD67), UINT32_C(0x0012B434),
9880           UINT32_C(0x00000973), UINT32_C(0x003CF995), UINT32_C(0x0045926B),
9881           UINT32_C(0x0002CF3D), UINT32_C(0x001B1027), UINT32_C(0x003876F6),
9882           UINT32_C(0x0039998A), UINT32_C(0x00398D3B), UINT32_C(0x000598D3),
9883           UINT32_C(0x0009E59F), UINT32_C(0x003DA91C), UINT32_C(0x0027F8FE),
9884           UINT32_C(0x001992EF), UINT32_C(0x001BD1E4)},
9885          {UINT32_C(0x005E09D8), UINT32_C(0x0027291C), UINT32_C(0x00042E2C),
9886           UINT32_C(0x005186A7), UINT32_C(0x00151430), UINT32_C(0x002A705A),
9887           UINT32_C(0x00312685), UINT32_C(0x001C5CD7), UINT32_C(0x002BC485),
9888           UINT32_C(0x0006B1B4), UINT32_C(0x003ED133), UINT32_C(0x006BA1BB),
9889           UINT32_C(0x0012B561), UINT32_C(0x001C6829), UINT32_C(0x0038F88D),
9890           UINT32_C(0x000FAFDF), UINT32_C(0x003A8F9C), UINT32_C(0x003B8278),
9891           UINT32_C(0x00075330), UINT32_C(0x00723D70), UINT32_C(0x0013971C),
9892           UINT32_C(0x0002A3A0), UINT32_C(0x0032D46E)}},
9893         {{UINT32_C(0x004A84E3), UINT32_C(0x000F993B), UINT32_C(0x0038E50F),
9894           UINT32_C(0x006F9D6C), UINT32_C(0x00222DDA), UINT32_C(0x00201C17),
9895           UINT32_C(0x003D690B), UINT32_C(0x00685E56), UINT32_C(0x003AE821),
9896           UINT32_C(0x00160832), UINT32_C(0x00267374), UINT32_C(0x0014A440),
9897           UINT32_C(0x00286466), UINT32_C(0x0037B81C), UINT32_C(0x0034FB56),
9898           UINT32_C(0x000A60A9), UINT32_C(0x00361F71), UINT32_C(0x002768E5),
9899           UINT32_C(0x002D9ADF), UINT32_C(0x00351ED3), UINT32_C(0x0026B155),
9900           UINT32_C(0x002ACF8B), UINT32_C(0x000CAB49)},
9901          {UINT32_C(0x002E7818), UINT32_C(0x00050DDB), UINT32_C(0x002F8281),
9902           UINT32_C(0x000426DB), UINT32_C(0x003BF6C0), UINT32_C(0x002F18B3),
9903           UINT32_C(0x000FDF15), UINT32_C(0x004326C8), UINT32_C(0x0034A233),
9904           UINT32_C(0x003F8BB5), UINT32_C(0x00252744), UINT32_C(0x005D0622),
9905           UINT32_C(0x000600E0), UINT32_C(0x000C538E), UINT32_C(0x002B9B96),
9906           UINT32_C(0x00240977), UINT32_C(0x00266E45), UINT32_C(0x000ED85F),
9907           UINT32_C(0x0016D56E), UINT32_C(0x005934A8), UINT32_C(0x000DE008),
9908           UINT32_C(0x000B7A70), UINT32_C(0x00333A6E)}},
9909         {{UINT32_C(0x0062AA91), UINT32_C(0x0004AD0D), UINT32_C(0x00290514),
9910           UINT32_C(0x0035EF4E), UINT32_C(0x003F0059), UINT32_C(0x0036F603),
9911           UINT32_C(0x001E8A95), UINT32_C(0x004E5E21), UINT32_C(0x003AAAD3),
9912           UINT32_C(0x001864B4), UINT32_C(0x00314695), UINT32_C(0x0061F315),
9913           UINT32_C(0x003E5320), UINT32_C(0x000A6A70), UINT32_C(0x00312DDA),
9914           UINT32_C(0x000CA432), UINT32_C(0x00089AF4), UINT32_C(0x0027EE81),
9915           UINT32_C(0x003314B2), UINT32_C(0x00569617), UINT32_C(0x00369C83),
9916           UINT32_C(0x00333762), UINT32_C(0x0004C25B)},
9917          {UINT32_C(0x0029163B), UINT32_C(0x0010F6C4), UINT32_C(0x003CFA87),
9918           UINT32_C(0x00413607), UINT32_C(0x0004D631), UINT32_C(0x0029CC9A),
9919           UINT32_C(0x0009B191), UINT32_C(0x0012E650), UINT32_C(0x0007576E),
9920           UINT32_C(0x002FAEF9), UINT32_C(0x001E71A7), UINT32_C(0x006D93A4),
9921           UINT32_C(0x00110BDB), UINT32_C(0x003C8A96), UINT32_C(0x000AB70A),
9922           UINT32_C(0x00161FF3), UINT32_C(0x00309EAC), UINT32_C(0x000887FB),
9923           UINT32_C(0x00199FC7), UINT32_C(0x007B0C04), UINT32_C(0x00030951),
9924           UINT32_C(0x00138445), UINT32_C(0x002C19E3)}},
9925         {{UINT32_C(0x001D9920), UINT32_C(0x0035A7F8), UINT32_C(0x0026F037),
9926           UINT32_C(0x00352EE6), UINT32_C(0x0036FF52), UINT32_C(0x000DA4B7),
9927           UINT32_C(0x000D5800), UINT32_C(0x0012D75B), UINT32_C(0x001E4378),
9928           UINT32_C(0x0006FB97), UINT32_C(0x003489D8), UINT32_C(0x007291B9),
9929           UINT32_C(0x002611FF), UINT32_C(0x0029220F), UINT32_C(0x003180AF),
9930           UINT32_C(0x003B64F1), UINT32_C(0x0029D493), UINT32_C(0x0029061E),
9931           UINT32_C(0x00287F20), UINT32_C(0x000A8410), UINT32_C(0x003B766F),
9932           UINT32_C(0x00194E12), UINT32_C(0x001C9672)},
9933          {UINT32_C(0x002BEBD9), UINT32_C(0x0034C959), UINT32_C(0x00372BCE),
9934           UINT32_C(0x0077E3FE), UINT32_C(0x002A76EF), UINT32_C(0x003B1215),
9935           UINT32_C(0x0017D01E), UINT32_C(0x001F6D6E), UINT32_C(0x001AF581),
9936           UINT32_C(0x002135B9), UINT32_C(0x0023AE9B), UINT32_C(0x00643EE2),
9937           UINT32_C(0x00309B0B), UINT32_C(0x00149E24), UINT32_C(0x002B829C),
9938           UINT32_C(0x0014D460), UINT32_C(0x0035AAB8), UINT32_C(0x001D64A4),
9939           UINT32_C(0x003C4123), UINT32_C(0x005FD0BE), UINT32_C(0x002680CE),
9940           UINT32_C(0x0032FC91), UINT32_C(0x000D5EFA)}},
9941         {{UINT32_C(0x0042107B), UINT32_C(0x002D79CB), UINT32_C(0x000E25C7),
9942           UINT32_C(0x0015D835), UINT32_C(0x0025EACC), UINT32_C(0x0038E784),
9943           UINT32_C(0x00133C3A), UINT32_C(0x0009780F), UINT32_C(0x0007A2B3),
9944           UINT32_C(0x003A0803), UINT32_C(0x00381D55), UINT32_C(0x00282268),
9945           UINT32_C(0x0020B921), UINT32_C(0x0037F7AC), UINT32_C(0x0013B76D),
9946           UINT32_C(0x003CE92F), UINT32_C(0x0025ECD4), UINT32_C(0x0030B106),
9947           UINT32_C(0x001D9F81), UINT32_C(0x006798C4), UINT32_C(0x000CF158),
9948           UINT32_C(0x003CAF9C), UINT32_C(0x003824DB)},
9949          {UINT32_C(0x007F6848), UINT32_C(0x0034A534), UINT32_C(0x0001B343),
9950           UINT32_C(0x006BF10C), UINT32_C(0x0008FCF1), UINT32_C(0x000025F0),
9951           UINT32_C(0x00105280), UINT32_C(0x0058FEE9), UINT32_C(0x0006B688),
9952           UINT32_C(0x001BEC79), UINT32_C(0x003D6BC7), UINT32_C(0x001DBC3E),
9953           UINT32_C(0x00298412), UINT32_C(0x002CAF5F), UINT32_C(0x003C0536),
9954           UINT32_C(0x006D0ED6), UINT32_C(0x002790F7), UINT32_C(0x0016B380),
9955           UINT32_C(0x000EA2CC), UINT32_C(0x007F2385), UINT32_C(0x001FC33E),
9956           UINT32_C(0x0001295D), UINT32_C(0x002EC02F)}},
9957         {{UINT32_C(0x001F7939), UINT32_C(0x002AC3E2), UINT32_C(0x001660F9),
9958           UINT32_C(0x00663A40), UINT32_C(0x001A8A13), UINT32_C(0x0023C8EF),
9959           UINT32_C(0x003AB7B7), UINT32_C(0x0039E16F), UINT32_C(0x001FA47B),
9960           UINT32_C(0x0025AB8D), UINT32_C(0x00384015), UINT32_C(0x003CE1A6),
9961           UINT32_C(0x0005F145), UINT32_C(0x000C1E4B), UINT32_C(0x001A72DB),
9962           UINT32_C(0x00203492), UINT32_C(0x003DE59E), UINT32_C(0x0010CD81),
9963           UINT32_C(0x002D2FAE), UINT32_C(0x0021F48A), UINT32_C(0x001C1285),
9964           UINT32_C(0x002EC41B), UINT32_C(0x001E8B07)},
9965          {UINT32_C(0x0018D1F3), UINT32_C(0x002EC53A), UINT32_C(0x00190D62),
9966           UINT32_C(0x0018FCFD), UINT32_C(0x000A3EE7), UINT32_C(0x0039D235),
9967           UINT32_C(0x00217FF2), UINT32_C(0x00142817), UINT32_C(0x002FB4F7),
9968           UINT32_C(0x001BB01D), UINT32_C(0x000BF067), UINT32_C(0x0052C1A1),
9969           UINT32_C(0x001029DF), UINT32_C(0x003B77AC), UINT32_C(0x001C5446),
9970           UINT32_C(0x000A8528), UINT32_C(0x00076849), UINT32_C(0x0024957C),
9971           UINT32_C(0x00255F16), UINT32_C(0x00464713), UINT32_C(0x0014A68E),
9972           UINT32_C(0x002A0E25), UINT32_C(0x0027874C)}},
9973         {{UINT32_C(0x00165C60), UINT32_C(0x000F1947), UINT32_C(0x00358DAC),
9974           UINT32_C(0x003112AB), UINT32_C(0x003CED7D), UINT32_C(0x0007D95D),
9975           UINT32_C(0x001BFB25), UINT32_C(0x0038039B), UINT32_C(0x002C49B9),
9976           UINT32_C(0x00226B1D), UINT32_C(0x00307B50), UINT32_C(0x002A8A6B),
9977           UINT32_C(0x003A8D6F), UINT32_C(0x002D72F9), UINT32_C(0x002F321D),
9978           UINT32_C(0x00530076), UINT32_C(0x002D8361), UINT32_C(0x002D2B58),
9979           UINT32_C(0x0032030C), UINT32_C(0x0032F5E5), UINT32_C(0x00164CE3),
9980           UINT32_C(0x0026D5D1), UINT32_C(0x0020444C)},
9981          {UINT32_C(0x002ABBE4), UINT32_C(0x003519D8), UINT32_C(0x00151482),
9982           UINT32_C(0x00773260), UINT32_C(0x0034B1AD), UINT32_C(0x00250B9E),
9983           UINT32_C(0x00302049), UINT32_C(0x00385164), UINT32_C(0x003E74F7),
9984           UINT32_C(0x0023B51F), UINT32_C(0x001A3158), UINT32_C(0x00527F9C),
9985           UINT32_C(0x003CABD3), UINT32_C(0x002F9178), UINT32_C(0x0006BAE5),
9986           UINT32_C(0x00600F3B), UINT32_C(0x002DF1B8), UINT32_C(0x000D590F),
9987           UINT32_C(0x00194149), UINT32_C(0x005DE8B8), UINT32_C(0x002325D5),
9988           UINT32_C(0x003EDBFF), UINT32_C(0x000AAFE1)}},
9989         {{UINT32_C(0x001A50FC), UINT32_C(0x00280217), UINT32_C(0x003A5F1B),
9990           UINT32_C(0x00412D41), UINT32_C(0x00285345), UINT32_C(0x002DBBAD),
9991           UINT32_C(0x000FF377), UINT32_C(0x0059899D), UINT32_C(0x0029B472),
9992           UINT32_C(0x00072A4A), UINT32_C(0x0028DC22), UINT32_C(0x001611B6),
9993           UINT32_C(0x003C3760), UINT32_C(0x0001466B), UINT32_C(0x003D8FA9),
9994           UINT32_C(0x00573081), UINT32_C(0x0013FB11), UINT32_C(0x00203758),
9995           UINT32_C(0x002E6367), UINT32_C(0x00482CF9), UINT32_C(0x003178F6),
9996           UINT32_C(0x001073E8), UINT32_C(0x001997C3)},
9997          {UINT32_C(0x0073FDFD), UINT32_C(0x002EFF90), UINT32_C(0x0014EBAD),
9998           UINT32_C(0x000F3618), UINT32_C(0x00162A1A), UINT32_C(0x00270E47),
9999           UINT32_C(0x0010A3E7), UINT32_C(0x00345497), UINT32_C(0x002C126D),
10000           UINT32_C(0x0036F8A6), UINT32_C(0x00166505), UINT32_C(0x0005C77A),
10001           UINT32_C(0x00197ED6), UINT32_C(0x00192ECC), UINT32_C(0x00233375),
10002           UINT32_C(0x003E0030), UINT32_C(0x000D5706), UINT32_C(0x0009709A),
10003           UINT32_C(0x003D8884), UINT32_C(0x00244795), UINT32_C(0x000B3F0C),
10004           UINT32_C(0x002420C0), UINT32_C(0x00286796)}},
10005         {{UINT32_C(0x000CAAE5), UINT32_C(0x00094457), UINT32_C(0x00152528),
10006           UINT32_C(0x001E3DB2), UINT32_C(0x0005EC25), UINT32_C(0x000BF941),
10007           UINT32_C(0x002A007F), UINT32_C(0x00504FD8), UINT32_C(0x003ED863),
10008           UINT32_C(0x003A902A), UINT32_C(0x0014F2EA), UINT32_C(0x0015DB81),
10009           UINT32_C(0x00280472), UINT32_C(0x003D790F), UINT32_C(0x00349779),
10010           UINT32_C(0x006EB09F), UINT32_C(0x00209701), UINT32_C(0x00377E4F),
10011           UINT32_C(0x002E600B), UINT32_C(0x00152371), UINT32_C(0x000BA435),
10012           UINT32_C(0x001FEF62), UINT32_C(0x0027E7F6)},
10013          {UINT32_C(0x00599CB9), UINT32_C(0x001549AA), UINT32_C(0x0013AF70),
10014           UINT32_C(0x00234B56), UINT32_C(0x00248CC3), UINT32_C(0x0032259C),
10015           UINT32_C(0x00203D97), UINT32_C(0x006AA891), UINT32_C(0x0005CEFE),
10016           UINT32_C(0x00199005), UINT32_C(0x001990D3), UINT32_C(0x00334DF5),
10017           UINT32_C(0x001B0BB0), UINT32_C(0x0011DD6C), UINT32_C(0x0038F1E0),
10018           UINT32_C(0x004EE490), UINT32_C(0x003C3321), UINT32_C(0x001F139B),
10019           UINT32_C(0x0006C59B), UINT32_C(0x00195C36), UINT32_C(0x00013ED7),
10020           UINT32_C(0x00020142), UINT32_C(0x0034FF5C)}},
10021         {{UINT32_C(0x002C93FF), UINT32_C(0x000319F9), UINT32_C(0x00002CB9),
10022           UINT32_C(0x002D18F3), UINT32_C(0x001DCA23), UINT32_C(0x000C5093),
10023           UINT32_C(0x001EFF04), UINT32_C(0x0075CFF0), UINT32_C(0x00064EA8),
10024           UINT32_C(0x0004571C), UINT32_C(0x0019B187), UINT32_C(0x0053F3E7),
10025           UINT32_C(0x002BFCD9), UINT32_C(0x00100147), UINT32_C(0x00381877),
10026           UINT32_C(0x0032E5D6), UINT32_C(0x002EC006), UINT32_C(0x00238ED2),
10027           UINT32_C(0x0032C67B), UINT32_C(0x00001663), UINT32_C(0x003C176A),
10028           UINT32_C(0x0014E21C), UINT32_C(0x00399D5E)},
10029          {UINT32_C(0x004E0B57), UINT32_C(0x001C2F95), UINT32_C(0x00363DC0),
10030           UINT32_C(0x0009DC71), UINT32_C(0x00151A34), UINT32_C(0x003159C5),
10031           UINT32_C(0x00201355), UINT32_C(0x00455C7C), UINT32_C(0x00070906),
10032           UINT32_C(0x002195FD), UINT32_C(0x001CE30A), UINT32_C(0x0073CADB),
10033           UINT32_C(0x0005C318), UINT32_C(0x00037022), UINT32_C(0x00053E6C),
10034           UINT32_C(0x0078D811), UINT32_C(0x002D5455), UINT32_C(0x000B37E3),
10035           UINT32_C(0x003A1081), UINT32_C(0x005948E6), UINT32_C(0x0032F5E3),
10036           UINT32_C(0x003F1006), UINT32_C(0x0029C6C7)}},
10037         {{UINT32_C(0x006A53F5), UINT32_C(0x00234585), UINT32_C(0x003B1248),
10038           UINT32_C(0x0031E22D), UINT32_C(0x0014C277), UINT32_C(0x001E4E41),
10039           UINT32_C(0x000C1028), UINT32_C(0x004CFB54), UINT32_C(0x000EA3E8),
10040           UINT32_C(0x00091AA9), UINT32_C(0x0026A9C7), UINT32_C(0x003266E7),
10041           UINT32_C(0x002E72A8), UINT32_C(0x002340FE), UINT32_C(0x00306573),
10042           UINT32_C(0x006B9E9A), UINT32_C(0x0035D59F), UINT32_C(0x001DB09E),
10043           UINT32_C(0x0005F131), UINT32_C(0x0002A91F), UINT32_C(0x003D10FA),
10044           UINT32_C(0x002D44C4), UINT32_C(0x001A9029)},
10045          {UINT32_C(0x004DC2D6), UINT32_C(0x000485AA), UINT32_C(0x00357F02),
10046           UINT32_C(0x00109ABD), UINT32_C(0x00277446), UINT32_C(0x002B2567),
10047           UINT32_C(0x003C69A7), UINT32_C(0x0031AA5D), UINT32_C(0x00308E0D),
10048           UINT32_C(0x000CDB91), UINT32_C(0x001A3AB7), UINT32_C(0x0043A830),
10049           UINT32_C(0x002FC1D1), UINT32_C(0x001FA04C), UINT32_C(0x002B3C22),
10050           UINT32_C(0x00400E6C), UINT32_C(0x00088655), UINT32_C(0x000D2E38),
10051           UINT32_C(0x002BEDE7), UINT32_C(0x0041F67A), UINT32_C(0x002EB40A),
10052           UINT32_C(0x00263E54), UINT32_C(0x000736A8)}},
10053         {{UINT32_C(0x00524DB7), UINT32_C(0x00329BD6), UINT32_C(0x002BC43F),
10054           UINT32_C(0x00407E56), UINT32_C(0x0006BA61), UINT32_C(0x001A5FC7),
10055           UINT32_C(0x000FC681), UINT32_C(0x001A5E17), UINT32_C(0x002AD8E2),
10056           UINT32_C(0x003C1B1E), UINT32_C(0x003028BA), UINT32_C(0x002CE10A),
10057           UINT32_C(0x0013F30E), UINT32_C(0x001966B5), UINT32_C(0x001C1DF1),
10058           UINT32_C(0x00540907), UINT32_C(0x0029361C), UINT32_C(0x000E7B5C),
10059           UINT32_C(0x00303DDE), UINT32_C(0x0059FB60), UINT32_C(0x00151554),
10060           UINT32_C(0x002838BD), UINT32_C(0x003D9CFA)},
10061          {UINT32_C(0x002063F9), UINT32_C(0x002731CA), UINT32_C(0x002003F0),
10062           UINT32_C(0x0079F9F9), UINT32_C(0x00347AC8), UINT32_C(0x0021973A),
10063           UINT32_C(0x001280CE), UINT32_C(0x00323A60), UINT32_C(0x00098D3C),
10064           UINT32_C(0x00306D49), UINT32_C(0x000109EC), UINT32_C(0x00511419),
10065           UINT32_C(0x0010C7B4), UINT32_C(0x001D2E21), UINT32_C(0x003991C3),
10066           UINT32_C(0x003C5990), UINT32_C(0x001DB860), UINT32_C(0x0014EC41),
10067           UINT32_C(0x00088BAC), UINT32_C(0x00448C44), UINT32_C(0x00084966),
10068           UINT32_C(0x0031E904), UINT32_C(0x000524F2)}},
10069         {{UINT32_C(0x0049E3D3), UINT32_C(0x00181A3B), UINT32_C(0x0011AA50),
10070           UINT32_C(0x007021E5), UINT32_C(0x00316EC7), UINT32_C(0x0029A769),
10071           UINT32_C(0x003F4C5A), UINT32_C(0x006AA0ED), UINT32_C(0x003E7379),
10072           UINT32_C(0x00150459), UINT32_C(0x0035CBC7), UINT32_C(0x005DEBB1),
10073           UINT32_C(0x00053C63), UINT32_C(0x000AA5E3), UINT32_C(0x0013545F),
10074           UINT32_C(0x00019A93), UINT32_C(0x0029934B), UINT32_C(0x000A94D0),
10075           UINT32_C(0x00260B29), UINT32_C(0x00298F53), UINT32_C(0x00377D15),
10076           UINT32_C(0x0029F246), UINT32_C(0x002F33B2)},
10077          {UINT32_C(0x0066FE62), UINT32_C(0x001037AD), UINT32_C(0x00370077),
10078           UINT32_C(0x00421175), UINT32_C(0x001E861C), UINT32_C(0x00033773),
10079           UINT32_C(0x002BFEA4), UINT32_C(0x0000380F), UINT32_C(0x0001544C),
10080           UINT32_C(0x00272751), UINT32_C(0x003FB134), UINT32_C(0x0039C926),
10081           UINT32_C(0x002CAB64), UINT32_C(0x0026F1D5), UINT32_C(0x00273824),
10082           UINT32_C(0x004BDF14), UINT32_C(0x001E4097), UINT32_C(0x00281D77),
10083           UINT32_C(0x00273464), UINT32_C(0x0005EB84), UINT32_C(0x002942CD),
10084           UINT32_C(0x003938B5), UINT32_C(0x00333CCF)}},
10085         {{UINT32_C(0x000B8466), UINT32_C(0x00335B47), UINT32_C(0x001C7C5F),
10086           UINT32_C(0x00130B87), UINT32_C(0x0002C697), UINT32_C(0x0011F099),
10087           UINT32_C(0x001909FC), UINT32_C(0x007C440B), UINT32_C(0x0006E6CD),
10088           UINT32_C(0x003604F5), UINT32_C(0x000A3664), UINT32_C(0x000E9448),
10089           UINT32_C(0x00375564), UINT32_C(0x00100ABB), UINT32_C(0x000A2BD1),
10090           UINT32_C(0x00610611), UINT32_C(0x000B0919), UINT32_C(0x00192DA1),
10091           UINT32_C(0x000CA6A0), UINT32_C(0x0022EC21), UINT32_C(0x0010021B),
10092           UINT32_C(0x0014AC0F), UINT32_C(0x003C3561)},
10093          {UINT32_C(0x001DE844), UINT32_C(0x000339F0), UINT32_C(0x00338277),
10094           UINT32_C(0x0039E865), UINT32_C(0x000C918F), UINT32_C(0x001B9202),
10095           UINT32_C(0x0039DB51), UINT32_C(0x0035E972), UINT32_C(0x00269806),
10096           UINT32_C(0x001A4703), UINT32_C(0x00128E3F), UINT32_C(0x0059736B),
10097           UINT32_C(0x0009133A), UINT32_C(0x000988FA), UINT32_C(0x003F5D17),
10098           UINT32_C(0x0075D549), UINT32_C(0x0035AF8B), UINT32_C(0x000EBF87),
10099           UINT32_C(0x002B5241), UINT32_C(0x001A47E1), UINT32_C(0x003FAD0B),
10100           UINT32_C(0x003F031A), UINT32_C(0x0000856D)}},
10101         {{UINT32_C(0x007BA242), UINT32_C(0x003F139F), UINT32_C(0x0011DEFD),
10102           UINT32_C(0x0023DE43), UINT32_C(0x00295AA0), UINT32_C(0x003AB6CE),
10103           UINT32_C(0x0000492A), UINT32_C(0x00038F1C), UINT32_C(0x001F3BEB),
10104           UINT32_C(0x000DEADE), UINT32_C(0x003039CC), UINT32_C(0x00546C46),
10105           UINT32_C(0x000F8C59), UINT32_C(0x00364F5D), UINT32_C(0x00278A38),
10106           UINT32_C(0x0003D22C), UINT32_C(0x000FDC4B), UINT32_C(0x0001BEAF),
10107           UINT32_C(0x00025B08), UINT32_C(0x0008F72C), UINT32_C(0x0027C5E7),
10108           UINT32_C(0x00252A05), UINT32_C(0x00107A50)},
10109          {UINT32_C(0x000EBA8F), UINT32_C(0x0027A1D4), UINT32_C(0x003EF3A3),
10110           UINT32_C(0x007BCF49), UINT32_C(0x003D3105), UINT32_C(0x0023E6FD),
10111           UINT32_C(0x00359B97), UINT32_C(0x0028F42A), UINT32_C(0x003E23D6),
10112           UINT32_C(0x00178851), UINT32_C(0x0037642F), UINT32_C(0x0042E04B),
10113           UINT32_C(0x00376AFD), UINT32_C(0x00198F42), UINT32_C(0x002F89CF),
10114           UINT32_C(0x000E495C), UINT32_C(0x002116C6), UINT32_C(0x00369883),
10115           UINT32_C(0x0005445E), UINT32_C(0x0028D909), UINT32_C(0x001123BE),
10116           UINT32_C(0x00395238), UINT32_C(0x000BDBC0)}},
10117         {{UINT32_C(0x0079A5E7), UINT32_C(0x001C3E7B), UINT32_C(0x00184F53),
10118           UINT32_C(0x003BBC86), UINT32_C(0x0010D687), UINT32_C(0x00038850),
10119           UINT32_C(0x0038E20E), UINT32_C(0x003E53AE), UINT32_C(0x0004A94C),
10120           UINT32_C(0x002AEB4D), UINT32_C(0x003AEB1A), UINT32_C(0x00448BCC),
10121           UINT32_C(0x0004DB71), UINT32_C(0x0003778D), UINT32_C(0x003944F0),
10122           UINT32_C(0x000CC500), UINT32_C(0x00008E46), UINT32_C(0x000F5C40),
10123           UINT32_C(0x00110507), UINT32_C(0x001F1E48), UINT32_C(0x003628D5),
10124           UINT32_C(0x00052A96), UINT32_C(0x003B94D2)},
10125          {UINT32_C(0x0004ABCF), UINT32_C(0x000A3BC2), UINT32_C(0x0001C80A),
10126           UINT32_C(0x007BDA93), UINT32_C(0x000ECD4F), UINT32_C(0x003F215D),
10127           UINT32_C(0x000EBBE2), UINT32_C(0x005395FC), UINT32_C(0x00074168),
10128           UINT32_C(0x0022A24A), UINT32_C(0x001A1B35), UINT32_C(0x0077FFE0),
10129           UINT32_C(0x003C9950), UINT32_C(0x0028A73C), UINT32_C(0x001AC592),
10130           UINT32_C(0x0023CB0D), UINT32_C(0x003F12D3), UINT32_C(0x0030ED1B),
10131           UINT32_C(0x002E878C), UINT32_C(0x003BA03C), UINT32_C(0x003CDBA8),
10132           UINT32_C(0x0021E634), UINT32_C(0x000F8610)}},
10133     },
10134     {
10135         {{UINT32_C(0x00374EA0), UINT32_C(0x003D49A3), UINT32_C(0x001F7E76),
10136           UINT32_C(0x001D6B9E), UINT32_C(0x002592C5), UINT32_C(0x000E14A2),
10137           UINT32_C(0x00190C56), UINT32_C(0x0063DAE2), UINT32_C(0x0039CB00),
10138           UINT32_C(0x001A96B0), UINT32_C(0x001112B0), UINT32_C(0x00125D57),
10139           UINT32_C(0x003E073B), UINT32_C(0x003BA300), UINT32_C(0x0010434F),
10140           UINT32_C(0x00584798), UINT32_C(0x00328C4D), UINT32_C(0x002C908E),
10141           UINT32_C(0x003F37C6), UINT32_C(0x0050852E), UINT32_C(0x000E2E46),
10142           UINT32_C(0x003A1A63), UINT32_C(0x001C643D)},
10143          {UINT32_C(0x00147D83), UINT32_C(0x000590DE), UINT32_C(0x001A30E1),
10144           UINT32_C(0x003223D8), UINT32_C(0x00092F2B), UINT32_C(0x002B60EE),
10145           UINT32_C(0x00044972), UINT32_C(0x0024B04F), UINT32_C(0x000F8784),
10146           UINT32_C(0x00015A35), UINT32_C(0x001E5404), UINT32_C(0x003B76C0),
10147           UINT32_C(0x0024ECFE), UINT32_C(0x00101933), UINT32_C(0x0029FDFB),
10148           UINT32_C(0x00224043), UINT32_C(0x00059771), UINT32_C(0x0035FA07),
10149           UINT32_C(0x00044AFE), UINT32_C(0x00168A97), UINT32_C(0x001D4795),
10150           UINT32_C(0x0016C054), UINT32_C(0x00202B01)}},
10151         {{UINT32_C(0x0063E7A6), UINT32_C(0x0034C8D6), UINT32_C(0x00280787),
10152           UINT32_C(0x001A7385), UINT32_C(0x003ABD2E), UINT32_C(0x00185E3E),
10153           UINT32_C(0x0000C346), UINT32_C(0x0075FF68), UINT32_C(0x00117390),
10154           UINT32_C(0x00234323), UINT32_C(0x00327433), UINT32_C(0x003FED4A),
10155           UINT32_C(0x003946EE), UINT32_C(0x00036FEB), UINT32_C(0x000C0F57),
10156           UINT32_C(0x00359C4A), UINT32_C(0x00092D1D), UINT32_C(0x0001A134),
10157           UINT32_C(0x002AD6D7), UINT32_C(0x0012395F), UINT32_C(0x003F988A),
10158           UINT32_C(0x001ACCFF), UINT32_C(0x002123C1)},
10159          {UINT32_C(0x002D5A19), UINT32_C(0x00156939), UINT32_C(0x00222C1A),
10160           UINT32_C(0x00619366), UINT32_C(0x0016036D), UINT32_C(0x0033459B),
10161           UINT32_C(0x00062D47), UINT32_C(0x004B8C12), UINT32_C(0x001B95CF),
10162           UINT32_C(0x00117F5F), UINT32_C(0x003F80DA), UINT32_C(0x00050A50),
10163           UINT32_C(0x003942D5), UINT32_C(0x00385EAE), UINT32_C(0x0033AB22),
10164           UINT32_C(0x00537468), UINT32_C(0x000DFF4B), UINT32_C(0x001879D6),
10165           UINT32_C(0x002388A7), UINT32_C(0x000FCEA6), UINT32_C(0x00375E35),
10166           UINT32_C(0x003398B3), UINT32_C(0x003F30BA)}},
10167         {{UINT32_C(0x003598D4), UINT32_C(0x0019A9A3), UINT32_C(0x003A267B),
10168           UINT32_C(0x002B12CC), UINT32_C(0x003839D5), UINT32_C(0x003B8D33),
10169           UINT32_C(0x0025BF3A), UINT32_C(0x00438430), UINT32_C(0x00189C5B),
10170           UINT32_C(0x003F2C8B), UINT32_C(0x003A8177), UINT32_C(0x007055A3),
10171           UINT32_C(0x002E6730), UINT32_C(0x00341821), UINT32_C(0x002142DE),
10172           UINT32_C(0x0010BC51), UINT32_C(0x000D1EA0), UINT32_C(0x0015FEF0),
10173           UINT32_C(0x00329B9B), UINT32_C(0x000508A4), UINT32_C(0x0001C1B9),
10174           UINT32_C(0x001FF600), UINT32_C(0x00328E8E)},
10175          {UINT32_C(0x00717603), UINT32_C(0x0033F89C), UINT32_C(0x0025C76B),
10176           UINT32_C(0x0018607B), UINT32_C(0x001303E9), UINT32_C(0x000F2CB5),
10177           UINT32_C(0x000F8CE4), UINT32_C(0x0011128F), UINT32_C(0x00216CE5),
10178           UINT32_C(0x003B4AEC), UINT32_C(0x0027F704), UINT32_C(0x005A2623),
10179           UINT32_C(0x002A1412), UINT32_C(0x0037E07D), UINT32_C(0x0007F5BF),
10180           UINT32_C(0x006BFF5F), UINT32_C(0x0000D2EA), UINT32_C(0x0028D09E),
10181           UINT32_C(0x0030FECE), UINT32_C(0x007CE886), UINT32_C(0x00163AD8),
10182           UINT32_C(0x00007318), UINT32_C(0x002C4F8D)}},
10183         {{UINT32_C(0x0022EF26), UINT32_C(0x0011DF21), UINT32_C(0x001A21E7),
10184           UINT32_C(0x0067A5B1), UINT32_C(0x00327468), UINT32_C(0x0031BA5C),
10185           UINT32_C(0x00156DC9), UINT32_C(0x001E7E4E), UINT32_C(0x003FB583),
10186           UINT32_C(0x001EB61F), UINT32_C(0x002ABBA4), UINT32_C(0x0040FEC8),
10187           UINT32_C(0x0004C5FF), UINT32_C(0x0010F939), UINT32_C(0x003D4DA2),
10188           UINT32_C(0x005C0941), UINT32_C(0x0013C311), UINT32_C(0x000BA027),
10189           UINT32_C(0x001845CC), UINT32_C(0x006FF264), UINT32_C(0x0038AC88),
10190           UINT32_C(0x003463D6), UINT32_C(0x000EADB9)},
10191          {UINT32_C(0x000B056C), UINT32_C(0x00288DB2), UINT32_C(0x001C02CF),
10192           UINT32_C(0x000BB175), UINT32_C(0x0018F094), UINT32_C(0x0027806D),
10193           UINT32_C(0x00355563), UINT32_C(0x0054C2AD), UINT32_C(0x001CCE8E),
10194           UINT32_C(0x002E2B85), UINT32_C(0x00073F85), UINT32_C(0x006D02CB),
10195           UINT32_C(0x0033434A), UINT32_C(0x003DA80B), UINT32_C(0x001550B8),
10196           UINT32_C(0x0053A65C), UINT32_C(0x003624AD), UINT32_C(0x00078142),
10197           UINT32_C(0x0017BFE5), UINT32_C(0x002EF056), UINT32_C(0x00126C8F),
10198           UINT32_C(0x00377035), UINT32_C(0x003C5FD9)}},
10199         {{UINT32_C(0x00692F52), UINT32_C(0x002D345A), UINT32_C(0x001014B5),
10200           UINT32_C(0x004A6F1C), UINT32_C(0x00279FEB), UINT32_C(0x00057359),
10201           UINT32_C(0x0005EE89), UINT32_C(0x000B0567), UINT32_C(0x002B38D3),
10202           UINT32_C(0x00243C26), UINT32_C(0x0000FE1B), UINT32_C(0x001499CE),
10203           UINT32_C(0x00326C87), UINT32_C(0x003808D0), UINT32_C(0x0024E577),
10204           UINT32_C(0x00559968), UINT32_C(0x0014EF5F), UINT32_C(0x00091017),
10205           UINT32_C(0x000A4B95), UINT32_C(0x0079EB0D), UINT32_C(0x000498F0),
10206           UINT32_C(0x002F7F3A), UINT32_C(0x00024E38)},
10207          {UINT32_C(0x000590D7), UINT32_C(0x000C5AFF), UINT32_C(0x0021F7AF),
10208           UINT32_C(0x00667CCB), UINT32_C(0x0038AC0E), UINT32_C(0x0023A769),
10209           UINT32_C(0x003E7C3D), UINT32_C(0x0052FB04), UINT32_C(0x002DE7EC),
10210           UINT32_C(0x002F29F5), UINT32_C(0x0023207B), UINT32_C(0x000CDF9D),
10211           UINT32_C(0x002B4365), UINT32_C(0x003A2FBF), UINT32_C(0x0011FB18),
10212           UINT32_C(0x0063AFCF), UINT32_C(0x0015B1DD), UINT32_C(0x0033B40C),
10213           UINT32_C(0x00012F31), UINT32_C(0x00087C46), UINT32_C(0x00099C9E),
10214           UINT32_C(0x0016BC64), UINT32_C(0x0032AD86)}},
10215         {{UINT32_C(0x00483715), UINT32_C(0x00368333), UINT32_C(0x00246073),
10216           UINT32_C(0x005FB045), UINT32_C(0x003A117A), UINT32_C(0x002FBC81),
10217           UINT32_C(0x0009FFFF), UINT32_C(0x003826CF), UINT32_C(0x00040665),
10218           UINT32_C(0x00248D34), UINT32_C(0x0020F6F7), UINT32_C(0x0064C39E),
10219           UINT32_C(0x000DDC2A), UINT32_C(0x0027F7AD), UINT32_C(0x002A0468),
10220           UINT32_C(0x004233A3), UINT32_C(0x0039012C), UINT32_C(0x001733DF),
10221           UINT32_C(0x002EFFEF), UINT32_C(0x00799097), UINT32_C(0x001FF171),
10222           UINT32_C(0x0018ED19), UINT32_C(0x0026CCEE)},
10223          {UINT32_C(0x0046E82C), UINT32_C(0x003D6F41), UINT32_C(0x001B2A06),
10224           UINT32_C(0x001FF2C3), UINT32_C(0x003F0F50), UINT32_C(0x0001A930),
10225           UINT32_C(0x003BF063), UINT32_C(0x002EE18D), UINT32_C(0x001CCFE3),
10226           UINT32_C(0x0036F969), UINT32_C(0x00149AD4), UINT32_C(0x0016E5BE),
10227           UINT32_C(0x001F9762), UINT32_C(0x0022D061), UINT32_C(0x0012E3B7),
10228           UINT32_C(0x0003E984), UINT32_C(0x003B3250), UINT32_C(0x0038C6B2),
10229           UINT32_C(0x00159530), UINT32_C(0x0073861F), UINT32_C(0x00251136),
10230           UINT32_C(0x00123D52), UINT32_C(0x0027A418)}},
10231         {{UINT32_C(0x003F3D56), UINT32_C(0x0035580A), UINT32_C(0x00315B32),
10232           UINT32_C(0x00683B54), UINT32_C(0x002E6B1B), UINT32_C(0x0030E284),
10233           UINT32_C(0x001A147C), UINT32_C(0x0057017E), UINT32_C(0x003F1CE4),
10234           UINT32_C(0x000739F3), UINT32_C(0x000BE2D0), UINT32_C(0x00237229),
10235           UINT32_C(0x0035DB98), UINT32_C(0x00013B31), UINT32_C(0x000885D5),
10236           UINT32_C(0x00734416), UINT32_C(0x002BCB46), UINT32_C(0x0025B709),
10237           UINT32_C(0x001F5588), UINT32_C(0x007AFB72), UINT32_C(0x000A3B67),
10238           UINT32_C(0x002F51E5), UINT32_C(0x0037F6D4)},
10239          {UINT32_C(0x0058DC2B), UINT32_C(0x003BC578), UINT32_C(0x003EFB94),
10240           UINT32_C(0x007AB5C0), UINT32_C(0x0033698C), UINT32_C(0x00384E73),
10241           UINT32_C(0x0018C54E), UINT32_C(0x0006017C), UINT32_C(0x00169895),
10242           UINT32_C(0x0032C34C), UINT32_C(0x001B77D2), UINT32_C(0x00668DCD),
10243           UINT32_C(0x0029D00C), UINT32_C(0x0035521D), UINT32_C(0x000871E7),
10244           UINT32_C(0x000881E9), UINT32_C(0x003F9CC2), UINT32_C(0x00273AEA),
10245           UINT32_C(0x000AFA2B), UINT32_C(0x00519C25), UINT32_C(0x00284813),
10246           UINT32_C(0x002F3204), UINT32_C(0x003A63D7)}},
10247         {{UINT32_C(0x00024391), UINT32_C(0x003BA776), UINT32_C(0x00033874),
10248           UINT32_C(0x0034FBCF), UINT32_C(0x00303978), UINT32_C(0x00022D87),
10249           UINT32_C(0x0005FC7A), UINT32_C(0x004D7ABB), UINT32_C(0x003F68E7),
10250           UINT32_C(0x0017EC8C), UINT32_C(0x00051303), UINT32_C(0x006259DA),
10251           UINT32_C(0x0021F4E5), UINT32_C(0x00121632), UINT32_C(0x0031BBFE),
10252           UINT32_C(0x0079B8A1), UINT32_C(0x003AE333), UINT32_C(0x0006A0FC),
10253           UINT32_C(0x00055308), UINT32_C(0x00601907), UINT32_C(0x002EA623),
10254           UINT32_C(0x003B33BA), UINT32_C(0x00349F3F)},
10255          {UINT32_C(0x0001E557), UINT32_C(0x000C8304), UINT32_C(0x0002EDBE),
10256           UINT32_C(0x001EFF0A), UINT32_C(0x003B6349), UINT32_C(0x00228976),
10257           UINT32_C(0x00317095), UINT32_C(0x00482B44), UINT32_C(0x002287BF),
10258           UINT32_C(0x00244B82), UINT32_C(0x003CFA63), UINT32_C(0x001D099B),
10259           UINT32_C(0x0023EB12), UINT32_C(0x00188057), UINT32_C(0x000D5E10),
10260           UINT32_C(0x005205C6), UINT32_C(0x002A8F5F), UINT32_C(0x002AB102),
10261           UINT32_C(0x00151E7A), UINT32_C(0x0031464E), UINT32_C(0x0016ACF5),
10262           UINT32_C(0x003C570E), UINT32_C(0x003D5498)}},
10263         {{UINT32_C(0x00528A5E), UINT32_C(0x001D1A41), UINT32_C(0x001D0B03),
10264           UINT32_C(0x006E975C), UINT32_C(0x000C8044), UINT32_C(0x0026C6AB),
10265           UINT32_C(0x001E178A), UINT32_C(0x0066B411), UINT32_C(0x00047104),
10266           UINT32_C(0x00204D14), UINT32_C(0x00228536), UINT32_C(0x000D099C),
10267           UINT32_C(0x000838AB), UINT32_C(0x001BC3DC), UINT32_C(0x0029FCE8),
10268           UINT32_C(0x00029FD9), UINT32_C(0x002E687A), UINT32_C(0x003E8AE4),
10269           UINT32_C(0x002DD424), UINT32_C(0x00432788), UINT32_C(0x0008979F),
10270           UINT32_C(0x0039EDD9), UINT32_C(0x001751D6)},
10271          {UINT32_C(0x00492D65), UINT32_C(0x001A7DE1), UINT32_C(0x0014FD58),
10272           UINT32_C(0x000C2887), UINT32_C(0x00170FFC), UINT32_C(0x0002CD82),
10273           UINT32_C(0x000C7EB0), UINT32_C(0x007BC59A), UINT32_C(0x00027399),
10274           UINT32_C(0x0007595A), UINT32_C(0x0006B074), UINT32_C(0x00362BD4),
10275           UINT32_C(0x001D090F), UINT32_C(0x0005CC42), UINT32_C(0x00350E6D),
10276           UINT32_C(0x000520BA), UINT32_C(0x003511C8), UINT32_C(0x00263B84),
10277           UINT32_C(0x0012CB4B), UINT32_C(0x00395148), UINT32_C(0x001557BE),
10278           UINT32_C(0x001A47CB), UINT32_C(0x00314464)}},
10279         {{UINT32_C(0x0043F2F2), UINT32_C(0x00194797), UINT32_C(0x00164AF2),
10280           UINT32_C(0x0039D872), UINT32_C(0x000104A3), UINT32_C(0x0016929A),
10281           UINT32_C(0x00282C81), UINT32_C(0x005F9C2C), UINT32_C(0x002A5D4B),
10282           UINT32_C(0x003192B8), UINT32_C(0x002E15CB), UINT32_C(0x004F6E26),
10283           UINT32_C(0x001DBE42), UINT32_C(0x0011C09D), UINT32_C(0x0036F64F),
10284           UINT32_C(0x004483FB), UINT32_C(0x00060CCE), UINT32_C(0x003148C2),
10285           UINT32_C(0x001EE90A), UINT32_C(0x003E6042), UINT32_C(0x002E64B1),
10286           UINT32_C(0x002C44F1), UINT32_C(0x002F2B60)},
10287          {UINT32_C(0x005DC792), UINT32_C(0x00397CAD), UINT32_C(0x0018311A),
10288           UINT32_C(0x000DB83D), UINT32_C(0x003A7FE0), UINT32_C(0x0036E2B7),
10289           UINT32_C(0x00208A0B), UINT32_C(0x00725417), UINT32_C(0x00055265),
10290           UINT32_C(0x0028A5C2), UINT32_C(0x002D7738), UINT32_C(0x0008626D),
10291           UINT32_C(0x00267142), UINT32_C(0x00335A17), UINT32_C(0x003E2E6A),
10292           UINT32_C(0x0023C202), UINT32_C(0x001CEC16), UINT32_C(0x0007C3CA),
10293           UINT32_C(0x0026178F), UINT32_C(0x007AF6B1), UINT32_C(0x003EC4B0),
10294           UINT32_C(0x000A5C59), UINT32_C(0x0005CC1B)}},
10295         {{UINT32_C(0x006D6CE3), UINT32_C(0x003CDDFA), UINT32_C(0x003536DB),
10296           UINT32_C(0x003AFD9F), UINT32_C(0x00097B34), UINT32_C(0x0005ECD4),
10297           UINT32_C(0x0034AA4D), UINT32_C(0x003B05FC), UINT32_C(0x0009BBAD),
10298           UINT32_C(0x003FDCEE), UINT32_C(0x0033D997), UINT32_C(0x0003C160),
10299           UINT32_C(0x003B6D37), UINT32_C(0x00315C67), UINT32_C(0x002362F6),
10300           UINT32_C(0x001A9401), UINT32_C(0x0014E9AD), UINT32_C(0x0033DA3E),
10301           UINT32_C(0x001BCD3C), UINT32_C(0x002D9F1B), UINT32_C(0x0030DD6A),
10302           UINT32_C(0x003EC5E7), UINT32_C(0x00308176)},
10303          {UINT32_C(0x003069BB), UINT32_C(0x0021C759), UINT32_C(0x0015A982),
10304           UINT32_C(0x000433F9), UINT32_C(0x000F0415), UINT32_C(0x0019193B),
10305           UINT32_C(0x000CB74A), UINT32_C(0x00550A79), UINT32_C(0x002D6049),
10306           UINT32_C(0x00207DAA), UINT32_C(0x000496F6), UINT32_C(0x00492EB6),
10307           UINT32_C(0x003490BF), UINT32_C(0x003D7E1A), UINT32_C(0x0029D71A),
10308           UINT32_C(0x001A99C6), UINT32_C(0x003442EC), UINT32_C(0x001FE876),
10309           UINT32_C(0x00307A44), UINT32_C(0x005B4A4F), UINT32_C(0x000DC29C),
10310           UINT32_C(0x0038C4EF), UINT32_C(0x002E915D)}},
10311         {{UINT32_C(0x000BEB8C), UINT32_C(0x00061A56), UINT32_C(0x000D8268),
10312           UINT32_C(0x00421E9B), UINT32_C(0x001AD305), UINT32_C(0x002C0C54),
10313           UINT32_C(0x002B4A5F), UINT32_C(0x003DF358), UINT32_C(0x001523F3),
10314           UINT32_C(0x0028B368), UINT32_C(0x00276FD0), UINT32_C(0x00442093),
10315           UINT32_C(0x000817D3), UINT32_C(0x002AE36B), UINT32_C(0x003C22DE),
10316           UINT32_C(0x0058669C), UINT32_C(0x000D7F6C), UINT32_C(0x00279A1A),
10317           UINT32_C(0x000D107C), UINT32_C(0x0021DE92), UINT32_C(0x00246CC9),
10318           UINT32_C(0x0034B4A4), UINT32_C(0x000EFACA)},
10319          {UINT32_C(0x00694EEC), UINT32_C(0x003C5044), UINT32_C(0x0016ECB7),
10320           UINT32_C(0x00412A48), UINT32_C(0x0017E21D), UINT32_C(0x001C1E82),
10321           UINT32_C(0x002BA6CD), UINT32_C(0x001CF647), UINT32_C(0x00306F34),
10322           UINT32_C(0x00146470), UINT32_C(0x00196674), UINT32_C(0x001418A3),
10323           UINT32_C(0x002CFE68), UINT32_C(0x0026B0A5), UINT32_C(0x000747E1),
10324           UINT32_C(0x0000076E), UINT32_C(0x002C52FE), UINT32_C(0x00381158),
10325           UINT32_C(0x003CB4BD), UINT32_C(0x000E909B), UINT32_C(0x0009F542),
10326           UINT32_C(0x000CB347), UINT32_C(0x0016D579)}},
10327         {{UINT32_C(0x0069D866), UINT32_C(0x0027D233), UINT32_C(0x0035A8F4),
10328           UINT32_C(0x006BC550), UINT32_C(0x0018DA15), UINT32_C(0x0030CE9E),
10329           UINT32_C(0x0015D2E1), UINT32_C(0x005388CB), UINT32_C(0x0032AC42),
10330           UINT32_C(0x001EDFA9), UINT32_C(0x00041ADC), UINT32_C(0x000232D9),
10331           UINT32_C(0x00278158), UINT32_C(0x003B9C91), UINT32_C(0x001DD2A0),
10332           UINT32_C(0x0033F780), UINT32_C(0x003E5C50), UINT32_C(0x00075CF3),
10333           UINT32_C(0x0015E7C2), UINT32_C(0x00440ADA), UINT32_C(0x0016D15D),
10334           UINT32_C(0x000586C1), UINT32_C(0x002A016C)},
10335          {UINT32_C(0x004AE04A), UINT32_C(0x003E7BC9), UINT32_C(0x00096110),
10336           UINT32_C(0x00066932), UINT32_C(0x001B3038), UINT32_C(0x001A7311),
10337           UINT32_C(0x002F1AEF), UINT32_C(0x0068EA21), UINT32_C(0x00095E5D),
10338           UINT32_C(0x0009883B), UINT32_C(0x00033990), UINT32_C(0x0024C0B3),
10339           UINT32_C(0x0029A84D), UINT32_C(0x0005EBA4), UINT32_C(0x00311E64),
10340           UINT32_C(0x0013FEAE), UINT32_C(0x0008156B), UINT32_C(0x002F4EE6),
10341           UINT32_C(0x000DF329), UINT32_C(0x001AE70A), UINT32_C(0x002847DD),
10342           UINT32_C(0x0018E0D7), UINT32_C(0x002BD42E)}},
10343         {{UINT32_C(0x000B9710), UINT32_C(0x001F475F), UINT32_C(0x000999F5),
10344           UINT32_C(0x0032B55C), UINT32_C(0x002E7C12), UINT32_C(0x00264CED),
10345           UINT32_C(0x00094F0A), UINT32_C(0x005A4E16), UINT32_C(0x000BECA0),
10346           UINT32_C(0x00349B97), UINT32_C(0x003CE972), UINT32_C(0x002B59D3),
10347           UINT32_C(0x002F203F), UINT32_C(0x000F211F), UINT32_C(0x003B07F1),
10348           UINT32_C(0x00786C83), UINT32_C(0x0001D952), UINT32_C(0x002B793E),
10349           UINT32_C(0x0033C2B1), UINT32_C(0x005E8A36), UINT32_C(0x0036E5E2),
10350           UINT32_C(0x00156A46), UINT32_C(0x00362C8F)},
10351          {UINT32_C(0x00317544), UINT32_C(0x000AEC08), UINT32_C(0x003109AC),
10352           UINT32_C(0x004EC46A), UINT32_C(0x00214545), UINT32_C(0x00338B7B),
10353           UINT32_C(0x0016C802), UINT32_C(0x004E4271), UINT32_C(0x003A07D9),
10354           UINT32_C(0x00019D25), UINT32_C(0x00198775), UINT32_C(0x0049A8C4),
10355           UINT32_C(0x00215656), UINT32_C(0x0009570A), UINT32_C(0x0004BCC8),
10356           UINT32_C(0x006ED97E), UINT32_C(0x003721B2), UINT32_C(0x001AB6C7),
10357           UINT32_C(0x00219EDF), UINT32_C(0x004291B1), UINT32_C(0x0021788D),
10358           UINT32_C(0x003CA653), UINT32_C(0x002C51F0)}},
10359         {{UINT32_C(0x00549A73), UINT32_C(0x001585E0), UINT32_C(0x001219AF),
10360           UINT32_C(0x00278B73), UINT32_C(0x000AB916), UINT32_C(0x003FB445),
10361           UINT32_C(0x003FC327), UINT32_C(0x00487904), UINT32_C(0x0008835A),
10362           UINT32_C(0x0013EBDD), UINT32_C(0x002B6722), UINT32_C(0x005F61F3),
10363           UINT32_C(0x0033C0B6), UINT32_C(0x00387E43), UINT32_C(0x000DC4FF),
10364           UINT32_C(0x00220AA8), UINT32_C(0x002411BD), UINT32_C(0x002D9844),
10365           UINT32_C(0x003BD35D), UINT32_C(0x000878BC), UINT32_C(0x001548F6),
10366           UINT32_C(0x003F932E), UINT32_C(0x00189EAF)},
10367          {UINT32_C(0x00243BBC), UINT32_C(0x00080398), UINT32_C(0x0010A82F),
10368           UINT32_C(0x006AB89B), UINT32_C(0x00021339), UINT32_C(0x00291FC3),
10369           UINT32_C(0x00145BA0), UINT32_C(0x005378D0), UINT32_C(0x0015B299),
10370           UINT32_C(0x00057581), UINT32_C(0x002112C0), UINT32_C(0x00642C8E),
10371           UINT32_C(0x003981D5), UINT32_C(0x0020F113), UINT32_C(0x00354642),
10372           UINT32_C(0x007C7721), UINT32_C(0x000CEDDA), UINT32_C(0x00220C78),
10373           UINT32_C(0x000FA861), UINT32_C(0x004B62AA), UINT32_C(0x000C4398),
10374           UINT32_C(0x001A528A), UINT32_C(0x001FA9C0)}},
10375         {{UINT32_C(0x00213FA6), UINT32_C(0x00303120), UINT32_C(0x002AB912),
10376           UINT32_C(0x00604140), UINT32_C(0x0025C250), UINT32_C(0x003C2A6C),
10377           UINT32_C(0x00322291), UINT32_C(0x0013477E), UINT32_C(0x001F06C8),
10378           UINT32_C(0x003B3F6A), UINT32_C(0x00283A23), UINT32_C(0x0038B2D8),
10379           UINT32_C(0x0029DD45), UINT32_C(0x002EBAA8), UINT32_C(0x001B3724),
10380           UINT32_C(0x00678E35), UINT32_C(0x00096D14), UINT32_C(0x0027B787),
10381           UINT32_C(0x0007AA23), UINT32_C(0x0025F092), UINT32_C(0x002170F1),
10382           UINT32_C(0x001BC371), UINT32_C(0x003AED1A)},
10383          {UINT32_C(0x00425B32), UINT32_C(0x00286AA0), UINT32_C(0x00023581),
10384           UINT32_C(0x006EE73F), UINT32_C(0x001E5A3B), UINT32_C(0x0030D82F),
10385           UINT32_C(0x002D1CA8), UINT32_C(0x006A5FF6), UINT32_C(0x001470F9),
10386           UINT32_C(0x00161816), UINT32_C(0x002350CB), UINT32_C(0x00113D17),
10387           UINT32_C(0x003F9A5E), UINT32_C(0x003C7C27), UINT32_C(0x00276EA7),
10388           UINT32_C(0x000CC5E8), UINT32_C(0x003022F0), UINT32_C(0x00293E6C),
10389           UINT32_C(0x001948B1), UINT32_C(0x00043775), UINT32_C(0x003051DB),
10390           UINT32_C(0x003D4E8F), UINT32_C(0x0016EAD0)}},
10391     },
10392     {
10393         {{UINT32_C(0x000E7229), UINT32_C(0x001A6628), UINT32_C(0x003C1B89),
10394           UINT32_C(0x001DEF3A), UINT32_C(0x0005F8AB), UINT32_C(0x00178896),
10395           UINT32_C(0x00120D1F), UINT32_C(0x00035812), UINT32_C(0x002204C7),
10396           UINT32_C(0x0025B252), UINT32_C(0x002627D9), UINT32_C(0x00295A6A),
10397           UINT32_C(0x00064F84), UINT32_C(0x002DD46E), UINT32_C(0x0018C55B),
10398           UINT32_C(0x0076AC5A), UINT32_C(0x0024BECB), UINT32_C(0x000D610A),
10399           UINT32_C(0x003CF93D), UINT32_C(0x0025BA10), UINT32_C(0x0001D8FF),
10400           UINT32_C(0x00111DC7), UINT32_C(0x001BA971)},
10401          {UINT32_C(0x00079874), UINT32_C(0x002A9BC0), UINT32_C(0x000AE07A),
10402           UINT32_C(0x002B976D), UINT32_C(0x0037698A), UINT32_C(0x001EFD5D),
10403           UINT32_C(0x00355FBE), UINT32_C(0x000FC35F), UINT32_C(0x003A64A2),
10404           UINT32_C(0x0037BE03), UINT32_C(0x002E85B5), UINT32_C(0x001D3118),
10405           UINT32_C(0x0027921A), UINT32_C(0x000C7471), UINT32_C(0x002BCAB5),
10406           UINT32_C(0x0033AB97), UINT32_C(0x0001C915), UINT32_C(0x0019A901),
10407           UINT32_C(0x001D2E71), UINT32_C(0x002A197E), UINT32_C(0x00115A8D),
10408           UINT32_C(0x0024BF73), UINT32_C(0x0003CC85)}},
10409         {{UINT32_C(0x002895B2), UINT32_C(0x00320735), UINT32_C(0x000CFB47),
10410           UINT32_C(0x003DB761), UINT32_C(0x0024C433), UINT32_C(0x0013E23C),
10411           UINT32_C(0x002BF3DF), UINT32_C(0x0050A160), UINT32_C(0x000ED8DF),
10412           UINT32_C(0x00023DC8), UINT32_C(0x0022ADA6), UINT32_C(0x0055A62F),
10413           UINT32_C(0x00118219), UINT32_C(0x00055FC7), UINT32_C(0x0016FC9A),
10414           UINT32_C(0x0019CDAC), UINT32_C(0x001F6533), UINT32_C(0x0039DEF8),
10415           UINT32_C(0x00365EB0), UINT32_C(0x001DE6A4), UINT32_C(0x002EC097),
10416           UINT32_C(0x0014ABA8), UINT32_C(0x003B186E)},
10417          {UINT32_C(0x0076F84F), UINT32_C(0x000A6360), UINT32_C(0x00389AFC),
10418           UINT32_C(0x007F347C), UINT32_C(0x0010F3A6), UINT32_C(0x0020172F),
10419           UINT32_C(0x002456C5), UINT32_C(0x0074D6FD), UINT32_C(0x003EBC5A),
10420           UINT32_C(0x0015702D), UINT32_C(0x002C322D), UINT32_C(0x0062EC4A),
10421           UINT32_C(0x001C6321), UINT32_C(0x001ECEE0), UINT32_C(0x000C4DCD),
10422           UINT32_C(0x00385F54), UINT32_C(0x0015A2F6), UINT32_C(0x003EA398),
10423           UINT32_C(0x00154A9E), UINT32_C(0x0035549D), UINT32_C(0x002902A3),
10424           UINT32_C(0x000E87D8), UINT32_C(0x002197A4)}},
10425         {{UINT32_C(0x000E5E61), UINT32_C(0x0004D26C), UINT32_C(0x0006E668),
10426           UINT32_C(0x00001B95), UINT32_C(0x0022CEB8), UINT32_C(0x002AD340),
10427           UINT32_C(0x00178FFF), UINT32_C(0x0068E92D), UINT32_C(0x001CE560),
10428           UINT32_C(0x00314785), UINT32_C(0x003C340C), UINT32_C(0x000E0359),
10429           UINT32_C(0x0012093F), UINT32_C(0x00126D05), UINT32_C(0x0001A73F),
10430           UINT32_C(0x006AADBB), UINT32_C(0x002D01CE), UINT32_C(0x001E4C4C),
10431           UINT32_C(0x0019B1E1), UINT32_C(0x001E252E), UINT32_C(0x0027C32F),
10432           UINT32_C(0x0027F7C8), UINT32_C(0x00274554)},
10433          {UINT32_C(0x0047C011), UINT32_C(0x0016AC83), UINT32_C(0x001C5FD0),
10434           UINT32_C(0x002B42DE), UINT32_C(0x00108C9B), UINT32_C(0x003E5C82),
10435           UINT32_C(0x001F47C2), UINT32_C(0x0067643D), UINT32_C(0x00253B0C),
10436           UINT32_C(0x003B23F4), UINT32_C(0x00285E6A), UINT32_C(0x0000127F),
10437           UINT32_C(0x001AFEDD), UINT32_C(0x001639C8), UINT32_C(0x0035C65D),
10438           UINT32_C(0x003890F9), UINT32_C(0x0026D0AD), UINT32_C(0x0024695D),
10439           UINT32_C(0x0033FF31), UINT32_C(0x00166142), UINT32_C(0x0032EBDF),
10440           UINT32_C(0x000D509E), UINT32_C(0x00190DE4)}},
10441         {{UINT32_C(0x005E3F2E), UINT32_C(0x0010C08C), UINT32_C(0x0010E26F),
10442           UINT32_C(0x0025A315), UINT32_C(0x0009E64F), UINT32_C(0x00002605),
10443           UINT32_C(0x003601E3), UINT32_C(0x00634D76), UINT32_C(0x003BFCD4),
10444           UINT32_C(0x00123253), UINT32_C(0x001D94E0), UINT32_C(0x003E9F61),
10445           UINT32_C(0x0025A1E6), UINT32_C(0x00075853), UINT32_C(0x001EC114),
10446           UINT32_C(0x00470547), UINT32_C(0x003E437A), UINT32_C(0x0019ED05),
10447           UINT32_C(0x00061623), UINT32_C(0x0038D391), UINT32_C(0x0031CCDE),
10448           UINT32_C(0x003374B4), UINT32_C(0x0007C7B9)},
10449          {UINT32_C(0x00512F62), UINT32_C(0x002E17FE), UINT32_C(0x0036CB08),
10450           UINT32_C(0x001BDB9E), UINT32_C(0x00394D71), UINT32_C(0x002A7EF7),
10451           UINT32_C(0x002E6818), UINT32_C(0x005F5A88), UINT32_C(0x00311E36),
10452           UINT32_C(0x002A6BB1), UINT32_C(0x0019CD43), UINT32_C(0x0045542F),
10453           UINT32_C(0x002B8CEA), UINT32_C(0x000FA346), UINT32_C(0x002E1A7A),
10454           UINT32_C(0x000BD16F), UINT32_C(0x00245C8D), UINT32_C(0x00314F13),
10455           UINT32_C(0x000FFBE8), UINT32_C(0x0056B54A), UINT32_C(0x00382922),
10456           UINT32_C(0x0035F251), UINT32_C(0x003ACEB3)}},
10457         {{UINT32_C(0x003E11B5), UINT32_C(0x0002716B), UINT32_C(0x002750E4),
10458           UINT32_C(0x003740A5), UINT32_C(0x00338906), UINT32_C(0x0013B5F0),
10459           UINT32_C(0x0027CFAE), UINT32_C(0x004AA6D3), UINT32_C(0x0039E3B9),
10460           UINT32_C(0x002D1B9F), UINT32_C(0x000035D9), UINT32_C(0x001E459B),
10461           UINT32_C(0x000CF781), UINT32_C(0x0020167F), UINT32_C(0x001BB777),
10462           UINT32_C(0x0038BA4C), UINT32_C(0x0028F2E3), UINT32_C(0x0037D8D5),
10463           UINT32_C(0x001ECF87), UINT32_C(0x004E758A), UINT32_C(0x002AA667),
10464           UINT32_C(0x002E97A6), UINT32_C(0x00352507)},
10465          {UINT32_C(0x00283BBD), UINT32_C(0x00263775), UINT32_C(0x000C63C9),
10466           UINT32_C(0x00001EE4), UINT32_C(0x003ACBBF), UINT32_C(0x00162A58),
10467           UINT32_C(0x0007B4FE), UINT32_C(0x00351728), UINT32_C(0x001973F1),
10468           UINT32_C(0x002770E0), UINT32_C(0x003116FA), UINT32_C(0x0046EBBD),
10469           UINT32_C(0x002C2896), UINT32_C(0x0036E872), UINT32_C(0x0013137C),
10470           UINT32_C(0x002F444F), UINT32_C(0x003B3375), UINT32_C(0x0003C6AB),
10471           UINT32_C(0x000FCBE7), UINT32_C(0x006D9063), UINT32_C(0x0020E15A),
10472           UINT32_C(0x000D5454), UINT32_C(0x0037BDB0)}},
10473         {{UINT32_C(0x00439E00), UINT32_C(0x001E43D1), UINT32_C(0x003DE476),
10474           UINT32_C(0x00148953), UINT32_C(0x0025C9E8), UINT32_C(0x001B6D92),
10475           UINT32_C(0x000AA405), UINT32_C(0x0040CB85), UINT32_C(0x00310A15),
10476           UINT32_C(0x003D0034), UINT32_C(0x001ACFB7), UINT32_C(0x00171502),
10477           UINT32_C(0x0034B2C2), UINT32_C(0x0027FB5D), UINT32_C(0x003B0085),
10478           UINT32_C(0x00344898), UINT32_C(0x003CA33C), UINT32_C(0x001BAF56),
10479           UINT32_C(0x00021B32), UINT32_C(0x00448603), UINT32_C(0x00091BA6),
10480           UINT32_C(0x000BAFC4), UINT32_C(0x0013D5A4)},
10481          {UINT32_C(0x00780D50), UINT32_C(0x0004D808), UINT32_C(0x002F1F9D),
10482           UINT32_C(0x006E9B4E), UINT32_C(0x001EDD73), UINT32_C(0x000A2602),
10483           UINT32_C(0x0032564D), UINT32_C(0x000A5962), UINT32_C(0x002D65F0),
10484           UINT32_C(0x001FF6E8), UINT32_C(0x00263DE7), UINT32_C(0x0028B02D),
10485           UINT32_C(0x000E0A8D), UINT32_C(0x002AE55E), UINT32_C(0x002EAA0B),
10486           UINT32_C(0x00508B9C), UINT32_C(0x002CA2CC), UINT32_C(0x0039B8A4),
10487           UINT32_C(0x000CF2D9), UINT32_C(0x002B0C05), UINT32_C(0x0036C4C9),
10488           UINT32_C(0x00115406), UINT32_C(0x003A4458)}},
10489         {{UINT32_C(0x001A9FEF), UINT32_C(0x0017C5B8), UINT32_C(0x0014F927),
10490           UINT32_C(0x0033E7CA), UINT32_C(0x001DE04B), UINT32_C(0x0021489F),
10491           UINT32_C(0x003223E7), UINT32_C(0x007F4816), UINT32_C(0x0016233A),
10492           UINT32_C(0x000E408A), UINT32_C(0x0025911C), UINT32_C(0x006CFEEF),
10493           UINT32_C(0x00162D98), UINT32_C(0x001FB3B2), UINT32_C(0x000CAFE2),
10494           UINT32_C(0x00140C69), UINT32_C(0x00373513), UINT32_C(0x0005EFAF),
10495           UINT32_C(0x00318C8D), UINT32_C(0x001ED26D), UINT32_C(0x0023E013),
10496           UINT32_C(0x000E235E), UINT32_C(0x002D6FB0)},
10497          {UINT32_C(0x004D9693), UINT32_C(0x0018038F), UINT32_C(0x001CF661),
10498           UINT32_C(0x002F57EB), UINT32_C(0x001E346F), UINT32_C(0x0030F7B0),
10499           UINT32_C(0x001DD4F8), UINT32_C(0x002D4964), UINT32_C(0x003D7230),
10500           UINT32_C(0x000FA730), UINT32_C(0x001D142C), UINT32_C(0x002276EA),
10501           UINT32_C(0x001BA178), UINT32_C(0x001466BF), UINT32_C(0x000BF8C5),
10502           UINT32_C(0x0040D605), UINT32_C(0x002D85AB), UINT32_C(0x001F11D4),
10503           UINT32_C(0x0016C7D7), UINT32_C(0x000AA5D0), UINT32_C(0x00359550),
10504           UINT32_C(0x0029A075), UINT32_C(0x00122CA4)}},
10505         {{UINT32_C(0x0072B845), UINT32_C(0x001BEE64), UINT32_C(0x0030577D),
10506           UINT32_C(0x006BAF51), UINT32_C(0x0024885D), UINT32_C(0x002BA5B1),
10507           UINT32_C(0x00236704), UINT32_C(0x000346DC), UINT32_C(0x002A639E),
10508           UINT32_C(0x003AF226), UINT32_C(0x002EA89E), UINT32_C(0x0026AF84),
10509           UINT32_C(0x00004D4C), UINT32_C(0x0003640E), UINT32_C(0x001D8986),
10510           UINT32_C(0x000E2826), UINT32_C(0x000D1018), UINT32_C(0x002CB972),
10511           UINT32_C(0x0009688A), UINT32_C(0x000489A0), UINT32_C(0x002E4F56),
10512           UINT32_C(0x003DD33C), UINT32_C(0x003609BA)},
10513          {UINT32_C(0x001692AF), UINT32_C(0x002C1F96), UINT32_C(0x003792D8),
10514           UINT32_C(0x00069079), UINT32_C(0x0016ED4A), UINT32_C(0x003B5304),
10515           UINT32_C(0x000FA6CC), UINT32_C(0x0018593E), UINT32_C(0x0000C409),
10516           UINT32_C(0x0004E36E), UINT32_C(0x0003E4B0), UINT32_C(0x0018A207),
10517           UINT32_C(0x00146BF4), UINT32_C(0x001CBDA5), UINT32_C(0x0011B878),
10518           UINT32_C(0x0062A10E), UINT32_C(0x0002D181), UINT32_C(0x001D3599),
10519           UINT32_C(0x00185943), UINT32_C(0x00609AB4), UINT32_C(0x002218D4),
10520           UINT32_C(0x003653F8), UINT32_C(0x0019F9FD)}},
10521         {{UINT32_C(0x002ED6C7), UINT32_C(0x003C5236), UINT32_C(0x00186569),
10522           UINT32_C(0x00428772), UINT32_C(0x003A69E3), UINT32_C(0x00087BF9),
10523           UINT32_C(0x003E9E5F), UINT32_C(0x003AE8B4), UINT32_C(0x003504F3),
10524           UINT32_C(0x000A8276), UINT32_C(0x003C584F), UINT32_C(0x0069143D),
10525           UINT32_C(0x002C8325), UINT32_C(0x000FFE9F), UINT32_C(0x00191129),
10526           UINT32_C(0x00319B36), UINT32_C(0x00115E02), UINT32_C(0x0016E07A),
10527           UINT32_C(0x002FA414), UINT32_C(0x0014619E), UINT32_C(0x0012CD22),
10528           UINT32_C(0x002D0E0D), UINT32_C(0x00125784)},
10529          {UINT32_C(0x00642A65), UINT32_C(0x00203D55), UINT32_C(0x0016C315),
10530           UINT32_C(0x003CF7A9), UINT32_C(0x003071DE), UINT32_C(0x00106DAE),
10531           UINT32_C(0x000B2C7D), UINT32_C(0x0047BA31), UINT32_C(0x002CA388),
10532           UINT32_C(0x0029FBFC), UINT32_C(0x00390EAC), UINT32_C(0x0057CD61),
10533           UINT32_C(0x0021CF36), UINT32_C(0x0034A05C), UINT32_C(0x00008B13),
10534           UINT32_C(0x00793DB5), UINT32_C(0x0017E8E7), UINT32_C(0x0035D12F),
10535           UINT32_C(0x003D6716), UINT32_C(0x004C990F), UINT32_C(0x003B6448),
10536           UINT32_C(0x000A7F2C), UINT32_C(0x0025B5C5)}},
10537         {{UINT32_C(0x005E98D9), UINT32_C(0x0026DFA6), UINT32_C(0x000864C2),
10538           UINT32_C(0x002E69DF), UINT32_C(0x00364C2C), UINT32_C(0x000D5FD3),
10539           UINT32_C(0x001356CE), UINT32_C(0x00454A4C), UINT32_C(0x003B0302),
10540           UINT32_C(0x0016D23C), UINT32_C(0x000B4AAA), UINT32_C(0x0057F380),
10541           UINT32_C(0x0007CFAC), UINT32_C(0x0027103B), UINT32_C(0x000CAA2B),
10542           UINT32_C(0x005B3BDE), UINT32_C(0x000D252E), UINT32_C(0x002FC387),
10543           UINT32_C(0x001B39E0), UINT32_C(0x003C0113), UINT32_C(0x0009ADA1),
10544           UINT32_C(0x002D5182), UINT32_C(0x00029B37)},
10545          {UINT32_C(0x003B5C86), UINT32_C(0x002985B6), UINT32_C(0x00193F46),
10546           UINT32_C(0x007D3FF4), UINT32_C(0x0017EA07), UINT32_C(0x003167A4),
10547           UINT32_C(0x0028ECD5), UINT32_C(0x00102560), UINT32_C(0x0014D8CD),
10548           UINT32_C(0x0009D70A), UINT32_C(0x0036C65B), UINT32_C(0x0077810C),
10549           UINT32_C(0x0038B843), UINT32_C(0x000AAA4F), UINT32_C(0x000423CC),
10550           UINT32_C(0x00609B5A), UINT32_C(0x000B047D), UINT32_C(0x0032FCF2),
10551           UINT32_C(0x00341089), UINT32_C(0x002F82CA), UINT32_C(0x0012D7A7),
10552           UINT32_C(0x002D3F89), UINT32_C(0x00189DD5)}},
10553         {{UINT32_C(0x0066582F), UINT32_C(0x00257453), UINT32_C(0x00210314),
10554           UINT32_C(0x0062A225), UINT32_C(0x00165C3B), UINT32_C(0x002E6592),
10555           UINT32_C(0x002F1436), UINT32_C(0x005EE3F8), UINT32_C(0x0007F555),
10556           UINT32_C(0x0020F441), UINT32_C(0x0034ED55), UINT32_C(0x00308313),
10557           UINT32_C(0x0034A8DF), UINT32_C(0x0019301D), UINT32_C(0x00173FDB),
10558           UINT32_C(0x00144214), UINT32_C(0x0019892A), UINT32_C(0x0027897A),
10559           UINT32_C(0x0021A061), UINT32_C(0x007D24B8), UINT32_C(0x0037F3B1),
10560           UINT32_C(0x00248CC2), UINT32_C(0x00373DB3)},
10561          {UINT32_C(0x000BF27A), UINT32_C(0x0039D46B), UINT32_C(0x001AD6FE),
10562           UINT32_C(0x00475AC8), UINT32_C(0x00063B06), UINT32_C(0x00233FD2),
10563           UINT32_C(0x0035C0AF), UINT32_C(0x006C6594), UINT32_C(0x002F3CD2),
10564           UINT32_C(0x0015DF1B), UINT32_C(0x002DF565), UINT32_C(0x0022D72E),
10565           UINT32_C(0x0004B112), UINT32_C(0x00022C9B), UINT32_C(0x00217D30),
10566           UINT32_C(0x00586404), UINT32_C(0x00175C8A), UINT32_C(0x003CD70E),
10567           UINT32_C(0x003F9D96), UINT32_C(0x007351B7), UINT32_C(0x00328F89),
10568           UINT32_C(0x00339645), UINT32_C(0x00147D37)}},
10569         {{UINT32_C(0x0006ACC7), UINT32_C(0x0017F7BC), UINT32_C(0x00043BCE),
10570           UINT32_C(0x00259C1D), UINT32_C(0x002CDB37), UINT32_C(0x0007238C),
10571           UINT32_C(0x00375E6F), UINT32_C(0x00022971), UINT32_C(0x001B4942),
10572           UINT32_C(0x003E301A), UINT32_C(0x00389E0C), UINT32_C(0x0014070B),
10573           UINT32_C(0x0029DEFC), UINT32_C(0x002DDAC4), UINT32_C(0x00236616),
10574           UINT32_C(0x0000A23A), UINT32_C(0x003BA71B), UINT32_C(0x00230957),
10575           UINT32_C(0x002229EB), UINT32_C(0x0073C8F9), UINT32_C(0x0025DF6A),
10576           UINT32_C(0x002BADCB), UINT32_C(0x000F1344)},
10577          {UINT32_C(0x001BEE3F), UINT32_C(0x001FA015), UINT32_C(0x000CFE6E),
10578           UINT32_C(0x006FB0F7), UINT32_C(0x003C54F5), UINT32_C(0x003503D8),
10579           UINT32_C(0x000B28FC), UINT32_C(0x0001F5C0), UINT32_C(0x00104298),
10580           UINT32_C(0x003AF43A), UINT32_C(0x003A5408), UINT32_C(0x0018DAC0),
10581           UINT32_C(0x0032EE35), UINT32_C(0x0031C65F), UINT32_C(0x000B31F5),
10582           UINT32_C(0x0018B829), UINT32_C(0x000133FD), UINT32_C(0x00280CF1),
10583           UINT32_C(0x00206DF2), UINT32_C(0x0009D76F), UINT32_C(0x001DC987),
10584           UINT32_C(0x00365635), UINT32_C(0x0014E280)}},
10585         {{UINT32_C(0x0052A016), UINT32_C(0x0006F577), UINT32_C(0x001C0241),
10586           UINT32_C(0x005E5024), UINT32_C(0x000DA944), UINT32_C(0x000855A1),
10587           UINT32_C(0x002A89F3), UINT32_C(0x000E86B5), UINT32_C(0x000CEF59),
10588           UINT32_C(0x003E508E), UINT32_C(0x00384B7E), UINT32_C(0x0032AAA5),
10589           UINT32_C(0x0018FF8F), UINT32_C(0x002CD18E), UINT32_C(0x00040821),
10590           UINT32_C(0x00189644), UINT32_C(0x002DEB40), UINT32_C(0x00132C27),
10591           UINT32_C(0x000B3030), UINT32_C(0x0054A603), UINT32_C(0x0006BBED),
10592           UINT32_C(0x0031D103), UINT32_C(0x002F003F)},
10593          {UINT32_C(0x001E656D), UINT32_C(0x002FF583), UINT32_C(0x0012A61F),
10594           UINT32_C(0x00346DBE), UINT32_C(0x002A6FB1), UINT32_C(0x0011FD3B),
10595           UINT32_C(0x0001276C), UINT32_C(0x006148C0), UINT32_C(0x00016501),
10596           UINT32_C(0x000C96D4), UINT32_C(0x003DB630), UINT32_C(0x00492C8D),
10597           UINT32_C(0x00057FDE), UINT32_C(0x000CF96C), UINT32_C(0x000164CA),
10598           UINT32_C(0x004FCB96), UINT32_C(0x00385504), UINT32_C(0x003E5188),
10599           UINT32_C(0x00286382), UINT32_C(0x0041E093), UINT32_C(0x0002DAB5),
10600           UINT32_C(0x0010BB0F), UINT32_C(0x0000784C)}},
10601         {{UINT32_C(0x0075746D), UINT32_C(0x003F9D7D), UINT32_C(0x002D54D0),
10602           UINT32_C(0x000CA2BA), UINT32_C(0x0034E004), UINT32_C(0x00145EDC),
10603           UINT32_C(0x0024946A), UINT32_C(0x002B2267), UINT32_C(0x0029D5D7),
10604           UINT32_C(0x001BD561), UINT32_C(0x00040FF1), UINT32_C(0x007A8818),
10605           UINT32_C(0x000347CA), UINT32_C(0x00368968), UINT32_C(0x003DFBFD),
10606           UINT32_C(0x0045E779), UINT32_C(0x0028CB15), UINT32_C(0x0006FE47),
10607           UINT32_C(0x002AE3AD), UINT32_C(0x000C1917), UINT32_C(0x001A6E74),
10608           UINT32_C(0x000C0AAF), UINT32_C(0x001EAD78)},
10609          {UINT32_C(0x0013957A), UINT32_C(0x000B13A3), UINT32_C(0x002FC29D),
10610           UINT32_C(0x00318258), UINT32_C(0x000316AF), UINT32_C(0x00159186),
10611           UINT32_C(0x002F9ACE), UINT32_C(0x002617A1), UINT32_C(0x002DA110),
10612           UINT32_C(0x0024827F), UINT32_C(0x0014B7E3), UINT32_C(0x005A1108),
10613           UINT32_C(0x002AD5AB), UINT32_C(0x001F8CD8), UINT32_C(0x00280CBB),
10614           UINT32_C(0x000F3352), UINT32_C(0x0021699D), UINT32_C(0x003D79ED),
10615           UINT32_C(0x000F2342), UINT32_C(0x000A46DF), UINT32_C(0x000765C5),
10616           UINT32_C(0x001562AA), UINT32_C(0x001933BE)}},
10617         {{UINT32_C(0x00771DC4), UINT32_C(0x00105963), UINT32_C(0x0013309E),
10618           UINT32_C(0x002D5F9C), UINT32_C(0x003816E4), UINT32_C(0x00183FD1),
10619           UINT32_C(0x0024CC65), UINT32_C(0x004C32C8), UINT32_C(0x00023344),
10620           UINT32_C(0x00127581), UINT32_C(0x00170A08), UINT32_C(0x003E271B),
10621           UINT32_C(0x00376C4A), UINT32_C(0x00378FA8), UINT32_C(0x0038BD67),
10622           UINT32_C(0x006DD9F1), UINT32_C(0x0013CB77), UINT32_C(0x00110A9A),
10623           UINT32_C(0x0011B015), UINT32_C(0x003AB2F7), UINT32_C(0x00203C14),
10624           UINT32_C(0x0037D1D9), UINT32_C(0x0017F513)},
10625          {UINT32_C(0x00383DC1), UINT32_C(0x0032B2DC), UINT32_C(0x003F0168),
10626           UINT32_C(0x00279081), UINT32_C(0x001E4F82), UINT32_C(0x00183A42),
10627           UINT32_C(0x000BFB80), UINT32_C(0x005A12C9), UINT32_C(0x00186FCD),
10628           UINT32_C(0x002E7365), UINT32_C(0x0026CDDE), UINT32_C(0x007856A6),
10629           UINT32_C(0x00241080), UINT32_C(0x000BB921), UINT32_C(0x003E1A85),
10630           UINT32_C(0x0062D604), UINT32_C(0x000BB5D8), UINT32_C(0x0026B482),
10631           UINT32_C(0x0019F5D5), UINT32_C(0x0028F3DC), UINT32_C(0x00143FEB),
10632           UINT32_C(0x003E5ADA), UINT32_C(0x00253DEF)}},
10633         {{UINT32_C(0x006BA123), UINT32_C(0x000A781D), UINT32_C(0x000B7D51),
10634           UINT32_C(0x00740F38), UINT32_C(0x002940F6), UINT32_C(0x00157C6F),
10635           UINT32_C(0x003E02CE), UINT32_C(0x007207C6), UINT32_C(0x001B64BC),
10636           UINT32_C(0x00372F37), UINT32_C(0x003A87CB), UINT32_C(0x002D7712),
10637           UINT32_C(0x001B97D4), UINT32_C(0x00391CB2), UINT32_C(0x003AB655),
10638           UINT32_C(0x00002E6F), UINT32_C(0x002C7D2F), UINT32_C(0x002AA52F),
10639           UINT32_C(0x0032378F), UINT32_C(0x0072D63D), UINT32_C(0x0038FA33),
10640           UINT32_C(0x003C9DB3), UINT32_C(0x0008013D)},
10641          {UINT32_C(0x0002066C), UINT32_C(0x0035DFEF), UINT32_C(0x001BC43F),
10642           UINT32_C(0x0029FB46), UINT32_C(0x0013F28B), UINT32_C(0x002A9E1C),
10643           UINT32_C(0x00316CE9), UINT32_C(0x002537F0), UINT32_C(0x002F07AC),
10644           UINT32_C(0x0037B3FA), UINT32_C(0x000BB76B), UINT32_C(0x0049349E),
10645           UINT32_C(0x00330713), UINT32_C(0x002755E1), UINT32_C(0x002928A9),
10646           UINT32_C(0x00636D8A), UINT32_C(0x0036549D), UINT32_C(0x00119414),
10647           UINT32_C(0x002CF725), UINT32_C(0x0037181E), UINT32_C(0x0001A2BC),
10648           UINT32_C(0x0019DA46), UINT32_C(0x003B690A)}},
10649     },
10650     {
10651         {{UINT32_C(0x0032A280), UINT32_C(0x001CB2CC), UINT32_C(0x000F9796),
10652           UINT32_C(0x00007D75), UINT32_C(0x001AF2EB), UINT32_C(0x003C758A),
10653           UINT32_C(0x003A6728), UINT32_C(0x0043B3E9), UINT32_C(0x00188CE5),
10654           UINT32_C(0x0029D0A4), UINT32_C(0x000113A0), UINT32_C(0x0022343F),
10655           UINT32_C(0x000890D8), UINT32_C(0x0012176A), UINT32_C(0x002971B0),
10656           UINT32_C(0x00785A55), UINT32_C(0x0001C0B7), UINT32_C(0x00273262),
10657           UINT32_C(0x002D06D6), UINT32_C(0x0006C271), UINT32_C(0x001E07EA),
10658           UINT32_C(0x003A1542), UINT32_C(0x0026C181)},
10659          {UINT32_C(0x00414498), UINT32_C(0x0014CB47), UINT32_C(0x000FFCA6),
10660           UINT32_C(0x002D51CC), UINT32_C(0x000008D4), UINT32_C(0x00244EA0),
10661           UINT32_C(0x002F062C), UINT32_C(0x000336A8), UINT32_C(0x00150722),
10662           UINT32_C(0x0019F588), UINT32_C(0x000CB860), UINT32_C(0x00604BC3),
10663           UINT32_C(0x0008902B), UINT32_C(0x003D5ADC), UINT32_C(0x00088D53),
10664           UINT32_C(0x000A2728), UINT32_C(0x003852C8), UINT32_C(0x001CE562),
10665           UINT32_C(0x003D7474), UINT32_C(0x000E17F9), UINT32_C(0x000ADBDE),
10666           UINT32_C(0x0002F321), UINT32_C(0x002B5370)}},
10667         {{UINT32_C(0x00720956), UINT32_C(0x0012FE7D), UINT32_C(0x003A4010),
10668           UINT32_C(0x0005E1F1), UINT32_C(0x002FCF68), UINT32_C(0x0001CA0D),
10669           UINT32_C(0x001F9A09), UINT32_C(0x00476576), UINT32_C(0x001BBE6F),
10670           UINT32_C(0x00157A43), UINT32_C(0x00041B45), UINT32_C(0x0069B21A),
10671           UINT32_C(0x0011A874), UINT32_C(0x00237329), UINT32_C(0x0010ABF2),
10672           UINT32_C(0x004A1BCF), UINT32_C(0x00248B43), UINT32_C(0x0039B567),
10673           UINT32_C(0x00162490), UINT32_C(0x002F2BDB), UINT32_C(0x00296C0C),
10674           UINT32_C(0x000A4FEE), UINT32_C(0x0004AD98)},
10675          {UINT32_C(0x004454EB), UINT32_C(0x002C8099), UINT32_C(0x0010E84D),
10676           UINT32_C(0x002E2241), UINT32_C(0x003207CA), UINT32_C(0x000F5910),
10677           UINT32_C(0x0003F04F), UINT32_C(0x00392613), UINT32_C(0x000ADE9F),
10678           UINT32_C(0x003DBD57), UINT32_C(0x0030B86D), UINT32_C(0x0009CC16),
10679           UINT32_C(0x000A209A), UINT32_C(0x003C2AFA), UINT32_C(0x00035E76),
10680           UINT32_C(0x005F940A), UINT32_C(0x002B2161), UINT32_C(0x000C7D9D),
10681           UINT32_C(0x00363B77), UINT32_C(0x0077A201), UINT32_C(0x00399B44),
10682           UINT32_C(0x0008E94D), UINT32_C(0x00008286)}},
10683         {{UINT32_C(0x002B92BC), UINT32_C(0x0006153E), UINT32_C(0x0000F8C6),
10684           UINT32_C(0x005F1B6C), UINT32_C(0x0003BA49), UINT32_C(0x001A925E),
10685           UINT32_C(0x000F9BBA), UINT32_C(0x00055F92), UINT32_C(0x002FBD92),
10686           UINT32_C(0x002177A5), UINT32_C(0x003FB8F5), UINT32_C(0x005D4BF2),
10687           UINT32_C(0x002146D4), UINT32_C(0x0036976B), UINT32_C(0x0022B1BA),
10688           UINT32_C(0x0032F949), UINT32_C(0x000965FD), UINT32_C(0x001E9F3E),
10689           UINT32_C(0x002DA23B), UINT32_C(0x00107070), UINT32_C(0x00398A1E),
10690           UINT32_C(0x00069BFE), UINT32_C(0x002FDDC0)},
10691          {UINT32_C(0x0072B741), UINT32_C(0x003D395C), UINT32_C(0x003A9B25),
10692           UINT32_C(0x00294646), UINT32_C(0x00021148), UINT32_C(0x0015DA45),
10693           UINT32_C(0x00113C40), UINT32_C(0x00419E05), UINT32_C(0x003F3B62),
10694           UINT32_C(0x001F8475), UINT32_C(0x0006EE22), UINT32_C(0x0066BC79),
10695           UINT32_C(0x0008B7CC), UINT32_C(0x00023931), UINT32_C(0x00167FA8),
10696           UINT32_C(0x003BD93E), UINT32_C(0x0039EE3D), UINT32_C(0x001DFEEA),
10697           UINT32_C(0x001FDCFE), UINT32_C(0x00613DB2), UINT32_C(0x00160B1F),
10698           UINT32_C(0x001970FE), UINT32_C(0x0023B0DD)}},
10699         {{UINT32_C(0x0023C1BA), UINT32_C(0x002E5121), UINT32_C(0x002C52E9),
10700           UINT32_C(0x007811E3), UINT32_C(0x0001A384), UINT32_C(0x002EABE1),
10701           UINT32_C(0x0024FBC8), UINT32_C(0x0045D98F), UINT32_C(0x001C8207),
10702           UINT32_C(0x0033DA7A), UINT32_C(0x0030B201), UINT32_C(0x0023DFB3),
10703           UINT32_C(0x0014CD7A), UINT32_C(0x000B9A13), UINT32_C(0x0029ED72),
10704           UINT32_C(0x003FDD61), UINT32_C(0x002FAEDB), UINT32_C(0x0016FDA9),
10705           UINT32_C(0x0006A7E0), UINT32_C(0x003CCE59), UINT32_C(0x00059683),
10706           UINT32_C(0x0034B4B3), UINT32_C(0x00344F10)},
10707          {UINT32_C(0x0064F192), UINT32_C(0x00121A7B), UINT32_C(0x001023D3),
10708           UINT32_C(0x004802FA), UINT32_C(0x000C0C74), UINT32_C(0x003436B0),
10709           UINT32_C(0x0028F327), UINT32_C(0x00104D43), UINT32_C(0x000B6D47),
10710           UINT32_C(0x003D9F11), UINT32_C(0x0038A86E), UINT32_C(0x0024B31C),
10711           UINT32_C(0x000D71F6), UINT32_C(0x0001075B), UINT32_C(0x00131E0B),
10712           UINT32_C(0x006451D8), UINT32_C(0x0023646D), UINT32_C(0x00185996),
10713           UINT32_C(0x00143B48), UINT32_C(0x0076F1C1), UINT32_C(0x000E8DA3),
10714           UINT32_C(0x002EB768), UINT32_C(0x003FBF6F)}},
10715         {{UINT32_C(0x004D2204), UINT32_C(0x002A5EA9), UINT32_C(0x00019369),
10716           UINT32_C(0x0070CD74), UINT32_C(0x001A76B1), UINT32_C(0x003815C4),
10717           UINT32_C(0x002E68F7), UINT32_C(0x005398A8), UINT32_C(0x0020AB8F),
10718           UINT32_C(0x00185D53), UINT32_C(0x00168C1D), UINT32_C(0x00274E1A),
10719           UINT32_C(0x000524F2), UINT32_C(0x003D9B1A), UINT32_C(0x0012E5AB),
10720           UINT32_C(0x004C1050), UINT32_C(0x0032ABC0), UINT32_C(0x0025971D),
10721           UINT32_C(0x003AC08F), UINT32_C(0x002F1AFC), UINT32_C(0x001407B9),
10722           UINT32_C(0x00277B2E), UINT32_C(0x001B1F71)},
10723          {UINT32_C(0x000D2E98), UINT32_C(0x0030B33B), UINT32_C(0x003037E7),
10724           UINT32_C(0x00425F13), UINT32_C(0x002EBDC3), UINT32_C(0x001D9BE6),
10725           UINT32_C(0x00111CD4), UINT32_C(0x007D7418), UINT32_C(0x001F1C08),
10726           UINT32_C(0x0027B843), UINT32_C(0x002D41E6), UINT32_C(0x004D0FDD),
10727           UINT32_C(0x00162312), UINT32_C(0x000A0EB8), UINT32_C(0x0004819A),
10728           UINT32_C(0x001E097B), UINT32_C(0x0000A336), UINT32_C(0x000C49B4),
10729           UINT32_C(0x001F6549), UINT32_C(0x0065532D), UINT32_C(0x00175C84),
10730           UINT32_C(0x0008B3CF), UINT32_C(0x001D68D8)}},
10731         {{UINT32_C(0x007E2EF2), UINT32_C(0x000CB9A8), UINT32_C(0x000968E6),
10732           UINT32_C(0x00367210), UINT32_C(0x00079EA4), UINT32_C(0x00115BCE),
10733           UINT32_C(0x002F228C), UINT32_C(0x007BE5BF), UINT32_C(0x003C8A27),
10734           UINT32_C(0x000C8607), UINT32_C(0x00319827), UINT32_C(0x006BF356),
10735           UINT32_C(0x00222BCA), UINT32_C(0x002D52EC), UINT32_C(0x001634C9),
10736           UINT32_C(0x00422BB5), UINT32_C(0x0020B569), UINT32_C(0x002745C9),
10737           UINT32_C(0x002547E2), UINT32_C(0x00692CC6), UINT32_C(0x00366369),
10738           UINT32_C(0x000C2F45), UINT32_C(0x002DCB38)},
10739          {UINT32_C(0x00432E57), UINT32_C(0x003BCE51), UINT32_C(0x002F50A1),
10740           UINT32_C(0x00010E21), UINT32_C(0x000B5704), UINT32_C(0x003603EC),
10741           UINT32_C(0x003DC6B0), UINT32_C(0x001D3C66), UINT32_C(0x003E876A),
10742           UINT32_C(0x001D2475), UINT32_C(0x003D0CFE), UINT32_C(0x00752FD6),
10743           UINT32_C(0x001389EE), UINT32_C(0x002682A3), UINT32_C(0x00006DE0),
10744           UINT32_C(0x00466661), UINT32_C(0x0025CA0B), UINT32_C(0x003A47DE),
10745           UINT32_C(0x001DBDDD), UINT32_C(0x00584C8D), UINT32_C(0x00097729),
10746           UINT32_C(0x003A3D36), UINT32_C(0x0026D79A)}},
10747         {{UINT32_C(0x0046DC32), UINT32_C(0x0039E30E), UINT32_C(0x001A553F),
10748           UINT32_C(0x00631635), UINT32_C(0x00137523), UINT32_C(0x0011F122),
10749           UINT32_C(0x0002887F), UINT32_C(0x0039C6A2), UINT32_C(0x003D3F52),
10750           UINT32_C(0x000E5C16), UINT32_C(0x001B4338), UINT32_C(0x001104AD),
10751           UINT32_C(0x0026AD2E), UINT32_C(0x000C1BE9), UINT32_C(0x000082A2),
10752           UINT32_C(0x0036D7B0), UINT32_C(0x003E62E1), UINT32_C(0x002AC82D),
10753           UINT32_C(0x00354EEE), UINT32_C(0x001B7162), UINT32_C(0x002F1507),
10754           UINT32_C(0x00064946), UINT32_C(0x002B777F)},
10755          {UINT32_C(0x00755CF4), UINT32_C(0x002F3F9D), UINT32_C(0x0027FBE0),
10756           UINT32_C(0x00250D1C), UINT32_C(0x003AD66C), UINT32_C(0x00220A36),
10757           UINT32_C(0x00324DD9), UINT32_C(0x000FD4E3), UINT32_C(0x002FB653),
10758           UINT32_C(0x001407E0), UINT32_C(0x0007BD23), UINT32_C(0x001BCA1B),
10759           UINT32_C(0x0023529D), UINT32_C(0x000512E2), UINT32_C(0x00322089),
10760           UINT32_C(0x0052FB0B), UINT32_C(0x00159218), UINT32_C(0x000A2629),
10761           UINT32_C(0x001ECC37), UINT32_C(0x000D691D), UINT32_C(0x001CDC35),
10762           UINT32_C(0x0025DECE), UINT32_C(0x0008B229)}},
10763         {{UINT32_C(0x00042A2E), UINT32_C(0x0002BECD), UINT32_C(0x000CE644),
10764           UINT32_C(0x007EB2C8), UINT32_C(0x000CDB86), UINT32_C(0x0038243C),
10765           UINT32_C(0x0013980F), UINT32_C(0x007DB14B), UINT32_C(0x003AF52F),
10766           UINT32_C(0x0034D34E), UINT32_C(0x00328903), UINT32_C(0x0012E910),
10767           UINT32_C(0x002F165C), UINT32_C(0x001F951B), UINT32_C(0x003DCC69),
10768           UINT32_C(0x006A2790), UINT32_C(0x001419B1), UINT32_C(0x003CD6D6),
10769           UINT32_C(0x000A88DC), UINT32_C(0x0065E513), UINT32_C(0x00038EAB),
10770           UINT32_C(0x000DA64E), UINT32_C(0x001E4802)},
10771          {UINT32_C(0x00411E28), UINT32_C(0x0038A31B), UINT32_C(0x000EA13F),
10772           UINT32_C(0x00692375), UINT32_C(0x003972E4), UINT32_C(0x003C7618),
10773           UINT32_C(0x0030675C), UINT32_C(0x000471A7), UINT32_C(0x001EAA31),
10774           UINT32_C(0x000332B8), UINT32_C(0x000BA219), UINT32_C(0x005949F6),
10775           UINT32_C(0x000721E9), UINT32_C(0x000B0539), UINT32_C(0x00351BFD),
10776           UINT32_C(0x006AF8C8), UINT32_C(0x001749B7), UINT32_C(0x001B4221),
10777           UINT32_C(0x00346E9F), UINT32_C(0x001D138C), UINT32_C(0x00315C0E),
10778           UINT32_C(0x003AE1BD), UINT32_C(0x001E5845)}},
10779         {{UINT32_C(0x0073DD11), UINT32_C(0x0038D066), UINT32_C(0x003B6E1E),
10780           UINT32_C(0x0058D879), UINT32_C(0x003FC188), UINT32_C(0x0026EA01),
10781           UINT32_C(0x003A5E72), UINT32_C(0x003EAE27), UINT32_C(0x0017EC7B),
10782           UINT32_C(0x0021435A), UINT32_C(0x0030A0EF), UINT32_C(0x00226F77),
10783           UINT32_C(0x00319511), UINT32_C(0x000EECC9), UINT32_C(0x00184FB1),
10784           UINT32_C(0x00485367), UINT32_C(0x0012DBCE), UINT32_C(0x00296D94),
10785           UINT32_C(0x001ECEF1), UINT32_C(0x0048A6EF), UINT32_C(0x000C1378),
10786           UINT32_C(0x000486F3), UINT32_C(0x00294CB6)},
10787          {UINT32_C(0x00659E15), UINT32_C(0x0021AFE5), UINT32_C(0x00035B7D),
10788           UINT32_C(0x0014905A), UINT32_C(0x00190940), UINT32_C(0x0028A11C),
10789           UINT32_C(0x003C2EC5), UINT32_C(0x0061D9FF), UINT32_C(0x003C91F9),
10790           UINT32_C(0x000C24F9), UINT32_C(0x0021D20C), UINT32_C(0x0069147F),
10791           UINT32_C(0x002C2485), UINT32_C(0x001F02A6), UINT32_C(0x001E436B),
10792           UINT32_C(0x0070B5EC), UINT32_C(0x003C8887), UINT32_C(0x000479C4),
10793           UINT32_C(0x00329212), UINT32_C(0x00023848), UINT32_C(0x000FD9D8),
10794           UINT32_C(0x001CA129), UINT32_C(0x002842CB)}},
10795         {{UINT32_C(0x007B92F5), UINT32_C(0x0037A067), UINT32_C(0x000074AF),
10796           UINT32_C(0x005B2F28), UINT32_C(0x000CBF5F), UINT32_C(0x00077719),
10797           UINT32_C(0x0015F2E0), UINT32_C(0x0016A3E7), UINT32_C(0x001CEB10),
10798           UINT32_C(0x0022F6C6), UINT32_C(0x003D1FA9), UINT32_C(0x004CD931),
10799           UINT32_C(0x001D7522), UINT32_C(0x001781A9), UINT32_C(0x003443CE),
10800           UINT32_C(0x006FA88B), UINT32_C(0x001564BA), UINT32_C(0x00110D1F),
10801           UINT32_C(0x0012896B), UINT32_C(0x000B6064), UINT32_C(0x00253009),
10802           UINT32_C(0x0007C604), UINT32_C(0x003E79C8)},
10803          {UINT32_C(0x0022EAC3), UINT32_C(0x001D3CBB), UINT32_C(0x001660EB),
10804           UINT32_C(0x00530D25), UINT32_C(0x001DDD46), UINT32_C(0x0038675B),
10805           UINT32_C(0x00270FCB), UINT32_C(0x0070D781), UINT32_C(0x0036DB98),
10806           UINT32_C(0x0010E11B), UINT32_C(0x0019CA07), UINT32_C(0x004B0308),
10807           UINT32_C(0x003E92E0), UINT32_C(0x00039F79), UINT32_C(0x002FAD1D),
10808           UINT32_C(0x0017B8FE), UINT32_C(0x001C8122), UINT32_C(0x0013FAE1),
10809           UINT32_C(0x00095301), UINT32_C(0x003B1103), UINT32_C(0x00031A89),
10810           UINT32_C(0x001447C4), UINT32_C(0x0009D34F)}},
10811         {{UINT32_C(0x007C8A6B), UINT32_C(0x002A2FE8), UINT32_C(0x0035E593),
10812           UINT32_C(0x004E1D4D), UINT32_C(0x0015A0B8), UINT32_C(0x0020842D),
10813           UINT32_C(0x0018D50D), UINT32_C(0x001081D4), UINT32_C(0x00126A85),
10814           UINT32_C(0x0005E191), UINT32_C(0x001BEF59), UINT32_C(0x005AA8B6),
10815           UINT32_C(0x003A3A60), UINT32_C(0x000ABF90), UINT32_C(0x0006196E),
10816           UINT32_C(0x00150E95), UINT32_C(0x000CB2DC), UINT32_C(0x000DDCD3),
10817           UINT32_C(0x003E2A72), UINT32_C(0x00582EAB), UINT32_C(0x0035F095),
10818           UINT32_C(0x0010E8B9), UINT32_C(0x002F9603)},
10819          {UINT32_C(0x00381ED7), UINT32_C(0x000655D9), UINT32_C(0x00270A8E),
10820           UINT32_C(0x00048245), UINT32_C(0x00309CD3), UINT32_C(0x0017ED44),
10821           UINT32_C(0x001D450E), UINT32_C(0x000312BA), UINT32_C(0x0005985D),
10822           UINT32_C(0x00358C0C), UINT32_C(0x002A7087), UINT32_C(0x0072F6C5),
10823           UINT32_C(0x00198D4B), UINT32_C(0x00266DA7), UINT32_C(0x0030D13D),
10824           UINT32_C(0x00164FAF), UINT32_C(0x001B3D2A), UINT32_C(0x00054328),
10825           UINT32_C(0x00297C8D), UINT32_C(0x0024974D), UINT32_C(0x000C4C24),
10826           UINT32_C(0x00233778), UINT32_C(0x000A3C4F)}},
10827         {{UINT32_C(0x0019EECE), UINT32_C(0x00162127), UINT32_C(0x001040AF),
10828           UINT32_C(0x001C475E), UINT32_C(0x00239506), UINT32_C(0x0009AF50),
10829           UINT32_C(0x001C9807), UINT32_C(0x003FA8CC), UINT32_C(0x003128F6),
10830           UINT32_C(0x00045734), UINT32_C(0x001442AC), UINT32_C(0x0047E27E),
10831           UINT32_C(0x003215CF), UINT32_C(0x00140684), UINT32_C(0x0023566D),
10832           UINT32_C(0x0062EA4E), UINT32_C(0x0026B67A), UINT32_C(0x00295AF8),
10833           UINT32_C(0x0006E548), UINT32_C(0x0040F0F6), UINT32_C(0x003FA25A),
10834           UINT32_C(0x003841B6), UINT32_C(0x0034374F)},
10835          {UINT32_C(0x0011DBC4), UINT32_C(0x001EE6DB), UINT32_C(0x00351C56),
10836           UINT32_C(0x003D4083), UINT32_C(0x001009D6), UINT32_C(0x003E9349),
10837           UINT32_C(0x00010A11), UINT32_C(0x00382D27), UINT32_C(0x003D7132),
10838           UINT32_C(0x001999FC), UINT32_C(0x003911D4), UINT32_C(0x0045D805),
10839           UINT32_C(0x0001B235), UINT32_C(0x00258644), UINT32_C(0x001B1DA8),
10840           UINT32_C(0x007D367D), UINT32_C(0x002106B2), UINT32_C(0x00096B2D),
10841           UINT32_C(0x001A078D), UINT32_C(0x007CE535), UINT32_C(0x003C6BB8),
10842           UINT32_C(0x0021FC86), UINT32_C(0x00388E7F)}},
10843         {{UINT32_C(0x003C849A), UINT32_C(0x00339DA9), UINT32_C(0x0001B56C),
10844           UINT32_C(0x0018B48F), UINT32_C(0x0036B241), UINT32_C(0x001C3E99),
10845           UINT32_C(0x001DC79F), UINT32_C(0x006E4794), UINT32_C(0x0014AD70),
10846           UINT32_C(0x0020AF6F), UINT32_C(0x00286589), UINT32_C(0x0000AA9B),
10847           UINT32_C(0x00287B90), UINT32_C(0x0036D3BA), UINT32_C(0x002CB788),
10848           UINT32_C(0x0036DAF5), UINT32_C(0x000DA427), UINT32_C(0x0003CD59),
10849           UINT32_C(0x00026B18), UINT32_C(0x002DA542), UINT32_C(0x0010AEF9),
10850           UINT32_C(0x003EA11A), UINT32_C(0x003453B3)},
10851          {UINT32_C(0x001D0091), UINT32_C(0x0020390C), UINT32_C(0x002D251A),
10852           UINT32_C(0x0043EFFA), UINT32_C(0x00284188), UINT32_C(0x00326C4E),
10853           UINT32_C(0x001965D5), UINT32_C(0x0052E6EE), UINT32_C(0x0000616F),
10854           UINT32_C(0x002561A4), UINT32_C(0x003AD411), UINT32_C(0x0036D206),
10855           UINT32_C(0x000E1BD3), UINT32_C(0x001392B2), UINT32_C(0x002A8475),
10856           UINT32_C(0x0066EFA5), UINT32_C(0x0037E866), UINT32_C(0x001BBD62),
10857           UINT32_C(0x001D1550), UINT32_C(0x0032E625), UINT32_C(0x00302306),
10858           UINT32_C(0x001E0DDA), UINT32_C(0x001CF60C)}},
10859         {{UINT32_C(0x0023F415), UINT32_C(0x0034D9CF), UINT32_C(0x0024E53D),
10860           UINT32_C(0x000875AF), UINT32_C(0x00052504), UINT32_C(0x003FD275),
10861           UINT32_C(0x0030C106), UINT32_C(0x006F3F46), UINT32_C(0x000B6725),
10862           UINT32_C(0x001DB8D9), UINT32_C(0x0028E8F0), UINT32_C(0x00172728),
10863           UINT32_C(0x0028DA5A), UINT32_C(0x0032E926), UINT32_C(0x002D0A85),
10864           UINT32_C(0x000530D4), UINT32_C(0x0035DC87), UINT32_C(0x002D07D2),
10865           UINT32_C(0x003F882E), UINT32_C(0x005C838F), UINT32_C(0x0026F2BF),
10866           UINT32_C(0x003EEE58), UINT32_C(0x00071443)},
10867          {UINT32_C(0x002CB0FF), UINT32_C(0x003E64EA), UINT32_C(0x0018EDB8),
10868           UINT32_C(0x003B4182), UINT32_C(0x001FC937), UINT32_C(0x002AAFB7),
10869           UINT32_C(0x002EA0F1), UINT32_C(0x0049D653), UINT32_C(0x000F4A39),
10870           UINT32_C(0x000B926E), UINT32_C(0x0010CA2F), UINT32_C(0x002208C8),
10871           UINT32_C(0x0039DE49), UINT32_C(0x000161ED), UINT32_C(0x0007EAFC),
10872           UINT32_C(0x00514FED), UINT32_C(0x00039404), UINT32_C(0x0018883A),
10873           UINT32_C(0x00023262), UINT32_C(0x0016E9C1), UINT32_C(0x003C573A),
10874           UINT32_C(0x002FB6FD), UINT32_C(0x00386202)}},
10875         {{UINT32_C(0x005D99DB), UINT32_C(0x00001D29), UINT32_C(0x000AF82D),
10876           UINT32_C(0x00444767), UINT32_C(0x0015C5E2), UINT32_C(0x002A81B3),
10877           UINT32_C(0x0024A5EF), UINT32_C(0x006F6AF5), UINT32_C(0x001EBBCB),
10878           UINT32_C(0x00305276), UINT32_C(0x001A7F7A), UINT32_C(0x006B1587),
10879           UINT32_C(0x0010BC41), UINT32_C(0x00233733), UINT32_C(0x0015633F),
10880           UINT32_C(0x006476A7), UINT32_C(0x00104F63), UINT32_C(0x001F393B),
10881           UINT32_C(0x00255507), UINT32_C(0x00708297), UINT32_C(0x000DB54C),
10882           UINT32_C(0x001A8A1D), UINT32_C(0x001A9756)},
10883          {UINT32_C(0x0033896F), UINT32_C(0x00011688), UINT32_C(0x001FBDA0),
10884           UINT32_C(0x002D7B5B), UINT32_C(0x00345043), UINT32_C(0x000409DD),
10885           UINT32_C(0x0023A47B), UINT32_C(0x0018CE42), UINT32_C(0x00005C57),
10886           UINT32_C(0x0010E46C), UINT32_C(0x0016395D), UINT32_C(0x0029A5E5),
10887           UINT32_C(0x00063854), UINT32_C(0x002F12A1), UINT32_C(0x00013E1B),
10888           UINT32_C(0x00407727), UINT32_C(0x001EEAAC), UINT32_C(0x0039D044),
10889           UINT32_C(0x0023C5C8), UINT32_C(0x003BB777), UINT32_C(0x00206B48),
10890           UINT32_C(0x0020CD62), UINT32_C(0x002C7DE1)}},
10891         {{UINT32_C(0x00431425), UINT32_C(0x003E66AF), UINT32_C(0x0039AA06),
10892           UINT32_C(0x0061F4D9), UINT32_C(0x001789C9), UINT32_C(0x002ECAAC),
10893           UINT32_C(0x0003F0C7), UINT32_C(0x0019C0FC), UINT32_C(0x00131E10),
10894           UINT32_C(0x001FDEC5), UINT32_C(0x00375C20), UINT32_C(0x0038CDA3),
10895           UINT32_C(0x0019FA41), UINT32_C(0x00339E14), UINT32_C(0x002C2643),
10896           UINT32_C(0x0060E1EB), UINT32_C(0x001F88C5), UINT32_C(0x002C520C),
10897           UINT32_C(0x000ED4A1), UINT32_C(0x0009B12C), UINT32_C(0x003385E8),
10898           UINT32_C(0x0007CEC0), UINT32_C(0x0025145A)},
10899          {UINT32_C(0x000C4BBC), UINT32_C(0x001CA76E), UINT32_C(0x00053791),
10900           UINT32_C(0x0071B24B), UINT32_C(0x002AEE0E), UINT32_C(0x003D38BC),
10901           UINT32_C(0x0014DF23), UINT32_C(0x00714100), UINT32_C(0x002621B3),
10902           UINT32_C(0x003EA6E9), UINT32_C(0x003351FD), UINT32_C(0x002F67A6),
10903           UINT32_C(0x003DD342), UINT32_C(0x002B6916), UINT32_C(0x0018E95C),
10904           UINT32_C(0x004F0EF0), UINT32_C(0x00063803), UINT32_C(0x0031C884),
10905           UINT32_C(0x0029F497), UINT32_C(0x0076FCD3), UINT32_C(0x0008E8DE),
10906           UINT32_C(0x00375097), UINT32_C(0x0034BF55)}},
10907     },
10908     {
10909         {{UINT32_C(0x00101002), UINT32_C(0x003E5E72), UINT32_C(0x0008B02E),
10910           UINT32_C(0x0050FB59), UINT32_C(0x0018AB92), UINT32_C(0x003EE716),
10911           UINT32_C(0x00097228), UINT32_C(0x0049BDB3), UINT32_C(0x003AF4F6),
10912           UINT32_C(0x003EC3F2), UINT32_C(0x000A2168), UINT32_C(0x002E9535),
10913           UINT32_C(0x001B90E4), UINT32_C(0x002BA88C), UINT32_C(0x00326E95),
10914           UINT32_C(0x003FEB7E), UINT32_C(0x002017BC), UINT32_C(0x000D0EEE),
10915           UINT32_C(0x0014761F), UINT32_C(0x0047526E), UINT32_C(0x00180227),
10916           UINT32_C(0x000611B5), UINT32_C(0x0035BCC9)},
10917          {UINT32_C(0x0065BB6C), UINT32_C(0x00254EB1), UINT32_C(0x00213662),
10918           UINT32_C(0x000C625D), UINT32_C(0x00291EF8), UINT32_C(0x00123964),
10919           UINT32_C(0x003C6A2D), UINT32_C(0x003CEFF9), UINT32_C(0x00263687),
10920           UINT32_C(0x0011917B), UINT32_C(0x000E22CF), UINT32_C(0x002846F8),
10921           UINT32_C(0x0034AE34), UINT32_C(0x001EA233), UINT32_C(0x001EA70A),
10922           UINT32_C(0x001C002F), UINT32_C(0x0008295D), UINT32_C(0x00358F85),
10923           UINT32_C(0x001292A5), UINT32_C(0x006FF9AD), UINT32_C(0x0006C51D),
10924           UINT32_C(0x0010C570), UINT32_C(0x003F9016)}},
10925         {{UINT32_C(0x00520C83), UINT32_C(0x0011B38F), UINT32_C(0x003659FA),
10926           UINT32_C(0x004B70A4), UINT32_C(0x002D7D78), UINT32_C(0x00317E0C),
10927           UINT32_C(0x002BCC8A), UINT32_C(0x00170479), UINT32_C(0x003049C8),
10928           UINT32_C(0x0035330F), UINT32_C(0x00292CAC), UINT32_C(0x00659C79),
10929           UINT32_C(0x000953DA), UINT32_C(0x002839AC), UINT32_C(0x000EEC75),
10930           UINT32_C(0x0034FE7A), UINT32_C(0x003DA567), UINT32_C(0x003E416C),
10931           UINT32_C(0x00007AD5), UINT32_C(0x00787665), UINT32_C(0x0023F8AC),
10932           UINT32_C(0x0022688F), UINT32_C(0x002F4735)},
10933          {UINT32_C(0x0048FDB2), UINT32_C(0x001EC71C), UINT32_C(0x003D8930),
10934           UINT32_C(0x00650536), UINT32_C(0x0022A057), UINT32_C(0x0034D941),
10935           UINT32_C(0x0033DA64), UINT32_C(0x002D8AF7), UINT32_C(0x0015A74D),
10936           UINT32_C(0x0002EE4D), UINT32_C(0x0020F500), UINT32_C(0x00050ADE),
10937           UINT32_C(0x0021DCE1), UINT32_C(0x00006CC2), UINT32_C(0x00004AF7),
10938           UINT32_C(0x00385379), UINT32_C(0x0014D7FD), UINT32_C(0x0035F5DC),
10939           UINT32_C(0x002CE71C), UINT32_C(0x004F1273), UINT32_C(0x00235AF5),
10940           UINT32_C(0x00073649), UINT32_C(0x001C5B77)}},
10941         {{UINT32_C(0x002D1D21), UINT32_C(0x003D3AFA), UINT32_C(0x003484FE),
10942           UINT32_C(0x003B8AEF), UINT32_C(0x0028E325), UINT32_C(0x00180681),
10943           UINT32_C(0x0008D952), UINT32_C(0x0004222B), UINT32_C(0x002EC06C),
10944           UINT32_C(0x00196929), UINT32_C(0x0003F38C), UINT32_C(0x004A5049),
10945           UINT32_C(0x000D9B6D), UINT32_C(0x001C481B), UINT32_C(0x003A16BA),
10946           UINT32_C(0x007F7383), UINT32_C(0x0016E539), UINT32_C(0x003CB657),
10947           UINT32_C(0x000CB3E0), UINT32_C(0x0017CB6E), UINT32_C(0x00282B60),
10948           UINT32_C(0x00168672), UINT32_C(0x0021396D)},
10949          {UINT32_C(0x00230B59), UINT32_C(0x002A3F7A), UINT32_C(0x002CEDD4),
10950           UINT32_C(0x0046B9E4), UINT32_C(0x0010DAFC), UINT32_C(0x0030ED59),
10951           UINT32_C(0x0034B350), UINT32_C(0x004C3909), UINT32_C(0x000D0E93),
10952           UINT32_C(0x003A3458), UINT32_C(0x00030157), UINT32_C(0x003E191D),
10953           UINT32_C(0x002A17A1), UINT32_C(0x001C795E), UINT32_C(0x00019E14),
10954           UINT32_C(0x00448635), UINT32_C(0x00364727), UINT32_C(0x002B17DB),
10955           UINT32_C(0x00013693), UINT32_C(0x0050F600), UINT32_C(0x0013ADED),
10956           UINT32_C(0x00267B88), UINT32_C(0x0012E874)}},
10957         {{UINT32_C(0x00491237), UINT32_C(0x000A3228), UINT32_C(0x0006A16F),
10958           UINT32_C(0x002BCC52), UINT32_C(0x002A58B0), UINT32_C(0x00223C2F),
10959           UINT32_C(0x000ECF49), UINT32_C(0x00310D98), UINT32_C(0x000E07C8),
10960           UINT32_C(0x0027A178), UINT32_C(0x002F51C1), UINT32_C(0x001D757E),
10961           UINT32_C(0x003D1406), UINT32_C(0x003F45BF), UINT32_C(0x003C049A),
10962           UINT32_C(0x00247F57), UINT32_C(0x001B4EA7), UINT32_C(0x002C3AA4),
10963           UINT32_C(0x0000C59A), UINT32_C(0x002C0BF5), UINT32_C(0x0004E1EC),
10964           UINT32_C(0x003B5C4F), UINT32_C(0x002ED5BD)},
10965          {UINT32_C(0x000DA809), UINT32_C(0x003F3B14), UINT32_C(0x00317876),
10966           UINT32_C(0x004FBBD1), UINT32_C(0x00145987), UINT32_C(0x0034043D),
10967           UINT32_C(0x0004E8DF), UINT32_C(0x0040B9A8), UINT32_C(0x003FB500),
10968           UINT32_C(0x00102180), UINT32_C(0x00002AD5), UINT32_C(0x000948B6),
10969           UINT32_C(0x0024E856), UINT32_C(0x001346B2), UINT32_C(0x001224DE),
10970           UINT32_C(0x00780CFE), UINT32_C(0x003527A8), UINT32_C(0x0015A63D),
10971           UINT32_C(0x00350B6B), UINT32_C(0x0019D0B1), UINT32_C(0x00125F42),
10972           UINT32_C(0x000C970B), UINT32_C(0x0030D16C)}},
10973         {{UINT32_C(0x005B8DD0), UINT32_C(0x002EFE9A), UINT32_C(0x002160B2),
10974           UINT32_C(0x006C25E9), UINT32_C(0x003648EE), UINT32_C(0x000F0498),
10975           UINT32_C(0x002E36A5), UINT32_C(0x0048709D), UINT32_C(0x003F3212),
10976           UINT32_C(0x0032A4D7), UINT32_C(0x0037EA02), UINT32_C(0x003554EF),
10977           UINT32_C(0x00080AFA), UINT32_C(0x0009F4D8), UINT32_C(0x000A370E),
10978           UINT32_C(0x0074C856), UINT32_C(0x00302B5C), UINT32_C(0x000F4BED),
10979           UINT32_C(0x00286A2A), UINT32_C(0x001B7967), UINT32_C(0x001EA28E),
10980           UINT32_C(0x0005C511), UINT32_C(0x0036A76A)},
10981          {UINT32_C(0x00470560), UINT32_C(0x002A01F5), UINT32_C(0x0000571A),
10982           UINT32_C(0x0049D849), UINT32_C(0x001EC4A9), UINT32_C(0x0032B83B),
10983           UINT32_C(0x001A8DF4), UINT32_C(0x00495FB3), UINT32_C(0x000BD33C),
10984           UINT32_C(0x000857FC), UINT32_C(0x00128475), UINT32_C(0x003B8705),
10985           UINT32_C(0x00243166), UINT32_C(0x001BCEBA), UINT32_C(0x0028F42F),
10986           UINT32_C(0x00530ED6), UINT32_C(0x001D8A5C), UINT32_C(0x001FC74F),
10987           UINT32_C(0x002D4804), UINT32_C(0x000367B6), UINT32_C(0x000327AF),
10988           UINT32_C(0x002863D0), UINT32_C(0x000900E7)}},
10989         {{UINT32_C(0x00780229), UINT32_C(0x001EF630), UINT32_C(0x000510ED),
10990           UINT32_C(0x006460B5), UINT32_C(0x000A8636), UINT32_C(0x00358DE6),
10991           UINT32_C(0x001EAE5F), UINT32_C(0x0054B5EB), UINT32_C(0x0024DDD6),
10992           UINT32_C(0x003EDDBF), UINT32_C(0x00373B40), UINT32_C(0x0026ABAC),
10993           UINT32_C(0x003A5597), UINT32_C(0x002BE3A2), UINT32_C(0x00167777),
10994           UINT32_C(0x0045D31B), UINT32_C(0x0032440D), UINT32_C(0x0015429F),
10995           UINT32_C(0x003A681A), UINT32_C(0x001D0AA3), UINT32_C(0x0036BA5B),
10996           UINT32_C(0x0025EA57), UINT32_C(0x00343F81)},
10997          {UINT32_C(0x0013FCD6), UINT32_C(0x0032B515), UINT32_C(0x00205A39),
10998           UINT32_C(0x006417AA), UINT32_C(0x00188962), UINT32_C(0x0030F077),
10999           UINT32_C(0x0030D896), UINT32_C(0x00618839), UINT32_C(0x000924CE),
11000           UINT32_C(0x00313575), UINT32_C(0x002445E3), UINT32_C(0x0004EECA),
11001           UINT32_C(0x002B4A7C), UINT32_C(0x0009D939), UINT32_C(0x0013DD92),
11002           UINT32_C(0x0023A94B), UINT32_C(0x0022A525), UINT32_C(0x002EC641),
11003           UINT32_C(0x000F31A9), UINT32_C(0x001D3493), UINT32_C(0x003DF626),
11004           UINT32_C(0x003C1521), UINT32_C(0x000E392E)}},
11005         {{UINT32_C(0x0066600B), UINT32_C(0x0004FDF8), UINT32_C(0x0007D4BD),
11006           UINT32_C(0x0026B138), UINT32_C(0x002EA81D), UINT32_C(0x00333EF4),
11007           UINT32_C(0x0015A59C), UINT32_C(0x0051B0C0), UINT32_C(0x0035D122),
11008           UINT32_C(0x003DA6C3), UINT32_C(0x003E2C86), UINT32_C(0x003CB4B4),
11009           UINT32_C(0x00044B44), UINT32_C(0x003424DE), UINT32_C(0x001D32E6),
11010           UINT32_C(0x002521D8), UINT32_C(0x003CCEC2), UINT32_C(0x000276F5),
11011           UINT32_C(0x00220217), UINT32_C(0x00008BA1), UINT32_C(0x000321CB),
11012           UINT32_C(0x00286E09), UINT32_C(0x0004C3E0)},
11013          {UINT32_C(0x002B8D50), UINT32_C(0x002E3BC1), UINT32_C(0x000F2753),
11014           UINT32_C(0x007FCE93), UINT32_C(0x003EF16C), UINT32_C(0x0035426B),
11015           UINT32_C(0x00206746), UINT32_C(0x007FCFC3), UINT32_C(0x003C1D6C),
11016           UINT32_C(0x0037F851), UINT32_C(0x0014034B), UINT32_C(0x005C71B5),
11017           UINT32_C(0x002AA534), UINT32_C(0x003695A5), UINT32_C(0x001CC377),
11018           UINT32_C(0x004B40F1), UINT32_C(0x003B0DD3), UINT32_C(0x0003CC25),
11019           UINT32_C(0x00296BD9), UINT32_C(0x0076050E), UINT32_C(0x0030853C),
11020           UINT32_C(0x0023CDDF), UINT32_C(0x0005051F)}},
11021         {{UINT32_C(0x001FAC05), UINT32_C(0x0038BF66), UINT32_C(0x00106AE1),
11022           UINT32_C(0x005F6C39), UINT32_C(0x002BCFD1), UINT32_C(0x0012C446),
11023           UINT32_C(0x002014B7), UINT32_C(0x0022CDD4), UINT32_C(0x002C0E46),
11024           UINT32_C(0x000068BA), UINT32_C(0x0009B619), UINT32_C(0x00112EBA),
11025           UINT32_C(0x001134DE), UINT32_C(0x00382BD9), UINT32_C(0x0038AB24),
11026           UINT32_C(0x003EFC51), UINT32_C(0x00125A98), UINT32_C(0x00166AE1),
11027           UINT32_C(0x001204D8), UINT32_C(0x00395F99), UINT32_C(0x0022EC93),
11028           UINT32_C(0x000C2334), UINT32_C(0x000F0DB3)},
11029          {UINT32_C(0x0065FB58), UINT32_C(0x0026949F), UINT32_C(0x00284E96),
11030           UINT32_C(0x000E9B6C), UINT32_C(0x003DCCC0), UINT32_C(0x00276266),
11031           UINT32_C(0x0011C074), UINT32_C(0x0006165B), UINT32_C(0x003618B9),
11032           UINT32_C(0x000C1873), UINT32_C(0x00210655), UINT32_C(0x0068168F),
11033           UINT32_C(0x002A5321), UINT32_C(0x00130FA1), UINT32_C(0x00288227),
11034           UINT32_C(0x00405D32), UINT32_C(0x002C76A2), UINT32_C(0x003544A1),
11035           UINT32_C(0x0021FFEE), UINT32_C(0x00372D2B), UINT32_C(0x001A438E),
11036           UINT32_C(0x002F5590), UINT32_C(0x001BBD78)}},
11037         {{UINT32_C(0x000324B7), UINT32_C(0x0005A62F), UINT32_C(0x003F767B),
11038           UINT32_C(0x006E0320), UINT32_C(0x0000FF7D), UINT32_C(0x001365D4),
11039           UINT32_C(0x0034C36F), UINT32_C(0x000AC0F4), UINT32_C(0x00037C47),
11040           UINT32_C(0x00022A9D), UINT32_C(0x001C6BCF), UINT32_C(0x000C25F1),
11041           UINT32_C(0x0019449E), UINT32_C(0x00272780), UINT32_C(0x00107BA2),
11042           UINT32_C(0x003A5F5D), UINT32_C(0x0010F210), UINT32_C(0x001A8365),
11043           UINT32_C(0x000FA62A), UINT32_C(0x000EEFAD), UINT32_C(0x00080B72),
11044           UINT32_C(0x003ABCCF), UINT32_C(0x00019B10)},
11045          {UINT32_C(0x0076B572), UINT32_C(0x003D6F9E), UINT32_C(0x000ADEC4),
11046           UINT32_C(0x00516D49), UINT32_C(0x003E0BD1), UINT32_C(0x00139E71),
11047           UINT32_C(0x00339678), UINT32_C(0x006ABDF0), UINT32_C(0x0038E886),
11048           UINT32_C(0x002299CE), UINT32_C(0x00367195), UINT32_C(0x0043A05B),
11049           UINT32_C(0x00361D28), UINT32_C(0x000796D9), UINT32_C(0x00373012),
11050           UINT32_C(0x001EC4D3), UINT32_C(0x001008A0), UINT32_C(0x002E74DD),
11051           UINT32_C(0x003C82F9), UINT32_C(0x004054A4), UINT32_C(0x0032570C),
11052           UINT32_C(0x00101897), UINT32_C(0x00118C2D)}},
11053         {{UINT32_C(0x00462F42), UINT32_C(0x00057E48), UINT32_C(0x001278B3),
11054           UINT32_C(0x0026CC97), UINT32_C(0x001E327A), UINT32_C(0x001598F9),
11055           UINT32_C(0x003DEF1B), UINT32_C(0x00079209), UINT32_C(0x0033F716),
11056           UINT32_C(0x003B919D), UINT32_C(0x003706F3), UINT32_C(0x00399A35),
11057           UINT32_C(0x0036C21D), UINT32_C(0x00323DF4), UINT32_C(0x000A940E),
11058           UINT32_C(0x000D518E), UINT32_C(0x000D882E), UINT32_C(0x003C191A),
11059           UINT32_C(0x00244FC8), UINT32_C(0x0005C226), UINT32_C(0x000509F7),
11060           UINT32_C(0x000F698A), UINT32_C(0x00007583)},
11061          {UINT32_C(0x007336DD), UINT32_C(0x002AE10E), UINT32_C(0x00262EEC),
11062           UINT32_C(0x0040454E), UINT32_C(0x003352A6), UINT32_C(0x002A34DE),
11063           UINT32_C(0x0033BCE4), UINT32_C(0x0024FD39), UINT32_C(0x001319FB),
11064           UINT32_C(0x001AE5AA), UINT32_C(0x00315D5B), UINT32_C(0x002C46BE),
11065           UINT32_C(0x001DF5A0), UINT32_C(0x002C4B31), UINT32_C(0x0034A43A),
11066           UINT32_C(0x004D4DD6), UINT32_C(0x000116D9), UINT32_C(0x000E599A),
11067           UINT32_C(0x0033B481), UINT32_C(0x0072C084), UINT32_C(0x003602A6),
11068           UINT32_C(0x000FA6A0), UINT32_C(0x00193096)}},
11069         {{UINT32_C(0x001FA23E), UINT32_C(0x0017DD44), UINT32_C(0x002B9851),
11070           UINT32_C(0x0078D9BF), UINT32_C(0x00300461), UINT32_C(0x000E650F),
11071           UINT32_C(0x0003235A), UINT32_C(0x001E10FD), UINT32_C(0x00191997),
11072           UINT32_C(0x00347E5B), UINT32_C(0x000EF26D), UINT32_C(0x00722710),
11073           UINT32_C(0x00091296), UINT32_C(0x0000DAC3), UINT32_C(0x00364C90),
11074           UINT32_C(0x00153FD5), UINT32_C(0x00386DE4), UINT32_C(0x0010D8C8),
11075           UINT32_C(0x001F9824), UINT32_C(0x000ADEC8), UINT32_C(0x003F9D31),
11076           UINT32_C(0x0022F161), UINT32_C(0x000FB294)},
11077          {UINT32_C(0x007CFE80), UINT32_C(0x002929EF), UINT32_C(0x001E66B0),
11078           UINT32_C(0x003A9598), UINT32_C(0x00040870), UINT32_C(0x00110507),
11079           UINT32_C(0x0002B8C7), UINT32_C(0x00218FE2), UINT32_C(0x0024A402),
11080           UINT32_C(0x00082D52), UINT32_C(0x0014DAF9), UINT32_C(0x003244A6),
11081           UINT32_C(0x000583BF), UINT32_C(0x00215F1C), UINT32_C(0x0035F85B),
11082           UINT32_C(0x000DE2B3), UINT32_C(0x0004BC8F), UINT32_C(0x000E7228),
11083           UINT32_C(0x002E9933), UINT32_C(0x0007BDB8), UINT32_C(0x001F7F0F),
11084           UINT32_C(0x003332AF), UINT32_C(0x00156268)}},
11085         {{UINT32_C(0x0002E3E7), UINT32_C(0x0025FA60), UINT32_C(0x001FB4E6),
11086           UINT32_C(0x0016C3C6), UINT32_C(0x00247D0E), UINT32_C(0x002D8D5E),
11087           UINT32_C(0x0006A675), UINT32_C(0x00149DD3), UINT32_C(0x0014833C),
11088           UINT32_C(0x002071D1), UINT32_C(0x00267269), UINT32_C(0x005E8399),
11089           UINT32_C(0x0015D1BF), UINT32_C(0x002573DB), UINT32_C(0x000E94C4),
11090           UINT32_C(0x0053F0CB), UINT32_C(0x000E6C01), UINT32_C(0x002C9873),
11091           UINT32_C(0x0003E40E), UINT32_C(0x002DC625), UINT32_C(0x000EE009),
11092           UINT32_C(0x0037B3C1), UINT32_C(0x00314D3B)},
11093          {UINT32_C(0x0012F52A), UINT32_C(0x00212A59), UINT32_C(0x0039A45C),
11094           UINT32_C(0x000237A1), UINT32_C(0x0002467E), UINT32_C(0x003AD286),
11095           UINT32_C(0x0014E2EE), UINT32_C(0x0079D3D0), UINT32_C(0x001D7205),
11096           UINT32_C(0x0019A1C3), UINT32_C(0x001A753E), UINT32_C(0x00648E5B),
11097           UINT32_C(0x001DA22B), UINT32_C(0x0032CBC7), UINT32_C(0x001A0350),
11098           UINT32_C(0x0051025A), UINT32_C(0x003A3047), UINT32_C(0x001814DC),
11099           UINT32_C(0x0015F660), UINT32_C(0x00384509), UINT32_C(0x0028C315),
11100           UINT32_C(0x0014D207), UINT32_C(0x001BFC3C)}},
11101         {{UINT32_C(0x000BF619), UINT32_C(0x001B0A4A), UINT32_C(0x002F5B04),
11102           UINT32_C(0x00066718), UINT32_C(0x000F956B), UINT32_C(0x00148057),
11103           UINT32_C(0x003D7C40), UINT32_C(0x002D779F), UINT32_C(0x000D96BA),
11104           UINT32_C(0x0034F9E9), UINT32_C(0x000ABC81), UINT32_C(0x00612100),
11105           UINT32_C(0x00094453), UINT32_C(0x001A7A84), UINT32_C(0x00395C2A),
11106           UINT32_C(0x001CCF9C), UINT32_C(0x001909AB), UINT32_C(0x000127F4),
11107           UINT32_C(0x003CC47F), UINT32_C(0x0053B36F), UINT32_C(0x001168B8),
11108           UINT32_C(0x003E681B), UINT32_C(0x0033586A)},
11109          {UINT32_C(0x003405C5), UINT32_C(0x0014C1F8), UINT32_C(0x00217C04),
11110           UINT32_C(0x0044F686), UINT32_C(0x003B975D), UINT32_C(0x001566BE),
11111           UINT32_C(0x000C3966), UINT32_C(0x00442F22), UINT32_C(0x002EEC1C),
11112           UINT32_C(0x001FBB59), UINT32_C(0x002C7F08), UINT32_C(0x005C2547),
11113           UINT32_C(0x002E399A), UINT32_C(0x00357E26), UINT32_C(0x00182B2F),
11114           UINT32_C(0x00428509), UINT32_C(0x0001036A), UINT32_C(0x000C10BF),
11115           UINT32_C(0x0038CF9D), UINT32_C(0x0037AD35), UINT32_C(0x000ED96E),
11116           UINT32_C(0x001A6435), UINT32_C(0x003E4F02)}},
11117         {{UINT32_C(0x0041EB8E), UINT32_C(0x000024BF), UINT32_C(0x003694DF),
11118           UINT32_C(0x00511BE5), UINT32_C(0x000A954F), UINT32_C(0x00206AB1),
11119           UINT32_C(0x003CF939), UINT32_C(0x00513701), UINT32_C(0x000E6080),
11120           UINT32_C(0x002108CE), UINT32_C(0x0020017E), UINT32_C(0x00105B07),
11121           UINT32_C(0x0011EE5F), UINT32_C(0x003E26E6), UINT32_C(0x000DCD93),
11122           UINT32_C(0x0008016D), UINT32_C(0x003FE138), UINT32_C(0x0003D710),
11123           UINT32_C(0x002881A3), UINT32_C(0x002E6638), UINT32_C(0x0013554C),
11124           UINT32_C(0x001A9737), UINT32_C(0x002F29B7)},
11125          {UINT32_C(0x0072FA30), UINT32_C(0x003860AB), UINT32_C(0x002A3A9B),
11126           UINT32_C(0x0046D4D4), UINT32_C(0x002C8E1C), UINT32_C(0x000B27C5),
11127           UINT32_C(0x002FB5F3), UINT32_C(0x006E389E), UINT32_C(0x0032BF68),
11128           UINT32_C(0x002F2032), UINT32_C(0x003D0E8B), UINT32_C(0x005EFF1B),
11129           UINT32_C(0x000E77F7), UINT32_C(0x0032D4D9), UINT32_C(0x000EE3B7),
11130           UINT32_C(0x002DD781), UINT32_C(0x002C515F), UINT32_C(0x001196A0),
11131           UINT32_C(0x003C1961), UINT32_C(0x00484EBE), UINT32_C(0x0007BCF4),
11132           UINT32_C(0x002FA36A), UINT32_C(0x00385130)}},
11133         {{UINT32_C(0x000B2CC6), UINT32_C(0x000E1DAF), UINT32_C(0x003ADA49),
11134           UINT32_C(0x0067C22D), UINT32_C(0x002135BF), UINT32_C(0x0034F418),
11135           UINT32_C(0x002F97CB), UINT32_C(0x003D4E4F), UINT32_C(0x00389246),
11136           UINT32_C(0x000605C0), UINT32_C(0x0005A49F), UINT32_C(0x00289A5C),
11137           UINT32_C(0x0019305F), UINT32_C(0x002BDB2B), UINT32_C(0x0037F1CC),
11138           UINT32_C(0x007C489D), UINT32_C(0x001CC3B8), UINT32_C(0x0022BE49),
11139           UINT32_C(0x0004F6FE), UINT32_C(0x004CDB36), UINT32_C(0x001ECD22),
11140           UINT32_C(0x00347FCC), UINT32_C(0x00121B6E)},
11141          {UINT32_C(0x0038250C), UINT32_C(0x003A9B9A), UINT32_C(0x0031B884),
11142           UINT32_C(0x0038B4E2), UINT32_C(0x002903F8), UINT32_C(0x000D4406),
11143           UINT32_C(0x0003337E), UINT32_C(0x000571CA), UINT32_C(0x0020FC99),
11144           UINT32_C(0x002BEC49), UINT32_C(0x0004A324), UINT32_C(0x0063E39A),
11145           UINT32_C(0x00248D5A), UINT32_C(0x0034EE85), UINT32_C(0x0012C541),
11146           UINT32_C(0x0036DF11), UINT32_C(0x001A9D56), UINT32_C(0x00114AD8),
11147           UINT32_C(0x002B0978), UINT32_C(0x004376FE), UINT32_C(0x0019DA75),
11148           UINT32_C(0x0036CC96), UINT32_C(0x002821E1)}},
11149         {{UINT32_C(0x003C6DB0), UINT32_C(0x00394096), UINT32_C(0x0015D4D8),
11150           UINT32_C(0x00624F58), UINT32_C(0x003A01CB), UINT32_C(0x002C9112),
11151           UINT32_C(0x003A878F), UINT32_C(0x00184B32), UINT32_C(0x001888A3),
11152           UINT32_C(0x00026E10), UINT32_C(0x000E5D54), UINT32_C(0x0055695D),
11153           UINT32_C(0x0004DC05), UINT32_C(0x001B0A95), UINT32_C(0x00230372),
11154           UINT32_C(0x000B124E), UINT32_C(0x0011DE6A), UINT32_C(0x000F2458),
11155           UINT32_C(0x002C9259), UINT32_C(0x00290AC1), UINT32_C(0x0020440B),
11156           UINT32_C(0x00114828), UINT32_C(0x002B166A)},
11157          {UINT32_C(0x0032B46D), UINT32_C(0x00207B45), UINT32_C(0x000473C9),
11158           UINT32_C(0x007FBBBF), UINT32_C(0x0015AFF8), UINT32_C(0x0039EB60),
11159           UINT32_C(0x0035D816), UINT32_C(0x000B1D9F), UINT32_C(0x0037A1A2),
11160           UINT32_C(0x000D8711), UINT32_C(0x0002DFDE), UINT32_C(0x001CBEC4),
11161           UINT32_C(0x002A1716), UINT32_C(0x003B7011), UINT32_C(0x002CED5F),
11162           UINT32_C(0x006BA8F2), UINT32_C(0x0002B544), UINT32_C(0x000C2201),
11163           UINT32_C(0x001B97B2), UINT32_C(0x0068B05E), UINT32_C(0x002ECFAD),
11164           UINT32_C(0x0014D41E), UINT32_C(0x00319D72)}},
11165     },
11166     {
11167         {{UINT32_C(0x00000297), UINT32_C(0x0028EE9D), UINT32_C(0x0025F457),
11168           UINT32_C(0x003A1C7F), UINT32_C(0x003D187E), UINT32_C(0x0016AAC2),
11169           UINT32_C(0x0018DA90), UINT32_C(0x0032CC34), UINT32_C(0x0000C9FE),
11170           UINT32_C(0x00083A39), UINT32_C(0x000ABFD1), UINT32_C(0x00056518),
11171           UINT32_C(0x0020E915), UINT32_C(0x0037F36C), UINT32_C(0x001C3CE8),
11172           UINT32_C(0x0016154B), UINT32_C(0x000D8F76), UINT32_C(0x001349C7),
11173           UINT32_C(0x002C5B2D), UINT32_C(0x00302ADF), UINT32_C(0x00347C0F),
11174           UINT32_C(0x001AD83E), UINT32_C(0x00337C01)},
11175          {UINT32_C(0x0044DBD8), UINT32_C(0x00161F8E), UINT32_C(0x003A4EAF),
11176           UINT32_C(0x007E41EE), UINT32_C(0x0020D593), UINT32_C(0x002B1752),
11177           UINT32_C(0x0008C520), UINT32_C(0x000F746C), UINT32_C(0x00251428),
11178           UINT32_C(0x00336F1A), UINT32_C(0x002F850D), UINT32_C(0x00363B2F),
11179           UINT32_C(0x003C91B4), UINT32_C(0x00373CAD), UINT32_C(0x00114941),
11180           UINT32_C(0x007F0C1B), UINT32_C(0x000AB3AA), UINT32_C(0x000B5CDA),
11181           UINT32_C(0x003A4CD6), UINT32_C(0x0013C09D), UINT32_C(0x003CFDAB),
11182           UINT32_C(0x0030F023), UINT32_C(0x002F9D40)}},
11183         {{UINT32_C(0x0016AB0F), UINT32_C(0x0002549A), UINT32_C(0x00324067),
11184           UINT32_C(0x001CAA0D), UINT32_C(0x001D43DA), UINT32_C(0x002D4798),
11185           UINT32_C(0x002FABBD), UINT32_C(0x00524E09), UINT32_C(0x003E65A7),
11186           UINT32_C(0x000E6579), UINT32_C(0x0006B2BA), UINT32_C(0x007B52B6),
11187           UINT32_C(0x0017769B), UINT32_C(0x0013CA17), UINT32_C(0x00179C6F),
11188           UINT32_C(0x005068DF), UINT32_C(0x00329383), UINT32_C(0x001C707E),
11189           UINT32_C(0x001906BF), UINT32_C(0x0076817B), UINT32_C(0x0010ED4F),
11190           UINT32_C(0x00185468), UINT32_C(0x003C4A19)},
11191          {UINT32_C(0x003A29A3), UINT32_C(0x0007D7E2), UINT32_C(0x000C6BC2),
11192           UINT32_C(0x007A5479), UINT32_C(0x0001F1CF), UINT32_C(0x0039F9E1),
11193           UINT32_C(0x00044B37), UINT32_C(0x005AA886), UINT32_C(0x002CDE04),
11194           UINT32_C(0x002B1FD3), UINT32_C(0x003036AE), UINT32_C(0x004BC454),
11195           UINT32_C(0x000E6063), UINT32_C(0x003E513C), UINT32_C(0x00142E11),
11196           UINT32_C(0x006EB792), UINT32_C(0x002A88A8), UINT32_C(0x003EE121),
11197           UINT32_C(0x000CAFA1), UINT32_C(0x0069BADD), UINT32_C(0x003F3982),
11198           UINT32_C(0x001A3478), UINT32_C(0x00051F0B)}},
11199         {{UINT32_C(0x0065CD56), UINT32_C(0x002C822B), UINT32_C(0x002F6B9C),
11200           UINT32_C(0x000A1BB8), UINT32_C(0x000AAF79), UINT32_C(0x000EA4D3),
11201           UINT32_C(0x00077BC8), UINT32_C(0x004E72DE), UINT32_C(0x00344B0B),
11202           UINT32_C(0x001E3ED5), UINT32_C(0x0038E0C9), UINT32_C(0x00798666),
11203           UINT32_C(0x002C7240), UINT32_C(0x00033538), UINT32_C(0x003C3C44),
11204           UINT32_C(0x00400702), UINT32_C(0x00200573), UINT32_C(0x003E2A4D),
11205           UINT32_C(0x0004ADF5), UINT32_C(0x007BCBC6), UINT32_C(0x001D81E3),
11206           UINT32_C(0x000E60C8), UINT32_C(0x0033E777)},
11207          {UINT32_C(0x0034AD00), UINT32_C(0x001B4772), UINT32_C(0x0003423A),
11208           UINT32_C(0x003B4DC7), UINT32_C(0x0020F3E4), UINT32_C(0x0039B171),
11209           UINT32_C(0x00127CDB), UINT32_C(0x003DCC1F), UINT32_C(0x002BC848),
11210           UINT32_C(0x00370405), UINT32_C(0x00012BF7), UINT32_C(0x002C5599),
11211           UINT32_C(0x0014AB0C), UINT32_C(0x00103733), UINT32_C(0x0002C167),
11212           UINT32_C(0x0072597A), UINT32_C(0x001A940B), UINT32_C(0x000AA67E),
11213           UINT32_C(0x0027936D), UINT32_C(0x006B2D36), UINT32_C(0x00236515),
11214           UINT32_C(0x003318C3), UINT32_C(0x0000665D)}},
11215         {{UINT32_C(0x007BF246), UINT32_C(0x0038A54E), UINT32_C(0x0017A2C6),
11216           UINT32_C(0x002DF25B), UINT32_C(0x0022DEB2), UINT32_C(0x003B118A),
11217           UINT32_C(0x00285430), UINT32_C(0x007EDA78), UINT32_C(0x0020F2EC),
11218           UINT32_C(0x002DC0F9), UINT32_C(0x000824DC), UINT32_C(0x0035CC91),
11219           UINT32_C(0x002C8632), UINT32_C(0x001D44DC), UINT32_C(0x0018CA86),
11220           UINT32_C(0x004A0FAD), UINT32_C(0x002945F8), UINT32_C(0x0002D0D5),
11221           UINT32_C(0x001B8CB7), UINT32_C(0x002990A6), UINT32_C(0x0019DEB1),
11222           UINT32_C(0x0025B0F2), UINT32_C(0x000568B1)},
11223          {UINT32_C(0x001B65CD), UINT32_C(0x000CDCF7), UINT32_C(0x000C0170),
11224           UINT32_C(0x00180F0B), UINT32_C(0x0016BD33), UINT32_C(0x002FFA3C),
11225           UINT32_C(0x00040868), UINT32_C(0x005D604E), UINT32_C(0x00100FF9),
11226           UINT32_C(0x00336B67), UINT32_C(0x003FF1A5), UINT32_C(0x0066724B),
11227           UINT32_C(0x003B381E), UINT32_C(0x002868B1), UINT32_C(0x0010D47B),
11228           UINT32_C(0x00776DC4), UINT32_C(0x00246BA9), UINT32_C(0x002AD2CD),
11229           UINT32_C(0x002AAF38), UINT32_C(0x000D0446), UINT32_C(0x002F27BB),
11230           UINT32_C(0x002943E1), UINT32_C(0x000F4F81)}},
11231         {{UINT32_C(0x003D4A9C), UINT32_C(0x00024A6D), UINT32_C(0x0014B9E1),
11232           UINT32_C(0x0052698E), UINT32_C(0x0030AB88), UINT32_C(0x003B378D),
11233           UINT32_C(0x003E866C), UINT32_C(0x006C9349), UINT32_C(0x00290E01),
11234           UINT32_C(0x001477AD), UINT32_C(0x0000E581), UINT32_C(0x001E06CC),
11235           UINT32_C(0x00310918), UINT32_C(0x003193C5), UINT32_C(0x002B6332),
11236           UINT32_C(0x005EA944), UINT32_C(0x001F5E4B), UINT32_C(0x0014F9B3),
11237           UINT32_C(0x000E2522), UINT32_C(0x004FCF6F), UINT32_C(0x002A3D76),
11238           UINT32_C(0x00048DB9), UINT32_C(0x001D02E8)},
11239          {UINT32_C(0x0037AF28), UINT32_C(0x0029FE6C), UINT32_C(0x0009EDFC),
11240           UINT32_C(0x0027B89F), UINT32_C(0x00301D20), UINT32_C(0x0032442E),
11241           UINT32_C(0x00200E28), UINT32_C(0x002D5E74), UINT32_C(0x0012B052),
11242           UINT32_C(0x003A45F3), UINT32_C(0x00317F8E), UINT32_C(0x001621A4),
11243           UINT32_C(0x0017C898), UINT32_C(0x00337293), UINT32_C(0x0017DFB5),
11244           UINT32_C(0x0071E94B), UINT32_C(0x001F139A), UINT32_C(0x001769A4),
11245           UINT32_C(0x003BA6FF), UINT32_C(0x005D3122), UINT32_C(0x002F863F),
11246           UINT32_C(0x000395F4), UINT32_C(0x00259438)}},
11247         {{UINT32_C(0x00698800), UINT32_C(0x003C6A37), UINT32_C(0x0021F1BB),
11248           UINT32_C(0x004E8C9D), UINT32_C(0x00033DB6), UINT32_C(0x000A7B27),
11249           UINT32_C(0x000E7C3D), UINT32_C(0x00611E5A), UINT32_C(0x0008E6DC),
11250           UINT32_C(0x001B99B7), UINT32_C(0x00011169), UINT32_C(0x000C1DEC),
11251           UINT32_C(0x002423CA), UINT32_C(0x00017B20), UINT32_C(0x000AB665),
11252           UINT32_C(0x002626D4), UINT32_C(0x0023799A), UINT32_C(0x002806DE),
11253           UINT32_C(0x003692DB), UINT32_C(0x002B1EC8), UINT32_C(0x000E1414),
11254           UINT32_C(0x0026B167), UINT32_C(0x00169029)},
11255          {UINT32_C(0x0013B973), UINT32_C(0x003B4AF9), UINT32_C(0x0031ACC0),
11256           UINT32_C(0x00393363), UINT32_C(0x000B4D81), UINT32_C(0x0015A3AE),
11257           UINT32_C(0x002B3D90), UINT32_C(0x001BCC23), UINT32_C(0x000CC79D),
11258           UINT32_C(0x003E07EC), UINT32_C(0x002EE5FF), UINT32_C(0x0045B99C),
11259           UINT32_C(0x0001C279), UINT32_C(0x001A54B4), UINT32_C(0x00175534),
11260           UINT32_C(0x004FEA24), UINT32_C(0x0010F58E), UINT32_C(0x00343EB1),
11261           UINT32_C(0x0039ED8E), UINT32_C(0x0022AE96), UINT32_C(0x0023467E),
11262           UINT32_C(0x00318A7F), UINT32_C(0x0029E05C)}},
11263         {{UINT32_C(0x006B581B), UINT32_C(0x002F4135), UINT32_C(0x0007FED7),
11264           UINT32_C(0x0060C57B), UINT32_C(0x003393FD), UINT32_C(0x00093667),
11265           UINT32_C(0x0004FA1F), UINT32_C(0x0054919F), UINT32_C(0x00229F53),
11266           UINT32_C(0x001AB18E), UINT32_C(0x0011D07D), UINT32_C(0x0002443C),
11267           UINT32_C(0x002AA483), UINT32_C(0x0008DA57), UINT32_C(0x0038A821),
11268           UINT32_C(0x007861E9), UINT32_C(0x0024D8C3), UINT32_C(0x00309579),
11269           UINT32_C(0x002A1002), UINT32_C(0x007B324A), UINT32_C(0x00291FD3),
11270           UINT32_C(0x002937C2), UINT32_C(0x00310CCC)},
11271          {UINT32_C(0x007B71A6), UINT32_C(0x003EB7A5), UINT32_C(0x00395509),
11272           UINT32_C(0x003F58C6), UINT32_C(0x002932CB), UINT32_C(0x003417F8),
11273           UINT32_C(0x000AD82F), UINT32_C(0x00251085), UINT32_C(0x0006F21E),
11274           UINT32_C(0x001588B0), UINT32_C(0x000C136A), UINT32_C(0x004E6BB6),
11275           UINT32_C(0x000C7C60), UINT32_C(0x0015A2FF), UINT32_C(0x001965F4),
11276           UINT32_C(0x006B3224), UINT32_C(0x00280D4B), UINT32_C(0x000374E1),
11277           UINT32_C(0x00187558), UINT32_C(0x007A1057), UINT32_C(0x0001A4DB),
11278           UINT32_C(0x00392A05), UINT32_C(0x002B7342)}},
11279         {{UINT32_C(0x00102D12), UINT32_C(0x00157E1D), UINT32_C(0x003819E1),
11280           UINT32_C(0x000436EA), UINT32_C(0x0033F4FE), UINT32_C(0x0004D63C),
11281           UINT32_C(0x003A559C), UINT32_C(0x005758F8), UINT32_C(0x0032A48C),
11282           UINT32_C(0x0036F300), UINT32_C(0x003C06D5), UINT32_C(0x004AC77E),
11283           UINT32_C(0x0012DD43), UINT32_C(0x001CDBEB), UINT32_C(0x000CBE11),
11284           UINT32_C(0x0003CB34), UINT32_C(0x003F6859), UINT32_C(0x00144DCF),
11285           UINT32_C(0x000BDC01), UINT32_C(0x0038921F), UINT32_C(0x00161041),
11286           UINT32_C(0x000B8BE6), UINT32_C(0x002AC248)},
11287          {UINT32_C(0x0067DD3E), UINT32_C(0x0036DB63), UINT32_C(0x0037BA32),
11288           UINT32_C(0x000AF959), UINT32_C(0x0025B293), UINT32_C(0x0010059F),
11289           UINT32_C(0x0035780D), UINT32_C(0x0046380C), UINT32_C(0x0018452D),
11290           UINT32_C(0x002B5B67), UINT32_C(0x0016B7B2), UINT32_C(0x007AF664),
11291           UINT32_C(0x003C1F41), UINT32_C(0x00097E6F), UINT32_C(0x003205A1),
11292           UINT32_C(0x00725EFF), UINT32_C(0x003E2E86), UINT32_C(0x0038F16D),
11293           UINT32_C(0x000B458E), UINT32_C(0x00385D51), UINT32_C(0x00006670),
11294           UINT32_C(0x0008BCC1), UINT32_C(0x00098C17)}},
11295         {{UINT32_C(0x006DBF88), UINT32_C(0x002D6BB0), UINT32_C(0x003DFE61),
11296           UINT32_C(0x003DF76A), UINT32_C(0x00035BAA), UINT32_C(0x000984CF),
11297           UINT32_C(0x00054134), UINT32_C(0x00556ECD), UINT32_C(0x001F1973),
11298           UINT32_C(0x0006D2EA), UINT32_C(0x002F57DA), UINT32_C(0x0024A56A),
11299           UINT32_C(0x002A7755), UINT32_C(0x000305FD), UINT32_C(0x001C8FD6),
11300           UINT32_C(0x00481CAF), UINT32_C(0x003D0B45), UINT32_C(0x000D68BC),
11301           UINT32_C(0x0039248B), UINT32_C(0x00290881), UINT32_C(0x001C8DB5),
11302           UINT32_C(0x000250CE), UINT32_C(0x000A5C50)},
11303          {UINT32_C(0x005313E5), UINT32_C(0x002F268C), UINT32_C(0x001D3B3E),
11304           UINT32_C(0x001FE5D2), UINT32_C(0x0006955A), UINT32_C(0x00336B39),
11305           UINT32_C(0x00290B6C), UINT32_C(0x00183F14), UINT32_C(0x0025ED57),
11306           UINT32_C(0x0006E18E), UINT32_C(0x00245AB9), UINT32_C(0x000AFADF),
11307           UINT32_C(0x001B239A), UINT32_C(0x003D1824), UINT32_C(0x00286527),
11308           UINT32_C(0x00619C72), UINT32_C(0x00341914), UINT32_C(0x00191683),
11309           UINT32_C(0x00365835), UINT32_C(0x006A9C8D), UINT32_C(0x000DCB56),
11310           UINT32_C(0x003D7D6F), UINT32_C(0x00312DA6)}},
11311         {{UINT32_C(0x002A34A8), UINT32_C(0x0011A273), UINT32_C(0x002EF0E7),
11312           UINT32_C(0x0056ED5F), UINT32_C(0x0022B29F), UINT32_C(0x003BC53B),
11313           UINT32_C(0x00374AF6), UINT32_C(0x001209F7), UINT32_C(0x00087894),
11314           UINT32_C(0x001D51AC), UINT32_C(0x001C55D9), UINT32_C(0x0007EA51),
11315           UINT32_C(0x0027A416), UINT32_C(0x002199BF), UINT32_C(0x00398181),
11316           UINT32_C(0x0050725A), UINT32_C(0x00016D8B), UINT32_C(0x00185F36),
11317           UINT32_C(0x0022B389), UINT32_C(0x00670F14), UINT32_C(0x003EE89C),
11318           UINT32_C(0x00208598), UINT32_C(0x0037FA4E)},
11319          {UINT32_C(0x002CBD11), UINT32_C(0x0025CA10), UINT32_C(0x0025A5C4),
11320           UINT32_C(0x0073CCEA), UINT32_C(0x001D4A0C), UINT32_C(0x003E1189),
11321           UINT32_C(0x0012D18F), UINT32_C(0x00202D6B), UINT32_C(0x0005142A),
11322           UINT32_C(0x000673EF), UINT32_C(0x00230DED), UINT32_C(0x005C9EF1),
11323           UINT32_C(0x00199F43), UINT32_C(0x000951F1), UINT32_C(0x0001FA9B),
11324           UINT32_C(0x0042FDCE), UINT32_C(0x003CF250), UINT32_C(0x00333B05),
11325           UINT32_C(0x003487E6), UINT32_C(0x001A46EF), UINT32_C(0x0009221A),
11326           UINT32_C(0x001601FA), UINT32_C(0x000A8F97)}},
11327         {{UINT32_C(0x0029B1A4), UINT32_C(0x001A205E), UINT32_C(0x0010D45B),
11328           UINT32_C(0x00009969), UINT32_C(0x003B86E1), UINT32_C(0x00263695),
11329           UINT32_C(0x0038303F), UINT32_C(0x000F276E), UINT32_C(0x003DD7EE),
11330           UINT32_C(0x0003D7B5), UINT32_C(0x0019C4B1), UINT32_C(0x003248D5),
11331           UINT32_C(0x0021E8FE), UINT32_C(0x000FC768), UINT32_C(0x001F35EC),
11332           UINT32_C(0x002FB73B), UINT32_C(0x001B945A), UINT32_C(0x00164C1B),
11333           UINT32_C(0x002F277F), UINT32_C(0x005EAE78), UINT32_C(0x00071711),
11334           UINT32_C(0x000C61BB), UINT32_C(0x000AB2C0)},
11335          {UINT32_C(0x0016DF7A), UINT32_C(0x0015DC01), UINT32_C(0x002BA091),
11336           UINT32_C(0x0011F44E), UINT32_C(0x000B08D7), UINT32_C(0x002E9923),
11337           UINT32_C(0x00092787), UINT32_C(0x002ADBB4), UINT32_C(0x003D7AA5),
11338           UINT32_C(0x0009E226), UINT32_C(0x002384F8), UINT32_C(0x003614F7),
11339           UINT32_C(0x003BEA0C), UINT32_C(0x002456BB), UINT32_C(0x00107C57),
11340           UINT32_C(0x004A575C), UINT32_C(0x000760C6), UINT32_C(0x0034DEA3),
11341           UINT32_C(0x002C29AE), UINT32_C(0x007702EC), UINT32_C(0x000797DD),
11342           UINT32_C(0x002C2EC2), UINT32_C(0x000B53B4)}},
11343         {{UINT32_C(0x004E14DC), UINT32_C(0x000DCCE7), UINT32_C(0x00268B67),
11344           UINT32_C(0x00671423), UINT32_C(0x000C36E7), UINT32_C(0x002EF482),
11345           UINT32_C(0x0002A811), UINT32_C(0x004F450D), UINT32_C(0x0019D6E8),
11346           UINT32_C(0x00379047), UINT32_C(0x0024CF74), UINT32_C(0x0017F363),
11347           UINT32_C(0x00242D1C), UINT32_C(0x000034DF), UINT32_C(0x002AEC5D),
11348           UINT32_C(0x0016D8E1), UINT32_C(0x0015B2FA), UINT32_C(0x00347EF8),
11349           UINT32_C(0x00075A03), UINT32_C(0x006AFAC1), UINT32_C(0x0010C4CC),
11350           UINT32_C(0x00216803), UINT32_C(0x001AA96E)},
11351          {UINT32_C(0x0057B948), UINT32_C(0x002E3492), UINT32_C(0x002E8BEB),
11352           UINT32_C(0x00500CA7), UINT32_C(0x002A1860), UINT32_C(0x001B6814),
11353           UINT32_C(0x0019C85F), UINT32_C(0x0061C4ED), UINT32_C(0x002EF6B7),
11354           UINT32_C(0x0038C2BF), UINT32_C(0x003C380D), UINT32_C(0x0011C0C0),
11355           UINT32_C(0x0011337C), UINT32_C(0x0015C779), UINT32_C(0x00136724),
11356           UINT32_C(0x00050BF7), UINT32_C(0x0005558D), UINT32_C(0x002EC289),
11357           UINT32_C(0x003637CA), UINT32_C(0x004B8113), UINT32_C(0x001A69CC),
11358           UINT32_C(0x00301379), UINT32_C(0x003F1AD7)}},
11359         {{UINT32_C(0x0012C055), UINT32_C(0x000EB55E), UINT32_C(0x000D7834),
11360           UINT32_C(0x0027B02C), UINT32_C(0x003B78F0), UINT32_C(0x0010001F),
11361           UINT32_C(0x002DD1EC), UINT32_C(0x0044CC9D), UINT32_C(0x003F406F),
11362           UINT32_C(0x002BBD9B), UINT32_C(0x003D495E), UINT32_C(0x002D8896),
11363           UINT32_C(0x0030CB6A), UINT32_C(0x001B5E53), UINT32_C(0x002AD9F8),
11364           UINT32_C(0x001E75BF), UINT32_C(0x000F94EA), UINT32_C(0x00057B4C),
11365           UINT32_C(0x00370072), UINT32_C(0x0014B385), UINT32_C(0x0005ACED),
11366           UINT32_C(0x002C28F0), UINT32_C(0x003AB7D9)},
11367          {UINT32_C(0x0020CF13), UINT32_C(0x00225C38), UINT32_C(0x002B6293),
11368           UINT32_C(0x0013F808), UINT32_C(0x00344CB9), UINT32_C(0x0033719D),
11369           UINT32_C(0x002FE2B6), UINT32_C(0x00282CB5), UINT32_C(0x00175559),
11370           UINT32_C(0x000403EA), UINT32_C(0x00359279), UINT32_C(0x005D8812),
11371           UINT32_C(0x000B1A40), UINT32_C(0x003EE682), UINT32_C(0x0016E724),
11372           UINT32_C(0x002FB1C5), UINT32_C(0x002F6BEE), UINT32_C(0x0022778B),
11373           UINT32_C(0x0019AEA3), UINT32_C(0x003D80A9), UINT32_C(0x0032D9D1),
11374           UINT32_C(0x003BF23F), UINT32_C(0x002DBA08)}},
11375         {{UINT32_C(0x00475A5B), UINT32_C(0x000AF126), UINT32_C(0x000E8D05),
11376           UINT32_C(0x0037AAD9), UINT32_C(0x003350FF), UINT32_C(0x003B6DF1),
11377           UINT32_C(0x000C70D2), UINT32_C(0x0031341A), UINT32_C(0x00166A1F),
11378           UINT32_C(0x003D3DBE), UINT32_C(0x0021F7E8), UINT32_C(0x006D14A1),
11379           UINT32_C(0x0039D159), UINT32_C(0x001EFA80), UINT32_C(0x0032B317),
11380           UINT32_C(0x0024939B), UINT32_C(0x001C82DD), UINT32_C(0x00061D7A),
11381           UINT32_C(0x00147571), UINT32_C(0x004FFE3E), UINT32_C(0x000965DE),
11382           UINT32_C(0x0028C381), UINT32_C(0x000DFE6C)},
11383          {UINT32_C(0x0035EAA0), UINT32_C(0x0009123B), UINT32_C(0x0032E9E6),
11384           UINT32_C(0x00084111), UINT32_C(0x0000F226), UINT32_C(0x003CD924),
11385           UINT32_C(0x000ABC8B), UINT32_C(0x00538B5D), UINT32_C(0x00023291),
11386           UINT32_C(0x000DB4A0), UINT32_C(0x00010030), UINT32_C(0x00328332),
11387           UINT32_C(0x001A2589), UINT32_C(0x00233EA0), UINT32_C(0x0017BE31),
11388           UINT32_C(0x00586460), UINT32_C(0x0012777E), UINT32_C(0x002D359E),
11389           UINT32_C(0x000D0BCC), UINT32_C(0x00245915), UINT32_C(0x000F3FAB),
11390           UINT32_C(0x00232DCC), UINT32_C(0x0026CC0F)}},
11391         {{UINT32_C(0x006107A0), UINT32_C(0x00348213), UINT32_C(0x001DB8EE),
11392           UINT32_C(0x003152F3), UINT32_C(0x0029336E), UINT32_C(0x001572BD),
11393           UINT32_C(0x002314E4), UINT32_C(0x0050D309), UINT32_C(0x002101EA),
11394           UINT32_C(0x0000EDBA), UINT32_C(0x0011643A), UINT32_C(0x002A8161),
11395           UINT32_C(0x00169D2D), UINT32_C(0x00105B84), UINT32_C(0x0007A268),
11396           UINT32_C(0x00602253), UINT32_C(0x000EAF07), UINT32_C(0x000BF9C0),
11397           UINT32_C(0x001F44D9), UINT32_C(0x0000BADF), UINT32_C(0x000B6708),
11398           UINT32_C(0x000F4EDA), UINT32_C(0x0027E80B)},
11399          {UINT32_C(0x0079EA50), UINT32_C(0x0012030F), UINT32_C(0x00175D43),
11400           UINT32_C(0x005CD824), UINT32_C(0x00334D4F), UINT32_C(0x002AEE35),
11401           UINT32_C(0x0021CFB0), UINT32_C(0x00199622), UINT32_C(0x000CA221),
11402           UINT32_C(0x0007BC44), UINT32_C(0x0029CBBF), UINT32_C(0x0019F06C),
11403           UINT32_C(0x0034ECA6), UINT32_C(0x0027BE0E), UINT32_C(0x002FE495),
11404           UINT32_C(0x00705DBB), UINT32_C(0x002F6511), UINT32_C(0x000D66C8),
11405           UINT32_C(0x000C392A), UINT32_C(0x0014BBEE), UINT32_C(0x0007F420),
11406           UINT32_C(0x0020EF1F), UINT32_C(0x002DD2C3)}},
11407         {{UINT32_C(0x001F311E), UINT32_C(0x0035E164), UINT32_C(0x000D7E33),
11408           UINT32_C(0x004EE0A2), UINT32_C(0x001B027B), UINT32_C(0x003AF8A9),
11409           UINT32_C(0x000897E1), UINT32_C(0x004E7636), UINT32_C(0x002CFEBD),
11410           UINT32_C(0x00349E23), UINT32_C(0x003A2005), UINT32_C(0x0033A740),
11411           UINT32_C(0x000273B7), UINT32_C(0x00018397), UINT32_C(0x0002783F),
11412           UINT32_C(0x00201E98), UINT32_C(0x0009D39F), UINT32_C(0x000A5722),
11413           UINT32_C(0x002D49F8), UINT32_C(0x00798C09), UINT32_C(0x000C4014),
11414           UINT32_C(0x0007D8C3), UINT32_C(0x002F570F)},
11415          {UINT32_C(0x00477116), UINT32_C(0x00161163), UINT32_C(0x002DF7BB),
11416           UINT32_C(0x001DD1D7), UINT32_C(0x003A92DB), UINT32_C(0x0036ACFC),
11417           UINT32_C(0x00211278), UINT32_C(0x0055790C), UINT32_C(0x000B98E9),
11418           UINT32_C(0x002EB711), UINT32_C(0x0009D7B7), UINT32_C(0x003CD366),
11419           UINT32_C(0x000622E0), UINT32_C(0x000D9307), UINT32_C(0x0001BD5F),
11420           UINT32_C(0x0073A35F), UINT32_C(0x003FC1C3), UINT32_C(0x0025C15B),
11421           UINT32_C(0x00359419), UINT32_C(0x006A6138), UINT32_C(0x002A142D),
11422           UINT32_C(0x000BBEDD), UINT32_C(0x0008A742)}},
11423     },
11424     {
11425         {{UINT32_C(0x00020495), UINT32_C(0x0029C46F), UINT32_C(0x0015C863),
11426           UINT32_C(0x001A9BE1), UINT32_C(0x002541BC), UINT32_C(0x003083D6),
11427           UINT32_C(0x000E2B6E), UINT32_C(0x004DEA6D), UINT32_C(0x00233C05),
11428           UINT32_C(0x00093178), UINT32_C(0x00300C16), UINT32_C(0x0047A8A8),
11429           UINT32_C(0x003EEE62), UINT32_C(0x003A3FFE), UINT32_C(0x002D8A6E),
11430           UINT32_C(0x003747DF), UINT32_C(0x0023EBEC), UINT32_C(0x003A703F),
11431           UINT32_C(0x00057635), UINT32_C(0x004C2FF0), UINT32_C(0x0013DB65),
11432           UINT32_C(0x0028F19D), UINT32_C(0x00333AB2)},
11433          {UINT32_C(0x0000A454), UINT32_C(0x0003242C), UINT32_C(0x00263770),
11434           UINT32_C(0x0070C7F5), UINT32_C(0x0007B940), UINT32_C(0x00062CBB),
11435           UINT32_C(0x000BB7CC), UINT32_C(0x00001E3F), UINT32_C(0x00107BEF),
11436           UINT32_C(0x0024BD77), UINT32_C(0x0003307A), UINT32_C(0x003C6EC5),
11437           UINT32_C(0x00357523), UINT32_C(0x003FE203), UINT32_C(0x002F4B77),
11438           UINT32_C(0x0039AB29), UINT32_C(0x00009871), UINT32_C(0x003024E6),
11439           UINT32_C(0x001EAE16), UINT32_C(0x003F3D08), UINT32_C(0x0029A969),
11440           UINT32_C(0x001642E9), UINT32_C(0x003925FE)}},
11441         {{UINT32_C(0x000C8333), UINT32_C(0x00134BA7), UINT32_C(0x0009B871),
11442           UINT32_C(0x0004CDC4), UINT32_C(0x00289CA0), UINT32_C(0x001FC8D2),
11443           UINT32_C(0x0039D91B), UINT32_C(0x0038FC3D), UINT32_C(0x0019773B),
11444           UINT32_C(0x0006D4DF), UINT32_C(0x0006221A), UINT32_C(0x004F1A1C),
11445           UINT32_C(0x0010AF9E), UINT32_C(0x0018553A), UINT32_C(0x00130550),
11446           UINT32_C(0x00111A01), UINT32_C(0x003C7519), UINT32_C(0x00287566),
11447           UINT32_C(0x001644E8), UINT32_C(0x0041602D), UINT32_C(0x0032CDC1),
11448           UINT32_C(0x001C2B40), UINT32_C(0x0030A48F)},
11449          {UINT32_C(0x0042DCF0), UINT32_C(0x0008B28F), UINT32_C(0x003EC6F9),
11450           UINT32_C(0x006A8D26), UINT32_C(0x0034DBA9), UINT32_C(0x002BD050),
11451           UINT32_C(0x003FE19C), UINT32_C(0x0030096C), UINT32_C(0x0013965D),
11452           UINT32_C(0x00010C86), UINT32_C(0x003C6698), UINT32_C(0x00731549),
11453           UINT32_C(0x000AAA24), UINT32_C(0x0010C344), UINT32_C(0x003F7448),
11454           UINT32_C(0x000C5964), UINT32_C(0x0019616E), UINT32_C(0x0035336F),
11455           UINT32_C(0x000723D5), UINT32_C(0x00244786), UINT32_C(0x002452D1),
11456           UINT32_C(0x001F0B6A), UINT32_C(0x0031D0BC)}},
11457         {{UINT32_C(0x001ABEAE), UINT32_C(0x00140094), UINT32_C(0x0025F718),
11458           UINT32_C(0x001FFB06), UINT32_C(0x002CE72A), UINT32_C(0x000678CF),
11459           UINT32_C(0x0007D404), UINT32_C(0x0073CB92), UINT32_C(0x000A9FC4),
11460           UINT32_C(0x000668BB), UINT32_C(0x0027BD0D), UINT32_C(0x002BDE2E),
11461           UINT32_C(0x003EDD2C), UINT32_C(0x00154AE6), UINT32_C(0x00290863),
11462           UINT32_C(0x00334512), UINT32_C(0x001E546A), UINT32_C(0x002467D8),
11463           UINT32_C(0x0006CBDB), UINT32_C(0x002139AD), UINT32_C(0x001CED3F),
11464           UINT32_C(0x00217DC2), UINT32_C(0x001F626B)},
11465          {UINT32_C(0x00390DFD), UINT32_C(0x0002F8B3), UINT32_C(0x000E30AF),
11466           UINT32_C(0x0005D7A3), UINT32_C(0x001EFA22), UINT32_C(0x002CAFDB),
11467           UINT32_C(0x00004971), UINT32_C(0x002EFBEA), UINT32_C(0x001F4ACB),
11468           UINT32_C(0x00302B99), UINT32_C(0x001DFC66), UINT32_C(0x007364F2),
11469           UINT32_C(0x00371C65), UINT32_C(0x0028108D), UINT32_C(0x003C66ED),
11470           UINT32_C(0x005D7568), UINT32_C(0x00212DC4), UINT32_C(0x0011A56E),
11471           UINT32_C(0x0034EE5A), UINT32_C(0x0031E1D4), UINT32_C(0x003CF9C2),
11472           UINT32_C(0x003EB41F), UINT32_C(0x003C84A7)}},
11473         {{UINT32_C(0x007FF718), UINT32_C(0x00032692), UINT32_C(0x002F052E),
11474           UINT32_C(0x00755B72), UINT32_C(0x003D2345), UINT32_C(0x0038E6DD),
11475           UINT32_C(0x0025DC5A), UINT32_C(0x0065158E), UINT32_C(0x0035F9E0),
11476           UINT32_C(0x0019A28C), UINT32_C(0x00178B35), UINT32_C(0x0044D5B8),
11477           UINT32_C(0x0039CE59), UINT32_C(0x00379216), UINT32_C(0x00098649),
11478           UINT32_C(0x00105E9E), UINT32_C(0x0037A436), UINT32_C(0x0035A4A6),
11479           UINT32_C(0x00087244), UINT32_C(0x002AA631), UINT32_C(0x001E9EDB),
11480           UINT32_C(0x000A2622), UINT32_C(0x001D1531)},
11481          {UINT32_C(0x003C8CB9), UINT32_C(0x003D6118), UINT32_C(0x00179E49),
11482           UINT32_C(0x002B0C0C), UINT32_C(0x0039C364), UINT32_C(0x002CA57A),
11483           UINT32_C(0x003F8C54), UINT32_C(0x001FB453), UINT32_C(0x003C0C82),
11484           UINT32_C(0x003B2FF0), UINT32_C(0x003A2B7F), UINT32_C(0x0058C732),
11485           UINT32_C(0x000C6E03), UINT32_C(0x0030EAAB), UINT32_C(0x002A43FC),
11486           UINT32_C(0x0029DF25), UINT32_C(0x00002B4F), UINT32_C(0x0022A3CA),
11487           UINT32_C(0x00104844), UINT32_C(0x004A0B3B), UINT32_C(0x001849CB),
11488           UINT32_C(0x001C4653), UINT32_C(0x002F1596)}},
11489         {{UINT32_C(0x001D4A19), UINT32_C(0x0035FDF4), UINT32_C(0x000F8F5B),
11490           UINT32_C(0x003FF4B0), UINT32_C(0x00157527), UINT32_C(0x0015F4FF),
11491           UINT32_C(0x00337DA4), UINT32_C(0x002BC44F), UINT32_C(0x00223C67),
11492           UINT32_C(0x001B663C), UINT32_C(0x00281B4B), UINT32_C(0x0078BDF6),
11493           UINT32_C(0x000D0B3B), UINT32_C(0x00099BBB), UINT32_C(0x002A4438),
11494           UINT32_C(0x00512DEC), UINT32_C(0x0007055E), UINT32_C(0x002AF2F0),
11495           UINT32_C(0x002C9105), UINT32_C(0x0023E635), UINT32_C(0x001CB35B),
11496           UINT32_C(0x0028C1C2), UINT32_C(0x002DE4D1)},
11497          {UINT32_C(0x00140ADA), UINT32_C(0x0011EC68), UINT32_C(0x0018DFDD),
11498           UINT32_C(0x006F5E0E), UINT32_C(0x00185618), UINT32_C(0x000B38F8),
11499           UINT32_C(0x0003AC86), UINT32_C(0x00345A9C), UINT32_C(0x0018811B),
11500           UINT32_C(0x0034EF90), UINT32_C(0x00309FA7), UINT32_C(0x002657B1),
11501           UINT32_C(0x0026A02F), UINT32_C(0x003FB112), UINT32_C(0x003E8E9A),
11502           UINT32_C(0x004E6284), UINT32_C(0x00310F7A), UINT32_C(0x0013E7DA),
11503           UINT32_C(0x0014C174), UINT32_C(0x0038C1FC), UINT32_C(0x0026EC4A),
11504           UINT32_C(0x0018C688), UINT32_C(0x002A438F)}},
11505         {{UINT32_C(0x004F0ACF), UINT32_C(0x001C15FB), UINT32_C(0x003CD5C1),
11506           UINT32_C(0x000D2292), UINT32_C(0x0025B6A8), UINT32_C(0x00221999),
11507           UINT32_C(0x0016BA08), UINT32_C(0x00792A56), UINT32_C(0x00215FF2),
11508           UINT32_C(0x002B39F1), UINT32_C(0x000F2F96), UINT32_C(0x00025D28),
11509           UINT32_C(0x0029609E), UINT32_C(0x00351C7F), UINT32_C(0x000A603D),
11510           UINT32_C(0x003F3CD9), UINT32_C(0x00024C3B), UINT32_C(0x000C25E9),
11511           UINT32_C(0x002157FF), UINT32_C(0x003E3F6F), UINT32_C(0x0015898B),
11512           UINT32_C(0x0007923F), UINT32_C(0x0011A75F)},
11513          {UINT32_C(0x001B8989), UINT32_C(0x0036B95E), UINT32_C(0x000B28EB),
11514           UINT32_C(0x006F0F0E), UINT32_C(0x001BB501), UINT32_C(0x0029744C),
11515           UINT32_C(0x002C2A82), UINT32_C(0x006278D2), UINT32_C(0x0006D540),
11516           UINT32_C(0x00338072), UINT32_C(0x0023F135), UINT32_C(0x006B3C7F),
11517           UINT32_C(0x003F9CA2), UINT32_C(0x003069ED), UINT32_C(0x001454A7),
11518           UINT32_C(0x001CEA39), UINT32_C(0x000EDAE9), UINT32_C(0x002BF356),
11519           UINT32_C(0x003B1BD9), UINT32_C(0x00073EF3), UINT32_C(0x003041D7),
11520           UINT32_C(0x00096064), UINT32_C(0x00142C76)}},
11521         {{UINT32_C(0x0068FFC6), UINT32_C(0x003C11C5), UINT32_C(0x0031DD2F),
11522           UINT32_C(0x002086BC), UINT32_C(0x00213A20), UINT32_C(0x000198C3),
11523           UINT32_C(0x003C70AA), UINT32_C(0x0064A691), UINT32_C(0x003F88A6),
11524           UINT32_C(0x0010B222), UINT32_C(0x001133AE), UINT32_C(0x0000D81A),
11525           UINT32_C(0x0008B4F2), UINT32_C(0x0037B644), UINT32_C(0x0020B08F),
11526           UINT32_C(0x002B77A7), UINT32_C(0x000AEF1B), UINT32_C(0x002AB9A7),
11527           UINT32_C(0x001FFD9C), UINT32_C(0x002D2887), UINT32_C(0x001829D4),
11528           UINT32_C(0x00291E60), UINT32_C(0x0024DD09)},
11529          {UINT32_C(0x005A1EE9), UINT32_C(0x000858BD), UINT32_C(0x0006666A),
11530           UINT32_C(0x00665E27), UINT32_C(0x001E2D76), UINT32_C(0x00151594),
11531           UINT32_C(0x003CBB31), UINT32_C(0x00274D76), UINT32_C(0x00385369),
11532           UINT32_C(0x002D97F4), UINT32_C(0x00213614), UINT32_C(0x005429E7),
11533           UINT32_C(0x001A6A17), UINT32_C(0x00022689), UINT32_C(0x0007C22E),
11534           UINT32_C(0x000CB237), UINT32_C(0x003B33BC), UINT32_C(0x003A2CF2),
11535           UINT32_C(0x001014A7), UINT32_C(0x004AFB82), UINT32_C(0x003DB97C),
11536           UINT32_C(0x0016FCCC), UINT32_C(0x001D22CE)}},
11537         {{UINT32_C(0x00583D1F), UINT32_C(0x001CAB29), UINT32_C(0x0021DFFC),
11538           UINT32_C(0x00579859), UINT32_C(0x00239960), UINT32_C(0x00287022),
11539           UINT32_C(0x000FBF8A), UINT32_C(0x00522225), UINT32_C(0x00084A9F),
11540           UINT32_C(0x0024948B), UINT32_C(0x002CC83C), UINT32_C(0x0067C4AC),
11541           UINT32_C(0x0034836D), UINT32_C(0x00216546), UINT32_C(0x00364159),
11542           UINT32_C(0x003ADB5A), UINT32_C(0x0003CEB5), UINT32_C(0x00345B44),
11543           UINT32_C(0x002138FD), UINT32_C(0x001743CA), UINT32_C(0x00069ABD),
11544           UINT32_C(0x0023EC4A), UINT32_C(0x00050B88)},
11545          {UINT32_C(0x006438C3), UINT32_C(0x00369425), UINT32_C(0x00279B67),
11546           UINT32_C(0x000D0143), UINT32_C(0x001F364D), UINT32_C(0x00177C5D),
11547           UINT32_C(0x00095B66), UINT32_C(0x002B4C4F), UINT32_C(0x002C159D),
11548           UINT32_C(0x0004AD5B), UINT32_C(0x00177C82), UINT32_C(0x0033A0E4),
11549           UINT32_C(0x003ACCD6), UINT32_C(0x0034623F), UINT32_C(0x000F5D74),
11550           UINT32_C(0x00680AEF), UINT32_C(0x002D31E0), UINT32_C(0x000BB398),
11551           UINT32_C(0x00233354), UINT32_C(0x00253484), UINT32_C(0x00385E50),
11552           UINT32_C(0x000F78CF), UINT32_C(0x000322BA)}},
11553         {{UINT32_C(0x00724124), UINT32_C(0x0030C69A), UINT32_C(0x00310E26),
11554           UINT32_C(0x00278477), UINT32_C(0x0012FFD4), UINT32_C(0x0005570F),
11555           UINT32_C(0x003EBD03), UINT32_C(0x006F51F4), UINT32_C(0x00043A21),
11556           UINT32_C(0x001A4CEA), UINT32_C(0x00172D44), UINT32_C(0x00696C4A),
11557           UINT32_C(0x003FA9A1), UINT32_C(0x0026633B), UINT32_C(0x0005F2B7),
11558           UINT32_C(0x0002C7C4), UINT32_C(0x0003A452), UINT32_C(0x003F240B),
11559           UINT32_C(0x003CBC7E), UINT32_C(0x00074F43), UINT32_C(0x002F68A2),
11560           UINT32_C(0x000623F6), UINT32_C(0x001D4282)},
11561          {UINT32_C(0x0014B428), UINT32_C(0x003E7D33), UINT32_C(0x002520C7),
11562           UINT32_C(0x0041CCF2), UINT32_C(0x00233BAB), UINT32_C(0x001589F9),
11563           UINT32_C(0x000D2E6E), UINT32_C(0x001FFD7C), UINT32_C(0x001DCFD2),
11564           UINT32_C(0x00390FFE), UINT32_C(0x00031026), UINT32_C(0x00772372),
11565           UINT32_C(0x0010F507), UINT32_C(0x0039D935), UINT32_C(0x0011504F),
11566           UINT32_C(0x0041B316), UINT32_C(0x001B31F1), UINT32_C(0x00309FCB),
11567           UINT32_C(0x002D1468), UINT32_C(0x00238297), UINT32_C(0x001B6605),
11568           UINT32_C(0x001B59F9), UINT32_C(0x000B6C96)}},
11569         {{UINT32_C(0x0043F6C2), UINT32_C(0x000763DF), UINT32_C(0x00308091),
11570           UINT32_C(0x006DDCFF), UINT32_C(0x002FC758), UINT32_C(0x001EFF60),
11571           UINT32_C(0x0018180E), UINT32_C(0x005F0A71), UINT32_C(0x001E4437),
11572           UINT32_C(0x000EADD7), UINT32_C(0x0012CA06), UINT32_C(0x0024EF90),
11573           UINT32_C(0x00188475), UINT32_C(0x0018B6D9), UINT32_C(0x001DEA6E),
11574           UINT32_C(0x0044FC14), UINT32_C(0x003D1458), UINT32_C(0x0031E96A),
11575           UINT32_C(0x000E2DAF), UINT32_C(0x00628BB3), UINT32_C(0x002A2193),
11576           UINT32_C(0x00011F06), UINT32_C(0x000C91E9)},
11577          {UINT32_C(0x00482FED), UINT32_C(0x002528F8), UINT32_C(0x002FD25C),
11578           UINT32_C(0x00261308), UINT32_C(0x00139233), UINT32_C(0x00302E3F),
11579           UINT32_C(0x002A13B0), UINT32_C(0x007DEDA6), UINT32_C(0x0011FB4F),
11580           UINT32_C(0x0008FBA1), UINT32_C(0x00196CC9), UINT32_C(0x0051E7E4),
11581           UINT32_C(0x0005A421), UINT32_C(0x003784E4), UINT32_C(0x00174AFF),
11582           UINT32_C(0x004725BC), UINT32_C(0x0004CD05), UINT32_C(0x0026FA6B),
11583           UINT32_C(0x001805BF), UINT32_C(0x0017519D), UINT32_C(0x001A7B71),
11584           UINT32_C(0x00280018), UINT32_C(0x0026EC17)}},
11585         {{UINT32_C(0x001C205B), UINT32_C(0x002CCC69), UINT32_C(0x0030F0E5),
11586           UINT32_C(0x00192A4E), UINT32_C(0x003D1B67), UINT32_C(0x0020DAE2),
11587           UINT32_C(0x000769DE), UINT32_C(0x001BFA4D), UINT32_C(0x000B7649),
11588           UINT32_C(0x000C1B2B), UINT32_C(0x0038C90F), UINT32_C(0x001D0BF8),
11589           UINT32_C(0x000577CB), UINT32_C(0x00190B4F), UINT32_C(0x003E238F),
11590           UINT32_C(0x0052DFF8), UINT32_C(0x0010D0F0), UINT32_C(0x000218C9),
11591           UINT32_C(0x0013F89C), UINT32_C(0x00714803), UINT32_C(0x003A6F8C),
11592           UINT32_C(0x00353B6D), UINT32_C(0x002FFEEA)},
11593          {UINT32_C(0x0030C7D2), UINT32_C(0x000CA103), UINT32_C(0x0021611C),
11594           UINT32_C(0x00188899), UINT32_C(0x001F54E9), UINT32_C(0x00010620),
11595           UINT32_C(0x000AE01A), UINT32_C(0x007A2DB9), UINT32_C(0x002A9401),
11596           UINT32_C(0x00209C63), UINT32_C(0x00389F5D), UINT32_C(0x00196FFF),
11597           UINT32_C(0x002CE291), UINT32_C(0x00340A01), UINT32_C(0x003FF906),
11598           UINT32_C(0x002C42FC), UINT32_C(0x0037C6A3), UINT32_C(0x001146A7),
11599           UINT32_C(0x00044BAD), UINT32_C(0x0063D883), UINT32_C(0x000BAB16),
11600           UINT32_C(0x001FF085), UINT32_C(0x00140B79)}},
11601         {{UINT32_C(0x0032C0E7), UINT32_C(0x00208DFF), UINT32_C(0x002F6660),
11602           UINT32_C(0x0070C915), UINT32_C(0x002D9AF5), UINT32_C(0x0012AB64),
11603           UINT32_C(0x0015326E), UINT32_C(0x001E8920), UINT32_C(0x0031383C),
11604           UINT32_C(0x000E45C6), UINT32_C(0x003FF494), UINT32_C(0x00792407),
11605           UINT32_C(0x0021A39A), UINT32_C(0x003EFC30), UINT32_C(0x0008C932),
11606           UINT32_C(0x0031D0D5), UINT32_C(0x0013E9B1), UINT32_C(0x0016F25F),
11607           UINT32_C(0x00251F58), UINT32_C(0x001D0CCC), UINT32_C(0x00189479),
11608           UINT32_C(0x001E2A1D), UINT32_C(0x001548E8)},
11609          {UINT32_C(0x007ED4E4), UINT32_C(0x003831E3), UINT32_C(0x0036B65B),
11610           UINT32_C(0x00173DB0), UINT32_C(0x0030B4B3), UINT32_C(0x003B0A38),
11611           UINT32_C(0x00176695), UINT32_C(0x0022F024), UINT32_C(0x002DC536),
11612           UINT32_C(0x0026D641), UINT32_C(0x003845E6), UINT32_C(0x006AE213),
11613           UINT32_C(0x000F1253), UINT32_C(0x0035B8B4), UINT32_C(0x002D1D2C),
11614           UINT32_C(0x0026072B), UINT32_C(0x000C4DFF), UINT32_C(0x00098C06),
11615           UINT32_C(0x003973E5), UINT32_C(0x006E815F), UINT32_C(0x0035E739),
11616           UINT32_C(0x0004E25A), UINT32_C(0x00323E06)}},
11617         {{UINT32_C(0x0018218E), UINT32_C(0x001C5A05), UINT32_C(0x00156FEA),
11618           UINT32_C(0x000DEF36), UINT32_C(0x003405AB), UINT32_C(0x000C8D8A),
11619           UINT32_C(0x003D4CE6), UINT32_C(0x0036C6B1), UINT32_C(0x0026347B),
11620           UINT32_C(0x002BEC62), UINT32_C(0x00135B49), UINT32_C(0x004ED20D),
11621           UINT32_C(0x002BCE15), UINT32_C(0x000A503C), UINT32_C(0x0030279F),
11622           UINT32_C(0x00124E30), UINT32_C(0x003AF38A), UINT32_C(0x0008EB83),
11623           UINT32_C(0x00141065), UINT32_C(0x004DF4DC), UINT32_C(0x00176DD3),
11624           UINT32_C(0x000FCB73), UINT32_C(0x000229CD)},
11625          {UINT32_C(0x0004041C), UINT32_C(0x003CAB13), UINT32_C(0x0029B3E4),
11626           UINT32_C(0x001B70DE), UINT32_C(0x00009B3A), UINT32_C(0x002C70AC),
11627           UINT32_C(0x00272EDA), UINT32_C(0x0010407E), UINT32_C(0x000645F0),
11628           UINT32_C(0x001E2E70), UINT32_C(0x000502A8), UINT32_C(0x00794831),
11629           UINT32_C(0x003AE5DE), UINT32_C(0x002799EA), UINT32_C(0x001CAFA4),
11630           UINT32_C(0x006E7B51), UINT32_C(0x0008984E), UINT32_C(0x0012EF3F),
11631           UINT32_C(0x000025E7), UINT32_C(0x000DDA10), UINT32_C(0x00119536),
11632           UINT32_C(0x003D6D8D), UINT32_C(0x0006C12F)}},
11633         {{UINT32_C(0x00435EE4), UINT32_C(0x000163D6), UINT32_C(0x00377C11),
11634           UINT32_C(0x003BD7D6), UINT32_C(0x002E05F5), UINT32_C(0x001FBA80),
11635           UINT32_C(0x00107C07), UINT32_C(0x00681A61), UINT32_C(0x0005189C),
11636           UINT32_C(0x0002C249), UINT32_C(0x003607CD), UINT32_C(0x000957D6),
11637           UINT32_C(0x003F952A), UINT32_C(0x0008ECBA), UINT32_C(0x001E29E1),
11638           UINT32_C(0x0033462B), UINT32_C(0x0022898D), UINT32_C(0x001AABD5),
11639           UINT32_C(0x002E885C), UINT32_C(0x000A2647), UINT32_C(0x0037A37C),
11640           UINT32_C(0x00297E79), UINT32_C(0x002A2CA3)},
11641          {UINT32_C(0x002C1A17), UINT32_C(0x00158B61), UINT32_C(0x0016816F),
11642           UINT32_C(0x0053A5A8), UINT32_C(0x001547B2), UINT32_C(0x0030AC66),
11643           UINT32_C(0x00202C4C), UINT32_C(0x00274C07), UINT32_C(0x000D322E),
11644           UINT32_C(0x0004A3E0), UINT32_C(0x000F7BC7), UINT32_C(0x00102196),
11645           UINT32_C(0x000C81FB), UINT32_C(0x00358316), UINT32_C(0x00063F2B),
11646           UINT32_C(0x007FF11C), UINT32_C(0x0025FFE3), UINT32_C(0x00256744),
11647           UINT32_C(0x002E91A0), UINT32_C(0x0064976E), UINT32_C(0x0038C948),
11648           UINT32_C(0x00396FAC), UINT32_C(0x0037CF6E)}},
11649         {{UINT32_C(0x00794F1D), UINT32_C(0x002B6A50), UINT32_C(0x00120AE4),
11650           UINT32_C(0x001CEC0F), UINT32_C(0x00383F87), UINT32_C(0x00216277),
11651           UINT32_C(0x00286CEA), UINT32_C(0x00103D5A), UINT32_C(0x002AA574),
11652           UINT32_C(0x003D3491), UINT32_C(0x0022931D), UINT32_C(0x00489498),
11653           UINT32_C(0x0032EEF4), UINT32_C(0x000CA2AA), UINT32_C(0x00080A27),
11654           UINT32_C(0x007FA661), UINT32_C(0x00094E9A), UINT32_C(0x003EE29E),
11655           UINT32_C(0x002AC21C), UINT32_C(0x001CE359), UINT32_C(0x003330FC),
11656           UINT32_C(0x001C6ADE), UINT32_C(0x00187790)},
11657          {UINT32_C(0x00340EF5), UINT32_C(0x000BDD62), UINT32_C(0x00333909),
11658           UINT32_C(0x0039146A), UINT32_C(0x0038BB2E), UINT32_C(0x00030F37),
11659           UINT32_C(0x00143B07), UINT32_C(0x0031CC3D), UINT32_C(0x002B5B5C),
11660           UINT32_C(0x00005892), UINT32_C(0x00052BD0), UINT32_C(0x000A282B),
11661           UINT32_C(0x0030D9C5), UINT32_C(0x001004FC), UINT32_C(0x0038922A),
11662           UINT32_C(0x000241A2), UINT32_C(0x000053C3), UINT32_C(0x002C02CA),
11663           UINT32_C(0x002D4F8F), UINT32_C(0x004AB17B), UINT32_C(0x003667C0),
11664           UINT32_C(0x0004EF7E), UINT32_C(0x000080E4)}},
11665         {{UINT32_C(0x005FA89B), UINT32_C(0x001D2F7D), UINT32_C(0x0019B385),
11666           UINT32_C(0x0053B863), UINT32_C(0x0022E414), UINT32_C(0x0011C620),
11667           UINT32_C(0x001F0CA5), UINT32_C(0x001B475A), UINT32_C(0x003E5B07),
11668           UINT32_C(0x0020C305), UINT32_C(0x0018A591), UINT32_C(0x007DE564),
11669           UINT32_C(0x001F654F), UINT32_C(0x003F1044), UINT32_C(0x000D7B16),
11670           UINT32_C(0x004E51E7), UINT32_C(0x00267972), UINT32_C(0x002A42F3),
11671           UINT32_C(0x000159C2), UINT32_C(0x0016007C), UINT32_C(0x000F9CA8),
11672           UINT32_C(0x00021184), UINT32_C(0x0007FCE7)},
11673          {UINT32_C(0x00045B0F), UINT32_C(0x000002C5), UINT32_C(0x0033642B),
11674           UINT32_C(0x0038378F), UINT32_C(0x001F29A8), UINT32_C(0x0018130B),
11675           UINT32_C(0x00340B0B), UINT32_C(0x007667B7), UINT32_C(0x0038B986),
11676           UINT32_C(0x00218A5C), UINT32_C(0x0020D3E4), UINT32_C(0x002B84EB),
11677           UINT32_C(0x001DBF61), UINT32_C(0x0006E45C), UINT32_C(0x000C2528),
11678           UINT32_C(0x003D5B87), UINT32_C(0x003B9631), UINT32_C(0x0016FFC9),
11679           UINT32_C(0x002577D8), UINT32_C(0x00084014), UINT32_C(0x00326179),
11680           UINT32_C(0x002B97FC), UINT32_C(0x0017D9B9)}},
11681     },
11682     {
11683         {{UINT32_C(0x0024FC6B), UINT32_C(0x00260048), UINT32_C(0x0027A39B),
11684           UINT32_C(0x004A6771), UINT32_C(0x002F8996), UINT32_C(0x00250571),
11685           UINT32_C(0x0022BD5A), UINT32_C(0x0016BA95), UINT32_C(0x00177752),
11686           UINT32_C(0x003AAE54), UINT32_C(0x000382BC), UINT32_C(0x002DBDCA),
11687           UINT32_C(0x00175D11), UINT32_C(0x000485AB), UINT32_C(0x00263BCC),
11688           UINT32_C(0x002CA217), UINT32_C(0x0033AA31), UINT32_C(0x001EB58F),
11689           UINT32_C(0x001CAA07), UINT32_C(0x00439150), UINT32_C(0x003350D2),
11690           UINT32_C(0x002E0A1C), UINT32_C(0x000B60E4)},
11691          {UINT32_C(0x006AFAB6), UINT32_C(0x001979BD), UINT32_C(0x00206F5D),
11692           UINT32_C(0x004F0B02), UINT32_C(0x001DC842), UINT32_C(0x0032D59A),
11693           UINT32_C(0x001DC451), UINT32_C(0x0022D419), UINT32_C(0x00003471),
11694           UINT32_C(0x00178E67), UINT32_C(0x002D0057), UINT32_C(0x006162BD),
11695           UINT32_C(0x000E5A47), UINT32_C(0x00139F7C), UINT32_C(0x0006E056),
11696           UINT32_C(0x00245E47), UINT32_C(0x0000179C), UINT32_C(0x0028BA82),
11697           UINT32_C(0x00229B1F), UINT32_C(0x003B6E93), UINT32_C(0x0012AE29),
11698           UINT32_C(0x0017CD91), UINT32_C(0x0014F8C1)}},
11699         {{UINT32_C(0x00340D60), UINT32_C(0x00077299), UINT32_C(0x003D596C),
11700           UINT32_C(0x005CAB48), UINT32_C(0x0018060B), UINT32_C(0x00108F8B),
11701           UINT32_C(0x00155345), UINT32_C(0x00555740), UINT32_C(0x0006639B),
11702           UINT32_C(0x000966BA), UINT32_C(0x0028B692), UINT32_C(0x000E0989),
11703           UINT32_C(0x000E36E6), UINT32_C(0x003EA5CF), UINT32_C(0x003E7233),
11704           UINT32_C(0x002BCE85), UINT32_C(0x003B53C6), UINT32_C(0x000B6428),
11705           UINT32_C(0x000CEB17), UINT32_C(0x001439C1), UINT32_C(0x003E1768),
11706           UINT32_C(0x00182028), UINT32_C(0x00063591)},
11707          {UINT32_C(0x004C6A3E), UINT32_C(0x0003B6B4), UINT32_C(0x00308620),
11708           UINT32_C(0x0042D6E7), UINT32_C(0x000688FB), UINT32_C(0x00242205),
11709           UINT32_C(0x0015FD4B), UINT32_C(0x006548A0), UINT32_C(0x00073894),
11710           UINT32_C(0x00059483), UINT32_C(0x00070BE7), UINT32_C(0x005EC1A3),
11711           UINT32_C(0x00138AF9), UINT32_C(0x00059A16), UINT32_C(0x000721C1),
11712           UINT32_C(0x003D327D), UINT32_C(0x000AC881), UINT32_C(0x0008254B),
11713           UINT32_C(0x00291DB6), UINT32_C(0x00202301), UINT32_C(0x002587BC),
11714           UINT32_C(0x002F4480), UINT32_C(0x000BB989)}},
11715         {{UINT32_C(0x0044D64A), UINT32_C(0x00169A22), UINT32_C(0x00198EE3),
11716           UINT32_C(0x001C1CF3), UINT32_C(0x001ABB64), UINT32_C(0x0002B70C),
11717           UINT32_C(0x000D1B40), UINT32_C(0x0000B41C), UINT32_C(0x001A07BF),
11718           UINT32_C(0x0031380A), UINT32_C(0x0037E0A3), UINT32_C(0x005959D5),
11719           UINT32_C(0x00195DCD), UINT32_C(0x00318DBC), UINT32_C(0x00014119),
11720           UINT32_C(0x0039F9F8), UINT32_C(0x002F8B00), UINT32_C(0x00035A9F),
11721           UINT32_C(0x001F77ED), UINT32_C(0x0042F50F), UINT32_C(0x0010F6EB),
11722           UINT32_C(0x00018D31), UINT32_C(0x00115505)},
11723          {UINT32_C(0x004A9CF0), UINT32_C(0x00396AE3), UINT32_C(0x002F36DC),
11724           UINT32_C(0x0059C454), UINT32_C(0x002372E1), UINT32_C(0x0017C289),
11725           UINT32_C(0x001DC88C), UINT32_C(0x00568BBB), UINT32_C(0x0038AAF3),
11726           UINT32_C(0x000AC735), UINT32_C(0x001D93C9), UINT32_C(0x0079763F),
11727           UINT32_C(0x000474DE), UINT32_C(0x001FFEA5), UINT32_C(0x0032E7A4),
11728           UINT32_C(0x00286D83), UINT32_C(0x001C592E), UINT32_C(0x002E08D4),
11729           UINT32_C(0x003C918F), UINT32_C(0x00635953), UINT32_C(0x00125ECD),
11730           UINT32_C(0x00218E30), UINT32_C(0x0038E348)}},
11731         {{UINT32_C(0x001F97CB), UINT32_C(0x00027C45), UINT32_C(0x0004CBBC),
11732           UINT32_C(0x003C768C), UINT32_C(0x002150EB), UINT32_C(0x00309BAC),
11733           UINT32_C(0x001BD192), UINT32_C(0x00449D0C), UINT32_C(0x00027761),
11734           UINT32_C(0x00334EC9), UINT32_C(0x0004B563), UINT32_C(0x0063BBA5),
11735           UINT32_C(0x0022D5EC), UINT32_C(0x0036D1DC), UINT32_C(0x0022C410),
11736           UINT32_C(0x005B8D6B), UINT32_C(0x00182967), UINT32_C(0x002A4F38),
11737           UINT32_C(0x00111A50), UINT32_C(0x00211F1F), UINT32_C(0x001EDAD2),
11738           UINT32_C(0x0018C6ED), UINT32_C(0x00195251)},
11739          {UINT32_C(0x002C575A), UINT32_C(0x00368BF8), UINT32_C(0x001817CE),
11740           UINT32_C(0x0023D30F), UINT32_C(0x00335F3C), UINT32_C(0x003D8B6B),
11741           UINT32_C(0x0036535C), UINT32_C(0x006E800F), UINT32_C(0x001D0FEE),
11742           UINT32_C(0x001D0E1D), UINT32_C(0x001030F4), UINT32_C(0x00575F2F),
11743           UINT32_C(0x000272DE), UINT32_C(0x0012885A), UINT32_C(0x001E98BE),
11744           UINT32_C(0x0002CEF1), UINT32_C(0x00343652), UINT32_C(0x0026244E),
11745           UINT32_C(0x00112950), UINT32_C(0x000CF99B), UINT32_C(0x0039E10D),
11746           UINT32_C(0x0019A48E), UINT32_C(0x000F62D8)}},
11747         {{UINT32_C(0x007F47CB), UINT32_C(0x000DB92B), UINT32_C(0x001CFE89),
11748           UINT32_C(0x00438C82), UINT32_C(0x002F9B60), UINT32_C(0x0029F531),
11749           UINT32_C(0x0036DACC), UINT32_C(0x000B743F), UINT32_C(0x0014BFCA),
11750           UINT32_C(0x003076AB), UINT32_C(0x00061C92), UINT32_C(0x00402803),
11751           UINT32_C(0x001F9BBE), UINT32_C(0x002BB4F0), UINT32_C(0x001D49FC),
11752           UINT32_C(0x0039DA58), UINT32_C(0x001B9F65), UINT32_C(0x001A4032),
11753           UINT32_C(0x001853D6), UINT32_C(0x0077F83B), UINT32_C(0x000BA641),
11754           UINT32_C(0x0028F440), UINT32_C(0x00036529)},
11755          {UINT32_C(0x00469CBC), UINT32_C(0x000ECB6B), UINT32_C(0x003ED688),
11756           UINT32_C(0x00448228), UINT32_C(0x000125E0), UINT32_C(0x001294BB),
11757           UINT32_C(0x003209CD), UINT32_C(0x00431140), UINT32_C(0x0024ADFE),
11758           UINT32_C(0x000A297C), UINT32_C(0x00343443), UINT32_C(0x003DC6B9),
11759           UINT32_C(0x003A8F4A), UINT32_C(0x003CD200), UINT32_C(0x0027F94A),
11760           UINT32_C(0x0026C683), UINT32_C(0x001010D7), UINT32_C(0x00291317),
11761           UINT32_C(0x001C01DB), UINT32_C(0x00323A9C), UINT32_C(0x0018F9E1),
11762           UINT32_C(0x000FB990), UINT32_C(0x001C0FD8)}},
11763         {{UINT32_C(0x002529B0), UINT32_C(0x00047C33), UINT32_C(0x00105D03),
11764           UINT32_C(0x00668833), UINT32_C(0x001D8A87), UINT32_C(0x001BE267),
11765           UINT32_C(0x002E8A17), UINT32_C(0x001BA406), UINT32_C(0x0012683B),
11766           UINT32_C(0x0032EFBE), UINT32_C(0x0033C9C9), UINT32_C(0x003816FD),
11767           UINT32_C(0x001E2856), UINT32_C(0x001FA678), UINT32_C(0x0034CF0E),
11768           UINT32_C(0x002BC6D4), UINT32_C(0x0021D8C3), UINT32_C(0x00138A8F),
11769           UINT32_C(0x00301A91), UINT32_C(0x007BA5BF), UINT32_C(0x0027ADBF),
11770           UINT32_C(0x00084950), UINT32_C(0x003344F2)},
11771          {UINT32_C(0x001D7DDB), UINT32_C(0x000B9FBD), UINT32_C(0x003A23D1),
11772           UINT32_C(0x000DAA8E), UINT32_C(0x0015296C), UINT32_C(0x00378879),
11773           UINT32_C(0x00080207), UINT32_C(0x006DACFA), UINT32_C(0x002C4D0C),
11774           UINT32_C(0x0003E240), UINT32_C(0x0005CDBB), UINT32_C(0x004B5100),
11775           UINT32_C(0x0024673C), UINT32_C(0x003EDDC4), UINT32_C(0x001C3104),
11776           UINT32_C(0x004EC191), UINT32_C(0x001B0572), UINT32_C(0x002EE934),
11777           UINT32_C(0x001E439A), UINT32_C(0x0008B8BC), UINT32_C(0x001D336D),
11778           UINT32_C(0x000C0450), UINT32_C(0x00264399)}},
11779         {{UINT32_C(0x0063BA75), UINT32_C(0x000E5577), UINT32_C(0x002D84D8),
11780           UINT32_C(0x0011F137), UINT32_C(0x003C0568), UINT32_C(0x001FCF04),
11781           UINT32_C(0x00369E84), UINT32_C(0x0026107B), UINT32_C(0x003793D0),
11782           UINT32_C(0x002FF753), UINT32_C(0x00080D0D), UINT32_C(0x0009FE5B),
11783           UINT32_C(0x000D568B), UINT32_C(0x00306219), UINT32_C(0x00057FB4),
11784           UINT32_C(0x00251274), UINT32_C(0x0028F357), UINT32_C(0x001868A6),
11785           UINT32_C(0x00245601), UINT32_C(0x00694DDA), UINT32_C(0x001BF932),
11786           UINT32_C(0x00291545), UINT32_C(0x000834DF)},
11787          {UINT32_C(0x005DE7C7), UINT32_C(0x00043FB9), UINT32_C(0x002022F7),
11788           UINT32_C(0x006DD20B), UINT32_C(0x0034DB2B), UINT32_C(0x0009812A),
11789           UINT32_C(0x000634E5), UINT32_C(0x00529BDD), UINT32_C(0x0037E7AF),
11790           UINT32_C(0x0020131E), UINT32_C(0x0028145E), UINT32_C(0x007D781A),
11791           UINT32_C(0x003F2E11), UINT32_C(0x00090377), UINT32_C(0x001FF3F0),
11792           UINT32_C(0x0029544B), UINT32_C(0x0004B34A), UINT32_C(0x00308A92),
11793           UINT32_C(0x00230957), UINT32_C(0x0030849F), UINT32_C(0x003BD197),
11794           UINT32_C(0x0036543D), UINT32_C(0x0013DB50)}},
11795         {{UINT32_C(0x006DBC4E), UINT32_C(0x000B8C36), UINT32_C(0x0033C975),
11796           UINT32_C(0x001B98FA), UINT32_C(0x000E1469), UINT32_C(0x003F57BB),
11797           UINT32_C(0x00366AF6), UINT32_C(0x002940D4), UINT32_C(0x002A7401),
11798           UINT32_C(0x000B24FA), UINT32_C(0x003D079C), UINT32_C(0x000BBF2B),
11799           UINT32_C(0x001C8DA1), UINT32_C(0x00281279), UINT32_C(0x003FD16B),
11800           UINT32_C(0x005F172D), UINT32_C(0x003BC575), UINT32_C(0x0003F2EE),
11801           UINT32_C(0x000EB6E0), UINT32_C(0x0025AA43), UINT32_C(0x0019146D),
11802           UINT32_C(0x000E2FCD), UINT32_C(0x000708D1)},
11803          {UINT32_C(0x00188A0A), UINT32_C(0x003280E1), UINT32_C(0x00375AE3),
11804           UINT32_C(0x005DEF79), UINT32_C(0x0030CA8C), UINT32_C(0x0011A4E2),
11805           UINT32_C(0x001A18EE), UINT32_C(0x0015160F), UINT32_C(0x003D4633),
11806           UINT32_C(0x00210DF1), UINT32_C(0x0039513D), UINT32_C(0x00032B85),
11807           UINT32_C(0x0000562C), UINT32_C(0x002B09DE), UINT32_C(0x0012E5D7),
11808           UINT32_C(0x00343965), UINT32_C(0x002482BA), UINT32_C(0x00358D60),
11809           UINT32_C(0x00210688), UINT32_C(0x001DE534), UINT32_C(0x0037E47D),
11810           UINT32_C(0x00306432), UINT32_C(0x00331A00)}},
11811         {{UINT32_C(0x000E3961), UINT32_C(0x00136E2C), UINT32_C(0x00396117),
11812           UINT32_C(0x003A4EA9), UINT32_C(0x002B633F), UINT32_C(0x00331384),
11813           UINT32_C(0x000E6FDA), UINT32_C(0x00110B81), UINT32_C(0x00083F56),
11814           UINT32_C(0x0010E231), UINT32_C(0x00377F5B), UINT32_C(0x00777CBF),
11815           UINT32_C(0x0027D587), UINT32_C(0x0016725E), UINT32_C(0x0022FAFB),
11816           UINT32_C(0x0050FCA0), UINT32_C(0x0035E866), UINT32_C(0x001F6AF5),
11817           UINT32_C(0x00131AFF), UINT32_C(0x0031B90B), UINT32_C(0x003D8FC9),
11818           UINT32_C(0x003CCAEF), UINT32_C(0x000BCF90)},
11819          {UINT32_C(0x0037CE7B), UINT32_C(0x003B57EC), UINT32_C(0x00161E92),
11820           UINT32_C(0x0065355B), UINT32_C(0x0024637B), UINT32_C(0x0008B2C0),
11821           UINT32_C(0x0002E6FD), UINT32_C(0x001ED2F1), UINT32_C(0x0024A016),
11822           UINT32_C(0x0022B354), UINT32_C(0x0019306E), UINT32_C(0x003009F9),
11823           UINT32_C(0x00130478), UINT32_C(0x0039951C), UINT32_C(0x003B9F26),
11824           UINT32_C(0x00129D8E), UINT32_C(0x0028EAE8), UINT32_C(0x002E0532),
11825           UINT32_C(0x002312B7), UINT32_C(0x001904D9), UINT32_C(0x001F8FB7),
11826           UINT32_C(0x00306139), UINT32_C(0x00191E58)}},
11827         {{UINT32_C(0x00315B6B), UINT32_C(0x0006110B), UINT32_C(0x002D0F7A),
11828           UINT32_C(0x000B35D8), UINT32_C(0x0039DD74), UINT32_C(0x0013BF7F),
11829           UINT32_C(0x00088A74), UINT32_C(0x00678A54), UINT32_C(0x0027C11E),
11830           UINT32_C(0x0039299C), UINT32_C(0x0009E852), UINT32_C(0x003A9738),
11831           UINT32_C(0x003BA90B), UINT32_C(0x003C704C), UINT32_C(0x00031EAD),
11832           UINT32_C(0x003F9F6D), UINT32_C(0x00060C99), UINT32_C(0x00210078),
11833           UINT32_C(0x000A43CC), UINT32_C(0x001D2C3A), UINT32_C(0x0016F165),
11834           UINT32_C(0x002CBE20), UINT32_C(0x003CBD2A)},
11835          {UINT32_C(0x006EA72C), UINT32_C(0x0019FAA9), UINT32_C(0x0027119B),
11836           UINT32_C(0x00002DB4), UINT32_C(0x003FC202), UINT32_C(0x00258426),
11837           UINT32_C(0x0017A426), UINT32_C(0x00591EA2), UINT32_C(0x000DAAC0),
11838           UINT32_C(0x00160BB2), UINT32_C(0x002B5C9B), UINT32_C(0x0034552F),
11839           UINT32_C(0x00354208), UINT32_C(0x003F73F6), UINT32_C(0x001D329F),
11840           UINT32_C(0x00541523), UINT32_C(0x001D2733), UINT32_C(0x003E6DA0),
11841           UINT32_C(0x00058267), UINT32_C(0x002FD1CD), UINT32_C(0x003085B8),
11842           UINT32_C(0x0037B13E), UINT32_C(0x0011D71D)}},
11843         {{UINT32_C(0x004EF58F), UINT32_C(0x00111078), UINT32_C(0x002A7D65),
11844           UINT32_C(0x0032333E), UINT32_C(0x0011BB9D), UINT32_C(0x0033FA14),
11845           UINT32_C(0x001ABD10), UINT32_C(0x007F9C0D), UINT32_C(0x0012F21C),
11846           UINT32_C(0x003C4D14), UINT32_C(0x003A59E2), UINT32_C(0x0017140E),
11847           UINT32_C(0x003EC05A), UINT32_C(0x002B8323), UINT32_C(0x0013D487),
11848           UINT32_C(0x0061B630), UINT32_C(0x000C1262), UINT32_C(0x0034A7E5),
11849           UINT32_C(0x0018DA22), UINT32_C(0x000DA70C), UINT32_C(0x001E1E78),
11850           UINT32_C(0x0037CE10), UINT32_C(0x000BEBB1)},
11851          {UINT32_C(0x004F54F0), UINT32_C(0x000A220B), UINT32_C(0x00161352),
11852           UINT32_C(0x007E4EA4), UINT32_C(0x002878DE), UINT32_C(0x001C80E5),
11853           UINT32_C(0x000C0855), UINT32_C(0x0075DF3B), UINT32_C(0x0039D0AB),
11854           UINT32_C(0x001D0301), UINT32_C(0x001594B9), UINT32_C(0x0078140B),
11855           UINT32_C(0x001A2C01), UINT32_C(0x0028FCE5), UINT32_C(0x003C573C),
11856           UINT32_C(0x0006E543), UINT32_C(0x003A90E6), UINT32_C(0x002D4FDD),
11857           UINT32_C(0x0022B1F7), UINT32_C(0x0062CB04), UINT32_C(0x002C12CA),
11858           UINT32_C(0x00389E83), UINT32_C(0x0007631E)}},
11859         {{UINT32_C(0x0023C68B), UINT32_C(0x000F609A), UINT32_C(0x000D7E01),
11860           UINT32_C(0x0069E56B), UINT32_C(0x0003D496), UINT32_C(0x001BC8DC),
11861           UINT32_C(0x00328E76), UINT32_C(0x00316565), UINT32_C(0x0011A340),
11862           UINT32_C(0x00374048), UINT32_C(0x0016C79E), UINT32_C(0x0014449B),
11863           UINT32_C(0x002EE9B6), UINT32_C(0x00032A11), UINT32_C(0x001212A3),
11864           UINT32_C(0x003D35C1), UINT32_C(0x003485FD), UINT32_C(0x001199A6),
11865           UINT32_C(0x001C3F0D), UINT32_C(0x0017F8CF), UINT32_C(0x0014AC02),
11866           UINT32_C(0x001E0EB1), UINT32_C(0x001ACA7C)},
11867          {UINT32_C(0x0031C47A), UINT32_C(0x00102E12), UINT32_C(0x002F6F4B),
11868           UINT32_C(0x005B2D93), UINT32_C(0x000A9886), UINT32_C(0x001CC034),
11869           UINT32_C(0x0023E81B), UINT32_C(0x0001A7CE), UINT32_C(0x0029ABC3),
11870           UINT32_C(0x0004048C), UINT32_C(0x002BC25D), UINT32_C(0x00368ABA),
11871           UINT32_C(0x0002746C), UINT32_C(0x00373868), UINT32_C(0x00061AA2),
11872           UINT32_C(0x0056401C), UINT32_C(0x00207F34), UINT32_C(0x001FCA2D),
11873           UINT32_C(0x00169B9E), UINT32_C(0x0064FDA3), UINT32_C(0x0028C18A),
11874           UINT32_C(0x000C0847), UINT32_C(0x001845F0)}},
11875         {{UINT32_C(0x002F9AD9), UINT32_C(0x0009590F), UINT32_C(0x00130486),
11876           UINT32_C(0x0059CC83), UINT32_C(0x0039A337), UINT32_C(0x0022C7C7),
11877           UINT32_C(0x0003C259), UINT32_C(0x00602650), UINT32_C(0x0008510C),
11878           UINT32_C(0x00384F8A), UINT32_C(0x001F3AA0), UINT32_C(0x003706DA),
11879           UINT32_C(0x00069456), UINT32_C(0x0002AD7C), UINT32_C(0x00003A14),
11880           UINT32_C(0x007327BA), UINT32_C(0x002F7478), UINT32_C(0x001FBB28),
11881           UINT32_C(0x0023BC3E), UINT32_C(0x007F5AB5), UINT32_C(0x001FFF4E),
11882           UINT32_C(0x00188D11), UINT32_C(0x0013BC8B)},
11883          {UINT32_C(0x0000C111), UINT32_C(0x0006AA72), UINT32_C(0x0012A2E9),
11884           UINT32_C(0x0055127A), UINT32_C(0x003C8991), UINT32_C(0x0036CFBC),
11885           UINT32_C(0x0037F0BB), UINT32_C(0x00655B21), UINT32_C(0x002B75E3),
11886           UINT32_C(0x00336687), UINT32_C(0x00210878), UINT32_C(0x00089C2C),
11887           UINT32_C(0x003CEE92), UINT32_C(0x00143383), UINT32_C(0x00371D45),
11888           UINT32_C(0x000BCDFE), UINT32_C(0x00238367), UINT32_C(0x001C2D8B),
11889           UINT32_C(0x003E06AD), UINT32_C(0x0053DBC8), UINT32_C(0x002A9F89),
11890           UINT32_C(0x002955F8), UINT32_C(0x00137029)}},
11891         {{UINT32_C(0x0002FB5B), UINT32_C(0x0032BB27), UINT32_C(0x001EE694),
11892           UINT32_C(0x002E2965), UINT32_C(0x00395F01), UINT32_C(0x003FEC08),
11893           UINT32_C(0x003ABDFB), UINT32_C(0x0068B88B), UINT32_C(0x00221DB7),
11894           UINT32_C(0x000F72D1), UINT32_C(0x0003F9DC), UINT32_C(0x005C1B93),
11895           UINT32_C(0x00073A9E), UINT32_C(0x00160BD0), UINT32_C(0x00053416),
11896           UINT32_C(0x0023242A), UINT32_C(0x0010FAB9), UINT32_C(0x0006D2C5),
11897           UINT32_C(0x00236E83), UINT32_C(0x0054747B), UINT32_C(0x00063F98),
11898           UINT32_C(0x001A8789), UINT32_C(0x003DC7DA)},
11899          {UINT32_C(0x00463909), UINT32_C(0x0029E3B4), UINT32_C(0x0002F0E2),
11900           UINT32_C(0x00593390), UINT32_C(0x0034320B), UINT32_C(0x003F6A3B),
11901           UINT32_C(0x002603E4), UINT32_C(0x00016676), UINT32_C(0x00254C99),
11902           UINT32_C(0x0023EB7B), UINT32_C(0x00119D88), UINT32_C(0x003D63F8),
11903           UINT32_C(0x00350BC8), UINT32_C(0x00140757), UINT32_C(0x002473C4),
11904           UINT32_C(0x0034D831), UINT32_C(0x0017BDB7), UINT32_C(0x003E24EB),
11905           UINT32_C(0x00231FE3), UINT32_C(0x0070EC64), UINT32_C(0x00043E18),
11906           UINT32_C(0x002A4D4F), UINT32_C(0x0005D554)}},
11907         {{UINT32_C(0x006FC15D), UINT32_C(0x001F5830), UINT32_C(0x0008AD9E),
11908           UINT32_C(0x002845F0), UINT32_C(0x001CD01E), UINT32_C(0x0000CFC1),
11909           UINT32_C(0x0032AE8B), UINT32_C(0x0019E673), UINT32_C(0x0030C5E5),
11910           UINT32_C(0x00050166), UINT32_C(0x00372FAC), UINT32_C(0x00057147),
11911           UINT32_C(0x0004060F), UINT32_C(0x00163807), UINT32_C(0x002BCADD),
11912           UINT32_C(0x00376726), UINT32_C(0x0028315B), UINT32_C(0x0009418F),
11913           UINT32_C(0x001E2957), UINT32_C(0x006D28BE), UINT32_C(0x001BCADE),
11914           UINT32_C(0x0031A352), UINT32_C(0x00052575)},
11915          {UINT32_C(0x00404C1D), UINT32_C(0x0024FA31), UINT32_C(0x0012C7A3),
11916           UINT32_C(0x007D71A8), UINT32_C(0x0028D167), UINT32_C(0x0020B8E9),
11917           UINT32_C(0x0032697E), UINT32_C(0x00202C6B), UINT32_C(0x00032212),
11918           UINT32_C(0x003AB37D), UINT32_C(0x0029EEED), UINT32_C(0x00239F39),
11919           UINT32_C(0x0007DC00), UINT32_C(0x003BD86F), UINT32_C(0x003B948C),
11920           UINT32_C(0x005D1965), UINT32_C(0x003C74AD), UINT32_C(0x001EAB46),
11921           UINT32_C(0x00255C49), UINT32_C(0x002402DB), UINT32_C(0x0004833F),
11922           UINT32_C(0x00181728), UINT32_C(0x002C23A4)}},
11923         {{UINT32_C(0x00069003), UINT32_C(0x001493A6), UINT32_C(0x003F6B49),
11924           UINT32_C(0x001B15E2), UINT32_C(0x003CB610), UINT32_C(0x003AC0D8),
11925           UINT32_C(0x0012E96D), UINT32_C(0x004C065C), UINT32_C(0x00318C4E),
11926           UINT32_C(0x00151ED2), UINT32_C(0x002348E6), UINT32_C(0x006AE001),
11927           UINT32_C(0x0012C641), UINT32_C(0x00126DF2), UINT32_C(0x001D6E0A),
11928           UINT32_C(0x00227223), UINT32_C(0x003493D1), UINT32_C(0x0027ED79),
11929           UINT32_C(0x00097233), UINT32_C(0x0004AB1D), UINT32_C(0x002E7F5A),
11930           UINT32_C(0x003ED69A), UINT32_C(0x003D2512)},
11931          {UINT32_C(0x002D81D0), UINT32_C(0x0012CD40), UINT32_C(0x00296981),
11932           UINT32_C(0x007D52C8), UINT32_C(0x002B5E71), UINT32_C(0x0018553C),
11933           UINT32_C(0x003F8695), UINT32_C(0x00730395), UINT32_C(0x00050DAB),
11934           UINT32_C(0x0015BCBA), UINT32_C(0x00220A46), UINT32_C(0x00762FDE),
11935           UINT32_C(0x0029B8D0), UINT32_C(0x0025890A), UINT32_C(0x002D307D),
11936           UINT32_C(0x0077543E), UINT32_C(0x001F282E), UINT32_C(0x00300B63),
11937           UINT32_C(0x000F826D), UINT32_C(0x00344F5F), UINT32_C(0x0017B455),
11938           UINT32_C(0x000FA526), UINT32_C(0x0013C162)}},
11939     }};
11940
11941 /*-
11942  * Q := 2P, both projective, Q and P same pointers OK
11943  * Autogenerated: op3/dbl_proj.op3
11944  * https://eprint.iacr.org/2015/1060 Alg 6
11945  * ASSERT: a = -3
11946  */
11947 static void point_double(pt_prj_t *Q, const pt_prj_t *P) {
11948     /* temporary variables */
11949     fe_t t0, t1, t2, t3, t4;
11950     /* constants */
11951     const limb_t *b = const_b;
11952     /* set pointers for legacy curve arith */
11953     const limb_t *X = P->X;
11954     const limb_t *Y = P->Y;
11955     const limb_t *Z = P->Z;
11956     limb_t *X3 = Q->X;
11957     limb_t *Y3 = Q->Y;
11958     limb_t *Z3 = Q->Z;
11959
11960     /* the curve arith formula */
11961     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(t0, X);
11962     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(t1, Y);
11963     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_square(t2, Z);
11964     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, X, Y);
11965     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, t3, t3);
11966     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t4, Y, Z);
11967     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, X, Z);
11968     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, Z3);
11969     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, b, t2);
11970     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, Z3);
11971     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, Y3, Y3);
11972     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, X3, Y3);
11973     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, t1, Y3);
11974     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t1, Y3);
11975     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X3, Y3);
11976     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, X3, t3);
11977     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, t2, t2);
11978     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t2, t2, t3);
11979     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, b, Z3);
11980     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, Z3, t2);
11981     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, Z3, t0);
11982     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, Z3, Z3);
11983     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, t3);
11984     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, t0, t0);
11985     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t3, t0);
11986     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t0, t0, t2);
11987     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t0, t0, Z3);
11988     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, t0);
11989     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t4, t4);
11990     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t0, Z3);
11991     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, X3, Z3);
11992     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t0, t1);
11993     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, Z3);
11994     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, Z3);
11995 }
11996
11997 /*-
11998  * out1 = (arg1 == 0) ? 0 : nz
11999  * NB: this is not a "mod p equiv" 0, but literal 0
12000  * NB: this is not a real Fiat function, just named that way for consistency.
12001  */
12002 static void fiat_id_tc26_gost_3410_2012_512_paramSetA_nonzero(limb_t *out1,
12003                                                               const fe_t arg1) {
12004     limb_t x1 = 0;
12005     int i;
12006
12007     for (i = 0; i < LIMB_CNT; i++) x1 |= arg1[i];
12008     *out1 = x1;
12009 }
12010
12011 /*-
12012  * R := Q + P where R and Q are projective, P affine.
12013  * R and Q same pointers OK
12014  * R and P same pointers not OK
12015  * Autogenerated: op3/add_mixed.op3
12016  * https://eprint.iacr.org/2015/1060 Alg 5
12017  * ASSERT: a = -3
12018  */
12019 static void point_add_mixed(pt_prj_t *R, const pt_prj_t *Q, const pt_aff_t *P) {
12020     /* temporary variables */
12021     fe_t t0, t1, t2, t3, t4;
12022     /* constants */
12023     const limb_t *b = const_b;
12024     /* set pointers for legacy curve arith */
12025     const limb_t *X1 = Q->X;
12026     const limb_t *Y1 = Q->Y;
12027     const limb_t *Z1 = Q->Z;
12028     const limb_t *X2 = P->X;
12029     const limb_t *Y2 = P->Y;
12030     fe_t X3;
12031     fe_t Y3;
12032     fe_t Z3;
12033     limb_t nz;
12034
12035     /* check P for affine inf */
12036     fiat_id_tc26_gost_3410_2012_512_paramSetA_nonzero(&nz, P->Y);
12037
12038     /* the curve arith formula */
12039     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t0, X1, X2);
12040     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, Y1, Y2);
12041     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, X2, Y2);
12042     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, X1, Y1);
12043     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, t3, t4);
12044     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, t0, t1);
12045     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t3, t3, t4);
12046     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t4, Y2, Z1);
12047     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, t4, Y1);
12048     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X2, Z1);
12049     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, X1);
12050     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, b, Z1);
12051     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, Y3, Z3);
12052     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, X3, X3);
12053     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, X3, Z3);
12054     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, t1, X3);
12055     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, t1, X3);
12056     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, b, Y3);
12057     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, Z1, Z1);
12058     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t2, t1, Z1);
12059     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t2);
12060     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t0);
12061     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, Y3, Y3);
12062     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t1, Y3);
12063     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, t0, t0);
12064     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t1, t0);
12065     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t0, t0, t2);
12066     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t4, Y3);
12067     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, t0, Y3);
12068     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X3, Z3);
12069     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, t2);
12070     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, t3, X3);
12071     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, X3, t1);
12072     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t4, Z3);
12073     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t3, t0);
12074     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, t1);
12075
12076     /* if P is inf, throw all that away and take Q */
12077     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(R->X, nz, Q->X, X3);
12078     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(R->Y, nz, Q->Y, Y3);
12079     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(R->Z, nz, Q->Z, Z3);
12080 }
12081
12082 /*-
12083  * R := Q + P all projective.
12084  * R and Q same pointers OK
12085  * R and P same pointers not OK
12086  * Autogenerated: op3/add_proj.op3
12087  * https://eprint.iacr.org/2015/1060 Alg 4
12088  * ASSERT: a = -3
12089  */
12090 static void point_add_proj(pt_prj_t *R, const pt_prj_t *Q, const pt_prj_t *P) {
12091     /* temporary variables */
12092     fe_t t0, t1, t2, t3, t4, t5;
12093     /* constants */
12094     const limb_t *b = const_b;
12095     /* set pointers for legacy curve arith */
12096     const limb_t *X1 = Q->X;
12097     const limb_t *Y1 = Q->Y;
12098     const limb_t *Z1 = Q->Z;
12099     const limb_t *X2 = P->X;
12100     const limb_t *Y2 = P->Y;
12101     const limb_t *Z2 = P->Z;
12102     limb_t *X3 = R->X;
12103     limb_t *Y3 = R->Y;
12104     limb_t *Z3 = R->Z;
12105
12106     /* the curve arith formula */
12107     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t0, X1, X2);
12108     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, Y1, Y2);
12109     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, Z1, Z2);
12110     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t3, X1, Y1);
12111     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, X2, Y2);
12112     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t3, t3, t4);
12113     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, t0, t1);
12114     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t3, t3, t4);
12115     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t4, Y1, Z1);
12116     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t5, Y2, Z2);
12117     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t4, t4, t5);
12118     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t5, t1, t2);
12119     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t4, t4, t5);
12120     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, X1, Z1);
12121     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, X2, Z2);
12122     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, X3, Y3);
12123     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t0, t2);
12124     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, X3, Y3);
12125     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, b, t2);
12126     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, Y3, Z3);
12127     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, X3, X3);
12128     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, X3, Z3);
12129     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Z3, t1, X3);
12130     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(X3, t1, X3);
12131     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, b, Y3);
12132     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, t2, t2);
12133     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t2, t1, t2);
12134     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t2);
12135     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(Y3, Y3, t0);
12136     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, Y3, Y3);
12137     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, t1, Y3);
12138     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t1, t0, t0);
12139     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(t0, t1, t0);
12140     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(t0, t0, t2);
12141     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t4, Y3);
12142     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t2, t0, Y3);
12143     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Y3, X3, Z3);
12144     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Y3, Y3, t2);
12145     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(X3, t3, X3);
12146     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_sub(X3, X3, t1);
12147     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(Z3, t4, Z3);
12148     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(t1, t3, t0);
12149     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_add(Z3, Z3, t1);
12150 }
12151
12152 /* constants */
12153 #define RADIX 5
12154 #define DRADIX (1 << RADIX)
12155 #define DRADIX_WNAF ((DRADIX) << 1)
12156
12157 /*-
12158  * precomp for wnaf scalar multiplication:
12159  * precomp[0] = 1P
12160  * precomp[1] = 3P
12161  * precomp[2] = 5P
12162  * precomp[3] = 7P
12163  * precomp[4] = 9P
12164  * ...
12165  */
12166 static void precomp_wnaf(pt_prj_t precomp[DRADIX / 2], const pt_aff_t *P) {
12167     int i;
12168
12169     fe_copy(precomp[0].X, P->X);
12170     fe_copy(precomp[0].Y, P->Y);
12171     fe_copy(precomp[0].Z, const_one);
12172     point_double(&precomp[DRADIX / 2 - 1], &precomp[0]);
12173
12174     for (i = 1; i < DRADIX / 2; i++)
12175         point_add_proj(&precomp[i], &precomp[DRADIX / 2 - 1], &precomp[i - 1]);
12176 }
12177
12178 /* fetch a scalar bit */
12179 static int scalar_get_bit(const unsigned char in[64], int idx) {
12180     int widx, rshift;
12181
12182     widx = idx >> 3;
12183     rshift = idx & 0x7;
12184
12185     if (idx < 0 || widx >= 64) return 0;
12186
12187     return (in[widx] >> rshift) & 0x1;
12188 }
12189
12190 /*-
12191  * Compute "regular" wnaf representation of a scalar.
12192  * See "Exponent Recoding and Regular Exponentiation Algorithms",
12193  * Tunstall et al., AfricaCrypt 2009, Alg 6.
12194  * It forces an odd scalar and outputs digits in
12195  * {\pm 1, \pm 3, \pm 5, \pm 7, \pm 9, ...}
12196  * i.e. signed odd digits with _no zeroes_ -- that makes it "regular".
12197  */
12198 static void scalar_rwnaf(char out[103], const unsigned char in[64]) {
12199     int i;
12200     char window, d;
12201
12202     window = (in[0] & (DRADIX_WNAF - 1)) | 1;
12203     for (i = 0; i < 102; i++) {
12204         d = (window & (DRADIX_WNAF - 1)) - DRADIX;
12205         out[i] = d;
12206         window = (window - d) >> RADIX;
12207         window += scalar_get_bit(in, (i + 1) * RADIX + 1) << 1;
12208         window += scalar_get_bit(in, (i + 1) * RADIX + 2) << 2;
12209         window += scalar_get_bit(in, (i + 1) * RADIX + 3) << 3;
12210         window += scalar_get_bit(in, (i + 1) * RADIX + 4) << 4;
12211         window += scalar_get_bit(in, (i + 1) * RADIX + 5) << 5;
12212     }
12213     out[i] = window;
12214 }
12215
12216 /*-
12217  * Compute "textbook" wnaf representation of a scalar.
12218  * NB: not constant time
12219  */
12220 static void scalar_wnaf(char out[513], const unsigned char in[64]) {
12221     int i;
12222     char window, d;
12223
12224     window = in[0] & (DRADIX_WNAF - 1);
12225     for (i = 0; i < 513; i++) {
12226         d = 0;
12227         if ((window & 1) && ((d = window & (DRADIX_WNAF - 1)) & DRADIX))
12228             d -= DRADIX_WNAF;
12229         out[i] = d;
12230         window = (window - d) >> 1;
12231         window += scalar_get_bit(in, i + 1 + RADIX) << RADIX;
12232     }
12233 }
12234
12235 /*-
12236  * Simulateous scalar multiplication: interleaved "textbook" wnaf.
12237  * NB: not constant time
12238  */
12239 static void var_smul_wnaf_two(pt_aff_t *out, const unsigned char a[64],
12240                               const unsigned char b[64], const pt_aff_t *P) {
12241     int i, d, is_neg, is_inf = 1, flipped = 0;
12242     char anaf[513] = {0};
12243     char bnaf[513] = {0};
12244     pt_prj_t Q;
12245     pt_prj_t precomp[DRADIX / 2];
12246
12247     precomp_wnaf(precomp, P);
12248     scalar_wnaf(anaf, a);
12249     scalar_wnaf(bnaf, b);
12250
12251     for (i = 512; i >= 0; i--) {
12252         if (!is_inf) point_double(&Q, &Q);
12253         if ((d = bnaf[i])) {
12254             if ((is_neg = d < 0) != flipped) {
12255                 fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(Q.Y, Q.Y);
12256                 flipped ^= 1;
12257             }
12258             d = (is_neg) ? (-d - 1) >> 1 : (d - 1) >> 1;
12259             if (is_inf) {
12260                 /* initialize accumulator */
12261                 fe_copy(Q.X, &precomp[d].X);
12262                 fe_copy(Q.Y, &precomp[d].Y);
12263                 fe_copy(Q.Z, &precomp[d].Z);
12264                 is_inf = 0;
12265             } else
12266                 point_add_proj(&Q, &Q, &precomp[d]);
12267         }
12268         if ((d = anaf[i])) {
12269             if ((is_neg = d < 0) != flipped) {
12270                 fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(Q.Y, Q.Y);
12271                 flipped ^= 1;
12272             }
12273             d = (is_neg) ? (-d - 1) >> 1 : (d - 1) >> 1;
12274             if (is_inf) {
12275                 /* initialize accumulator */
12276                 fe_copy(Q.X, &lut_cmb[0][d].X);
12277                 fe_copy(Q.Y, &lut_cmb[0][d].Y);
12278                 fe_copy(Q.Z, const_one);
12279                 is_inf = 0;
12280             } else
12281                 point_add_mixed(&Q, &Q, &lut_cmb[0][d]);
12282         }
12283     }
12284
12285     if (is_inf) {
12286         /* initialize accumulator to inf: all-zero scalars */
12287         fe_set_zero(Q.X);
12288         fe_copy(Q.Y, const_one);
12289         fe_set_zero(Q.Z);
12290     }
12291
12292     if (flipped) {
12293         /* correct sign */
12294         fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(Q.Y, Q.Y);
12295     }
12296
12297     /* convert to affine -- NB depends on coordinate system */
12298     fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(Q.Z, Q.Z);
12299     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->X, Q.X, Q.Z);
12300     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->Y, Q.Y, Q.Z);
12301 }
12302
12303 /*-
12304  * Variable point scalar multiplication with "regular" wnaf.
12305  */
12306 static void var_smul_rwnaf(pt_aff_t *out, const unsigned char scalar[64],
12307                            const pt_aff_t *P) {
12308     int i, j, d, diff, is_neg;
12309     char rnaf[103] = {0};
12310     pt_prj_t Q, lut;
12311     pt_prj_t precomp[DRADIX / 2];
12312
12313     precomp_wnaf(precomp, P);
12314     scalar_rwnaf(rnaf, scalar);
12315
12316 #if defined(_MSC_VER)
12317     /* result still unsigned: yes we know */
12318 #pragma warning(push)
12319 #pragma warning(disable : 4146)
12320 #endif
12321
12322     /* initialize accumulator to high digit */
12323     d = (rnaf[102] - 1) >> 1;
12324     for (j = 0; j < DRADIX / 2; j++) {
12325         diff = (1 - (-(d ^ j) >> (8 * sizeof(int) - 1))) & 1;
12326         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.X, diff, Q.X,
12327                                                             precomp[j].X);
12328         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Y, diff, Q.Y,
12329                                                             precomp[j].Y);
12330         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Z, diff, Q.Z,
12331                                                             precomp[j].Z);
12332     }
12333
12334     for (i = 101; i >= 0; i--) {
12335         for (j = 0; j < RADIX; j++) point_double(&Q, &Q);
12336         d = rnaf[i];
12337         /* is_neg = (d < 0) ? 1 : 0 */
12338         is_neg = (d >> (8 * sizeof(int) - 1)) & 1;
12339         /* d = abs(d) */
12340         d = (d ^ -is_neg) + is_neg;
12341         d = (d - 1) >> 1;
12342         for (j = 0; j < DRADIX / 2; j++) {
12343             diff = (1 - (-(d ^ j) >> (8 * sizeof(int) - 1))) & 1;
12344             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
12345                 lut.X, diff, lut.X, precomp[j].X);
12346             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
12347                 lut.Y, diff, lut.Y, precomp[j].Y);
12348             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
12349                 lut.Z, diff, lut.Z, precomp[j].Z);
12350         }
12351         /* negate lut point if digit is negative */
12352         fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(out->Y, lut.Y);
12353         fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(lut.Y, is_neg,
12354                                                             lut.Y, out->Y);
12355         point_add_proj(&Q, &Q, &lut);
12356     }
12357
12358 #if defined(_MSC_VER)
12359 #pragma warning(pop)
12360 #endif
12361
12362     /* conditionally subtract P if the scalar was even */
12363     fe_copy(lut.X, precomp[0].X);
12364     fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(lut.Y, precomp[0].Y);
12365     fe_copy(lut.Z, precomp[0].Z);
12366     point_add_proj(&lut, &lut, &Q);
12367     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.X, scalar[0] & 1,
12368                                                         lut.X, Q.X);
12369     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Y, scalar[0] & 1,
12370                                                         lut.Y, Q.Y);
12371     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Z, scalar[0] & 1,
12372                                                         lut.Z, Q.Z);
12373
12374     /* convert to affine -- NB depends on coordinate system */
12375     fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(Q.Z, Q.Z);
12376     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->X, Q.X, Q.Z);
12377     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->Y, Q.Y, Q.Z);
12378 }
12379
12380 /*-
12381  * Fixed scalar multiplication: comb with interleaving.
12382  */
12383 static void fixed_smul_cmb(pt_aff_t *out, const unsigned char scalar[64]) {
12384     int i, j, k, d, diff, is_neg = 0;
12385     char rnaf[103] = {0};
12386     pt_prj_t Q, R;
12387     pt_aff_t lut;
12388
12389     scalar_rwnaf(rnaf, scalar);
12390
12391     /* initalize accumulator to inf */
12392     fe_set_zero(Q.X);
12393     fe_copy(Q.Y, const_one);
12394     fe_set_zero(Q.Z);
12395
12396 #if defined(_MSC_VER)
12397     /* result still unsigned: yes we know */
12398 #pragma warning(push)
12399 #pragma warning(disable : 4146)
12400 #endif
12401
12402     for (i = 10; i >= 0; i--) {
12403         for (j = 0; i != 10 && j < RADIX; j++) point_double(&Q, &Q);
12404         for (j = 0; j < 11; j++) {
12405             if (j * 11 + i > 102) continue;
12406             d = rnaf[j * 11 + i];
12407             /* is_neg = (d < 0) ? 1 : 0 */
12408             is_neg = (d >> (8 * sizeof(int) - 1)) & 1;
12409             /* d = abs(d) */
12410             d = (d ^ -is_neg) + is_neg;
12411             d = (d - 1) >> 1;
12412             for (k = 0; k < DRADIX / 2; k++) {
12413                 diff = (1 - (-(d ^ k) >> (8 * sizeof(int) - 1))) & 1;
12414                 fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
12415                     lut.X, diff, lut.X, lut_cmb[j][k].X);
12416                 fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(
12417                     lut.Y, diff, lut.Y, lut_cmb[j][k].Y);
12418             }
12419             /* negate lut point if digit is negative */
12420             fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(out->Y, lut.Y);
12421             fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(lut.Y, is_neg,
12422                                                                 lut.Y, out->Y);
12423             point_add_mixed(&Q, &Q, &lut);
12424         }
12425     }
12426
12427 #if defined(_MSC_VER)
12428 #pragma warning(pop)
12429 #endif
12430
12431     /* conditionally subtract P if the scalar was even */
12432     fe_copy(lut.X, lut_cmb[0][0].X);
12433     fiat_id_tc26_gost_3410_2012_512_paramSetA_opp(lut.Y, lut_cmb[0][0].Y);
12434     point_add_mixed(&R, &Q, &lut);
12435     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.X, scalar[0] & 1, R.X,
12436                                                         Q.X);
12437     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Y, scalar[0] & 1, R.Y,
12438                                                         Q.Y);
12439     fiat_id_tc26_gost_3410_2012_512_paramSetA_selectznz(Q.Z, scalar[0] & 1, R.Z,
12440                                                         Q.Z);
12441
12442     /* convert to affine -- NB depends on coordinate system */
12443     fiat_id_tc26_gost_3410_2012_512_paramSetA_inv(Q.Z, Q.Z);
12444     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->X, Q.X, Q.Z);
12445     fiat_id_tc26_gost_3410_2012_512_paramSetA_carry_mul(out->Y, Q.Y, Q.Z);
12446 }
12447
12448 static void point_mul_two(unsigned char outx[64], unsigned char outy[64],
12449                           const unsigned char a[64], const unsigned char b[64],
12450                           const unsigned char inx[64],
12451                           const unsigned char iny[64]) {
12452     pt_aff_t P;
12453
12454     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.X, inx);
12455     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.Y, iny);
12456     /* simultaneous scalar multiplication */
12457     var_smul_wnaf_two(&P, a, b, &P);
12458
12459     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outx, P.X);
12460     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outy, P.Y);
12461 }
12462
12463 static void point_mul_g(unsigned char outx[64], unsigned char outy[64],
12464                         const unsigned char scalar[64]) {
12465     pt_aff_t P;
12466
12467     /* fixed scmul function */
12468     fixed_smul_cmb(&P, scalar);
12469     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outx, P.X);
12470     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outy, P.Y);
12471 }
12472
12473 static void point_mul(unsigned char outx[64], unsigned char outy[64],
12474                       const unsigned char scalar[64],
12475                       const unsigned char inx[64],
12476                       const unsigned char iny[64]) {
12477     pt_aff_t P;
12478
12479     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.X, inx);
12480     fiat_id_tc26_gost_3410_2012_512_paramSetA_from_bytes(P.Y, iny);
12481     /* var scmul function */
12482     var_smul_rwnaf(&P, scalar, &P);
12483     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outx, P.X);
12484     fiat_id_tc26_gost_3410_2012_512_paramSetA_to_bytes(outy, P.Y);
12485 }
12486
12487 #include <openssl/ec.h>
12488
12489 static const unsigned char const_zb[64] = {0};
12490
12491     int
12492     point_mul_two_id_tc26_gost_3410_2012_512_paramSetA(
12493         const EC_GROUP *group, EC_POINT *r, const BIGNUM *n, const EC_POINT *q,
12494         const BIGNUM *m, BN_CTX *ctx) {
12495     int ret = 0;
12496     unsigned char b_x[64];
12497     unsigned char b_y[64];
12498     unsigned char b_n[64];
12499     unsigned char b_m[64];
12500     BIGNUM *x = NULL, *y = NULL;
12501
12502     BN_CTX_start(ctx);
12503     x = BN_CTX_get(ctx);
12504     if ((y = BN_CTX_get(ctx)) == NULL
12505         /* pull out coords as bytes */
12506         || !EC_POINT_get_affine_coordinates(group, q, x, y, ctx) ||
12507         BN_bn2lebinpad(x, b_x, 64) != 64 || BN_bn2lebinpad(y, b_y, 64) != 64 ||
12508         BN_bn2lebinpad(n, b_n, 64) != 64 || BN_bn2lebinpad(m, b_m, 64) != 64)
12509         goto err;
12510     /* do the simultaneous scalar multiplication */
12511     point_mul_two(b_x, b_y, b_n, b_m, b_x, b_y);
12512     /* check for infinity */
12513     if (CRYPTO_memcmp(const_zb, b_x, 64) == 0 &&
12514         CRYPTO_memcmp(const_zb, b_y, 64) == 0) {
12515         if (!EC_POINT_set_to_infinity(group, r)) goto err;
12516     } else {
12517         /* otherwise, pack the bytes into the result */
12518         if (BN_lebin2bn(b_x, 64, x) == NULL ||
12519             BN_lebin2bn(b_y, 64, y) == NULL ||
12520             !EC_POINT_set_affine_coordinates(group, r, x, y, ctx))
12521             goto err;
12522     }
12523     ret = 1;
12524 err:
12525     BN_CTX_end(ctx);
12526     return ret;
12527 }
12528
12529     int
12530     point_mul_id_tc26_gost_3410_2012_512_paramSetA(const EC_GROUP *group,
12531                                                    EC_POINT *r,
12532                                                    const EC_POINT *q,
12533                                                    const BIGNUM *m,
12534                                                    BN_CTX *ctx) {
12535     int ret = 0;
12536     unsigned char b_x[64];
12537     unsigned char b_y[64];
12538     unsigned char b_m[64];
12539     BIGNUM *x = NULL, *y = NULL;
12540
12541     BN_CTX_start(ctx);
12542     x = BN_CTX_get(ctx);
12543     if ((y = BN_CTX_get(ctx)) == NULL
12544         /* pull out coords as bytes */
12545         || !EC_POINT_get_affine_coordinates(group, q, x, y, ctx) ||
12546         BN_bn2lebinpad(x, b_x, 64) != 64 || BN_bn2lebinpad(y, b_y, 64) != 64 ||
12547         BN_bn2lebinpad(m, b_m, 64) != 64)
12548         goto err;
12549     /* do the variable scalar multiplication */
12550     point_mul(b_x, b_y, b_m, b_x, b_y);
12551     /* check for infinity */
12552     if (CRYPTO_memcmp(const_zb, b_x, 64) == 0 &&
12553         CRYPTO_memcmp(const_zb, b_y, 64) == 0) {
12554         if (!EC_POINT_set_to_infinity(group, r)) goto err;
12555     } else {
12556         /* otherwise, pack the bytes into the result */
12557         if (BN_lebin2bn(b_x, 64, x) == NULL ||
12558             BN_lebin2bn(b_y, 64, y) == NULL ||
12559             !EC_POINT_set_affine_coordinates(group, r, x, y, ctx))
12560             goto err;
12561     }
12562     ret = 1;
12563 err:
12564     BN_CTX_end(ctx);
12565     return ret;
12566 }
12567
12568     int
12569     point_mul_g_id_tc26_gost_3410_2012_512_paramSetA(const EC_GROUP *group,
12570                                                      EC_POINT *r,
12571                                                      const BIGNUM *n,
12572                                                      BN_CTX *ctx) {
12573     int ret = 0;
12574     unsigned char b_x[64];
12575     unsigned char b_y[64];
12576     unsigned char b_n[64];
12577     BIGNUM *x = NULL, *y = NULL;
12578
12579     BN_CTX_start(ctx);
12580     x = BN_CTX_get(ctx);
12581     if ((y = BN_CTX_get(ctx)) == NULL || BN_bn2lebinpad(n, b_n, 64) != 64)
12582         goto err;
12583     /* do the fixed scalar multiplication */
12584     point_mul_g(b_x, b_y, b_n);
12585     /* check for infinity */
12586     if (CRYPTO_memcmp(const_zb, b_x, 64) == 0 &&
12587         CRYPTO_memcmp(const_zb, b_y, 64) == 0) {
12588         if (!EC_POINT_set_to_infinity(group, r)) goto err;
12589     } else {
12590         /* otherwise, pack the bytes into the result */
12591         if (BN_lebin2bn(b_x, 64, x) == NULL ||
12592             BN_lebin2bn(b_y, 64, y) == NULL ||
12593             !EC_POINT_set_affine_coordinates(group, r, x, y, ctx))
12594             goto err;
12595     }
12596     ret = 1;
12597 err:
12598     BN_CTX_end(ctx);
12599     return ret;
12600 }
12601
12602
12603
12604 #endif /* __SIZEOF_INT128__ */