summaryrefslogtreecommitdiff
path: root/src/trig.c
blob: 2181ebef75cad163187971dac4b2179f95a4ef31 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
#include "global.h"

// Values of sin(x*(π/128)) as Q8.8 fixed-point numbers from x = 0 to x = 319
const s16 gSineTable[] =
{
    Q_8_8(0),           // sin(0*(π/128))
    Q_8_8(0.0234375),   // sin(1*(π/128))
    Q_8_8(0.046875),    // sin(2*(π/128))
    Q_8_8(0.0703125),   // sin(3*(π/128))
    Q_8_8(0.09765625),  // sin(4*(π/128))
    Q_8_8(0.12109375),  // sin(5*(π/128))
    Q_8_8(0.14453125),  // sin(6*(π/128))
    Q_8_8(0.16796875),  // sin(7*(π/128))
    Q_8_8(0.19140625),  // sin(8*(π/128))
    Q_8_8(0.21875),     // sin(9*(π/128))
    Q_8_8(0.2421875),   // sin(10*(π/128))
    Q_8_8(0.265625),    // sin(11*(π/128))
    Q_8_8(0.2890625),   // sin(12*(π/128))
    Q_8_8(0.3125),      // sin(13*(π/128))
    Q_8_8(0.3359375),   // sin(14*(π/128))
    Q_8_8(0.359375),    // sin(15*(π/128))
    Q_8_8(0.37890625),  // sin(16*(π/128))
    Q_8_8(0.40234375),  // sin(17*(π/128))
    Q_8_8(0.42578125),  // sin(18*(π/128))
    Q_8_8(0.44921875),  // sin(19*(π/128))
    Q_8_8(0.46875),     // sin(20*(π/128))
    Q_8_8(0.4921875),   // sin(21*(π/128))
    Q_8_8(0.51171875),  // sin(22*(π/128))
    Q_8_8(0.53125),     // sin(23*(π/128))
    Q_8_8(0.5546875),   // sin(24*(π/128))
    Q_8_8(0.57421875),  // sin(25*(π/128))
    Q_8_8(0.59375),     // sin(26*(π/128))
    Q_8_8(0.61328125),  // sin(27*(π/128))
    Q_8_8(0.6328125),   // sin(28*(π/128))
    Q_8_8(0.65234375),  // sin(29*(π/128))
    Q_8_8(0.66796875),  // sin(30*(π/128))
    Q_8_8(0.6875),      // sin(31*(π/128))
    Q_8_8(0.70703125),  // sin(32*(π/128))
    Q_8_8(0.72265625),  // sin(33*(π/128))
    Q_8_8(0.73828125),  // sin(34*(π/128))
    Q_8_8(0.75390625),  // sin(35*(π/128))
    Q_8_8(0.76953125),  // sin(36*(π/128))
    Q_8_8(0.78515625),  // sin(37*(π/128))
    Q_8_8(0.80078125),  // sin(38*(π/128))
    Q_8_8(0.81640625),  // sin(39*(π/128))
    Q_8_8(0.828125),    // sin(40*(π/128))
    Q_8_8(0.84375),     // sin(41*(π/128))
    Q_8_8(0.85546875),  // sin(42*(π/128))
    Q_8_8(0.8671875),   // sin(43*(π/128))
    Q_8_8(0.87890625),  // sin(44*(π/128))
    Q_8_8(0.890625),    // sin(45*(π/128))
    Q_8_8(0.90234375),  // sin(46*(π/128))
    Q_8_8(0.9140625),   // sin(47*(π/128))
    Q_8_8(0.921875),    // sin(48*(π/128))
    Q_8_8(0.9296875),   // sin(49*(π/128))
    Q_8_8(0.94140625),  // sin(50*(π/128))
    Q_8_8(0.94921875),  // sin(51*(π/128))
    Q_8_8(0.953125),    // sin(52*(π/128))
    Q_8_8(0.9609375),   // sin(53*(π/128))
    Q_8_8(0.96875),     // sin(54*(π/128))
    Q_8_8(0.97265625),  // sin(55*(π/128))
    Q_8_8(0.98046875),  // sin(56*(π/128))
    Q_8_8(0.984375),    // sin(57*(π/128))
    Q_8_8(0.98828125),  // sin(58*(π/128))
    Q_8_8(0.9921875),   // sin(59*(π/128))
    Q_8_8(0.9921875),   // sin(60*(π/128))
    Q_8_8(0.99609375),  // sin(61*(π/128))
    Q_8_8(0.99609375),  // sin(62*(π/128))
    Q_8_8(0.99609375),  // sin(63*(π/128))
    Q_8_8(1),           // sin(64*(π/128))
    Q_8_8(0.99609375),  // sin(65*(π/128))
    Q_8_8(0.99609375),  // sin(66*(π/128))
    Q_8_8(0.99609375),  // sin(67*(π/128))
    Q_8_8(0.9921875),   // sin(68*(π/128))
    Q_8_8(0.9921875),   // sin(69*(π/128))
    Q_8_8(0.98828125),  // sin(70*(π/128))
    Q_8_8(0.984375),    // sin(71*(π/128))
    Q_8_8(0.98046875),  // sin(72*(π/128))
    Q_8_8(0.97265625),  // sin(73*(π/128))
    Q_8_8(0.96875),     // sin(74*(π/128))
    Q_8_8(0.9609375),   // sin(75*(π/128))
    Q_8_8(0.953125),    // sin(76*(π/128))
    Q_8_8(0.94921875),  // sin(77*(π/128))
    Q_8_8(0.94140625),  // sin(78*(π/128))
    Q_8_8(0.9296875),   // sin(79*(π/128))
    Q_8_8(0.921875),    // sin(80*(π/128))
    Q_8_8(0.9140625),   // sin(81*(π/128))
    Q_8_8(0.90234375),  // sin(82*(π/128))
    Q_8_8(0.890625),    // sin(83*(π/128))
    Q_8_8(0.87890625),  // sin(84*(π/128))
    Q_8_8(0.8671875),   // sin(85*(π/128))
    Q_8_8(0.85546875),  // sin(86*(π/128))
    Q_8_8(0.84375),     // sin(87*(π/128))
    Q_8_8(0.828125),    // sin(88*(π/128))
    Q_8_8(0.81640625),  // sin(89*(π/128))
    Q_8_8(0.80078125),  // sin(90*(π/128))
    Q_8_8(0.78515625),  // sin(91*(π/128))
    Q_8_8(0.76953125),  // sin(92*(π/128))
    Q_8_8(0.75390625),  // sin(93*(π/128))
    Q_8_8(0.73828125),  // sin(94*(π/128))
    Q_8_8(0.72265625),  // sin(95*(π/128))
    Q_8_8(0.70703125),  // sin(96*(π/128))
    Q_8_8(0.6875),      // sin(97*(π/128))
    Q_8_8(0.66796875),  // sin(98*(π/128))
    Q_8_8(0.65234375),  // sin(99*(π/128))
    Q_8_8(0.6328125),   // sin(100*(π/128))
    Q_8_8(0.61328125),  // sin(101*(π/128))
    Q_8_8(0.59375),     // sin(102*(π/128))
    Q_8_8(0.57421875),  // sin(103*(π/128))
    Q_8_8(0.5546875),   // sin(104*(π/128))
    Q_8_8(0.53125),     // sin(105*(π/128))
    Q_8_8(0.51171875),  // sin(106*(π/128))
    Q_8_8(0.4921875),   // sin(107*(π/128))
    Q_8_8(0.46875),     // sin(108*(π/128))
    Q_8_8(0.44921875),  // sin(109*(π/128))
    Q_8_8(0.42578125),  // sin(110*(π/128))
    Q_8_8(0.40234375),  // sin(111*(π/128))
    Q_8_8(0.37890625),  // sin(112*(π/128))
    Q_8_8(0.359375),    // sin(113*(π/128))
    Q_8_8(0.3359375),   // sin(114*(π/128))
    Q_8_8(0.3125),      // sin(115*(π/128))
    Q_8_8(0.2890625),   // sin(116*(π/128))
    Q_8_8(0.265625),    // sin(117*(π/128))
    Q_8_8(0.2421875),   // sin(118*(π/128))
    Q_8_8(0.21875),     // sin(119*(π/128))
    Q_8_8(0.19140625),  // sin(120*(π/128))
    Q_8_8(0.16796875),  // sin(121*(π/128))
    Q_8_8(0.14453125),  // sin(122*(π/128))
    Q_8_8(0.12109375),  // sin(123*(π/128))
    Q_8_8(0.09765625),  // sin(124*(π/128))
    Q_8_8(0.0703125),   // sin(125*(π/128))
    Q_8_8(0.046875),    // sin(126*(π/128))
    Q_8_8(0.0234375),   // sin(127*(π/128))
    Q_8_8(0),           // sin(128*(π/128))
    Q_8_8(-0.0234375),  // sin(129*(π/128))
    Q_8_8(-0.046875),   // sin(130*(π/128))
    Q_8_8(-0.0703125),  // sin(131*(π/128))
    Q_8_8(-0.09765625), // sin(132*(π/128))
    Q_8_8(-0.12109375), // sin(133*(π/128))
    Q_8_8(-0.14453125), // sin(134*(π/128))
    Q_8_8(-0.16796875), // sin(135*(π/128))
    Q_8_8(-0.19140625), // sin(136*(π/128))
    Q_8_8(-0.21875),    // sin(137*(π/128))
    Q_8_8(-0.2421875),  // sin(138*(π/128))
    Q_8_8(-0.265625),   // sin(139*(π/128))
    Q_8_8(-0.2890625),  // sin(140*(π/128))
    Q_8_8(-0.3125),     // sin(141*(π/128))
    Q_8_8(-0.3359375),  // sin(142*(π/128))
    Q_8_8(-0.359375),   // sin(143*(π/128))
    Q_8_8(-0.37890625), // sin(144*(π/128))
    Q_8_8(-0.40234375), // sin(145*(π/128))
    Q_8_8(-0.42578125), // sin(146*(π/128))
    Q_8_8(-0.44921875), // sin(147*(π/128))
    Q_8_8(-0.46875),    // sin(148*(π/128))
    Q_8_8(-0.4921875),  // sin(149*(π/128))
    Q_8_8(-0.51171875), // sin(150*(π/128))
    Q_8_8(-0.53125),    // sin(151*(π/128))
    Q_8_8(-0.5546875),  // sin(152*(π/128))
    Q_8_8(-0.57421875), // sin(153*(π/128))
    Q_8_8(-0.59375),    // sin(154*(π/128))
    Q_8_8(-0.61328125), // sin(155*(π/128))
    Q_8_8(-0.6328125),  // sin(156*(π/128))
    Q_8_8(-0.65234375), // sin(157*(π/128))
    Q_8_8(-0.66796875), // sin(158*(π/128))
    Q_8_8(-0.6875),     // sin(159*(π/128))
    Q_8_8(-0.70703125), // sin(160*(π/128))
    Q_8_8(-0.72265625), // sin(161*(π/128))
    Q_8_8(-0.73828125), // sin(162*(π/128))
    Q_8_8(-0.75390625), // sin(163*(π/128))
    Q_8_8(-0.76953125), // sin(164*(π/128))
    Q_8_8(-0.78515625), // sin(165*(π/128))
    Q_8_8(-0.80078125), // sin(166*(π/128))
    Q_8_8(-0.81640625), // sin(167*(π/128))
    Q_8_8(-0.828125),   // sin(168*(π/128))
    Q_8_8(-0.84375),    // sin(169*(π/128))
    Q_8_8(-0.85546875), // sin(170*(π/128))
    Q_8_8(-0.8671875),  // sin(171*(π/128))
    Q_8_8(-0.87890625), // sin(172*(π/128))
    Q_8_8(-0.890625),   // sin(173*(π/128))
    Q_8_8(-0.90234375), // sin(174*(π/128))
    Q_8_8(-0.9140625),  // sin(175*(π/128))
    Q_8_8(-0.921875),   // sin(176*(π/128))
    Q_8_8(-0.9296875),  // sin(177*(π/128))
    Q_8_8(-0.94140625), // sin(178*(π/128))
    Q_8_8(-0.94921875), // sin(179*(π/128))
    Q_8_8(-0.953125),   // sin(180*(π/128))
    Q_8_8(-0.9609375),  // sin(181*(π/128))
    Q_8_8(-0.96875),    // sin(182*(π/128))
    Q_8_8(-0.97265625), // sin(183*(π/128))
    Q_8_8(-0.98046875), // sin(184*(π/128))
    Q_8_8(-0.984375),   // sin(185*(π/128))
    Q_8_8(-0.98828125), // sin(186*(π/128))
    Q_8_8(-0.9921875),  // sin(187*(π/128))
    Q_8_8(-0.9921875),  // sin(188*(π/128))
    Q_8_8(-0.99609375), // sin(189*(π/128))
    Q_8_8(-0.99609375), // sin(190*(π/128))
    Q_8_8(-0.99609375), // sin(191*(π/128))
    Q_8_8(-1),          // sin(192*(π/128))
    Q_8_8(-0.99609375), // sin(193*(π/128))
    Q_8_8(-0.99609375), // sin(194*(π/128))
    Q_8_8(-0.99609375), // sin(195*(π/128))
    Q_8_8(-0.9921875),  // sin(196*(π/128))
    Q_8_8(-0.9921875),  // sin(197*(π/128))
    Q_8_8(-0.98828125), // sin(198*(π/128))
    Q_8_8(-0.984375),   // sin(199*(π/128))
    Q_8_8(-0.98046875), // sin(200*(π/128))
    Q_8_8(-0.97265625), // sin(201*(π/128))
    Q_8_8(-0.96875),    // sin(202*(π/128))
    Q_8_8(-0.9609375),  // sin(203*(π/128))
    Q_8_8(-0.953125),   // sin(204*(π/128))
    Q_8_8(-0.94921875), // sin(205*(π/128))
    Q_8_8(-0.94140625), // sin(206*(π/128))
    Q_8_8(-0.9296875),  // sin(207*(π/128))
    Q_8_8(-0.921875),   // sin(208*(π/128))
    Q_8_8(-0.9140625),  // sin(209*(π/128))
    Q_8_8(-0.90234375), // sin(210*(π/128))
    Q_8_8(-0.890625),   // sin(211*(π/128))
    Q_8_8(-0.87890625), // sin(212*(π/128))
    Q_8_8(-0.8671875),  // sin(213*(π/128))
    Q_8_8(-0.85546875), // sin(214*(π/128))
    Q_8_8(-0.84375),    // sin(215*(π/128))
    Q_8_8(-0.828125),   // sin(216*(π/128))
    Q_8_8(-0.81640625), // sin(217*(π/128))
    Q_8_8(-0.80078125), // sin(218*(π/128))
    Q_8_8(-0.78515625), // sin(219*(π/128))
    Q_8_8(-0.76953125), // sin(220*(π/128))
    Q_8_8(-0.75390625), // sin(221*(π/128))
    Q_8_8(-0.73828125), // sin(222*(π/128))
    Q_8_8(-0.72265625), // sin(223*(π/128))
    Q_8_8(-0.70703125), // sin(224*(π/128))
    Q_8_8(-0.6875),     // sin(225*(π/128))
    Q_8_8(-0.66796875), // sin(226*(π/128))
    Q_8_8(-0.65234375), // sin(227*(π/128))
    Q_8_8(-0.6328125),  // sin(228*(π/128))
    Q_8_8(-0.61328125), // sin(229*(π/128))
    Q_8_8(-0.59375),    // sin(230*(π/128))
    Q_8_8(-0.57421875), // sin(231*(π/128))
    Q_8_8(-0.5546875),  // sin(232*(π/128))
    Q_8_8(-0.53125),    // sin(233*(π/128))
    Q_8_8(-0.51171875), // sin(234*(π/128))
    Q_8_8(-0.4921875),  // sin(235*(π/128))
    Q_8_8(-0.46875),    // sin(236*(π/128))
    Q_8_8(-0.44921875), // sin(237*(π/128))
    Q_8_8(-0.42578125), // sin(238*(π/128))
    Q_8_8(-0.40234375), // sin(239*(π/128))
    Q_8_8(-0.37890625), // sin(240*(π/128))
    Q_8_8(-0.359375),   // sin(241*(π/128))
    Q_8_8(-0.3359375),  // sin(242*(π/128))
    Q_8_8(-0.3125),     // sin(243*(π/128))
    Q_8_8(-0.2890625),  // sin(244*(π/128))
    Q_8_8(-0.265625),   // sin(245*(π/128))
    Q_8_8(-0.2421875),  // sin(246*(π/128))
    Q_8_8(-0.21875),    // sin(247*(π/128))
    Q_8_8(-0.19140625), // sin(248*(π/128))
    Q_8_8(-0.16796875), // sin(249*(π/128))
    Q_8_8(-0.14453125), // sin(250*(π/128))
    Q_8_8(-0.12109375), // sin(251*(π/128))
    Q_8_8(-0.09765625), // sin(252*(π/128))
    Q_8_8(-0.0703125),  // sin(253*(π/128))
    Q_8_8(-0.046875),   // sin(254*(π/128))
    Q_8_8(-0.0234375),  // sin(255*(π/128))
    Q_8_8(0),           // sin(256*(π/128))
    Q_8_8(0.0234375),   // sin(257*(π/128))
    Q_8_8(0.046875),    // sin(258*(π/128))
    Q_8_8(0.0703125),   // sin(259*(π/128))
    Q_8_8(0.09765625),  // sin(260*(π/128))
    Q_8_8(0.12109375),  // sin(261*(π/128))
    Q_8_8(0.14453125),  // sin(262*(π/128))
    Q_8_8(0.16796875),  // sin(263*(π/128))
    Q_8_8(0.19140625),  // sin(264*(π/128))
    Q_8_8(0.21875),     // sin(265*(π/128))
    Q_8_8(0.2421875),   // sin(266*(π/128))
    Q_8_8(0.265625),    // sin(267*(π/128))
    Q_8_8(0.2890625),   // sin(268*(π/128))
    Q_8_8(0.3125),      // sin(269*(π/128))
    Q_8_8(0.3359375),   // sin(270*(π/128))
    Q_8_8(0.359375),    // sin(271*(π/128))
    Q_8_8(0.37890625),  // sin(272*(π/128))
    Q_8_8(0.40234375),  // sin(273*(π/128))
    Q_8_8(0.42578125),  // sin(274*(π/128))
    Q_8_8(0.44921875),  // sin(275*(π/128))
    Q_8_8(0.46875),     // sin(276*(π/128))
    Q_8_8(0.4921875),   // sin(277*(π/128))
    Q_8_8(0.51171875),  // sin(278*(π/128))
    Q_8_8(0.53125),     // sin(279*(π/128))
    Q_8_8(0.5546875),   // sin(280*(π/128))
    Q_8_8(0.57421875),  // sin(281*(π/128))
    Q_8_8(0.59375),     // sin(282*(π/128))
    Q_8_8(0.61328125),  // sin(283*(π/128))
    Q_8_8(0.6328125),   // sin(284*(π/128))
    Q_8_8(0.65234375),  // sin(285*(π/128))
    Q_8_8(0.66796875),  // sin(286*(π/128))
    Q_8_8(0.6875),      // sin(287*(π/128))
    Q_8_8(0.70703125),  // sin(288*(π/128))
    Q_8_8(0.72265625),  // sin(289*(π/128))
    Q_8_8(0.73828125),  // sin(290*(π/128))
    Q_8_8(0.75390625),  // sin(291*(π/128))
    Q_8_8(0.76953125),  // sin(292*(π/128))
    Q_8_8(0.78515625),  // sin(293*(π/128))
    Q_8_8(0.80078125),  // sin(294*(π/128))
    Q_8_8(0.81640625),  // sin(295*(π/128))
    Q_8_8(0.828125),    // sin(296*(π/128))
    Q_8_8(0.84375),     // sin(297*(π/128))
    Q_8_8(0.85546875),  // sin(298*(π/128))
    Q_8_8(0.8671875),   // sin(299*(π/128))
    Q_8_8(0.87890625),  // sin(300*(π/128))
    Q_8_8(0.890625),    // sin(301*(π/128))
    Q_8_8(0.90234375),  // sin(302*(π/128))
    Q_8_8(0.9140625),   // sin(303*(π/128))
    Q_8_8(0.921875),    // sin(304*(π/128))
    Q_8_8(0.9296875),   // sin(305*(π/128))
    Q_8_8(0.94140625),  // sin(306*(π/128))
    Q_8_8(0.94921875),  // sin(307*(π/128))
    Q_8_8(0.953125),    // sin(308*(π/128))
    Q_8_8(0.9609375),   // sin(309*(π/128))
    Q_8_8(0.96875),     // sin(310*(π/128))
    Q_8_8(0.97265625),  // sin(311*(π/128))
    Q_8_8(0.98046875),  // sin(312*(π/128))
    Q_8_8(0.984375),    // sin(313*(π/128))
    Q_8_8(0.98828125),  // sin(314*(π/128))
    Q_8_8(0.9921875),   // sin(315*(π/128))
    Q_8_8(0.9921875),   // sin(316*(π/128))
    Q_8_8(0.99609375),  // sin(317*(π/128))
    Q_8_8(0.99609375),  // sin(318*(π/128))
    Q_8_8(0.99609375),  // sin(319*(π/128))
};

