nodes2ts 1.1.9 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/.eslintignore +3 -0
  2. package/.eslintrc.cjs +11 -0
  3. package/.github/workflows/lint.js.yml +22 -0
  4. package/.github/workflows/node.js.yml +22 -0
  5. package/.mocharc.js +7 -0
  6. package/README.md +22 -5
  7. package/dist/Interval.d.ts +7 -8
  8. package/dist/Interval.js +12 -12
  9. package/dist/Interval.js.map +1 -1
  10. package/dist/MutableInteger.js +5 -4
  11. package/dist/MutableInteger.js.map +1 -1
  12. package/dist/Platform.d.ts +15 -0
  13. package/dist/Platform.js +53 -0
  14. package/dist/Platform.js.map +1 -0
  15. package/dist/R1Interval.d.ts +8 -9
  16. package/dist/R1Interval.js +59 -78
  17. package/dist/R1Interval.js.map +1 -1
  18. package/dist/R2Vector.d.ts +12 -13
  19. package/dist/R2Vector.js +65 -85
  20. package/dist/R2Vector.js.map +1 -1
  21. package/dist/S1Angle.d.ts +38 -5
  22. package/dist/S1Angle.js +89 -37
  23. package/dist/S1Angle.js.map +1 -1
  24. package/dist/S1ChordAngle.d.ts +166 -0
  25. package/dist/S1ChordAngle.js +318 -0
  26. package/dist/S1ChordAngle.js.map +1 -0
  27. package/dist/S1Interval.d.ts +11 -12
  28. package/dist/S1Interval.js +134 -140
  29. package/dist/S1Interval.js.map +1 -1
  30. package/dist/S2.d.ts +8 -5
  31. package/dist/S2.js +91 -108
  32. package/dist/S2.js.map +1 -1
  33. package/dist/S2Cap.d.ts +33 -25
  34. package/dist/S2Cap.js +199 -203
  35. package/dist/S2Cap.js.map +1 -1
  36. package/dist/S2Cell.d.ts +15 -13
  37. package/dist/S2Cell.js +196 -206
  38. package/dist/S2Cell.js.map +1 -1
  39. package/dist/S2CellId.d.ts +37 -14
  40. package/dist/S2CellId.js +407 -359
  41. package/dist/S2CellId.js.map +1 -1
  42. package/dist/S2CellUnion.d.ts +1 -2
  43. package/dist/S2CellUnion.js +137 -133
  44. package/dist/S2CellUnion.js.map +1 -1
  45. package/dist/S2EdgeUtil.js +14 -17
  46. package/dist/S2EdgeUtil.js.map +1 -1
  47. package/dist/S2LatLng.d.ts +15 -11
  48. package/dist/S2LatLng.js +100 -114
  49. package/dist/S2LatLng.js.map +1 -1
  50. package/dist/S2LatLngRect.d.ts +8 -4
  51. package/dist/S2LatLngRect.js +215 -197
  52. package/dist/S2LatLngRect.js.map +1 -1
  53. package/dist/S2Metric.d.ts +4 -5
  54. package/dist/S2Metric.js +30 -27
  55. package/dist/S2Metric.js.map +1 -1
  56. package/dist/S2Point.d.ts +48 -14
  57. package/dist/S2Point.js +156 -109
  58. package/dist/S2Point.js.map +1 -1
  59. package/dist/S2Projections.d.ts +43 -9
  60. package/dist/S2Projections.js +226 -47
  61. package/dist/S2Projections.js.map +1 -1
  62. package/dist/S2Region.js +2 -1
  63. package/dist/S2Region.js.map +1 -1
  64. package/dist/S2RegionCoverer.d.ts +21 -6
  65. package/dist/S2RegionCoverer.js +144 -109
  66. package/dist/S2RegionCoverer.js.map +1 -1
  67. package/dist/export.d.ts +0 -1
  68. package/dist/export.js +42 -32
  69. package/dist/export.js.map +1 -1
  70. package/dist/utils/preconditions.d.ts +2 -0
  71. package/dist/utils/preconditions.js +16 -0
  72. package/dist/utils/preconditions.js.map +1 -0
  73. package/package.json +28 -34
  74. package/.npmignore +0 -8
  75. package/.nyc_output/1eb1f420a13c15f529aac41a40bcaa21.json +0 -1
  76. package/.nyc_output/5ff62256eb1c111254ba0b469fb547da.json +0 -1
  77. package/.nyc_output/949d6e8c2061067f3bdfd27dfff5ba83.json +0 -1
  78. package/coverage/Interval.ts.html +0 -203
  79. package/coverage/MutableInteger.ts.html +0 -77
  80. package/coverage/R1Interval.ts.html +0 -647
  81. package/coverage/R2Vector.ts.html +0 -587
  82. package/coverage/S1Angle.ts.html +0 -344
  83. package/coverage/S1Interval.ts.html +0 -1349
  84. package/coverage/S2.ts.html +0 -1178
  85. package/coverage/S2Cap.ts.html +0 -1433
  86. package/coverage/S2Cell.ts.html +0 -1415
  87. package/coverage/S2CellId.ts.html +0 -3329
  88. package/coverage/S2EdgeUtil.ts.html +0 -2534
  89. package/coverage/S2LatLng.ts.html +0 -848
  90. package/coverage/S2LatLngRect.ts.html +0 -2222
  91. package/coverage/S2Point.ts.html +0 -758
  92. package/coverage/S2Projections.ts.html +0 -518
  93. package/coverage/base.css +0 -212
  94. package/coverage/decimal.ts.html +0 -68
  95. package/coverage/index.html +0 -288
  96. package/coverage/prettify.css +0 -1
  97. package/coverage/prettify.js +0 -1
  98. package/coverage/sort-arrow-sprite.png +0 -0
  99. package/coverage/sorter.js +0 -158
  100. package/dist/decimal.d.ts +0 -3
  101. package/dist/decimal.js +0 -4
  102. package/dist/decimal.js.map +0 -1
  103. package/dist/decimal_augmentation.d.ts +0 -24
  104. package/dist/decimal_augmentation.js +0 -2
  105. package/dist/decimal_augmentation.js.map +0 -1
