xref: /aosp_15_r20/external/skia/modules/bentleyottmann/tests/BentleyOttmann1Test.cpp (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
1*c8dee2aaSAndroid Build Coastguard Worker // Copyright 2023 Google LLC
2*c8dee2aaSAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
3*c8dee2aaSAndroid Build Coastguard Worker 
4*c8dee2aaSAndroid Build Coastguard Worker #include "modules/bentleyottmann/include/BentleyOttmann1.h"
5*c8dee2aaSAndroid Build Coastguard Worker 
6*c8dee2aaSAndroid Build Coastguard Worker #include "modules/bentleyottmann/include/Point.h"
7*c8dee2aaSAndroid Build Coastguard Worker #include "modules/bentleyottmann/include/Segment.h"
8*c8dee2aaSAndroid Build Coastguard Worker #include "tests/Test.h"
9*c8dee2aaSAndroid Build Coastguard Worker 
10*c8dee2aaSAndroid Build Coastguard Worker #include <vector>
11*c8dee2aaSAndroid Build Coastguard Worker 
12*c8dee2aaSAndroid Build Coastguard Worker using namespace bentleyottmann;
13*c8dee2aaSAndroid Build Coastguard Worker 
DEF_TEST(BO_bentley_ottmann_1_Basic,reporter)14*c8dee2aaSAndroid Build Coastguard Worker DEF_TEST(BO_bentley_ottmann_1_Basic, reporter) {
15*c8dee2aaSAndroid Build Coastguard Worker 
16*c8dee2aaSAndroid Build Coastguard Worker     {
17*c8dee2aaSAndroid Build Coastguard Worker         Segment s0 = {{-1, 0}, {1,  0}},
18*c8dee2aaSAndroid Build Coastguard Worker                 s1 = {{ 0, 1}, {0, -1}};
19*c8dee2aaSAndroid Build Coastguard Worker 
20*c8dee2aaSAndroid Build Coastguard Worker         std::vector<Segment> segments;
21*c8dee2aaSAndroid Build Coastguard Worker         segments.push_back(s0);
22*c8dee2aaSAndroid Build Coastguard Worker         segments.push_back(s1);
23*c8dee2aaSAndroid Build Coastguard Worker 
24*c8dee2aaSAndroid Build Coastguard Worker         auto possibleCrossings = bentley_ottmann_1(segments);
25*c8dee2aaSAndroid Build Coastguard Worker 
26*c8dee2aaSAndroid Build Coastguard Worker         REPORTER_ASSERT(reporter, possibleCrossings.has_value());
27*c8dee2aaSAndroid Build Coastguard Worker 
28*c8dee2aaSAndroid Build Coastguard Worker         if (possibleCrossings) {
29*c8dee2aaSAndroid Build Coastguard Worker             auto crossings = possibleCrossings.value();
30*c8dee2aaSAndroid Build Coastguard Worker             REPORTER_ASSERT(reporter, crossings.size() == 1);
31*c8dee2aaSAndroid Build Coastguard Worker             Point p = {0, 0};
32*c8dee2aaSAndroid Build Coastguard Worker             REPORTER_ASSERT(reporter, crossings[0].crossing == p);
33*c8dee2aaSAndroid Build Coastguard Worker             REPORTER_ASSERT(reporter, (crossings[0].s0 == s0 && crossings[0].s1 == s1) ||
34*c8dee2aaSAndroid Build Coastguard Worker                                       (crossings[0].s0 == s1 && crossings[0].s1 == s0));
35*c8dee2aaSAndroid Build Coastguard Worker         }
36*c8dee2aaSAndroid Build Coastguard Worker     }
37*c8dee2aaSAndroid Build Coastguard Worker     {
38*c8dee2aaSAndroid Build Coastguard Worker         Point p0 = {-50, -100},
39*c8dee2aaSAndroid Build Coastguard Worker               p1 = { 50, -100},
40*c8dee2aaSAndroid Build Coastguard Worker               p2 = {  0, 100};
41*c8dee2aaSAndroid Build Coastguard Worker         Segment s0 = {p0, p1},
42*c8dee2aaSAndroid Build Coastguard Worker                 s1 = {p1, p2},
43*c8dee2aaSAndroid Build Coastguard Worker                 s2 = {p2, p0};
44*c8dee2aaSAndroid Build Coastguard Worker 
45*c8dee2aaSAndroid Build Coastguard Worker         std::vector<Segment> segments{s0, s1, s2};
46*c8dee2aaSAndroid Build Coastguard Worker         auto possibleCrossings = bentley_ottmann_1(segments);
47*c8dee2aaSAndroid Build Coastguard Worker 
48*c8dee2aaSAndroid Build Coastguard Worker         REPORTER_ASSERT(reporter, possibleCrossings.has_value());
49*c8dee2aaSAndroid Build Coastguard Worker         if (possibleCrossings) {
50*c8dee2aaSAndroid Build Coastguard Worker             auto crossings = possibleCrossings.value();
51*c8dee2aaSAndroid Build Coastguard Worker             REPORTER_ASSERT(reporter, crossings.size() == 0);
52*c8dee2aaSAndroid Build Coastguard Worker         }
53*c8dee2aaSAndroid Build Coastguard Worker     }
54*c8dee2aaSAndroid Build Coastguard Worker     {
55*c8dee2aaSAndroid Build Coastguard Worker         Point p0 = {-50, 100},
56*c8dee2aaSAndroid Build Coastguard Worker               p1 = { 50, 100},
57*c8dee2aaSAndroid Build Coastguard Worker               p2 = {  0, -100};
58*c8dee2aaSAndroid Build Coastguard Worker         Segment s0 = {p0, p1},
59*c8dee2aaSAndroid Build Coastguard Worker                 s1 = {p1, p2},
60*c8dee2aaSAndroid Build Coastguard Worker                 s2 = {p2, p0};
61*c8dee2aaSAndroid Build Coastguard Worker 
62*c8dee2aaSAndroid Build Coastguard Worker         std::vector<Segment> segments{s0, s1, s2};
63*c8dee2aaSAndroid Build Coastguard Worker         auto possibleCrossings = bentley_ottmann_1(segments);
64*c8dee2aaSAndroid Build Coastguard Worker 
65*c8dee2aaSAndroid Build Coastguard Worker         REPORTER_ASSERT(reporter, possibleCrossings.has_value());
66*c8dee2aaSAndroid Build Coastguard Worker         if (possibleCrossings) {
67*c8dee2aaSAndroid Build Coastguard Worker             auto crossings = possibleCrossings.value();
68*c8dee2aaSAndroid Build Coastguard Worker             REPORTER_ASSERT(reporter, crossings.size() == 0);
69*c8dee2aaSAndroid Build Coastguard Worker         }
70*c8dee2aaSAndroid Build Coastguard Worker     }
71*c8dee2aaSAndroid Build Coastguard Worker }
72