// values of sin(x) as Q4.12 fixed-point numbers from x = 0° to x = 179°
const s16 gSineDegreeTable[] =
{
    Q_4_12(0),              // sin(0°)
    Q_4_12(0.017333984375), // sin(1°)
    Q_4_12(0.034912109375), // sin(2°)
    Q_4_12(0.05224609375),  // sin(3°)
    Q_4_12(0.06982421875),  // sin(4°)
    Q_4_12(0.087158203125), // sin(5°)
    Q_4_12(0.1044921875),   // sin(6°)
    Q_4_12(0.121826171875), // sin(7°)
    Q_4_12(0.13916015625),  // sin(8°)
    Q_4_12(0.156494140625), // sin(9°)
    Q_4_12(0.173583984375), // sin(10°)
    Q_4_12(0.19091796875),  // sin(11°)
    Q_4_12(0.2080078125),   // sin(12°)
    Q_4_12(0.224853515625), // sin(13°)
    Q_4_12(0.241943359375), // sin(14°)
    Q_4_12(0.2587890625),   // sin(15°)
    Q_4_12(0.275634765625), // sin(16°)
    Q_4_12(0.29248046875),  // sin(17°)
    Q_4_12(0.30908203125),  // sin(18°)
    Q_4_12(0.32568359375),  // sin(19°)
    Q_4_12(0.342041015625), // sin(20°)
    Q_4_12(0.3583984375),   // sin(21°)
    Q_4_12(0.37451171875),  // sin(22°)
    Q_4_12(0.390625),       // sin(23°)
    Q_4_12(0.40673828125),  // sin(24°)
    Q_4_12(0.422607421875), // sin(25°)
    Q_4_12(0.4384765625),   // sin(26°)
    Q_4_12(0.4541015625),   // sin(27°)
    Q_4_12(0.469482421875), // sin(28°)
    Q_4_12(0.48486328125),  // sin(29°)
    Q_4_12(0.5),            // sin(30°)
    Q_4_12(0.51513671875),  // sin(31°)
    Q_4_12(0.530029296875), // sin(32°)
    Q_4_12(0.544677734375), // sin(33°)
    Q_4_12(0.55908203125),  // sin(34°)
    Q_4_12(0.573486328125), // sin(35°)
    Q_4_12(0.587890625),    // sin(36°)
    Q_4_12(0.601806640625), // sin(37°)
    Q_4_12(0.61572265625),  // sin(38°)
    Q_4_12(0.62939453125),  // sin(39°)
    Q_4_12(0.642822265625), // sin(40°)
    Q_4_12(0.656005859375), // sin(41°)
    Q_4_12(0.669189453125), // sin(42°)
    Q_4_12(0.681884765625), // sin(43°)
    Q_4_12(0.694580078125), // sin(44°)
    Q_4_12(0.70703125),     // sin(45°)
    Q_4_12(0.71923828125),  // sin(46°)
    Q_4_12(0.7314453125),   // sin(47°)
    Q_4_12(0.7431640625),   // sin(48°)
    Q_4_12(0.754638671875), // sin(49°)
    Q_4_12(0.76611328125),  // sin(50°)
    Q_4_12(0.777099609375), // sin(51°)
    Q_4_12(0.7880859375),   // sin(52°)
    Q_4_12(0.798583984375), // sin(53°)
    Q_4_12(0.80908203125),  // sin(54°)
    Q_4_12(0.819091796875), // sin(55°)
    Q_4_12(0.8291015625),   // sin(56°)
    Q_4_12(0.838623046875), // sin(57°)
    Q_4_12(0.84814453125),  // sin(58°)
    Q_4_12(0.857177734375), // sin(59°)
    Q_4_12(0.865966796875), // sin(60°)
    Q_4_12(0.87451171875),  // sin(61°)
    Q_4_12(0.883056640625), // sin(62°)
    Q_4_12(0.89111328125),  // sin(63°)
    Q_4_12(0.898681640625), // sin(64°)
    Q_4_12(0.90625),        // sin(65°)
    Q_4_12(0.91357421875),  // sin(66°)
    Q_4_12(0.92041015625),  // sin(67°)
    Q_4_12(0.92724609375),  // sin(68°)
    Q_4_12(0.93359375),     // sin(69°)
    Q_4_12(0.939697265625), // sin(70°)
    Q_4_12(0.945556640625), // sin(71°)
    Q_4_12(0.951171875),    // sin(72°)
    Q_4_12(0.956298828125), // sin(73°)
    Q_4_12(0.961181640625), // sin(74°)
    Q_4_12(0.9658203125),   // sin(75°)
    Q_4_12(0.97021484375),  // sin(76°)
    Q_4_12(0.974365234375), // sin(77°)
    Q_4_12(0.97802734375),  // sin(78°)
    Q_4_12(0.981689453125), // sin(79°)
    Q_4_12(0.98486328125),  // sin(80°)
    Q_4_12(0.98779296875),  // sin(81°)
    Q_4_12(0.990234375),    // sin(82°)
    Q_4_12(0.992431640625), // sin(83°)
    Q_4_12(0.994384765625), // sin(84°)
    Q_4_12(0.99609375),     // sin(85°)
    Q_4_12(0.99755859375),  // sin(86°)
    Q_4_12(0.99853515625),  // sin(87°)
    Q_4_12(0.999267578125), // sin(88°)
    Q_4_12(0.999755859375), // sin(89°)
    Q_4_12(1),              // sin(90°)
    Q_4_12(0.999755859375), // sin(91°)
    Q_4_12(0.999267578125), // sin(92°)
    Q_4_12(0.99853515625),  // sin(93°)
    Q_4_12(0.99755859375),  // sin(94°)
    Q_4_12(0.99609375),     // sin(95°)
    Q_4_12(0.994384765625), // sin(96°)
    Q_4_12(0.992431640625), // sin(97°)
    Q_4_12(0.990234375),    // sin(98°)
    Q_4_12(0.98779296875),  // sin(99°)
    Q_4_12(0.98486328125),  // sin(100°)
    Q_4_12(0.981689453125), // sin(101°)
    Q_4_12(0.97802734375),  // sin(102°)
    Q_4_12(0.974365234375), // sin(103°)
    Q_4_12(0.97021484375),  // sin(104°)
    Q_4_12(0.9658203125),   // sin(105°)
    Q_4_12(0.961181640625), // sin(106°)
    Q_4_12(0.956298828125), // sin(107°)
    Q_4_12(0.951171875),    // sin(108°)
    Q_4_12(0.945556640625), // sin(109°)
    Q_4_12(0.939697265625), // sin(110°)
    Q_4_12(0.93359375),     // sin(111°)
    Q_4_12(0.92724609375),  // sin(112°)
    Q_4_12(0.92041015625),  // sin(113°)
    Q_4_12(0.91357421875),  // sin(114°)
    Q_4_12(0.90625),        // sin(115°)
    Q_4_12(0.898681640625), // sin(116°)
    Q_4_12(0.89111328125),  // sin(117°)
    Q_4_12(0.883056640625), // sin(118°)
    Q_4_12(0.87451171875),  // sin(119°)
    Q_4_12(0.865966796875), // sin(120°)
    Q_4_12(0.857177734375), // sin(121°)
    Q_4_12(0.84814453125),  // sin(122°)
    Q_4_12(0.838623046875), // sin(123°)
    Q_4_12(0.8291015625),   // sin(124°)
    Q_4_12(0.819091796875), // sin(125°)
    Q_4_12(0.80908203125),  // sin(126°)
    Q_4_12(0.798583984375), // sin(127°)
    Q_4_12(0.7880859375),   // sin(128°)
    Q_4_12(0.777099609375), // sin(129°)
    Q_4_12(0.76611328125),  // sin(130°)
    Q_4_12(0.754638671875), // sin(131°)
    Q_4_12(0.7431640625),   // sin(132°)
    Q_4_12(0.7314453125),   // sin(133°)
    Q_4_12(0.71923828125),  // sin(134°)
    Q_4_12(0.70703125),     // sin(135°)
    Q_4_12(0.694580078125), // sin(136°)
    Q_4_12(0.681884765625), // sin(137°)
    Q_4_12(0.669189453125), // sin(138°)
    Q_4_12(0.656005859375), // sin(139°)
    Q_4_12(0.642822265625), // sin(140°)
    Q_4_12(0.62939453125),  // sin(141°)
    Q_4_12(0.61572265625),  // sin(142°)
    Q_4_12(0.601806640625), // sin(143°)
    Q_4_12(0.587890625),    // sin(144°)
    Q_4_12(0.573486328125), // sin(145°)
    Q_4_12(0.55908203125),  // sin(146°)
    Q_4_12(0.544677734375), // sin(147°)
    Q_4_12(0.530029296875), // sin(148°)
    Q_4_12(0.51513671875),  // sin(149°)
    Q_4_12(0.5),            // sin(150°)
    Q_4_12(0.48486328125),  // sin(151°)
    Q_4_12(0.469482421875), // sin(152°)
    Q_4_12(0.4541015625),   // sin(153°)
    Q_4_12(0.4384765625),   // sin(154°)
    Q_4_12(0.422607421875), // sin(155°)
    Q_4_12(0.40673828125),  // sin(156°)
    Q_4_12(0.390625),       // sin(157°)
    Q_4_12(0.37451171875),  // sin(158°)
    Q_4_12(0.3583984375),   // sin(159°)
    Q_4_12(0.342041015625), // sin(160°)
    Q_4_12(0.32568359375),  // sin(161°)
    Q_4_12(0.30908203125),  // sin(162°)
    Q_4_12(0.29248046875),  // sin(163°)
    Q_4_12(0.275634765625), // sin(164°)
    Q_4_12(0.2587890625),   // sin(165°)
    Q_4_12(0.241943359375), // sin(166°)
    Q_4_12(0.224853515625), // sin(167°)
    Q_4_12(0.2080078125),   // sin(168°)
    Q_4_12(0.19091796875),  // sin(169°)
    Q_4_12(0.173583984375), // sin(170°)
    Q_4_12(0.156494140625), // sin(171°)
    Q_4_12(0.13916015625),  // sin(172°)
    Q_4_12(0.121826171875), // sin(173°)
    Q_4_12(0.1044921875),   // sin(174°)
    Q_4_12(0.087158203125), // sin(175°)
    Q_4_12(0.06982421875),  // sin(176°)
    Q_4_12(0.05224609375),  // sin(177°)
    Q_4_12(0.034912109375), // sin(178°)
    Q_4_12(0.017333984375), // sin(179°)
};

// amplitude * sin(index*(π/128))
s16 Sin(s16 index, s16 amplitude)
{
    return (amplitude * gSineTable[index]) >> 8;
}

// amplitude * cos(index*(π/128))
s16 Cos(s16 index, s16 amplitude)
{
    return (amplitude * gSineTable[index + 64]) >> 8;
}

// angle in degrees
s16 Sin2(u16 angle)
{
    s32 angleMod = angle % 180;
    s32 negate = ((angle / 180) & 1);
    s16 value = gSineDegreeTable[angleMod];

    if (negate)
        return -value;
    else
        return value;
}

// angle in degrees
s16 Cos2(u16 angle)
{
    return Sin2(angle + 90);
}