@@ -1,1349 +0,0 @@
1
- <!doctype html>
2
- <html lang="en">
3
- <head>
4
- <title>Code coverage report for S1Interval.ts</title>
5
- <meta charset="utf-8" />
6
- <link rel="stylesheet" href="prettify.css" />
7
- <link rel="stylesheet" href="base.css" />
8
- <meta name="viewport" content="width=device-width, initial-scale=1">
9
- <style type='text/css'>
10
- .coverage-summary .sorter {
11
- background-image: url(sort-arrow-sprite.png);
12
- }
13
- </style>
14
- </head>
15
- <body>
16
- <div class='wrapper'>
17
- <div class='pad1'>
18
- <h1>
19
- <a href="index.html">All files</a> S1Interval.ts
20
- </h1>
21
- <div class='clearfix'>
22
- <div class='fl pad1y space-right2'>
23
- <span class="strong">55.75% </span>
24
- <span class="quiet">Statements</span>
25
- <span class='fraction'>97/174</span>
26
- </div>
27
- <div class='fl pad1y space-right2'>
28
- <span class="strong">29.59% </span>
29
- <span class="quiet">Branches</span>
30
- <span class='fraction'>50/169</span>
31
- </div>
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">80.77% </span>
34
- <span class="quiet">Functions</span>
35
- <span class='fraction'>21/26</span>
36
- </div>
37
- <div class='fl pad1y space-right2'>
38
- <span class="strong">54.97% </span>
39
- <span class="quiet">Lines</span>
40
- <span class='fraction'>94/171</span>
41
- </div>
42
- </div>
43
- </div>
44
- <div class='status-line medium'></div>
45
- <pre><table class="coverage">
46
- <tr><td class="line-count quiet">1
47
- 2
48
- 3
49
- 4
50
- 5
51
- 6
52
- 7
53
- 8
54
- 9
55
- 10
56
- 11
57
- 12
58
- 13
59
- 14
60
- 15
61
- 16
62
- 17
63
- 18
64
- 19
65
- 20
66
- 21
67
- 22
68
- 23
69
- 24
70
- 25
71
- 26
72
- 27
73
- 28
74
- 29
75
- 30
76
- 31
77
- 32
78
- 33
79
- 34
80
- 35
81
- 36
82
- 37
83
- 38
84
- 39
85
- 40
86
- 41
87
- 42
88
- 43
89
- 44
90
- 45
91
- 46
92
- 47
93
- 48
94
- 49
95
- 50
96
- 51
97
- 52
98
- 53
99
- 54
100
- 55
101
- 56
102
- 57
103
- 58
104
- 59
105
- 60
106
- 61
107
- 62
108
- 63
109
- 64
110
- 65
111
- 66
112
- 67
113
- 68
114
- 69
115
- 70
116
- 71
117
- 72
118
- 73
119
- 74
120
- 75
121
- 76
122
- 77
123
- 78
124
- 79
125
- 80
126
- 81
127
- 82
128
- 83
129
- 84
130
- 85
131
- 86
132
- 87
133
- 88
134
- 89
135
- 90
136
- 91
137
- 92
138
- 93
139
- 94
140
- 95
141
- 96
142
- 97
143
- 98
144
- 99
145
- 100
146
- 101
147
- 102
148
- 103
149
- 104
150
- 105
151
- 106
152
- 107
153
- 108
154
- 109
155
- 110
156
- 111
157
- 112
158
- 113
159
- 114
160
- 115
161
- 116
162
- 117
163
- 118
164
- 119
165
- 120
166
- 121
167
- 122
168
- 123
169
- 124
170
- 125
171
- 126
172
- 127
173
- 128
174
- 129
175
- 130
176
- 131
177
- 132
178
- 133
179
- 134
180
- 135
181
- 136
182
- 137
183
- 138
184
- 139
185
- 140
186
- 141
187
- 142
188
- 143
189
- 144
190
- 145
191
- 146
192
- 147
193
- 148
194
- 149
195
- 150
196
- 151
197
- 152
198
- 153
199
- 154
200
- 155
201
- 156
202
- 157
203
- 158
204
- 159
205
- 160
206
- 161
207
- 162
208
- 163
209
- 164
210
- 165
211
- 166
212
- 167
213
- 168
214
- 169
215
- 170
216
- 171
217
- 172
218
- 173
219
- 174
220
- 175
221
- 176
222
- 177
223
- 178
224
- 179
225
- 180
226
- 181
227
- 182
228
- 183
229
- 184
230
- 185
231
- 186
232
- 187
233
- 188
234
- 189
235
- 190
236
- 191
237
- 192
238
- 193
239
- 194
240
- 195
241
- 196
242
- 197
243
- 198
244
- 199
245
- 200
246
- 201
247
- 202
248
- 203
249
- 204
250
- 205
251
- 206
252
- 207
253
- 208
254
- 209
255
- 210
256
- 211
257
- 212
258
- 213
259
- 214
260
- 215
261
- 216
262
- 217
263
- 218
264
- 219
265
- 220
266
- 221
267
- 222
268
- 223
269
- 224
270
- 225
271
- 226
272
- 227
273
- 228
274
- 229
275
- 230
276
- 231
277
- 232
278
- 233
279
- 234
280
- 235
281
- 236
282
- 237
283
- 238
284
- 239
285
- 240
286
- 241
287
- 242
288
- 243
289
- 244
290
- 245
291
- 246
292
- 247
293
- 248
294
- 249
295
- 250
296
- 251
297
- 252
298
- 253
299
- 254
300
- 255
301
- 256
302
- 257
303
- 258
304
- 259
305
- 260
306
- 261
307
- 262
308
- 263
309
- 264
310
- 265
311
- 266
312
- 267
313
- 268
314
- 269
315
- 270
316
- 271
317
- 272
318
- 273
319
- 274
320
- 275
321
- 276
322
- 277
323
- 278
324
- 279
325
- 280
326
- 281
327
- 282
328
- 283
329
- 284
330
- 285
331
- 286
332
- 287
333
- 288
334
- 289
335
- 290
336
- 291
337
- 292
338
- 293
339
- 294
340
- 295
341
- 296
342
- 297
343
- 298
344
- 299
345
- 300
346
- 301
347
- 302
348
- 303
349
- 304
350
- 305
351
- 306
352
- 307
353
- 308
354
- 309
355
- 310
356
- 311
357
- 312
358
- 313
359
- 314
360
- 315
361
- 316
362
- 317
363
- 318
364
- 319
365
- 320
366
- 321
367
- 322
368
- 323
369
- 324
370
- 325
371
- 326
372
- 327
373
- 328
374
- 329
375
- 330
376
- 331
377
- 332
378
- 333
379
- 334
380
- 335
381
- 336
382
- 337
383
- 338
384
- 339
385
- 340
386
- 341
387
- 342
388
- 343
389
- 344
390
- 345
391
- 346
392
- 347
393
- 348
394
- 349
395
- 350
396
- 351
397
- 352
398
- 353
399
- 354
400
- 355
401
- 356
402
- 357
403
- 358
404
- 359
405
- 360
406
- 361
407
- 362
408
- 363
409
- 364
410
- 365
411
- 366
412
- 367
413
- 368
414
- 369
415
- 370
416
- 371
417
- 372
418
- 373
419
- 374
420
- 375
421
- 376
422
- 377
423
- 378
424
- 379
425
- 380
426
- 381
427
- 382
428
- 383
429
- 384
430
- 385
431
- 386
432
- 387
433
- 388
434
- 389
435
- 390
436
- 391
437
- 392
438
- 393
439
- 394
440
- 395
441
- 396
442
- 397
443
- 398
444
- 399
445
- 400
446
- 401
447
- 402
448
- 403
449
- 404
450
- 405
451
- 406
452
- 407
453
- 408
454
- 409
455
- 410
456
- 411
457
- 412
458
- 413
459
- 414
460
- 415
461
- 416
462
- 417
463
- 418
464
- 419
465
- 420
466
- 421
467
- 422
468
- 423
469
- 424
470
- 425
471
- 426
472
- 427
473
- 428
474
- 429</td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
475
- <span class="cline-any cline-yes">1x</span>
476
- <span class="cline-any cline-yes">1x</span>
477
- <span class="cline-any cline-neutral">&nbsp;</span>
478
- <span class="cline-any cline-yes">1065x</span>
479
- <span class="cline-any cline-yes">704x</span>
480
- <span class="cline-any cline-yes">704x</span>
481
- <span class="cline-any cline-yes">361x</span>
482
- <span class="cline-any cline-no">&nbsp;</span>
483
- <span class="cline-any cline-neutral">&nbsp;</span>
484
- <span class="cline-any cline-yes">361x</span>
485
- <span class="cline-any cline-no">&nbsp;</span>
486
- <span class="cline-any cline-neutral">&nbsp;</span>
487
- <span class="cline-any cline-neutral">&nbsp;</span>
488
- <span class="cline-any cline-neutral">&nbsp;</span>
489
- <span class="cline-any cline-neutral">&nbsp;</span>
490
- <span class="cline-any cline-neutral">&nbsp;</span>
491
- <span class="cline-any cline-neutral">&nbsp;</span>
492
- <span class="cline-any cline-neutral">&nbsp;</span>
493
- <span class="cline-any cline-neutral">&nbsp;</span>
494
- <span class="cline-any cline-yes">1x</span>
495
- <span class="cline-any cline-no">&nbsp;</span>
496
- <span class="cline-any cline-neutral">&nbsp;</span>
497
- <span class="cline-any cline-neutral">&nbsp;</span>
498
- <span class="cline-any cline-neutral">&nbsp;</span>
499
- <span class="cline-any cline-neutral">&nbsp;</span>
500
- <span class="cline-any cline-neutral">&nbsp;</span>
501
- <span class="cline-any cline-neutral">&nbsp;</span>
502
- <span class="cline-any cline-neutral">&nbsp;</span>
503
- <span class="cline-any cline-yes">1x</span>
504
- <span class="cline-any cline-neutral">&nbsp;</span>
505
- <span class="cline-any cline-yes">1x</span>
506
- <span class="cline-any cline-neutral">&nbsp;</span>
507
- <span class="cline-any cline-neutral">&nbsp;</span>
508
- <span class="cline-any cline-neutral">&nbsp;</span>
509
- <span class="cline-any cline-neutral">&nbsp;</span>
510
- <span class="cline-any cline-yes">1x</span>
511
- <span class="cline-any cline-yes">520x</span>
512
- <span class="cline-any cline-neutral">&nbsp;</span>
513
- <span class="cline-any cline-neutral">&nbsp;</span>
514
- <span class="cline-any cline-neutral">&nbsp;</span>
515
- <span class="cline-any cline-neutral">&nbsp;</span>
516
- <span class="cline-any cline-yes">1x</span>
517
- <span class="cline-any cline-yes">200x</span>
518
- <span class="cline-any cline-neutral">&nbsp;</span>
519
- <span class="cline-any cline-neutral">&nbsp;</span>
520
- <span class="cline-any cline-neutral">&nbsp;</span>
521
- <span class="cline-any cline-neutral">&nbsp;</span>
522
- <span class="cline-any cline-neutral">&nbsp;</span>
523
- <span class="cline-any cline-neutral">&nbsp;</span>
524
- <span class="cline-any cline-neutral">&nbsp;</span>
525
- <span class="cline-any cline-yes">1x</span>
526
- <span class="cline-any cline-yes">171x</span>
527
- <span class="cline-any cline-neutral">&nbsp;</span>
528
- <span class="cline-any cline-yes">171x</span>
529
- <span class="cline-any cline-yes">170x</span>
530
- <span class="cline-any cline-neutral">&nbsp;</span>
531
- <span class="cline-any cline-neutral">&nbsp;</span>
532
- <span class="cline-any cline-yes">1x</span>
533
- <span class="cline-any cline-neutral">&nbsp;</span>
534
- <span class="cline-any cline-neutral">&nbsp;</span>
535
- <span class="cline-any cline-neutral">&nbsp;</span>
536
- <span class="cline-any cline-neutral">&nbsp;</span>
537
- <span class="cline-any cline-neutral">&nbsp;</span>
538
- <span class="cline-any cline-neutral">&nbsp;</span>
539
- <span class="cline-any cline-neutral">&nbsp;</span>
540
- <span class="cline-any cline-yes">1x</span>
541
- <span class="cline-any cline-yes">176x</span>
542
- <span class="cline-any cline-yes">176x</span>
543
- <span class="cline-any cline-yes">176x</span>
544
- <span class="cline-any cline-neutral">&nbsp;</span>
545
- <span class="cline-any cline-no">&nbsp;</span>
546
- <span class="cline-any cline-neutral">&nbsp;</span>
547
- <span class="cline-any cline-no">&nbsp;</span>
548
- <span class="cline-any cline-neutral">&nbsp;</span>
549
- <span class="cline-any cline-neutral">&nbsp;</span>
550
- <span class="cline-any cline-neutral">&nbsp;</span>
551
- <span class="cline-any cline-neutral">&nbsp;</span>
552
- <span class="cline-any cline-neutral">&nbsp;</span>
553
- <span class="cline-any cline-neutral">&nbsp;</span>
554
- <span class="cline-any cline-neutral">&nbsp;</span>
555
- <span class="cline-any cline-neutral">&nbsp;</span>
556
- <span class="cline-any cline-neutral">&nbsp;</span>
557
- <span class="cline-any cline-yes">1x</span>
558
- <span class="cline-any cline-yes">1x</span>
559
- <span class="cline-any cline-no">&nbsp;</span>
560
- <span class="cline-any cline-neutral">&nbsp;</span>
561
- <span class="cline-any cline-yes">1x</span>
562
- <span class="cline-any cline-neutral">&nbsp;</span>
563
- <span class="cline-any cline-neutral">&nbsp;</span>
564
- <span class="cline-any cline-neutral">&nbsp;</span>
565
- <span class="cline-any cline-neutral">&nbsp;</span>
566
- <span class="cline-any cline-neutral">&nbsp;</span>
567
- <span class="cline-any cline-yes">1x</span>
568
- <span class="cline-any cline-yes">13x</span>
569
- <span class="cline-any cline-neutral">&nbsp;</span>
570
- <span class="cline-any cline-neutral">&nbsp;</span>
571
- <span class="cline-any cline-yes">13x</span>
572
- <span class="cline-any cline-no">&nbsp;</span>
573
- <span class="cline-any cline-neutral">&nbsp;</span>
574
- <span class="cline-any cline-yes">13x</span>
575
- <span class="cline-any cline-neutral">&nbsp;</span>
576
- <span class="cline-any cline-neutral">&nbsp;</span>
577
- <span class="cline-any cline-neutral">&nbsp;</span>
578
- <span class="cline-any cline-neutral">&nbsp;</span>
579
- <span class="cline-any cline-neutral">&nbsp;</span>
580
- <span class="cline-any cline-neutral">&nbsp;</span>
581
- <span class="cline-any cline-neutral">&nbsp;</span>
582
- <span class="cline-any cline-yes">1x</span>
583
- <span class="cline-any cline-yes">18x</span>
584
- <span class="cline-any cline-yes">18x</span>
585
- <span class="cline-any cline-no">&nbsp;</span>
586
- <span class="cline-any cline-neutral">&nbsp;</span>
587
- <span class="cline-any cline-yes">18x</span>
588
- <span class="cline-any cline-neutral">&nbsp;</span>
589
- <span class="cline-any cline-neutral">&nbsp;</span>
590
- <span class="cline-any cline-neutral">&nbsp;</span>
591
- <span class="cline-any cline-neutral">&nbsp;</span>
592
- <span class="cline-any cline-yes">1x</span>
593
- <span class="cline-any cline-neutral">&nbsp;</span>
594
- <span class="cline-any cline-neutral">&nbsp;</span>
595
- <span class="cline-any cline-yes">1x</span>
596
- <span class="cline-any cline-yes">1x</span>
597
- <span class="cline-any cline-no">&nbsp;</span>
598
- <span class="cline-any cline-neutral">&nbsp;</span>
599
- <span class="cline-any cline-neutral">&nbsp;</span>
600
- <span class="cline-any cline-yes">1x</span>
601
- <span class="cline-any cline-no">&nbsp;</span>
602
- <span class="cline-any cline-neutral">&nbsp;</span>
603
- <span class="cline-any cline-yes">1x</span>
604
- <span class="cline-any cline-neutral">&nbsp;</span>
605
- <span class="cline-any cline-neutral">&nbsp;</span>
606
- <span class="cline-any cline-neutral">&nbsp;</span>
607
- <span class="cline-any cline-neutral">&nbsp;</span>
608
- <span class="cline-any cline-neutral">&nbsp;</span>
609
- <span class="cline-any cline-neutral">&nbsp;</span>
610
- <span class="cline-any cline-neutral">&nbsp;</span>
611
- <span class="cline-any cline-yes">1x</span>
612
- <span class="cline-any cline-neutral">&nbsp;</span>
613
- <span class="cline-any cline-neutral">&nbsp;</span>
614
- <span class="cline-any cline-neutral">&nbsp;</span>
615
- <span class="cline-any cline-yes">1x</span>
616
- <span class="cline-any cline-no">&nbsp;</span>
617
- <span class="cline-any cline-no">&nbsp;</span>
618
- <span class="cline-any cline-neutral">&nbsp;</span>
619
- <span class="cline-any cline-no">&nbsp;</span>
620
- <span class="cline-any cline-neutral">&nbsp;</span>
621
- <span class="cline-any cline-yes">1x</span>
622
- <span class="cline-any cline-no">&nbsp;</span>
623
- <span class="cline-any cline-neutral">&nbsp;</span>
624
- <span class="cline-any cline-yes">1x</span>
625
- <span class="cline-any cline-neutral">&nbsp;</span>
626
- <span class="cline-any cline-neutral">&nbsp;</span>
627
- <span class="cline-any cline-neutral">&nbsp;</span>
628
- <span class="cline-any cline-neutral">&nbsp;</span>
629
- <span class="cline-any cline-neutral">&nbsp;</span>
630
- <span class="cline-any cline-neutral">&nbsp;</span>
631
- <span class="cline-any cline-neutral">&nbsp;</span>
632
- <span class="cline-any cline-neutral">&nbsp;</span>
633
- <span class="cline-any cline-neutral">&nbsp;</span>
634
- <span class="cline-any cline-yes">1x</span>
635
- <span class="cline-any cline-yes">1x</span>
636
- <span class="cline-any cline-no">&nbsp;</span>
637
- <span class="cline-any cline-no">&nbsp;</span>
638
- <span class="cline-any cline-neutral">&nbsp;</span>
639
- <span class="cline-any cline-no">&nbsp;</span>
640
- <span class="cline-any cline-neutral">&nbsp;</span>
641
- <span class="cline-any cline-yes">1x</span>
642
- <span class="cline-any cline-no">&nbsp;</span>
643
- <span class="cline-any cline-neutral">&nbsp;</span>
644
- <span class="cline-any cline-yes">1x</span>
645
- <span class="cline-any cline-neutral">&nbsp;</span>
646
- <span class="cline-any cline-neutral">&nbsp;</span>
647
- <span class="cline-any cline-neutral">&nbsp;</span>
648
- <span class="cline-any cline-neutral">&nbsp;</span>
649
- <span class="cline-any cline-neutral">&nbsp;</span>
650
- <span class="cline-any cline-neutral">&nbsp;</span>
651
- <span class="cline-any cline-neutral">&nbsp;</span>
652
- <span class="cline-any cline-neutral">&nbsp;</span>
653
- <span class="cline-any cline-yes">1x</span>
654
- <span class="cline-any cline-yes">3x</span>
655
- <span class="cline-any cline-no">&nbsp;</span>
656
- <span class="cline-any cline-neutral">&nbsp;</span>
657
- <span class="cline-any cline-yes">3x</span>
658
- <span class="cline-any cline-neutral">&nbsp;</span>
659
- <span class="cline-any cline-no">&nbsp;</span>
660
- <span class="cline-any cline-neutral">&nbsp;</span>
661
- <span class="cline-any cline-yes">3x</span>
662
- <span class="cline-any cline-no">&nbsp;</span>
663
- <span class="cline-any cline-neutral">&nbsp;</span>
664
- <span class="cline-any cline-yes">3x</span>
665
- <span class="cline-any cline-neutral">&nbsp;</span>
666
- <span class="cline-any cline-neutral">&nbsp;</span>
667
- <span class="cline-any cline-neutral">&nbsp;</span>
668
- <span class="cline-any cline-neutral">&nbsp;</span>
669
- <span class="cline-any cline-neutral">&nbsp;</span>
670
- <span class="cline-any cline-neutral">&nbsp;</span>
671
- <span class="cline-any cline-neutral">&nbsp;</span>
672
- <span class="cline-any cline-neutral">&nbsp;</span>
673
- <span class="cline-any cline-yes">1x</span>
674
- <span class="cline-any cline-no">&nbsp;</span>
675
- <span class="cline-any cline-no">&nbsp;</span>
676
- <span class="cline-any cline-neutral">&nbsp;</span>
677
- <span class="cline-any cline-no">&nbsp;</span>
678
- <span class="cline-any cline-no">&nbsp;</span>
679
- <span class="cline-any cline-neutral">&nbsp;</span>
680
- <span class="cline-any cline-no">&nbsp;</span>
681
- <span class="cline-any cline-no">&nbsp;</span>
682
- <span class="cline-any cline-neutral">&nbsp;</span>
683
- <span class="cline-any cline-no">&nbsp;</span>
684
- <span class="cline-any cline-neutral">&nbsp;</span>
685
- <span class="cline-any cline-neutral">&nbsp;</span>
686
- <span class="cline-any cline-neutral">&nbsp;</span>
687
- <span class="cline-any cline-neutral">&nbsp;</span>
688
- <span class="cline-any cline-neutral">&nbsp;</span>
689
- <span class="cline-any cline-neutral">&nbsp;</span>
690
- <span class="cline-any cline-neutral">&nbsp;</span>
691
- <span class="cline-any cline-yes">1x</span>
692
- <span class="cline-any cline-yes">5x</span>
693
- <span class="cline-any cline-neutral">&nbsp;</span>
694
- <span class="cline-any cline-yes">5x</span>
695
- <span class="cline-any cline-no">&nbsp;</span>
696
- <span class="cline-any cline-neutral">&nbsp;</span>
697
- <span class="cline-any cline-neutral">&nbsp;</span>
698
- <span class="cline-any cline-yes">5x</span>
699
- <span class="cline-any cline-yes">5x</span>
700
- <span class="cline-any cline-neutral">&nbsp;</span>
701
- <span class="cline-any cline-neutral">&nbsp;</span>
702
- <span class="cline-any cline-no">&nbsp;</span>
703
- <span class="cline-any cline-no">&nbsp;</span>
704
- <span class="cline-any cline-neutral">&nbsp;</span>
705
- <span class="cline-any cline-neutral">&nbsp;</span>
706
- <span class="cline-any cline-no">&nbsp;</span>
707
- <span class="cline-any cline-no">&nbsp;</span>
708
- <span class="cline-any cline-no">&nbsp;</span>
709
- <span class="cline-any cline-no">&nbsp;</span>
710
- <span class="cline-any cline-neutral">&nbsp;</span>
711
- <span class="cline-any cline-no">&nbsp;</span>
712
- <span class="cline-any cline-neutral">&nbsp;</span>
713
- <span class="cline-any cline-neutral">&nbsp;</span>
714
- <span class="cline-any cline-neutral">&nbsp;</span>
715
- <span class="cline-any cline-neutral">&nbsp;</span>
716
- <span class="cline-any cline-neutral">&nbsp;</span>
717
- <span class="cline-any cline-neutral">&nbsp;</span>
718
- <span class="cline-any cline-neutral">&nbsp;</span>
719
- <span class="cline-any cline-neutral">&nbsp;</span>
720
- <span class="cline-any cline-neutral">&nbsp;</span>
721
- <span class="cline-any cline-neutral">&nbsp;</span>
722
- <span class="cline-any cline-yes">1x</span>
723
- <span class="cline-any cline-yes">176x</span>
724
- <span class="cline-any cline-neutral">&nbsp;</span>
725
- <span class="cline-any cline-yes">176x</span>
726
- <span class="cline-any cline-no">&nbsp;</span>
727
- <span class="cline-any cline-neutral">&nbsp;</span>
728
- <span class="cline-any cline-neutral">&nbsp;</span>
729
- <span class="cline-any cline-neutral">&nbsp;</span>
730
- <span class="cline-any cline-neutral">&nbsp;</span>
731
- <span class="cline-any cline-yes">176x</span>
732
- <span class="cline-any cline-no">&nbsp;</span>
733
- <span class="cline-any cline-neutral">&nbsp;</span>
734
- <span class="cline-any cline-neutral">&nbsp;</span>
735
- <span class="cline-any cline-neutral">&nbsp;</span>
736
- <span class="cline-any cline-yes">176x</span>
737
- <span class="cline-any cline-yes">176x</span>
738
- <span class="cline-any cline-yes">176x</span>
739
- <span class="cline-any cline-no">&nbsp;</span>
740
- <span class="cline-any cline-neutral">&nbsp;</span>
741
- <span class="cline-any cline-yes">176x</span>
742
- <span class="cline-any cline-neutral">&nbsp;</span>
743
- <span class="cline-any cline-neutral">&nbsp;</span>
744
- <span class="cline-any cline-neutral">&nbsp;</span>
745
- <span class="cline-any cline-neutral">&nbsp;</span>
746
- <span class="cline-any cline-neutral">&nbsp;</span>
747
- <span class="cline-any cline-neutral">&nbsp;</span>
748
- <span class="cline-any cline-yes">1x</span>
749
- <span class="cline-any cline-neutral">&nbsp;</span>
750
- <span class="cline-any cline-neutral">&nbsp;</span>
751
- <span class="cline-any cline-neutral">&nbsp;</span>
752
- <span class="cline-any cline-neutral">&nbsp;</span>
753
- <span class="cline-any cline-no">&nbsp;</span>
754
- <span class="cline-any cline-no">&nbsp;</span>
755
- <span class="cline-any cline-neutral">&nbsp;</span>
756
- <span class="cline-any cline-no">&nbsp;</span>
757
- <span class="cline-any cline-no">&nbsp;</span>
758
- <span class="cline-any cline-neutral">&nbsp;</span>
759
- <span class="cline-any cline-neutral">&nbsp;</span>
760
- <span class="cline-any cline-no">&nbsp;</span>
761
- <span class="cline-any cline-no">&nbsp;</span>
762
- <span class="cline-any cline-neutral">&nbsp;</span>
763
- <span class="cline-any cline-no">&nbsp;</span>
764
- <span class="cline-any cline-neutral">&nbsp;</span>
765
- <span class="cline-any cline-no">&nbsp;</span>
766
- <span class="cline-any cline-neutral">&nbsp;</span>
767
- <span class="cline-any cline-no">&nbsp;</span>
768
- <span class="cline-any cline-no">&nbsp;</span>
769
- <span class="cline-any cline-neutral">&nbsp;</span>
770
- <span class="cline-any cline-neutral">&nbsp;</span>
771
- <span class="cline-any cline-neutral">&nbsp;</span>
772
- <span class="cline-any cline-neutral">&nbsp;</span>
773
- <span class="cline-any cline-no">&nbsp;</span>
774
- <span class="cline-any cline-no">&nbsp;</span>
775
- <span class="cline-any cline-neutral">&nbsp;</span>
776
- <span class="cline-any cline-neutral">&nbsp;</span>
777
- <span class="cline-any cline-neutral">&nbsp;</span>
778
- <span class="cline-any cline-no">&nbsp;</span>
779
- <span class="cline-any cline-no">&nbsp;</span>
780
- <span class="cline-any cline-no">&nbsp;</span>
781
- <span class="cline-any cline-no">&nbsp;</span>
782
- <span class="cline-any cline-neutral">&nbsp;</span>
783
- <span class="cline-any cline-no">&nbsp;</span>
784
- <span class="cline-any cline-neutral">&nbsp;</span>
785
- <span class="cline-any cline-neutral">&nbsp;</span>
786
- <span class="cline-any cline-neutral">&nbsp;</span>
787
- <span class="cline-any cline-neutral">&nbsp;</span>
788
- <span class="cline-any cline-neutral">&nbsp;</span>
789
- <span class="cline-any cline-neutral">&nbsp;</span>
790
- <span class="cline-any cline-neutral">&nbsp;</span>
791
- <span class="cline-any cline-neutral">&nbsp;</span>
792
- <span class="cline-any cline-yes">1x</span>
793
- <span class="cline-any cline-neutral">&nbsp;</span>
794
- <span class="cline-any cline-neutral">&nbsp;</span>
795
- <span class="cline-any cline-neutral">&nbsp;</span>
796
- <span class="cline-any cline-neutral">&nbsp;</span>
797
- <span class="cline-any cline-no">&nbsp;</span>
798
- <span class="cline-any cline-no">&nbsp;</span>
799
- <span class="cline-any cline-neutral">&nbsp;</span>
800
- <span class="cline-any cline-no">&nbsp;</span>
801
- <span class="cline-any cline-no">&nbsp;</span>
802
- <span class="cline-any cline-neutral">&nbsp;</span>
803
- <span class="cline-any cline-neutral">&nbsp;</span>
804
- <span class="cline-any cline-neutral">&nbsp;</span>
805
- <span class="cline-any cline-no">&nbsp;</span>
806
- <span class="cline-any cline-no">&nbsp;</span>
807
- <span class="cline-any cline-neutral">&nbsp;</span>
808
- <span class="cline-any cline-no">&nbsp;</span>
809
- <span class="cline-any cline-neutral">&nbsp;</span>
810
- <span class="cline-any cline-no">&nbsp;</span>
811
- <span class="cline-any cline-neutral">&nbsp;</span>
812
- <span class="cline-any cline-no">&nbsp;</span>
813
- <span class="cline-any cline-no">&nbsp;</span>
814
- <span class="cline-any cline-neutral">&nbsp;</span>
815
- <span class="cline-any cline-neutral">&nbsp;</span>
816
- <span class="cline-any cline-neutral">&nbsp;</span>
817
- <span class="cline-any cline-neutral">&nbsp;</span>
818
- <span class="cline-any cline-neutral">&nbsp;</span>
819
- <span class="cline-any cline-no">&nbsp;</span>
820
- <span class="cline-any cline-no">&nbsp;</span>
821
- <span class="cline-any cline-neutral">&nbsp;</span>
822
- <span class="cline-any cline-neutral">&nbsp;</span>
823
- <span class="cline-any cline-no">&nbsp;</span>
824
- <span class="cline-any cline-neutral">&nbsp;</span>
825
- <span class="cline-any cline-neutral">&nbsp;</span>
826
- <span class="cline-any cline-neutral">&nbsp;</span>
827
- <span class="cline-any cline-neutral">&nbsp;</span>
828
- <span class="cline-any cline-neutral">&nbsp;</span>
829
- <span class="cline-any cline-neutral">&nbsp;</span>
830
- <span class="cline-any cline-yes">169x</span>
831
- <span class="cline-any cline-yes">169x</span>
832
- <span class="cline-any cline-no">&nbsp;</span>
833
- <span class="cline-any cline-neutral">&nbsp;</span>
834
- <span class="cline-any cline-yes">169x</span>
835
- <span class="cline-any cline-no">&nbsp;</span>
836
- <span class="cline-any cline-neutral">&nbsp;</span>
837
- <span class="cline-any cline-neutral">&nbsp;</span>
838
- <span class="cline-any cline-yes">169x</span>
839
- <span class="cline-any cline-neutral">&nbsp;</span>
840
- <span class="cline-any cline-neutral">&nbsp;</span>
841
- <span class="cline-any cline-neutral">&nbsp;</span>
842
- <span class="cline-any cline-neutral">&nbsp;</span>
843
- <span class="cline-any cline-neutral">&nbsp;</span>
844
- <span class="cline-any cline-neutral">&nbsp;</span>
845
- <span class="cline-any cline-yes">1x</span>
846
- <span class="cline-any cline-yes">2x</span>
847
- <span class="cline-any cline-neutral">&nbsp;</span>
848
- <span class="cline-any cline-neutral">&nbsp;</span>
849
- <span class="cline-any cline-yes">1x</span>
850
- <span class="cline-any cline-yes">2x</span>
851
- <span class="cline-any cline-neutral">&nbsp;</span>
852
- <span class="cline-any cline-neutral">&nbsp;</span>
853
- <span class="cline-any cline-yes">1x</span>
854
- <span class="cline-any cline-no">&nbsp;</span>
855
- <span class="cline-any cline-no">&nbsp;</span>
856
- <span class="cline-any cline-no">&nbsp;</span>
857
- <span class="cline-any cline-neutral">&nbsp;</span>
858
- <span class="cline-any cline-no">&nbsp;</span>
859
- <span class="cline-any cline-neutral">&nbsp;</span>
860
- <span class="cline-any cline-neutral">&nbsp;</span>
861
- <span class="cline-any cline-neutral">&nbsp;</span>
862
- <span class="cline-any cline-neutral">&nbsp;</span>
863
- <span class="cline-any cline-neutral">&nbsp;</span>
864
- <span class="cline-any cline-neutral">&nbsp;</span>
865
- <span class="cline-any cline-neutral">&nbsp;</span>
866
- <span class="cline-any cline-neutral">&nbsp;</span>
867
- <span class="cline-any cline-yes">1x</span>
868
- <span class="cline-any cline-neutral">&nbsp;</span>
869
- <span class="cline-any cline-yes">338x</span>
870
- <span class="cline-any cline-yes">338x</span>
871
- <span class="cline-any cline-yes">338x</span>
872
- <span class="cline-any cline-no">&nbsp;</span>
873
- <span class="cline-any cline-neutral">&nbsp;</span>
874
- <span class="cline-any cline-yes">338x</span>
875
- <span class="cline-any cline-no">&nbsp;</span>
876
- <span class="cline-any cline-neutral">&nbsp;</span>
877
- <span class="cline-any cline-yes">338x</span>
878
- <span class="cline-any cline-yes">253x</span>
879
- <span class="cline-any cline-neutral">&nbsp;</span>
880
- <span class="cline-any cline-yes">85x</span>
881
- <span class="cline-any cline-neutral">&nbsp;</span>
882
- <span class="cline-any cline-neutral">&nbsp;</span>
883
- <span class="cline-any cline-neutral">&nbsp;</span>
884
- <span class="cline-any cline-neutral">&nbsp;</span>
885
- <span class="cline-any cline-neutral">&nbsp;</span>
886
- <span class="cline-any cline-neutral">&nbsp;</span>
887
- <span class="cline-any cline-neutral">&nbsp;</span>
888
- <span class="cline-any cline-neutral">&nbsp;</span>
889
- <span class="cline-any cline-neutral">&nbsp;</span>
890
- <span class="cline-any cline-yes">1x</span>
891
- <span class="cline-any cline-yes">338x</span>
892
- <span class="cline-any cline-yes">338x</span>
893
- <span class="cline-any cline-yes">338x</span>
894
- <span class="cline-any cline-yes">338x</span>
895
- <span class="cline-any cline-yes">253x</span>
896
- <span class="cline-any cline-neutral">&nbsp;</span>
897
- <span class="cline-any cline-neutral">&nbsp;</span>
898
- <span class="cline-any cline-neutral">&nbsp;</span>
899
- <span class="cline-any cline-yes">85x</span>
900
- <span class="cline-any cline-neutral">&nbsp;</span>
901
- <span class="cline-any cline-neutral">&nbsp;</span>
902
- <span class="cline-any cline-yes">1x</span></td><td class="text"><pre class="prettyprint lang-js">import {Interval} from "./Interval";
903
- import {S2} from "./S2";
904
- export class S1Interval extends Interval {
905
- &nbsp;
906
- constructor(lo:number|decimal.Decimal, hi:number|decimal.Decimal, checked:boolean = false) {
907
- super(lo, hi);
908
- if (!checked) {
909
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.lo.eq(-S2.M_PI) &amp;&amp; <span class="branch-1 cbranch-no" title="branch not covered" >!this.hi.eq(S2.M_PI))</span> {
910
- <span class="cstat-no" title="statement not covered" > this.lo = S2.toDecimal(S2.M_PI);</span>
911
- }
912
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.hi.eq(-S2.M_PI) &amp;&amp; <span class="branch-1 cbranch-no" title="branch not covered" >!this.lo.eq(S2.M_PI))</span> {
913
- <span class="cstat-no" title="statement not covered" > this.hi = S2.toDecimal(S2.M_PI);</span>
914
- }
915
- }
916
- }
917
- &nbsp;
918
- /**
919
- * An interval is valid if neither bound exceeds Pi in absolute value, and the
920
- * value -Pi appears only in the Empty() and Full() intervals.
921
- */
922
- <span class="fstat-no" title="function not covered" > isValid():boolean {</span>
923
- <span class="cstat-no" title="statement not covered" > return this.lo.abs().lte(S2.M_PI) &amp;&amp; this.hi.abs().lte(S2.M_PI)</span>
924
- &amp;&amp; !(this.lo.eq(-S2.M_PI) &amp;&amp; !this.hi.eq(S2.M_PI))
925
- &amp;&amp; !(this.hi.eq(-S2.M_PI) &amp;&amp; !this.lo.eq(S2.M_PI));
926
- // return (Math.abs(this.lo) &lt;= S2.M_PI &amp;&amp; Math.abs(this.hi) &lt;= S2.M_PI
927
- // &amp;&amp; !(this.lo == -S2.M_PI &amp;&amp; this.hi != S2.M_PI) &amp;&amp; !(this.hi == -S2.M_PI &amp;&amp; this.lo != S2.M_PI));
928
- }
929
- &nbsp;
930
- /** Return true if the interval contains all points on the unit circle. */
931
- isFull() {
932
- // console.log(this.hi.minus(this.lo).eq(2 * S2.M_PI));
933
- return this.hi.minus(this.lo).eq(2 * S2.M_PI)
934
- }
935
- &nbsp;
936
- &nbsp;
937
- /** Return true if the interval is empty, i.e. it contains no points. */
938
- public isEmpty() {
939
- return this.lo.minus(this.hi).eq(2 * S2.M_PI);
940
- }
941
- &nbsp;
942
- &nbsp;
943
- /* Return true if this.lo &gt; this.hi. (This is true for empty intervals.) */
944
- public isInverted():boolean {
945
- return this.lo.gt(this.hi);
946
- }
947
- &nbsp;
948
- &nbsp;
949
- /**
950
- * Return the midpoint of the interval. For full and empty intervals, the
951
- * result is arbitrary.
952
- */
953
- public getCenter():decimal.Decimal {
954
- let center = this.lo.plus(this.hi).dividedBy(2);
955
- // let center = 0.5 * (this.lo + this.hi);
956
- if (!this.isInverted()) {
957
- return center;
958
- }
959
- // Return the center in the range (-Pi, Pi].
960
- return (center.lte(0)) ? (center.plus(S2.M_PI)) : (<span class="branch-1 cbranch-no" title="branch not covered" >center.minus(S2.M_PI))</span>;
961
- }
962
- &nbsp;
963
- &nbsp;
964
- /**
965
- * Return the length of the interval. The length of an empty interval is
966
- * negative.
967
- */
968
- public getLength():decimal.Decimal {
969
- let length = this.hi.minus(this.lo);
970
- <span class="missing-if-branch" title="else path not taken" >E</span>if (length.gte(0)) {
971
- return length;
972
- }
973
- <span class="cstat-no" title="statement not covered" > length = length.plus(2 * S2.M_PI);</span>
974
- // Empty intervals have a negative length.
975
- <span class="cstat-no" title="statement not covered" > return (length.gt(0)) ? length : S2.toDecimal(-1);</span>
976
- }
977
- &nbsp;
978
- /**
979
- * Return the complement of the interior of the interval. An interval and its
980
- * complement have the same boundary but do not share any interior values. The
981
- * complement operator is not a bijection, since the complement of a singleton
982
- * interval (containing a single value) is the same as the complement of an
983
- * empty interval.
984
- */
985
- public complement():S1Interval {
986
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.lo.eq(this.hi)) {
987
- <span class="cstat-no" title="statement not covered" > return S1Interval.full(); </span>// Singleton.
988
- }
989
- return new S1Interval(this.hi, this.lo, true); // Handles
990
- // empty and
991
- // full.
992
- }
993
- &nbsp;
994
- /** Return true if the interval (which is closed) contains the point 'p'. */
995
- public contains(_p:number|decimal.Decimal):boolean {
996
- let p = S2.toDecimal(_p);
997
- // Works for empty, full, and singleton intervals.
998
- // assert (Math.abs(p) &lt;= S2.M_PI);
999
- <span class="missing-if-branch" title="if path not taken" >I</span>if (p.eq(-S2.M_PI)) {
1000
- <span class="cstat-no" title="statement not covered" > p = S2.toDecimal(S2.M_PI);</span>
1001
- }
1002
- return this.fastContains(p);
1003
- }
1004
- &nbsp;
1005
- /**
1006
- * Return true if the interval (which is closed) contains the point 'p'. Skips
1007
- * the normalization of 'p' from -Pi to Pi.
1008
- *
1009
- */
1010
- public fastContains(_p:number|decimal.Decimal):boolean {
1011
- const p = S2.toDecimal(_p);
1012
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isInverted()) {
1013
- <span class="cstat-no" title="statement not covered" > return (p.gte(this.lo) || p.lte(this.hi)) &amp;&amp; !this.isEmpty();</span>
1014
- } else {
1015
- return p.gte(this.lo) &amp;&amp; p.lte(this.hi);
1016
- }
1017
- }
1018
- &nbsp;
1019
- /** Return true if the interior of the interval contains the point 'p'. */
1020
- public interiorContains(_p:number|decimal.Decimal):boolean {
1021
- // Works for empty, full, and singleton intervals.
1022
- // assert (Math.abs(p) &lt;= S2.M_PI);
1023
- let p = S2.toDecimal(_p);
1024
- <span class="missing-if-branch" title="if path not taken" >I</span>if (p.eq(-S2.M_PI)) {
1025
- <span class="cstat-no" title="statement not covered" > p = S2.toDecimal(S2.M_PI);</span>
1026
- }
1027
- &nbsp;
1028
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isInverted()) {
1029
- <span class="cstat-no" title="statement not covered" > return p.gt(this.lo) || p.lt(this.hi);</span>
1030
- } else {
1031
- return (p.gt(this.lo) &amp;&amp; p.lt(this.hi)) || <span class="branch-2 cbranch-no" title="branch not covered" >this.isFull();</span>
1032
- }
1033
- }
1034
- &nbsp;
1035
- /**
1036
- * Return true if the interval contains the given interval 'y'. Works for
1037
- * empty, full, and singleton intervals.
1038
- */
1039
- public containsI(y:S1Interval):boolean {
1040
- // It might be helpful to compare the structure of these tests to
1041
- // the simpler Contains(number) method above.
1042
- &nbsp;
1043
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isInverted()) {
1044
- <span class="cstat-no" title="statement not covered" > if (y.isInverted()) {</span>
1045
- <span class="cstat-no" title="statement not covered" > return y.lo.gte(this.lo) &amp;&amp; y.hi.lte(this.hi);</span>
1046
- }
1047
- <span class="cstat-no" title="statement not covered" > return (y.lo.gte(this.lo) || y.hi.lte(this.hi)) &amp;&amp; !this.isEmpty();</span>
1048
- } else {
1049
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isInverted()) {
1050
- <span class="cstat-no" title="statement not covered" > return this.isFull() || y.isEmpty();</span>
1051
- }
1052
- return y.lo.gte(this.lo) &amp;&amp; y.hi.lte(this.hi);
1053
- }
1054
- }
1055
- &nbsp;
1056
- /**
1057
- * Returns true if the interior of this interval contains the entire interval
1058
- * 'y'. Note that x.InteriorContains(x) is true only when x is the empty or
1059
- * full interval, and x.InteriorContains(S1Interval(p,p)) is equivalent to
1060
- * x.InteriorContains(p).
1061
- */
1062
- public interiorContainsI(y:S1Interval):boolean {
1063
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isInverted()) {
1064
- <span class="cstat-no" title="statement not covered" > if (!y.isInverted()) {</span>
1065
- <span class="cstat-no" title="statement not covered" > return this.lo.gt(this.lo) || y.hi.lt(this.hi);</span>
1066
- }
1067
- <span class="cstat-no" title="statement not covered" > return (y.lo.gt(this.lo) &amp;&amp; y.hi.lt(this.hi)) || y.isEmpty();</span>
1068
- } else {
1069
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isInverted()) {
1070
- <span class="cstat-no" title="statement not covered" > return this.isFull() || y.isEmpty();</span>
1071
- }
1072
- return (y.lo.gt(this.lo) &amp;&amp; y.hi.lt(this.hi)) || <span class="branch-2 cbranch-no" title="branch not covered" >this.isFull();</span>
1073
- }
1074
- }
1075
- &nbsp;
1076
- /**
1077
- * Return true if the two intervals contain any points in common. Note that
1078
- * the point +/-Pi has two representations, so the intervals [-Pi,-3] and
1079
- * [2,Pi] intersect, for example.
1080
- */
1081
- public intersects(y:S1Interval):boolean {
1082
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isEmpty() || y.isEmpty()) {
1083
- <span class="cstat-no" title="statement not covered" > return false;</span>
1084
- }
1085
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isInverted()) {
1086
- // Every non-empty inverted interval contains Pi.
1087
- <span class="cstat-no" title="statement not covered" > return y.isInverted() || y.lo.lte(this.hi) || y.hi.gte(this.lo);</span>
1088
- } else {
1089
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isInverted()) {
1090
- <span class="cstat-no" title="statement not covered" > return y.lo.lte(this.hi) || y.hi.gte(this.lo);</span>
1091
- }
1092
- return y.lo.lte(this.hi) &amp;&amp; y.hi.gte(this.lo);
1093
- }
1094
- }
1095
- &nbsp;
1096
- /**
1097
- * Return true if the interior of this interval contains any point of the
1098
- * interval 'y' (including its boundary). Works for empty, full, and singleton
1099
- * intervals.
1100
- */
1101
- <span class="fstat-no" title="function not covered" > public interiorIntersects(</span>y:S1Interval):boolean {
1102
- <span class="cstat-no" title="statement not covered" > if (this.isEmpty() || y.isEmpty() || this.lo.eq(this.hi)) {</span>
1103
- <span class="cstat-no" title="statement not covered" > return false;</span>
1104
- }
1105
- <span class="cstat-no" title="statement not covered" > if (this.isInverted()) {</span>
1106
- <span class="cstat-no" title="statement not covered" > return y.isInverted() || y.lo.lt(this.hi) || y.hi.gt(this.lo);</span>
1107
- } else {
1108
- <span class="cstat-no" title="statement not covered" > if (y.isInverted()) {</span>
1109
- <span class="cstat-no" title="statement not covered" > return y.lo.lt(this.hi) || y.hi.gt(this.lo);</span>
1110
- }
1111
- <span class="cstat-no" title="statement not covered" > return (y.lo.lt(this.hi) &amp;&amp; y.hi.gt(this.lo)) || this.isFull();</span>
1112
- }
1113
- }
1114
- &nbsp;
1115
- /**
1116
- * Expand the interval by the minimum amount necessary so that it contains the
1117
- * given point "p" (an angle in the range [-Pi, Pi]).
1118
- */
1119
- public addPoint(_p:number|decimal.Decimal):S1Interval {
1120
- let p = S2.toDecimal(_p);
1121
- // assert (Math.abs(p) &lt;= S2.M_PI);
1122
- <span class="missing-if-branch" title="if path not taken" >I</span>if (p.eq(-S2.M_PI)) {
1123
- <span class="cstat-no" title="statement not covered" > p = S2.toDecimal(S2.M_PI);</span>
1124
- }
1125
- &nbsp;
1126
- <span class="missing-if-branch" title="else path not taken" >E</span>if (this.fastContains(p)) {
1127
- return new S1Interval(this.lo, this.hi);
1128
- }
1129
- &nbsp;
1130
- <span class="cstat-no" title="statement not covered" > if (this.isEmpty()) {</span>
1131
- <span class="cstat-no" title="statement not covered" > return S1Interval.fromPoint(p);</span>
1132
- } else {
1133
- // Compute distance from p to each endpoint.
1134
- let dlo = <span class="cstat-no" title="statement not covered" >S1Interval.positiveDistance(p, this.lo);</span>
1135
- let dhi = <span class="cstat-no" title="statement not covered" >S1Interval.positiveDistance(this.hi, p);</span>
1136
- <span class="cstat-no" title="statement not covered" > if (dlo.lt(dhi)) {</span>
1137
- <span class="cstat-no" title="statement not covered" > return new S1Interval(p, this.hi);</span>
1138
- } else {
1139
- <span class="cstat-no" title="statement not covered" > return new S1Interval(this.lo, p);</span>
1140
- }
1141
- // Adding a point can never turn a non-full interval into a full one.
1142
- }
1143
- }
1144
- &nbsp;
1145
- /**
1146
- * Return an interval that contains all points within a distance "radius" of
1147
- * a point in this interval. Note that the expansion of an empty interval is
1148
- * always empty. The radius must be non-negative.
1149
- */
1150
- public expanded(_radius:number|decimal.Decimal):S1Interval {
1151
- const radius = S2.toDecimal(_radius);
1152
- // assert (radius &gt;= 0);
1153
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isEmpty()) {
1154
- <span class="cstat-no" title="statement not covered" > return this;</span>
1155
- }
1156
- &nbsp;
1157
- // Check whether this interval will be full after expansion, allowing
1158
- // for a 1-bit rounding error when computing each endpoint.
1159
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.getLength().plus(radius.times(2)).gte(2*S2.M_PI-1e-15)) {
1160
- <span class="cstat-no" title="statement not covered" > return S1Interval.full();</span>
1161
- }
1162
- &nbsp;
1163
- // NOTE(dbeaumont): Should this remainder be 2 * M_PI or just M_PI ??
1164
- let lo = S2.IEEEremainder(this.lo.minus(radius), 2 * S2.M_PI);
1165
- let hi = S2.IEEEremainder(this.hi.plus(radius), 2 * S2.M_PI);
1166
- <span class="missing-if-branch" title="if path not taken" >I</span>if (lo.eq(-S2.M_PI)) {
1167
- <span class="cstat-no" title="statement not covered" > lo = S2.toDecimal(S2.M_PI);</span>
1168
- }
1169
- return new S1Interval(lo, hi);
1170
- }
1171
- &nbsp;
1172
- /**
1173
- * Return the smallest interval that contains this interval and the given
1174
- * interval "y".
1175
- */
1176
- <span class="fstat-no" title="function not covered" > public union(</span>y:S1Interval):S1Interval {
1177
- // The y.is_full() case is handled correctly in all cases by the code
1178
- // below, but can follow three separate code paths depending on whether
1179
- // this interval is inverted, is non-inverted but contains Pi, or neither.
1180
- &nbsp;
1181
- <span class="cstat-no" title="statement not covered" > if (y.isEmpty()) {</span>
1182
- <span class="cstat-no" title="statement not covered" > return this;</span>
1183
- }
1184
- <span class="cstat-no" title="statement not covered" > if (this.fastContains(y.lo)) {</span>
1185
- <span class="cstat-no" title="statement not covered" > if (this.fastContains(y.hi)) {</span>
1186
- // Either this interval contains y, or the union of the two
1187
- // intervals is the Full() interval.
1188
- <span class="cstat-no" title="statement not covered" > if (this.containsI(y)) {</span>
1189
- <span class="cstat-no" title="statement not covered" > return this; </span>// is_full() code path
1190
- }
1191
- <span class="cstat-no" title="statement not covered" > return S1Interval.full();</span>
1192
- }
1193
- <span class="cstat-no" title="statement not covered" > return new S1Interval(this.lo, this.hi, true);</span>
1194
- }
1195
- <span class="cstat-no" title="statement not covered" > if (this.fastContains(y.hi)) {</span>
1196
- <span class="cstat-no" title="statement not covered" > return new S1Interval(y.lo, this.hi, true);</span>
1197
- }
1198
- &nbsp;
1199
- // This interval contains neither endpoint of y. This means that either y
1200
- // contains all of this interval, or the two intervals are disjoint.
1201
- <span class="cstat-no" title="statement not covered" > if (this.isEmpty() || y.fastContains(this.lo)) {</span>
1202
- <span class="cstat-no" title="statement not covered" > return y;</span>
1203
- }
1204
- &nbsp;
1205
- // Check which pair of endpoints are closer together.
1206
- let dlo = <span class="cstat-no" title="statement not covered" >S1Interval.positiveDistance(y.hi, this.lo);</span>
1207
- let dhi = <span class="cstat-no" title="statement not covered" >S1Interval.positiveDistance(this.hi, y.lo);</span>
1208
- <span class="cstat-no" title="statement not covered" > if (dlo &lt; dhi) {</span>
1209
- <span class="cstat-no" title="statement not covered" > return new S1Interval(y.lo, this.hi, true);</span>
1210
- } else {
1211
- <span class="cstat-no" title="statement not covered" > return new S1Interval(this.lo, y.hi, true);</span>
1212
- }
1213
- }
1214
- &nbsp;
1215
- /**
1216
- * Return the smallest interval that contains the intersection of this
1217
- * interval with "y". Note that the region of intersection may consist of two
1218
- * disjoint intervals.
1219
- */
1220
- <span class="fstat-no" title="function not covered" > public intersection(</span>y:S1Interval):S1Interval {
1221
- // The y.is_full() case is handled correctly in all cases by the code
1222
- // below, but can follow three separate code paths depending on whether
1223
- // this interval is inverted, is non-inverted but contains Pi, or neither.
1224
- &nbsp;
1225
- <span class="cstat-no" title="statement not covered" > if (y.isEmpty()) {</span>
1226
- <span class="cstat-no" title="statement not covered" > return S1Interval.empty();</span>
1227
- }
1228
- <span class="cstat-no" title="statement not covered" > if (this.fastContains(y.lo)) {</span>
1229
- <span class="cstat-no" title="statement not covered" > if (this.fastContains(y.hi)) {</span>
1230
- // Either this interval contains y, or the region of intersection
1231
- // consists of two disjoint subintervals. In either case, we want
1232
- // to return the shorter of the two original intervals.
1233
- <span class="cstat-no" title="statement not covered" > if (y.getLength().lt(this.getLength())) {</span>
1234
- <span class="cstat-no" title="statement not covered" > return y; </span>// is_full() code path
1235
- }
1236
- <span class="cstat-no" title="statement not covered" > return this;</span>
1237
- }
1238
- <span class="cstat-no" title="statement not covered" > return new S1Interval(y.lo, this.hi, true);</span>
1239
- }
1240
- <span class="cstat-no" title="statement not covered" > if (this.fastContains(y.hi)) {</span>
1241
- <span class="cstat-no" title="statement not covered" > return new S1Interval(this.lo, y.hi, true);</span>
1242
- }
1243
- &nbsp;
1244
- // This interval contains neither endpoint of y. This means that either y
1245
- // contains all of this interval, or the two intervals are disjoint.
1246
- &nbsp;
1247
- <span class="cstat-no" title="statement not covered" > if (y.fastContains(this.lo)) {</span>
1248
- <span class="cstat-no" title="statement not covered" > return this; </span>// is_empty() okay here
1249
- }
1250
- // assert (!intersects(y));
1251
- <span class="cstat-no" title="statement not covered" > return S1Interval.empty();</span>
1252
- }
1253
- &nbsp;
1254
- /**
1255
- * Return true if the length of the symmetric difference between the two
1256
- * intervals is at most the given tolerance.
1257
- */
1258
- public approxEquals(y:S1Interval, <span class="missing-if-branch" title="if path not taken" >I</span>maxError:number=1e-9):boolean {
1259
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isEmpty()) {
1260
- <span class="cstat-no" title="statement not covered" > return y.getLength().lte(maxError);</span>
1261
- }
1262
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isEmpty()) {
1263
- <span class="cstat-no" title="statement not covered" > return this.getLength().lte(maxError);</span>
1264
- }
1265
- &nbsp;
1266
- return S2.IEEEremainder(y.lo.minus(this.lo), 2 * S2.M_PI).abs()
1267
- .plus(S2.IEEEremainder(y.hi.minus(this.hi), 2 * S2.M_PI).abs())
1268
- .lte(maxError);
1269
- }
1270
- &nbsp;
1271
- &nbsp;
1272
- &nbsp;
1273
- static empty():S1Interval {
1274
- return new S1Interval(S2.M_PI, -S2.M_PI, true);
1275
- }
1276
- &nbsp;
1277
- static full():S1Interval {
1278
- return new S1Interval(-S2.M_PI, S2.M_PI, true);
1279
- }
1280
- &nbsp;
1281
- <span class="fstat-no" title="function not covered" > static fromPoint(</span>_p:number|decimal.Decimal):S1Interval {
1282
- let p = <span class="cstat-no" title="statement not covered" >S2.toDecimal(_p);</span>
1283
- <span class="cstat-no" title="statement not covered" > if (p.eq(-S2.M_PI)) {</span>
1284
- <span class="cstat-no" title="statement not covered" > p = S2.toDecimal(S2.M_PI);</span>
1285
- }
1286
- <span class="cstat-no" title="statement not covered" > return new S1Interval(p, p, true);</span>
1287
- }
1288
- &nbsp;
1289
- &nbsp;
1290
- /**
1291
- * Convenience method to construct the minimal interval containing the two
1292
- * given points. This is equivalent to starting with an empty interval and
1293
- * calling AddPoint() twice, but it is more efficient.
1294
- */
1295
- static fromPointPair(_p1:number|decimal.Decimal, _p2:number|decimal.Decimal):S1Interval {
1296
- // assert (Math.abs(p1) &lt;= S2.M_PI &amp;&amp; Math.abs(p2) &lt;= S2.M_PI);
1297
- let p1 = S2.toDecimal(_p1);
1298
- let p2 = S2.toDecimal(_p2);
1299
- <span class="missing-if-branch" title="if path not taken" >I</span>if (p1.eq(-S2.M_PI)) {
1300
- <span class="cstat-no" title="statement not covered" > p1 = S2.toDecimal(S2.M_PI);</span>
1301
- }
1302
- <span class="missing-if-branch" title="if path not taken" >I</span>if (p2.eq(-S2.M_PI)) {
1303
- <span class="cstat-no" title="statement not covered" > p2 = S2.toDecimal(S2.M_PI);</span>
1304
- }
1305
- if (S1Interval.positiveDistance(p1, p2).lte(S2.M_PI)) {
1306
- return new S1Interval(p1, p2, true);
1307
- } else {
1308
- return new S1Interval(p2, p1, true);
1309
- }
1310
- }
1311
- &nbsp;
1312
- /**
1313
- * Compute the distance from "a" to "b" in the range [0, 2*Pi). This is
1314
- * equivalent to (drem(b - a - S2.M_PI, 2 * S2.M_PI) + S2.M_PI), except that
1315
- * it is more numerically stable (it does not lose precision for very small
1316
- * positive distances).
1317
- */
1318
- public static positiveDistance(_a:number|decimal.Decimal, _b:number|decimal.Decimal):decimal.Decimal {
1319
- const a = S2.toDecimal(_a);
1320
- const b = S2.toDecimal(_b);
1321
- let d = b.minus(a);
1322
- if (d .gte(0)) {
1323
- return d;
1324
- }
1325
- // We want to ensure that if b == Pi and a == (-Pi + eps),
1326
- // the return result is approximately 2*Pi and not zero.
1327
- return b.plus(S2.M_PI).minus(a.minus(S2.M_PI));
1328
- }
1329
- &nbsp;
1330
- }</pre></td></tr>
1331
- </table></pre>
1332
- <div class='push'></div><!-- for sticky footer -->
1333
- </div><!-- /wrapper -->
1334
- <div class='footer quiet pad2 space-top1 center small'>
1335
- Code coverage
1336
- generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Wed Sep 28 2016 14:48:27 GMT+0200 (CEST)
1337
- </div>
1338
- </div>
1339
- <script src="prettify.js"></script>
1340
- <script>
1341
- window.onload = function () {
1342
- if (typeof prettyPrint === 'function') {
1343
- prettyPrint();
1344
- }
1345
- };
1346
- </script>
1347
- <script src="sorter.js"></script>
1348
- </body>
1349
- </html>