-
-
Notifications
You must be signed in to change notification settings - Fork 878
/
Copy pathpoint_in_polygon.dart
76 lines (60 loc) · 2 KB
/
point_in_polygon.dart
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
import 'dart:async';
import 'dart:math' as math;
import 'dart:ui';
import 'package:flutter_map/src/misc/point_in_polygon.dart';
import 'package:logger/logger.dart';
class NoFilter extends LogFilter {
@override
bool shouldLog(LogEvent event) => true;
}
typedef Result = ({
String name,
Duration duration,
});
Future<Result> timedRun(String name, dynamic Function() body) async {
Logger().i('running $name...');
final watch = Stopwatch()..start();
await body();
watch.stop();
return (name: name, duration: watch.elapsed);
}
List<Offset> makeCircle(int points, double radius, double phase) {
final slice = math.pi * 2 / (points - 1);
return List.generate(points, (i) {
// Note the modulo is only there to deal with floating point imprecision
// and ensure first == last.
final angle = slice * (i % (points - 1)) + phase;
return Offset(radius * math.cos(angle), radius * math.sin(angle));
}, growable: false);
}
// NOTE: to have a more prod like comparison, run with:
// $ dart compile exe benchmark/crs.dart && ./benchmark/crs.exe
//
// If you run in JIT mode, the resulting execution times will be a lot more similar.
Future<void> main() async {
Logger.level = Level.all;
Logger.defaultFilter = NoFilter.new;
Logger.defaultPrinter = SimplePrinter.new;
final results = <Result>[];
const N = 3000000;
final circle = makeCircle(1000, 1, 0);
results.add(await timedRun('In circle', () {
const point = Offset.zero;
bool yesPlease = true;
for (int i = 0; i < N; ++i) {
yesPlease = yesPlease && isPointInPolygon(point, circle);
}
assert(yesPlease, 'should be in circle');
return yesPlease;
}));
results.add(await timedRun('Not in circle', () {
const point = Offset(4, 4);
bool noSir = false;
for (int i = 0; i < N; ++i) {
noSir = noSir || isPointInPolygon(point, circle);
}
assert(!noSir, 'should not be in circle');
return noSir;
}));
Logger().i('Results:\n${results.map((r) => r.toString()).join('\n')}');
}