blob: f5f6250ec116564e0f4d7427dc27804a75a9cda8 [file] [log] [blame]
caryclark@google.comf839c032012-10-26 21:03:50 +00001<html>
2<head>
3<div style="height:0">
4
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005<div id="cubicOp36u">
6 SimplifyNew_Test [cubicOp36u]
7{{0,1}, {1,6}, {2,0}, {5,1}},
8{{5,1}, {0,1}},
9op union
10{{0,2}, {1,5}, {1,0}, {6,1}},
11{{6,1}, {0,2}},
12debugShowCubicIntersection no self intersect {{0,2}, {1,5}, {1,0}, {6,1}}
13debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {1,5}, {1,0}, {6,1}} {{0,2}} wtTs[1]=0.633333333 {{2.2208888888888882,1.6298518518518521}} wtTs[2]=1 {{6,1}} wnTs[0]=1 {{6,1}, {0,2}} wnTs[1]=0.629851852 wnTs[2]=0
14debugShowCubicIntersection wtTs[0]=0.281761651 {{0,2}, {1,5}, {1,0}, {6,1}} {{0.74132978521392334,2.9436691246202122}} wtTs[1]=0.83051493 {{3.8593908381032738,0.94043932231067462}} wtTs[2]=0.830515061 {{3.8593922073023155,0.94043907360367252}} wtTs[3]=0.867315861 {{4.2597986321159249,0.88613622701319239}} wtTs[4]=0.867316009 {{4.2598003089230945,0.88613607359480184}} wnTs[0]=0.23811 {{0,1}, {1,6}, {2,0}, {5,1}} wnTs[1]=0.860977989 wnTs[2]=0.860978176 wnTs[3]=0.912837717 wnTs[4]=0.912837923
15debugShowCubicLineIntersection wtTs[0]=0.803214143 {{0,2}, {1,5}, {1,0}, {6,1}} {{3.5833594368204942,1}} wnTs[0]=0.283328 {{5,1}, {0,1}}
16debugShowCubicLineIntersection wtTs[0]=0.0764226429 {{0,1}, {1,6}, {2,0}, {5,1}} {{0.23016060940409022,1.9616398984326517}} wtTs[1]=0.691654855 {{2.7367211708698314,1.543879804855028}} wnTs[0]=0.96164 {{6,1}, {0,2}} wnTs[1]=0.543879805
17debugShowLineIntersection no intersect {{6,1}, {0,2}} {{5,1}, {0,1}}
18debugShowCubicIntersection no self intersect {{0,1}, {1,6}, {2,0}, {5,1}}
19debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {1,6}, {2,0}, {5,1}} {{0,1}} wtTs[1]=0.833333333 {{3.6574074074074132,0.99999999999999789}} wtTs[2]=1 {{5,1}} wnTs[0]=1 {{5,1}, {0,1}} wnTs[1]=0.268518519 wnTs[2]=0
20debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0 (0,2) tEnd=0.281761651 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
21debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.281761651 (0.741329789,2.94366908) tEnd=0.633333333 other=1 otherT=0.238109917 otherIndex=2 windSum=? windValue=1 oppValue=0
22debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.633333333 (2.22088885,1.62985182) tEnd=0.803214143 other=4 otherT=0.629851852 otherIndex=2 windSum=? windValue=1 oppValue=0
23debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.803214143 (3.58335948,1) tEnd=0.83051493 other=2 otherT=0.283328113 otherIndex=2 windSum=? windValue=1 oppValue=0
24debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.83051493 (3.85939074,0.940439343) tEnd=0.830515061 other=1 otherT=0.860977989 otherIndex=5 windSum=? windValue=1 oppValue=0
25debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.830515061 (3.85939217,0.940439045) tEnd=0.867315861 other=1 otherT=0.860978176 otherIndex=6 windSum=? windValue=1 oppValue=0
26debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.867315861 (4.25979853,0.886136234) tEnd=0.867316009 other=1 otherT=0.912837717 otherIndex=7 windSum=? windValue=1 oppValue=0
27debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.867316009 (4.25980043,0.886136055) tEnd=1 other=1 otherT=0.912837923 otherIndex=8 windSum=? windValue=1 oppValue=0
28debugShowActiveSpans id=4 (6,1 0,2) t=0 (6,1) tEnd=0.543879805 other=3 otherT=1 otherIndex=8 windSum=? windValue=1 oppValue=0
29debugShowActiveSpans id=4 (6,1 0,2) t=0.543879805 (2.73672128,1.54387975) tEnd=0.629851852 other=1 otherT=0.691654855 otherIndex=3 windSum=? windValue=1 oppValue=0
30debugShowActiveSpans id=4 (6,1 0,2) t=0.629851852 (2.22088885,1.62985182) tEnd=0.961639898 other=3 otherT=0.633333333 otherIndex=2 windSum=? windValue=1 oppValue=0
31debugShowActiveSpans id=4 (6,1 0,2) t=0.961639898 (0.230160609,1.96163988) tEnd=1 other=1 otherT=0.0764226429 otherIndex=1 windSum=? windValue=1 oppValue=0
32debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0 (0,1) tEnd=0.0764226429 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
33debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.0764226429 (0.230160609,1.96163988) tEnd=0.238109917 other=4 otherT=0.961639898 otherIndex=3 windSum=? windValue=1 oppValue=0
34debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.238109917 (0.741329789,2.94366908) tEnd=0.691654855 other=3 otherT=0.281761651 otherIndex=1 windSum=? windValue=1 oppValue=0
35debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.691654855 (2.73672128,1.54387975) tEnd=0.833333333 other=4 otherT=0.543879805 otherIndex=1 windSum=? windValue=1 oppValue=0
36debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.833333333 (3.65740752,1) tEnd=0.860977989 other=2 otherT=0.268518519 otherIndex=1 windSum=? windValue=1 oppValue=0
37debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.860977989 (3.85939074,0.940439343) tEnd=0.860978176 other=3 otherT=0.83051493 otherIndex=4 windSum=? windValue=1 oppValue=0
38debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.860978176 (3.85939217,0.940439045) tEnd=0.912837717 other=3 otherT=0.830515061 otherIndex=5 windSum=? windValue=1 oppValue=0
39debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.912837717 (4.25979853,0.886136234) tEnd=0.912837923 other=3 otherT=0.867315861 otherIndex=6 windSum=? windValue=1 oppValue=0
40debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.912837923 (4.25980043,0.886136055) tEnd=1 other=3 otherT=0.867316009 otherIndex=7 windSum=? windValue=1 oppValue=0
41debugShowActiveSpans id=2 (5,1 0,1) t=0 (5,1) tEnd=0.268518519 other=1 otherT=1 otherIndex=9 windSum=? windValue=1 oppValue=0
42debugShowActiveSpans id=2 (5,1 0,1) t=0.268518519 (3.65740752,1) tEnd=0.283328113 other=1 otherT=0.833333333 otherIndex=4 windSum=? windValue=1 oppValue=0
43debugShowActiveSpans id=2 (5,1 0,1) t=0.283328113 (3.58335948,1) tEnd=1 other=3 otherT=0.803214143 otherIndex=3 windSum=? windValue=1 oppValue=0
44findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
45debugShowSort [0] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=1 tEnd=0.867316009 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
46debugShowSort [1] {{6,1}, {0,2}} tStart=0 tEnd=0.543879805 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
47findTop xyE=(6,1) xyS=(4.25980043,0.886136055)
48findTop dxyE=(15,3) dxyS=(11.3363714,-1.03721189) cross=-49.5672913 bumpsUp=true
49markWinding id=3 (0,2 1,5 1,0 6,1) t=0.867316009 [7] (4.25980043,0.886136055) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
50markWinding id=4 (6,1 0,2) t=0 [0] (6,1) tEnd=0.543879805 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
51markWinding id=3 (0,2 1,5 1,0 6,1) t=0.867316009 [7] (4.25980043,0.886136055) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
52activeOp op=union miFrom=0 miTo=0 suFrom=1 suTo=0 result=1
caryclark@google.com4aaaaea2013-02-28 16:12:39 +000053findNextOp simple
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +000054markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.867316009 [7] (4.25980043,0.886136055) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
55bridgeOp current id=3 from=(4.25980043,0.886136055) to=(6,1)
56path.moveTo(4.25980043,0.886136055);
57path.cubicTo(4.76118517,0.840262294, 5.33658028,0.867316008, 6,1);
58findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
59debugShowSort [0] {{6,1}, {0,2}} tStart=0.543879805 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
60debugShowSort [1] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.691654855 tEnd=0.833333333 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
61debugShowSort [2] {{6,1}, {0,2}} tStart=0.543879805 tEnd=0.629851852 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
62debugShowSort [3] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.691654855 tEnd=0.238109917 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
caryclark@google.com4aaaaea2013-02-28 16:12:39 +000063findNextOp firstIndex=[0] sign=1
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +000064activeOp op=union miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
65markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.691654855 [3] (2.73672128,1.54387975) tEnd=0.833333333 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
66findNextOp chase.append id=1
67activeOp op=union miFrom=1 miTo=1 suFrom=1 suTo=0 result=0
68markDoneBinary id=4 (6,1 0,2) t=0.543879805 [1] (2.73672128,1.54387975) tEnd=0.629851852 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
69findNextOp chase.append id=4
70activeOp op=union miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
71markWinding id=1 (0,1 1,6 2,0 5,1) t=0.238109917 [2] (0.741329789,2.94366908) tEnd=0.691654855 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
72findNextOp chase.append id=1
caryclark@google.com1304bb22013-03-13 20:29:41 +000073markDoneBinary id=4 (6,1 0,2) t=0 [0] (6,1) tEnd=0.543879805 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +000074findNextOp from:[4] to:[1] start=3 end=2
75bridgeOp current id=4 from=(6,1) to=(2.73672128,1.54387975)
76findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
77debugShowSort [3] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.238109917 tEnd=0.691654855 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
78debugShowSort [0] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.281761651 tEnd=0.633333333 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
79debugShowSort [1] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.238109917 tEnd=0.0764226429 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
80debugShowSort [2] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.281761651 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
81findNextOp firstIndex=[3] sign=-1
82activeOp op=union miFrom=1 miTo=1 suFrom=0 suTo=1 result=0
83markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.281761651 [1] (0.741329789,2.94366908) tEnd=0.633333333 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
84findNextOp chase.append id=3
85activeOp op=union miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
86markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.0764226429 [1] (0.230160609,1.96163988) tEnd=0.238109917 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
87findNextOp chase.append id=1
88activeOp op=union miFrom=0 miTo=0 suFrom=1 suTo=0 result=1
89markWinding id=3 (0,2 1,5 1,0 6,1) t=0 [0] (0,2) tEnd=0.281761651 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
90markWinding id=4 (6,1 0,2) t=0.961639898 [3] (0.230160609,1.96163988) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
91findNextOp chase.append id=4
92markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.238109917 [2] (0.741329789,2.94366908) tEnd=0.691654855 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
93findNextOp from:[1] to:[3] start=1 end=0
94bridgeOp current id=1 from=(2.73672128,1.54387975) to=(0.741329789,2.94366908)
95path.lineTo(2.73672128,1.54387975);
96path.cubicTo(1.84923673,2.27202392, 1.2463032,3.29839373, 0.741329789,2.94366908);
97findNextOp simple
98markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0 [0] (0,2) tEnd=0.281761651 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
99bridgeOp current id=3 from=(0.741329789,2.94366908) to=(0,2)
100path.cubicTo(0.484133661,3.05545282, 0.281761646,2.84528494, 0,2);
101findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
102debugShowSort [2] {{6,1}, {0,2}} tStart=0.961639898 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
103debugShowSort [3] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.0764226429 tEnd=0.238109917 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
104debugShowSort [0] {{6,1}, {0,2}} tStart=0.961639898 tEnd=0.629851852 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
105debugShowSort [1] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.0764226429 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
106findNextOp firstIndex=[2] sign=-1
107activeOp op=union miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
108activeOp op=union miFrom=1 miTo=1 suFrom=1 suTo=0 result=0
109markDoneBinary id=4 (6,1 0,2) t=0.629851852 [2] (2.22088885,1.62985182) tEnd=0.961639898 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
110findNextOp chase.append id=4
111activeOp op=union miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
112markWinding id=1 (0,1 1,6 2,0 5,1) t=0 [0] (0,1) tEnd=0.0764226429 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
113markWinding id=2 (5,1 0,1) t=0.283328113 [2] (3.58335948,1) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
114findNextOp chase.append id=2
115markDoneBinary id=4 (6,1 0,2) t=0.961639898 [3] (0.230160609,1.96163988) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
116findNextOp from:[4] to:[1] start=1 end=0
117bridgeOp current id=4 from=(0,2) to=(0.230160609,1.96163988)
118findNextOp simple
119markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0 [0] (0,1) tEnd=0.0764226429 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
120bridgeOp current id=1 from=(0.230160609,1.96163988) to=(0,1)
121path.lineTo(0.230160609,1.96163988);
122path.cubicTo(0.152845293,1.69998181, 0.0764226392,1.38211322, 0,1);
123findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
124debugShowSort [1] {{5,1}, {0,1}} tStart=0.283328113 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
125debugShowSort [2] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.803214143 tEnd=0.633333333 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
126debugShowSort [3] {{5,1}, {0,1}} tStart=0.283328113 tEnd=0.268518519 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
127debugShowSort [0] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.803214143 tEnd=0.83051493 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
128findNextOp firstIndex=[1] sign=-1
129activeOp op=union miFrom=1 miTo=1 suFrom=0 suTo=1 result=0
130markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.633333333 [2] (2.22088885,1.62985182) tEnd=0.803214143 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
131findNextOp chase.append id=3
132activeOp op=union miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
133markDoneBinary id=2 (5,1 0,1) t=0.268518519 [1] (3.65740752,1) tEnd=0.283328113 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
134findNextOp chase.append id=2
135activeOp op=union miFrom=0 miTo=0 suFrom=1 suTo=0 result=1
136markWinding id=3 (0,2 1,5 1,0 6,1) t=0.803214143 [3] (3.58335948,1) tEnd=0.83051493 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
137findNextOp chase.append id=3
138markDoneBinary id=2 (5,1 0,1) t=0.283328113 [2] (3.58335948,1) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
139findNextOp from:[2] to:[3] start=3 end=4
140bridgeOp current id=2 from=(0,1) to=(3.58335948,1)
141findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
142debugShowSort [0] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.83051493 tEnd=0.803214143 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
143debugShowSort [1] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.860977989 tEnd=0.833333333 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
144debugShowSort [2] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.860977989 tEnd=0.860978176 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
145debugShowSort [3] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.83051493 tEnd=0.830515061 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
146findNextOp firstIndex=[0] sign=1
147activeOp op=union miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
148markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.833333333 [4] (3.65740752,1) tEnd=0.860977989 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
149findNextOp chase.append id=1
150activeOp op=union miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
151markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.860977989 [5] (3.85939074,0.940439343) tEnd=0.860978176 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
152findNextOp chase.append id=1
153activeOp op=union miFrom=0 miTo=0 suFrom=1 suTo=0 result=1
154markWinding id=3 (0,2 1,5 1,0 6,1) t=0.83051493 [4] (3.85939074,0.940439343) tEnd=0.830515061 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
155findNextOp chase.append id=3
156markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.803214143 [3] (3.58335948,1) tEnd=0.83051493 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
157findNextOp from:[3] to:[3] start=4 end=5
158bridgeOp current id=3 from=(3.58335948,1) to=(3.85939074,0.940439343)
159path.lineTo(3.58335948,1);
160path.cubicTo(3.67248249,0.97763288, 3.76445246,0.957684338, 3.85939074,0.940439343);
161findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
162debugShowSort [2] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.830515061 tEnd=0.83051493 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
163debugShowSort [3] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.860978176 tEnd=0.860977989 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
164debugShowSort [0] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.830515061 tEnd=0.867315861 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
165debugShowSort [1] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.860978176 tEnd=0.912837717 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
caryclark@google.com4aaaaea2013-02-28 16:12:39 +0000166findNextOp firstIndex=[2] sign=1
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +0000167activeOp op=union miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
168activeOp op=union miFrom=1 miTo=1 suFrom=1 suTo=0 result=0
169markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.830515061 [5] (3.85939217,0.940439045) tEnd=0.867315861 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
170findNextOp chase.append id=3
171activeOp op=union miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
172markWinding id=1 (0,1 1,6 2,0 5,1) t=0.860978176 [6] (3.85939217,0.940439045) tEnd=0.912837717 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
173findNextOp chase.append id=1
174markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.83051493 [4] (3.85939074,0.940439343) tEnd=0.830515061 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
175findNextOp from:[3] to:[1] start=6 end=7
176bridgeOp current id=3 from=(3.85939074,0.940439343) to=(3.85939217,0.940439045)
177path.cubicTo(3.85939145,0.940439224, 3.85939169,0.940439165, 3.85939217,0.940439045);
178findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
179debugShowSort [0] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.912837717 tEnd=0.860978176 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
180debugShowSort [1] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.867315861 tEnd=0.830515061 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
181debugShowSort [2] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.912837717 tEnd=0.912837923 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
182debugShowSort [3] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.867315861 tEnd=0.867316009 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
183findNextOp firstIndex=[0] sign=1
184activeOp op=union miFrom=1 miTo=1 suFrom=0 suTo=1 result=0
185activeOp op=union miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
186markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.912837717 [7] (4.25979853,0.886136234) tEnd=0.912837923 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
187findNextOp chase.append id=1
188activeOp op=union miFrom=0 miTo=0 suFrom=1 suTo=0 result=1
189markWinding id=3 (0,2 1,5 1,0 6,1) t=0.867315861 [6] (4.25979853,0.886136234) tEnd=0.867316009 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
190findNextOp chase.append id=3
191markDoneBinary id=1 (0,1 1,6 2,0 5,1) t=0.860978176 [6] (3.85939217,0.940439045) tEnd=0.912837717 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
192findNextOp from:[1] to:[3] start=6 end=7
193bridgeOp current id=1 from=(3.85939217,0.940439045) to=(4.25979853,0.886136234)
194path.cubicTo(3.98813701,0.909405351, 4.12151289,0.890467525, 4.25980043,0.886136055);
195path.close();
196debugShowActiveSpans id=3 (0,2 1,5 1,0 6,1) t=0.867315861 (4.25979853,0.886136234) tEnd=0.867316009 other=1 otherT=0.912837717 otherIndex=7 windSum=-1 windValue=1 oppValue=0
197debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.912837923 (4.25980043,0.886136055) tEnd=1 other=3 otherT=0.867316009 otherIndex=7 windSum=? windValue=1 oppValue=0
198debugShowActiveSpans id=2 (5,1 0,1) t=0 (5,1) tEnd=0.268518519 other=1 otherT=1 otherIndex=9 windSum=? windValue=1 oppValue=0
199activeOp op=union miFrom=0 miTo=0 suFrom=0 suTo=1 result=1
200findNextOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
201debugShowSort [3] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.867315861 tEnd=0.867316009 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
202debugShowSort [0] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.912837717 tEnd=0.860978176 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
203debugShowSort [1] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.867315861 tEnd=0.830515061 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
204debugShowSort [2] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.912837717 tEnd=0.912837923 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
205findNextOp firstIndex=[3] sign=-1
206activeOp op=union miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
207activeOp op=union miFrom=1 miTo=1 suFrom=0 suTo=1 result=0
208activeOp op=union miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
209markDoneBinary id=3 (0,2 1,5 1,0 6,1) t=0.867315861 [6] (4.25979853,0.886136234) tEnd=0.867316009 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
210findNextOp from:[3] to:[1] start=7 end=6
211bridgeOp current id=3 from=(4.25980043,0.886136055) to=(4.25979853,0.886136234)
212path.moveTo(4.25980043,0.886136055);
213path.cubicTo(4.25979948,0.886136115, 4.25979948,0.886136174, 4.25979853,0.886136234);
214findNextOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
215debugShowSort [1] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.860978176 tEnd=0.912837717 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
216debugShowSort [2] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.830515061 tEnd=0.83051493 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
217debugShowSort [3] {{0,1}, {1,6}, {2,0}, {5,1}} tStart=0.860978176 tEnd=0.860977989 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
218debugShowSort [0] {{0,2}, {1,5}, {1,0}, {6,1}} tStart=0.830515061 tEnd=0.867315861 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
219findNextOp firstIndex=[1] sign=-1
220activeOp op=union miFrom=0 miTo=0 suFrom=0 suTo=1 result=1
221activeOp op=union miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
222activeOp op=union miFrom=1 miTo=1 suFrom=1 suTo=0 result=0
223findNextOp from:[1] to:[3] start=5 end=4
224bridgeOp current id=1 from=(4.25979853,0.886136234) to=(3.85939217,0.940439045)
225path.cubicTo(4.12151289,0.890467525, 3.98813701,0.909405351, 3.85939217,0.940439045);
226debugShowActiveSpans id=1 (0,1 1,6 2,0 5,1) t=0.912837923 (4.25980043,0.886136055) tEnd=1 other=3 otherT=0.867316009 otherIndex=7 windSum=? windValue=1 oppValue=0
227debugShowActiveSpans id=2 (5,1 0,1) t=0 (5,1) tEnd=0.268518519 other=1 otherT=1 otherIndex=9 windSum=? windValue=1 oppValue=0
228</div>
229
230<div id="cubicOp35da">
231{{x = 0.44618727783085621, y = 2.2840286415243063}, {x = 0.51170845243761109, y = 2.4044088819954914}, {x = 0.57783675570457882, y = 2.4985733182515446}, {x = 0.64483584772311509, y = 2.5694222112973661}}
232{{x = 0.64244110111854291, y = 2.5673840215265367}, {x = 0.63479413812245555, y = 2.5620057200094775}, {x = 0.64115438240274059, y = 2.533597555954064}, {x = 0.6620248993310307, y = 2.4876932484482714}}
caryclark@google.com4aaaaea2013-02-28 16:12:39 +0000233</div>
234
caryclark@google.com1304bb22013-03-13 20:29:41 +0000235<div id="cubicOp38d">
236 SimplifyNew_Test [cubicOp38d]
237{{0,1}, {0,6}, {3,2}, {4,1}},
238{{4,1}, {0,1}},
239op difference
240{{2,3}, {1,4}, {1,0}, {6,0}},
241{{6,0}, {2,3}},
242debugShowCubicIntersection no self intersect {{2,3}, {1,4}, {1,0}, {6,0}}
243debugShowCubicLineIntersection wtTs[0]=0 {{2,3}, {1,4}, {1,0}, {6,0}} {{2,3}} wtTs[1]=1 {{6,0}} wnTs[0]=1 {{6,0}, {2,3}} wnTs[1]=0
244debugShowCubicIntersection no intersect {{2,3}, {1,4}, {1,0}, {6,0}} {{0,1}, {0,6}, {3,2}, {4,1}}
245debugShowCubicLineIntersection wtTs[0]=0.666666667 {{2,3}, {1,4}, {1,0}, {6,0}} {{2.518518518518519,0.99999999999999967}} wnTs[0]=0.37037 {{4,1}, {0,1}}
246debugShowCubicLineIntersection no intersect {{0,1}, {0,6}, {3,2}, {4,1}} {{6,0}, {2,3}}
247debugShowLineIntersection no intersect {{6,0}, {2,3}} {{4,1}, {0,1}}
248debugShowCubicIntersection no self intersect {{0,1}, {0,6}, {3,2}, {4,1}}
249debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {0,6}, {3,2}, {4,1}} {{0,1}} wtTs[1]=1 {{4,1}} wnTs[0]=1 {{4,1}, {0,1}} wnTs[1]=0
250debugShowActiveSpans id=3 (2,3 1,4 1,0 6,0) t=0 (2,3) tEnd=0.666666667 other=4 otherT=1 otherIndex=1 windSum=? windValue=1 oppValue=0
251debugShowActiveSpans id=3 (2,3 1,4 1,0 6,0) t=0.666666667 (2.51851845,1) tEnd=1 other=2 otherT=0.37037037 otherIndex=1 windSum=? windValue=1 oppValue=0
252debugShowActiveSpans id=4 (6,0 2,3) t=0 (6,0) tEnd=1 other=3 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
253debugShowActiveSpans id=1 (0,1 0,6 3,2 4,1) t=0 (0,1) tEnd=1 other=2 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
254debugShowActiveSpans id=2 (4,1 0,1) t=0 (4,1) tEnd=0.37037037 other=1 otherT=1 otherIndex=1 windSum=? windValue=1 oppValue=0
255debugShowActiveSpans id=2 (4,1 0,1) t=0.37037037 (2.51851845,1) tEnd=1 other=3 otherT=0.666666667 otherIndex=1 windSum=? windValue=1 oppValue=0
256findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
257debugShowSort [0] {{2,3}, {1,4}, {1,0}, {6,0}} tStart=1 tEnd=0.666666667 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
258debugShowSort [1] {{6,0}, {2,3}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
259findTop xyE=(6,0) xyS=(2.51851845,1)
260findTop dxyE=(15,0) dxyS=(6.33333349,-5) cross=-75 bumpsUp=false
261markWinding id=3 (2,3 1,4 1,0 6,0) t=0.666666667 [1] (2.51851845,1) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
262markWinding id=4 (6,0 2,3) t=0 [0] (6,0) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
263markWinding id=3 (2,3 1,4 1,0 6,0) t=0 [0] (2,3) tEnd=0.666666667 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
264markWinding id=3 (2,3 1,4 1,0 6,0) t=0.666666667 [1] (2.51851845,1) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
265activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
266markDoneBinary id=3 (2,3 1,4 1,0 6,0) t=0.666666667 [1] (2.51851845,1) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
267markDoneBinary id=4 (6,0 2,3) t=0 [0] (6,0) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
268markDoneBinary id=3 (2,3 1,4 1,0 6,0) t=0 [0] (2,3) tEnd=0.666666667 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
269findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
270debugShowSort [0] {{2,3}, {1,4}, {1,0}, {6,0}} tStart=0.666666667 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
271debugShowSort [1] {{4,1}, {0,1}} tStart=0.37037037 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
272debugShowSort [2] {{2,3}, {1,4}, {1,0}, {6,0}} tStart=0.666666667 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
273debugShowSort [3] {{4,1}, {0,1}} tStart=0.37037037 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
274findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
275debugShowSort [0] {{2,3}, {1,4}, {1,0}, {6,0}} tStart=0.666666667 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
276debugShowSort [1] {{4,1}, {0,1}} tStart=0.37037037 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
277debugShowSort [2] {{2,3}, {1,4}, {1,0}, {6,0}} tStart=0.666666667 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
278debugShowSort [3] {{4,1}, {0,1}} tStart=0.37037037 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
279markWinding id=2 (4,1 0,1) t=0.37037037 [1] (2.51851845,1) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
280markWinding id=1 (0,1 0,6 3,2 4,1) t=0 [0] (0,1) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
281markWinding id=2 (4,1 0,1) t=0 [0] (4,1) tEnd=0.37037037 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
282markWinding id=2 (4,1 0,1) t=0 [0] (4,1) tEnd=0.37037037 newWindSum=1 newOppSum=-1 oppSum=0 windSum=1 windValue=1
283</div>
284
285<div id="cubicOp38da">
286 {{0,1}, {0,6}, {3,2}, {4,1}},
287 {{2,3}, {1,4}, {1,0}, {6,0}},
288computed quadratics set 2
289 {{2,3}, {1.46296296,3.41666667}, {1.48148148,2.66666667}},
290 {{1.48148148,2.66666667}, {1.5,1.91666667}, {2.51851852,1}},
291 {{2.51851852,1}, {3.53703704,0.0833333333}, {6,0}},
292computed quadratics set 1
293 {{0,1}, {0.0311951689,3.11686153}, {0.643808143,3.37716704}},
294 {{0.643808143,3.37716704}, {1.25642112,3.63747255}, {2.07610987,2.9396429}},
295 {{2.07610987,2.9396429}, {2.89579862,2.24181325}, {3.54822112,1.48426931}},
296 {{3.54822112,1.48426931}, {3.81269436,1.19058669}, {4,1}},
297</div>
298
299<div id="cubicOp39d">
300 SimplifyNew_Test [cubicOp39d]
301{{0,1}, {2,3}, {5,1}, {4,3}},
302{{4,3}, {0,1}},
303op difference
304{{1,5}, {3,4}, {1,0}, {3,2}},
305{{3,2}, {1,5}},
306debugShowCubicIntersection no self intersect {{0,1}, {2,3}, {5,1}, {4,3}}
307debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {2,3}, {5,1}, {4,3}} {{0,1}} wtTs[1]=0.285714286 {{1.8425655976676385,1.9212827988338192}} wtTs[2]=1 {{4,3}} wnTs[0]=1 {{4,3}, {0,1}} wnTs[1]=0.539358601 wnTs[2]=0
308debugShowCubicIntersection wtTs[0]=0.311007457 {{0,1}, {2,3}, {5,1}, {4,3}} {{2.005809685956442,1.9459962410665144}} wnTs[0]=0.589885 {{1,5}, {3,4}, {1,0}, {3,2}}
309debugShowCubicLineIntersection no intersect {{0,1}, {2,3}, {5,1}, {4,3}} {{3,2}, {1,5}}
310debugShowCubicLineIntersection wtTs[0]=0.576935809 {{1,5}, {3,4}, {1,0}, {3,2}} {{2.0036431374219883,2.0018215687109939}} wnTs[0]=0.499089 {{4,3}, {0,1}}
311debugShowLineIntersection wtTs[0]=0.3125 {{4,3}, {0,1}} {{2.75,2.375}} wnTs[0]=0.125 {{3,2}, {1,5}}
312debugShowCubicIntersection no self intersect {{1,5}, {3,4}, {1,0}, {3,2}}
313debugShowCubicLineIntersection wtTs[0]=0 {{1,5}, {3,4}, {1,0}, {3,2}} {{1,5}} wtTs[1]=0.285714286 {{1.9212827988338184,3.6180758017492725}} wtTs[2]=1 {{3,2}} wnTs[0]=1 {{3,2}, {1,5}} wnTs[1]=0.539358601 wnTs[2]=0
314debugShowActiveSpans id=1 (0,1 2,3 5,1 4,3) t=0 (0,1) tEnd=0.285714286 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
315debugShowActiveSpans id=1 (0,1 2,3 5,1 4,3) t=0.285714286 (1.84256566,1.92128277) tEnd=0.311007457 other=2 otherT=0.539358601 otherIndex=3 windSum=? windValue=1 oppValue=0
316debugShowActiveSpans id=1 (0,1 2,3 5,1 4,3) t=0.311007457 (2.00580978,1.94599628) tEnd=1 other=3 otherT=0.589885081 otherIndex=3 windSum=? windValue=1 oppValue=0
317debugShowActiveSpans id=2 (4,3 0,1) t=0 (4,3) tEnd=0.3125 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
318debugShowActiveSpans id=2 (4,3 0,1) t=0.3125 (2.75,2.375) tEnd=0.499089216 other=4 otherT=0.125 otherIndex=1 windSum=? windValue=1 oppValue=0
319debugShowActiveSpans id=2 (4,3 0,1) t=0.499089216 (2.00364304,2.00182152) tEnd=0.539358601 other=3 otherT=0.576935809 otherIndex=2 windSum=? windValue=1 oppValue=0
320debugShowActiveSpans id=2 (4,3 0,1) t=0.539358601 (1.84256566,1.92128277) tEnd=1 other=1 otherT=0.285714286 otherIndex=1 windSum=? windValue=1 oppValue=0
321debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0 (1,5) tEnd=0.285714286 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
322debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0.285714286 (1.92128277,3.61807585) tEnd=0.576935809 other=4 otherT=0.539358601 otherIndex=2 windSum=? windValue=1 oppValue=0
323debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0.576935809 (2.00364304,2.00182152) tEnd=0.589885081 other=2 otherT=0.499089216 otherIndex=2 windSum=? windValue=1 oppValue=0
324debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0.589885081 (2.00580978,1.94599628) tEnd=1 other=1 otherT=0.311007457 otherIndex=2 windSum=? windValue=1 oppValue=0
325debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
326debugShowActiveSpans id=4 (3,2 1,5) t=0.125 (2.75,2.375) tEnd=0.539358601 other=2 otherT=0.3125 otherIndex=1 windSum=? windValue=1 oppValue=0
327debugShowActiveSpans id=4 (3,2 1,5) t=0.539358601 (1.92128277,3.61807585) tEnd=1 other=3 otherT=0.285714286 otherIndex=1 windSum=? windValue=1 oppValue=0
328findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
329debugShowSort [0] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0 tEnd=0.285714286 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
330debugShowSort [1] {{4,3}, {0,1}} tStart=1 tEnd=0.539358601 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
331findTop xyE=(0,1) xyS=(1.84256566,1.92128277)
332findTop dxyE=(6,6) dxyS=(6.48979568,1.10204077) cross=-32.3265305 bumpsUp=false
333markWinding id=1 (0,1 2,3 5,1 4,3) t=0 [0] (0,1) tEnd=0.285714286 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
334markWinding id=2 (4,3 0,1) t=0.539358601 [3] (1.84256566,1.92128277) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
335markWinding id=1 (0,1 2,3 5,1 4,3) t=0 [0] (0,1) tEnd=0.285714286 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
336activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
337findNextOp simple
338markDoneBinary id=1 (0,1 2,3 5,1 4,3) t=0 [0] (0,1) tEnd=0.285714286 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
339bridgeOp current id=1 from=(1.84256566,1.92128277) to=(0,1)
340path.moveTo(1.84256566,1.92128277);
341path.cubicTo(1.22448969,1.8163265, 0.571428597,1.57142854, 0,1);
342findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
343debugShowSort [0] {{4,3}, {0,1}} tStart=0.539358601 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
344debugShowSort [1] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0.285714286 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
345debugShowSort [2] {{4,3}, {0,1}} tStart=0.539358601 tEnd=0.499089216 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
346debugShowSort [3] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0.285714286 tEnd=0.311007457 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
347findNextOp firstIndex=[0] sign=-1
348activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
349activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
350markWinding id=2 (4,3 0,1) t=0.499089216 [2] (2.00364304,2.00182152) tEnd=0.539358601 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
351findNextOp chase.append id=2
352activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
353markWinding id=1 (0,1 2,3 5,1 4,3) t=0.285714286 [1] (1.84256566,1.92128277) tEnd=0.311007457 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
354findNextOp chase.append id=1
355markDoneBinary id=2 (4,3 0,1) t=0.539358601 [3] (1.84256566,1.92128277) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
356findNextOp from:[2] to:[1] start=1 end=2
357bridgeOp current id=2 from=(0,1) to=(1.84256566,1.92128277)
358path.lineTo(1.84256566,1.92128277);
359path.close();
360debugShowActiveSpans id=1 (0,1 2,3 5,1 4,3) t=0.285714286 (1.84256566,1.92128277) tEnd=0.311007457 other=2 otherT=0.539358601 otherIndex=3 windSum=-1 windValue=1 oppValue=0
361debugShowActiveSpans id=1 (0,1 2,3 5,1 4,3) t=0.311007457 (2.00580978,1.94599628) tEnd=1 other=3 otherT=0.589885081 otherIndex=3 windSum=? windValue=1 oppValue=0
362debugShowActiveSpans id=2 (4,3 0,1) t=0 (4,3) tEnd=0.3125 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
363debugShowActiveSpans id=2 (4,3 0,1) t=0.3125 (2.75,2.375) tEnd=0.499089216 other=4 otherT=0.125 otherIndex=1 windSum=? windValue=1 oppValue=0
364debugShowActiveSpans id=2 (4,3 0,1) t=0.499089216 (2.00364304,2.00182152) tEnd=0.539358601 other=3 otherT=0.576935809 otherIndex=2 windSum=-1 windValue=1 oppValue=0
365debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0 (1,5) tEnd=0.285714286 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
366debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0.285714286 (1.92128277,3.61807585) tEnd=0.576935809 other=4 otherT=0.539358601 otherIndex=2 windSum=? windValue=1 oppValue=0
367debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0.576935809 (2.00364304,2.00182152) tEnd=0.589885081 other=2 otherT=0.499089216 otherIndex=2 windSum=? windValue=1 oppValue=0
368debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0.589885081 (2.00580978,1.94599628) tEnd=1 other=1 otherT=0.311007457 otherIndex=2 windSum=? windValue=1 oppValue=0
369debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
370debugShowActiveSpans id=4 (3,2 1,5) t=0.125 (2.75,2.375) tEnd=0.539358601 other=2 otherT=0.3125 otherIndex=1 windSum=? windValue=1 oppValue=0
371debugShowActiveSpans id=4 (3,2 1,5) t=0.539358601 (1.92128277,3.61807585) tEnd=1 other=3 otherT=0.285714286 otherIndex=1 windSum=? windValue=1 oppValue=0
372activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
373findNextOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
374debugShowSort [3] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0.285714286 tEnd=0.311007457 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
375debugShowSort [0] {{4,3}, {0,1}} tStart=0.539358601 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
376debugShowSort [1] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0.285714286 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
377debugShowSort [2] {{4,3}, {0,1}} tStart=0.539358601 tEnd=0.499089216 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
378findNextOp firstIndex=[3] sign=-1
379activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
380activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
381activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
382markDoneBinary id=1 (0,1 2,3 5,1 4,3) t=0.285714286 [1] (1.84256566,1.92128277) tEnd=0.311007457 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
383findNextOp from:[1] to:[2] start=3 end=2
384bridgeOp current id=1 from=(2.00580978,1.94599628) to=(1.84256566,1.92128277)
385path.moveTo(2.00580978,1.94599628);
386path.cubicTo(1.9517231,1.93876874, 1.89728141,1.93057418, 1.84256566,1.92128277);
387findNextOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
388debugShowSort [1] {{4,3}, {0,1}} tStart=0.499089216 tEnd=0.539358601 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
389debugShowSort [2] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.576935809 tEnd=0.285714286 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
390debugShowSort [3] {{4,3}, {0,1}} tStart=0.499089216 tEnd=0.3125 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
391debugShowSort [0] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.576935809 tEnd=0.589885081 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
392findNextOp firstIndex=[1] sign=-1
393activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
394markDoneBinary id=3 (1,5 3,4 1,0 3,2) t=0.285714286 [1] (1.92128277,3.61807585) tEnd=0.576935809 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
395findNextOp chase.append id=3
396activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
397markDoneBinary id=2 (4,3 0,1) t=0.3125 [1] (2.75,2.375) tEnd=0.499089216 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
398findNextOp chase.append id=2
399activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
400markWinding id=3 (1,5 3,4 1,0 3,2) t=0.576935809 [2] (2.00364304,2.00182152) tEnd=0.589885081 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
401findNextOp chase.append id=3
402markDoneBinary id=2 (4,3 0,1) t=0.499089216 [2] (2.00364304,2.00182152) tEnd=0.539358601 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
403findNextOp from:[2] to:[3] start=2 end=3
404bridgeOp current id=2 from=(1.84256566,1.92128277) to=(2.00364304,2.00182152)
405findNextOp debugShowSort contourWinding=0 oppContourWinding=-1 sign=1
406debugShowSort [2] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.589885081 tEnd=0.576935809 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
407debugShowSort [3] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0.311007457 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
408debugShowSort [0] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.589885081 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
409debugShowSort [1] {{0,1}, {2,3}, {5,1}, {4,3}} tStart=0.311007457 tEnd=0.285714286 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
410findNextOp firstIndex=[2] sign=1
411activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
412markDoneBinary id=1 (0,1 2,3 5,1 4,3) t=0.311007457 [2] (2.00580978,1.94599628) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
413markDoneBinary id=2 (4,3 0,1) t=0 [0] (4,3) tEnd=0.3125 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
414findNextOp chase.append id=2
415activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
416markDoneBinary id=3 (1,5 3,4 1,0 3,2) t=0.589885081 [3] (2.00580978,1.94599628) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
417markDoneBinary id=4 (3,2 1,5) t=0 [0] (3,2) tEnd=0.125 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
418findNextOp chase.append id=4
419activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
420markDoneBinary id=3 (1,5 3,4 1,0 3,2) t=0.576935809 [2] (2.00364304,2.00182152) tEnd=0.589885081 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
421findNextOp from:[3] to:[1] start=2 end=1
422bridgeOp current id=3 from=(2.00364304,2.00182152) to=(2.00580978,1.94599628)
423path.lineTo(2.00364304,2.00182152);
424path.cubicTo(2.00425649,1.98283899, 2.0049727,1.96422386, 2.00580978,1.94599628);
425path.close();
426findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
427debugShowSort [0] {{3,2}, {1,5}} tStart=0.125 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
428debugShowSort [1] {{4,3}, {0,1}} tStart=0.3125 tEnd=0.499089216 sign=-1 windValue=1 windSum=-1 0->1 (max=1) done=1 tiny=0 opp=1
429debugShowSort [2] {{3,2}, {1,5}} tStart=0.125 tEnd=0.539358601 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
430debugShowSort [3] {{4,3}, {0,1}} tStart=0.3125 tEnd=0 sign=1 windValue=1 windSum=-1 1->0 (max=1) done=1 tiny=0 opp=1
431findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
432debugShowSort [0] {{3,2}, {1,5}} tStart=0.125 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
433debugShowSort [1] {{4,3}, {0,1}} tStart=0.3125 tEnd=0.499089216 sign=-1 windValue=1 windSum=-1 0->1 (max=1) done=1 tiny=0 opp=1
434debugShowSort [2] {{3,2}, {1,5}} tStart=0.125 tEnd=0.539358601 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
435debugShowSort [3] {{4,3}, {0,1}} tStart=0.3125 tEnd=0 sign=1 windValue=1 windSum=-1 1->0 (max=1) done=1 tiny=0 opp=1
436markWinding id=4 (3,2 1,5) t=0.125 [1] (2.75,2.375) tEnd=0.539358601 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
437debugShowActiveSpans id=3 (1,5 3,4 1,0 3,2) t=0 (1,5) tEnd=0.285714286 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
438debugShowActiveSpans id=4 (3,2 1,5) t=0.125 (2.75,2.375) tEnd=0.539358601 other=2 otherT=0.3125 otherIndex=1 windSum=-1 windValue=1 oppValue=0
439debugShowActiveSpans id=4 (3,2 1,5) t=0.539358601 (1.92128277,3.61807585) tEnd=1 other=3 otherT=0.285714286 otherIndex=1 windSum=? windValue=1 oppValue=0
440activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
441findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
442debugShowSort [0] {{3,2}, {1,5}} tStart=0.539358601 tEnd=0.125 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
443debugShowSort [1] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.285714286 tEnd=0.576935809 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
444debugShowSort [2] {{3,2}, {1,5}} tStart=0.539358601 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
445debugShowSort [3] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.285714286 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
446findNextOp firstIndex=[0] sign=1
447activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
448activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
449markWinding id=4 (3,2 1,5) t=0.539358601 [2] (1.92128277,3.61807585) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
450markWinding id=3 (1,5 3,4 1,0 3,2) t=0 [0] (1,5) tEnd=0.285714286 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
451findNextOp chase.append id=3
452activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
453markDoneBinary id=4 (3,2 1,5) t=0.125 [1] (2.75,2.375) tEnd=0.539358601 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
454findNextOp from:[4] to:[3] start=1 end=0
455bridgeOp current id=4 from=(2.75,2.375) to=(1.92128277,3.61807585)
456findNextOp simple
457markDoneBinary id=3 (1,5 3,4 1,0 3,2) t=0 [0] (1,5) tEnd=0.285714286 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
458bridgeOp current id=3 from=(1.92128277,3.61807585) to=(1,5)
459path.moveTo(2.75,2.375);
460path.lineTo(1.92128277,3.61807585);
461path.cubicTo(1.8163265,4.18367338, 1.57142854,4.71428585, 1,5);
462findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=-1
463debugShowSort [2] {{3,2}, {1,5}} tStart=0.539358601 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
464debugShowSort [3] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.285714286 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
465debugShowSort [0] {{3,2}, {1,5}} tStart=0.539358601 tEnd=0.125 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
466debugShowSort [1] {{1,5}, {3,4}, {1,0}, {3,2}} tStart=0.285714286 tEnd=0.576935809 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
467findNextOp firstIndex=[2] sign=-1
468activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
469activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
470activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
471markDoneBinary id=4 (3,2 1,5) t=0.539358601 [2] (1.92128277,3.61807585) tEnd=1 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
472findNextOp from:[4] to:[3] start=1 end=2
473bridgeOp current id=4 from=(1,5) to=(1.92128277,3.61807585)
474</div>
475
476<div id="cubicOp39da">
477computed quadratics given
478 {{2.512,1.571}, {2.64,1.66}, {2.8,1.8}, {3,2}},
479 {{2.41818762,1.98497726}, {2.82699049,2.00933065}, {3.20046793,1.99420472}, {3.49861995,2.00359946}},
480computed quadratics set 1
481 {{2.512,1.571}, {2.702,1.70225}, {3,2}},
482computed quadratics set 2
483 {{2.41818762,1.98497726}, {2.79879886,2.00375569}, {3.125,2}},
484 {{3.125,2}, {3.32670858,1.99910014}, {3.49861995,2.00359946}},
485</div>
486
487<div id="cubicOp40d">
488 SimplifyNew_Test [cubicOp40d]
489{{0,1}, {1,5}, {3,2}, {4,2}},
490{{4,2}, {0,1}},
491op difference
492{{2,3}, {2,4}, {1,0}, {5,1}},
493{{5,1}, {2,3}},
494debugShowCubicIntersection no self intersect {{2,3}, {2,4}, {1,0}, {5,1}}
495debugShowCubicLineIntersection wtTs[0]=0 {{2,3}, {2,4}, {1,0}, {5,1}} {{2,3}} wtTs[1]=1 {{5,1}} wnTs[0]=1 {{5,1}, {2,3}} wnTs[1]=0
496debugShowCubicIntersection wtTs[0]=0 {{2,3}, {2,4}, {1,0}, {5,1}} {{2,3}} wtTs[1]=0.226611502 {{1.915764455286163,3.0259142027140675}} wnTs[0]=0.5 {{0,1}, {1,5}, {3,2}, {4,2}} wnTs[1]=0.481278074
497debugShowCubicLineIntersection wtTs[0]=0.601219833 {{2,3}, {2,4}, {1,0}, {5,1}} {{2.2195247359544519,1.554881183988613}} wnTs[0]=0.445119 {{4,2}, {0,1}}
498debugShowCubicLineIntersection wtTs[0]=0.5 {{0,1}, {1,5}, {3,2}, {4,2}} {{2.0000000000000009,2.9999999999999996}} wnTs[0]=1 {{5,1}, {2,3}}
499debugShowLineIntersection wtTs[0]=0.454545455 {{5,1}, {2,3}} {{3.6363636363636362,1.9090909090909089}} wnTs[0]=0.0909091 {{4,2}, {0,1}}
500debugShowCubicIntersection no self intersect {{0,1}, {1,5}, {3,2}, {4,2}}
501debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {1,5}, {3,2}, {4,2}} {{0,1}} wtTs[1]=1 {{4,2}} wnTs[0]=1 {{4,2}, {0,1}} wnTs[1]=0
502debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0 (2,3) tEnd=0.226611502 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
503debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0.226611502 (1.91576445,3.02591419) tEnd=0.601219833 other=1 otherT=0.481278074 otherIndex=1 windSum=? windValue=1 oppValue=0
504debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0.601219833 (2.21952462,1.55488122) tEnd=1 other=2 otherT=0.445118816 otherIndex=2 windSum=? windValue=1 oppValue=0
505debugShowActiveSpans id=4 (5,1 2,3) t=0 (5,1) tEnd=0.454545455 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
506debugShowActiveSpans id=4 (5,1 2,3) t=0.454545455 (3.63636374,1.90909088) tEnd=1 other=2 otherT=0.0909090909 otherIndex=1 windSum=? windValue=1 oppValue=0
507debugShowActiveSpans id=4 (5,1 2,3) t=1 (2,3) tEnd=1 other=1 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
508debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0 (0,1) tEnd=0.481278074 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
509debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.481278074 (1.91576445,3.02591419) tEnd=0.5 other=3 otherT=0.226611502 otherIndex=2 windSum=? windValue=1 oppValue=0
510debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=3 otherT=0 otherIndex=1 windSum=? windValue=1 oppValue=0
511debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
512debugShowActiveSpans id=2 (4,2 0,1) t=0 (4,2) tEnd=0.0909090909 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
513debugShowActiveSpans id=2 (4,2 0,1) t=0.0909090909 (3.63636374,1.90909088) tEnd=0.445118816 other=4 otherT=0.454545455 otherIndex=1 windSum=? windValue=1 oppValue=0
514debugShowActiveSpans id=2 (4,2 0,1) t=0.445118816 (2.21952462,1.55488122) tEnd=1 other=3 otherT=0.601219833 otherIndex=3 windSum=? windValue=1 oppValue=0
515findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
516debugShowSort [0] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=1 tEnd=0.601219833 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
517debugShowSort [1] {{5,1}, {2,3}} tStart=0 tEnd=0.454545455 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
518findTop xyE=(5,1) xyS=(2.21952462,1.55488122)
519findTop dxyE=(12,3) dxyS=(2.8990562,-4.19263649) cross=-59.0088043 bumpsUp=true
520markWinding id=3 (2,3 2,4 1,0 5,1) t=0.601219833 [3] (2.21952462,1.55488122) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
521markWinding id=4 (5,1 2,3) t=0 [0] (5,1) tEnd=0.454545455 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
522markWinding id=3 (2,3 2,4 1,0 5,1) t=0.601219833 [3] (2.21952462,1.55488122) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
523activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
524markDoneBinary id=3 (2,3 2,4 1,0 5,1) t=0.601219833 [3] (2.21952462,1.55488122) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
525markDoneBinary id=4 (5,1 2,3) t=0 [0] (5,1) tEnd=0.454545455 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
526findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
527debugShowSort [0] {{5,1}, {2,3}} tStart=0.454545455 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
528debugShowSort [1] {{4,2}, {0,1}} tStart=0.0909090909 tEnd=0.445118816 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
529debugShowSort [2] {{5,1}, {2,3}} tStart=0.454545455 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
530debugShowSort [3] {{4,2}, {0,1}} tStart=0.0909090909 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
531findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
532debugShowSort [0] {{5,1}, {2,3}} tStart=0.454545455 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
533debugShowSort [1] {{4,2}, {0,1}} tStart=0.0909090909 tEnd=0.445118816 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
534debugShowSort [2] {{5,1}, {2,3}} tStart=0.454545455 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
535debugShowSort [3] {{4,2}, {0,1}} tStart=0.0909090909 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
536markWinding id=2 (4,2 0,1) t=0.0909090909 [1] (3.63636374,1.90909088) tEnd=0.445118816 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
537markWinding id=4 (5,1 2,3) t=0.454545455 [1] (3.63636374,1.90909088) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
538markWinding id=2 (4,2 0,1) t=0 [0] (4,2) tEnd=0.0909090909 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
539markWinding id=1 (0,1 1,5 3,2 4,2) t=0.5 [2] (2,3) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
540markWinding id=1 (0,1 1,5 3,2 4,2) t=0.5 [3] (2,3) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
541debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0 (2,3) tEnd=0.226611502 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
542debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0.226611502 (1.91576445,3.02591419) tEnd=0.601219833 other=1 otherT=0.481278074 otherIndex=1 windSum=? windValue=1 oppValue=0
543debugShowActiveSpans id=4 (5,1 2,3) t=0.454545455 (3.63636374,1.90909088) tEnd=1 other=2 otherT=0.0909090909 otherIndex=1 windSum=-1 windValue=1 oppValue=0
544debugShowActiveSpans id=4 (5,1 2,3) t=1 (2,3) tEnd=1 other=1 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
545debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0 (0,1) tEnd=0.481278074 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
546debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.481278074 (1.91576445,3.02591419) tEnd=0.5 other=3 otherT=0.226611502 otherIndex=2 windSum=? windValue=1 oppValue=0
547debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=3 otherT=0 otherIndex=1 windSum=1 windValue=1 oppValue=0
548debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=4 otherT=1 otherIndex=2 windSum=1 windValue=1 oppValue=0
549debugShowActiveSpans id=2 (4,2 0,1) t=0 (4,2) tEnd=0.0909090909 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
550debugShowActiveSpans id=2 (4,2 0,1) t=0.0909090909 (3.63636374,1.90909088) tEnd=0.445118816 other=4 otherT=0.454545455 otherIndex=1 windSum=1 windValue=1 oppValue=0
551debugShowActiveSpans id=2 (4,2 0,1) t=0.445118816 (2.21952462,1.55488122) tEnd=1 other=3 otherT=0.601219833 otherIndex=3 windSum=? windValue=1 oppValue=0
552activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
553markDoneBinary id=2 (4,2 0,1) t=0.0909090909 [1] (3.63636374,1.90909088) tEnd=0.445118816 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
554findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
555debugShowSort [0] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.601219833 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
556debugShowSort [1] {{4,2}, {0,1}} tStart=0.445118816 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
557debugShowSort [2] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.601219833 tEnd=0.226611502 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
558debugShowSort [3] {{4,2}, {0,1}} tStart=0.445118816 tEnd=0.0909090909 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
559findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
560debugShowSort [0] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.601219833 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
561debugShowSort [1] {{4,2}, {0,1}} tStart=0.445118816 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
562debugShowSort [2] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.601219833 tEnd=0.226611502 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
563debugShowSort [3] {{4,2}, {0,1}} tStart=0.445118816 tEnd=0.0909090909 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
564markWinding id=2 (4,2 0,1) t=0.445118816 [2] (2.21952462,1.55488122) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
565markWinding id=1 (0,1 1,5 3,2 4,2) t=0 [0] (0,1) tEnd=0.481278074 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
566markWinding id=3 (2,3 2,4 1,0 5,1) t=0.226611502 [2] (1.91576445,3.02591419) tEnd=0.601219833 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
567debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0 (2,3) tEnd=0.226611502 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
568debugShowActiveSpans id=3 (2,3 2,4 1,0 5,1) t=0.226611502 (1.91576445,3.02591419) tEnd=0.601219833 other=1 otherT=0.481278074 otherIndex=1 windSum=-1 windValue=1 oppValue=0
569debugShowActiveSpans id=4 (5,1 2,3) t=0.454545455 (3.63636374,1.90909088) tEnd=1 other=2 otherT=0.0909090909 otherIndex=1 windSum=-1 windValue=1 oppValue=0
570debugShowActiveSpans id=4 (5,1 2,3) t=1 (2,3) tEnd=1 other=1 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
571debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0 (0,1) tEnd=0.481278074 other=2 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
572debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.481278074 (1.91576445,3.02591419) tEnd=0.5 other=3 otherT=0.226611502 otherIndex=2 windSum=? windValue=1 oppValue=0
573debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=3 otherT=0 otherIndex=1 windSum=1 windValue=1 oppValue=0
574debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=4 otherT=1 otherIndex=2 windSum=1 windValue=1 oppValue=0
575debugShowActiveSpans id=2 (4,2 0,1) t=0 (4,2) tEnd=0.0909090909 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
576debugShowActiveSpans id=2 (4,2 0,1) t=0.445118816 (2.21952462,1.55488122) tEnd=1 other=3 otherT=0.601219833 otherIndex=3 windSum=1 windValue=1 oppValue=0
577activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
578findNextOp simple
579markDoneBinary id=2 (4,2 0,1) t=0.445118816 [2] (2.21952462,1.55488122) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
580bridgeOp current id=2 from=(2.21952462,1.55488122) to=(0,1)
581findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
582debugShowSort [2] {{0,1}, {1,5}, {3,2}, {4,2}} tStart=0.481278074 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
583debugShowSort [3] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.226611502 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
584debugShowSort [0] {{0,1}, {1,5}, {3,2}, {4,2}} tStart=0.481278074 tEnd=0.5 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
585debugShowSort [1] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.226611502 tEnd=0.601219833 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
586findNextOp firstIndex=[2] sign=1
587activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
588markDoneBinary id=3 (2,3 2,4 1,0 5,1) t=0 [0] (2,3) tEnd=0 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
589markDoneBinary id=3 (2,3 2,4 1,0 5,1) t=0 [1] (2,3) tEnd=0.226611502 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
590findNextOp chase.append id=3
591activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
592markDoneBinary id=1 (0,1 1,5 3,2 4,2) t=0.481278074 [1] (1.91576445,3.02591419) tEnd=0.5 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
593findNextOp chase.append id=1
594activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
595markDoneBinary id=1 (0,1 1,5 3,2 4,2) t=0 [0] (0,1) tEnd=0.481278074 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
596findNextOp from:[1] to:[3] start=2 end=3
597bridgeOp current id=1 from=(0,1) to=(1.91576445,3.02591419)
598path.moveTo(2.21952462,1.55488122);
599path.lineTo(0,1);
600path.cubicTo(0.481278062,2.92511225, 1.19418478,3.22882462, 1.91576445,3.02591419);
601findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
602debugShowSort [2] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.601219833 tEnd=0.226611502 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
603debugShowSort [3] {{4,2}, {0,1}} tStart=0.445118816 tEnd=0.0909090909 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
604debugShowSort [0] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0.601219833 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
605debugShowSort [1] {{4,2}, {0,1}} tStart=0.445118816 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
606findNextOp firstIndex=[2] sign=1
607activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
608activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
609activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
610markDoneBinary id=3 (2,3 2,4 1,0 5,1) t=0.226611502 [2] (1.91576445,3.02591419) tEnd=0.601219833 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
611findNextOp from:[3] to:[2] start=2 end=3
612bridgeOp current id=3 from=(1.91576445,3.02591419) to=(2.21952462,1.55488122)
613path.cubicTo(1.86140633,2.74398875, 1.8575213,2.07841325, 2.21952462,1.55488122);
614path.close();
615debugShowActiveSpans id=4 (5,1 2,3) t=0.454545455 (3.63636374,1.90909088) tEnd=1 other=2 otherT=0.0909090909 otherIndex=1 windSum=-1 windValue=1 oppValue=0
616debugShowActiveSpans id=4 (5,1 2,3) t=1 (2,3) tEnd=1 other=1 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
617debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=3 otherT=0 otherIndex=1 windSum=1 windValue=1 oppValue=0
618debugShowActiveSpans id=1 (0,1 1,5 3,2 4,2) t=0.5 (2,3) tEnd=1 other=4 otherT=1 otherIndex=2 windSum=1 windValue=1 oppValue=0
619debugShowActiveSpans id=2 (4,2 0,1) t=0 (4,2) tEnd=0.0909090909 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
620activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
621findNextOp simple
622markDoneBinary id=1 (0,1 1,5 3,2 4,2) t=0.5 [2] (2,3) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
623markDoneBinary id=1 (0,1 1,5 3,2 4,2) t=0.5 [3] (2,3) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
624bridgeOp current id=1 from=(2,3) to=(4,2)
625path.moveTo(2,3);
626path.cubicTo(2.75,2.75, 3.5,2, 4,2);
627findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
628debugShowSort [3] {{4,2}, {0,1}} tStart=0.0909090909 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
629debugShowSort [0] {{5,1}, {2,3}} tStart=0.454545455 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
630debugShowSort [1] {{4,2}, {0,1}} tStart=0.0909090909 tEnd=0.445118816 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
631debugShowSort [2] {{5,1}, {2,3}} tStart=0.454545455 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
632findNextOp firstIndex=[3] sign=1
633activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
634activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
635activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
636markDoneBinary id=2 (4,2 0,1) t=0 [0] (4,2) tEnd=0.0909090909 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
637findNextOp from:[2] to:[4] start=1 end=2
638bridgeOp current id=2 from=(4,2) to=(3.63636374,1.90909088)
639findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
640debugShowSort [1] {{5,1}, {2,3}} tStart=1 tEnd=0.454545455 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
641debugShowSort [2] {{0,1}, {1,5}, {3,2}, {4,2}} tStart=0.5 tEnd=0.481278074 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
642debugShowSort [3] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0 tEnd=0.226611502 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
643debugShowSort [0] {{0,1}, {1,5}, {3,2}, {4,2}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
644findNextOp firstIndex=[1] sign=1
645activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
646activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
647activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
648markDoneBinary id=4 (5,1 2,3) t=0.454545455 [1] (3.63636374,1.90909088) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
649findNextOp from:[4] to:[1] start=3 end=4
650bridgeOp current id=4 from=(3.63636374,1.90909088) to=(2,3)
651path.lineTo(3.63636374,1.90909088);
652path.lineTo(2,3);
653path.close();
654debugShowActiveSpans id=4 (5,1 2,3) t=1 (2,3) tEnd=1 other=1 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
655findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
656debugShowSort [0] {{0,1}, {1,5}, {3,2}, {4,2}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
657debugShowSort [1] {{5,1}, {2,3}} tStart=1 tEnd=0.454545455 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
658debugShowSort [2] {{0,1}, {1,5}, {3,2}, {4,2}} tStart=0.5 tEnd=0.481278074 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
659debugShowSort [3] {{2,3}, {2,4}, {1,0}, {5,1}} tStart=0 tEnd=0.226611502 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
660</div>
661
662<div id="cubicOp41i">
663 SimplifyNew_Test [cubicOp41i]
664{{0,1}, {2,6}, {4,3}, {6,4}},
665{{6,4}, {0,1}},
666op intersect
667{{3,4}, {4,6}, {1,0}, {6,2}},
668{{6,2}, {3,4}},
669debugShowCubicIntersection no self intersect {{0,1}, {2,6}, {4,3}, {6,4}}
670debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {2,6}, {4,3}, {6,4}} {{0,1}} wtTs[1]=1 {{6,4}} wnTs[0]=1 {{6,4}, {0,1}} wnTs[1]=0
671debugShowCubicIntersection wtTs[0]=0.5 {{0,1}, {2,6}, {4,3}, {6,4}} {{2.9999999999509201,3.9999999999999996}} wtTs[1]=0.521137715 {{3.1268262924910069,3.9974325146613827}} wnTs[0]=0 {{3,4}, {4,6}, {1,0}, {6,2}} wnTs[1]=0.317571165
672debugShowCubicLineIntersection wtTs[0]=0.5 {{0,1}, {2,6}, {4,3}, {6,4}} {{3,4}} wnTs[0]=1 {{6,2}, {3,4}}
673debugShowCubicLineIntersection wtTs[0]=0.580941393 {{3,4}, {4,6}, {1,0}, {6,2}} {{3.0456725133851208,2.5228362566925604}} wnTs[0]=0.492388 {{6,4}, {0,1}}
674debugShowLineIntersection wtTs[0]=0.285714286 {{6,4}, {0,1}} {{4.2857142857142856,3.1428571428571428}} wnTs[0]=0.571429 {{6,2}, {3,4}}
675debugShowCubicIntersection no self intersect {{3,4}, {4,6}, {1,0}, {6,2}}
676debugShowCubicLineIntersection wtTs[0]=0 {{3,4}, {4,6}, {1,0}, {6,2}} {{3,4}} wtTs[1]=0.333333333 {{3.1111111111111116,3.9259259259259256}} wtTs[2]=1 {{6,2}} wnTs[0]=1 {{6,2}, {3,4}} wnTs[1]=0.962962963 wnTs[2]=0
677debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0 (0,1) tEnd=0.5 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
678debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0.5 (3,4) tEnd=0.521137715 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
679debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0.521137715 (3.12682629,3.99743247) tEnd=1 other=3 otherT=0.317571165 otherIndex=2 windSum=? windValue=1 oppValue=0
680debugShowActiveSpans id=2 (6,4 0,1) t=0 (6,4) tEnd=0.285714286 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
681debugShowActiveSpans id=2 (6,4 0,1) t=0.285714286 (4.28571415,3.14285707) tEnd=0.492387914 other=4 otherT=0.571428571 otherIndex=1 windSum=? windValue=1 oppValue=0
682debugShowActiveSpans id=2 (6,4 0,1) t=0.492387914 (3.04567242,2.52283621) tEnd=1 other=3 otherT=0.580941393 otherIndex=4 windSum=? windValue=1 oppValue=0
683debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0 (3,4) tEnd=0.317571165 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
684debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.317571165 (3.12682629,3.99743247) tEnd=0.333333333 other=1 otherT=0.521137715 otherIndex=3 windSum=? windValue=1 oppValue=0
685debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.333333333 (3.11111116,3.92592597) tEnd=0.580941393 other=4 otherT=0.962962963 otherIndex=2 windSum=? windValue=1 oppValue=0
686debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.580941393 (3.04567242,2.52283621) tEnd=1 other=2 otherT=0.492387914 otherIndex=2 windSum=? windValue=1 oppValue=0
687debugShowActiveSpans id=4 (6,2 3,4) t=0 (6,2) tEnd=0.571428571 other=3 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
688debugShowActiveSpans id=4 (6,2 3,4) t=0.571428571 (4.28571415,3.14285707) tEnd=0.962962963 other=2 otherT=0.285714286 otherIndex=1 windSum=? windValue=1 oppValue=0
689debugShowActiveSpans id=4 (6,2 3,4) t=0.962962963 (3.11111116,3.92592597) tEnd=1 other=3 otherT=0.333333333 otherIndex=3 windSum=? windValue=1 oppValue=0
690findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
691debugShowSort [0] {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0 tEnd=0.5 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
692debugShowSort [1] {{6,4}, {0,1}} tStart=1 tEnd=0.492387914 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
693findTop xyE=(0,1) xyS=(3,4)
694findTop dxyE=(6,15) dxyS=(6,9.81599801e-11) cross=-90 bumpsUp=false
695markWinding id=1 (0,1 2,6 4,3 6,4) t=0 [0] (0,1) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
696markWinding id=2 (6,4 0,1) t=0.492387914 [2] (3.04567242,2.52283621) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
697markWinding id=1 (0,1 2,6 4,3 6,4) t=0 [0] (0,1) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
698activeOp op=sect miFrom=1 miTo=0 suFrom=0 suTo=0 result=0
699markDoneBinary id=1 (0,1 2,6 4,3 6,4) t=0 [0] (0,1) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
700markDoneBinary id=2 (6,4 0,1) t=0.492387914 [2] (3.04567242,2.52283621) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
701findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=-1
702debugShowSort [0] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.580941393 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
703debugShowSort [1] {{6,4}, {0,1}} tStart=0.492387914 tEnd=1 sign=-1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=1
704debugShowSort [2] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.580941393 tEnd=0.333333333 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
705debugShowSort [3] {{6,4}, {0,1}} tStart=0.492387914 tEnd=0.285714286 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
706findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
707debugShowSort [1] {{6,4}, {0,1}} tStart=0.492387914 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
708debugShowSort [2] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.580941393 tEnd=0.333333333 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
709debugShowSort [3] {{6,4}, {0,1}} tStart=0.492387914 tEnd=0.285714286 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
710debugShowSort [0] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.580941393 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
711markWinding id=3 (3,4 4,6 1,0 6,2) t=0.333333333 [3] (3.11111116,3.92592597) tEnd=0.580941393 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
712markWinding id=2 (6,4 0,1) t=0.285714286 [1] (4.28571415,3.14285707) tEnd=0.492387914 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
713markWinding id=3 (3,4 4,6 1,0 6,2) t=0.580941393 [4] (3.04567242,2.52283621) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
714markWinding id=4 (6,2 3,4) t=0 [0] (6,2) tEnd=0.571428571 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
715debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0.5 (3,4) tEnd=0.521137715 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
716debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0.521137715 (3.12682629,3.99743247) tEnd=1 other=3 otherT=0.317571165 otherIndex=2 windSum=? windValue=1 oppValue=0
717debugShowActiveSpans id=2 (6,4 0,1) t=0 (6,4) tEnd=0.285714286 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
718debugShowActiveSpans id=2 (6,4 0,1) t=0.285714286 (4.28571415,3.14285707) tEnd=0.492387914 other=4 otherT=0.571428571 otherIndex=1 windSum=1 windValue=1 oppValue=0
719debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0 (3,4) tEnd=0.317571165 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
720debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.317571165 (3.12682629,3.99743247) tEnd=0.333333333 other=1 otherT=0.521137715 otherIndex=3 windSum=? windValue=1 oppValue=0
721debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.333333333 (3.11111116,3.92592597) tEnd=0.580941393 other=4 otherT=0.962962963 otherIndex=2 windSum=-1 windValue=1 oppValue=0
722debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.580941393 (3.04567242,2.52283621) tEnd=1 other=2 otherT=0.492387914 otherIndex=2 windSum=-1 windValue=1 oppValue=0
723debugShowActiveSpans id=4 (6,2 3,4) t=0 (6,2) tEnd=0.571428571 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
724debugShowActiveSpans id=4 (6,2 3,4) t=0.571428571 (4.28571415,3.14285707) tEnd=0.962962963 other=2 otherT=0.285714286 otherIndex=1 windSum=? windValue=1 oppValue=0
725debugShowActiveSpans id=4 (6,2 3,4) t=0.962962963 (3.11111116,3.92592597) tEnd=1 other=3 otherT=0.333333333 otherIndex=3 windSum=? windValue=1 oppValue=0
726activeOp op=sect miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
727findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
728debugShowSort [1] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.333333333 tEnd=0.580941393 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
729debugShowSort [2] {{6,2}, {3,4}} tStart=0.962962963 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
730debugShowSort [3] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.333333333 tEnd=0.317571165 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
731debugShowSort [0] {{6,2}, {3,4}} tStart=0.962962963 tEnd=0.571428571 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
732findNextOp firstIndex=[1] sign=-1
733activeOp op=sect miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
734markWinding id=4 (6,2 3,4) t=0.962962963 [2] (3.11111116,3.92592597) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
735findNextOp chase.append id=4
736activeOp op=sect miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
737markWinding id=3 (3,4 4,6 1,0 6,2) t=0.317571165 [2] (3.12682629,3.99743247) tEnd=0.333333333 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
738findNextOp chase.append id=3
739activeOp op=sect miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
740markWinding id=4 (6,2 3,4) t=0.571428571 [1] (4.28571415,3.14285707) tEnd=0.962962963 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
741findNextOp chase.append id=4
742markDoneBinary id=3 (3,4 4,6 1,0 6,2) t=0.333333333 [3] (3.11111116,3.92592597) tEnd=0.580941393 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
743findNextOp from:[3] to:[4] start=2 end=3
744bridgeOp current id=3 from=(3.04567242,2.52283621) to=(3.11111116,3.92592597)
745path.moveTo(3.04567242,2.52283621);
746path.cubicTo(2.9460392,2.99209714, 3.02857494,3.54075789, 3.11111116,3.92592597);
747markUnsortable id=4 (6,2 3,4) t=0.962962963 [2] (3.11111116,3.92592597) tEnd=1 newWindSum=0 windSum=1 windValue=1
748markUnsortable id=1 (0,1 2,6 4,3 6,4) t=0.5 [2] (3,4) tEnd=0.521137715 newWindSum=0 windSum=? windValue=1
749markUnsortable id=1 (0,1 2,6 4,3 6,4) t=0.5 [1] (3,4) tEnd=0.5 newWindSum=0 windSum=? windValue=1
750markUnsortable id=3 (3,4 4,6 1,0 6,2) t=0 [1] (3,4) tEnd=0.317571165 newWindSum=0 windSum=? windValue=1
751findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
752debugShowSort [0] {{6,2}, {3,4}} tStart=1 tEnd=0.962962963 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
753debugShowSort [1] {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0.5 tEnd=0.521137715 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=1
754debugShowSort [2] *** UNSORTABLE *** {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0.5 tEnd=0.5 sign=1 windValue=1 windSum=? 2->1 (max=2) done=1 tiny=1 opp=1
755debugShowSort [3] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0 tEnd=0.317571165 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
756markDoneBinary id=4 (6,2 3,4) t=0.962962963 [2] (3.11111116,3.92592597) tEnd=1 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
757path.lineTo(3,4);
758debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0.5 (3,4) tEnd=0.521137715 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
759debugShowActiveSpans id=1 (0,1 2,6 4,3 6,4) t=0.521137715 (3.12682629,3.99743247) tEnd=1 other=3 otherT=0.317571165 otherIndex=2 windSum=? windValue=1 oppValue=0
760debugShowActiveSpans id=2 (6,4 0,1) t=0 (6,4) tEnd=0.285714286 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
761debugShowActiveSpans id=2 (6,4 0,1) t=0.285714286 (4.28571415,3.14285707) tEnd=0.492387914 other=4 otherT=0.571428571 otherIndex=1 windSum=1 windValue=1 oppValue=0
762debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0 (3,4) tEnd=0.317571165 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
763debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.317571165 (3.12682629,3.99743247) tEnd=0.333333333 other=1 otherT=0.521137715 otherIndex=3 windSum=1 windValue=1 oppValue=0
764debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.580941393 (3.04567242,2.52283621) tEnd=1 other=2 otherT=0.492387914 otherIndex=2 windSum=-1 windValue=1 oppValue=0
765debugShowActiveSpans id=4 (6,2 3,4) t=0 (6,2) tEnd=0.571428571 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
766debugShowActiveSpans id=4 (6,2 3,4) t=0.571428571 (4.28571415,3.14285707) tEnd=0.962962963 other=2 otherT=0.285714286 otherIndex=1 windSum=-1 windValue=1 oppValue=0
767activeOp op=sect miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
768findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
769debugShowSort [0] {{6,2}, {3,4}} tStart=0.962962963 tEnd=0.571428571 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
770debugShowSort [1] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.333333333 tEnd=0.580941393 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
771debugShowSort [2] {{6,2}, {3,4}} tStart=0.962962963 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
772debugShowSort [3] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.333333333 tEnd=0.317571165 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
773findNextOp firstIndex=[0] sign=1
774activeOp op=sect miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
775activeOp op=sect miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
776activeOp op=sect miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
777markDoneBinary id=4 (6,2 3,4) t=0.571428571 [1] (4.28571415,3.14285707) tEnd=0.962962963 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
778findNextOp from:[4] to:[3] start=3 end=2
779bridgeOp current id=4 from=(4.28571415,3.14285707) to=(3.11111116,3.92592597)
780findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=-1
781debugShowSort [1] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.317571165 tEnd=0.333333333 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
782debugShowSort [2] {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0.521137715 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
783debugShowSort [3] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.317571165 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
784debugShowSort [0] {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0.521137715 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
785findNextOp firstIndex=[1] sign=-1
786activeOp op=sect miFrom=1 miTo=0 suFrom=1 suTo=1 result=1
787markWinding id=1 (0,1 2,6 4,3 6,4) t=0.5 [2] (3,4) tEnd=0.521137715 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
788findNextOp chase.append id=1
789activeOp op=sect miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
790markDoneBinary id=3 (3,4 4,6 1,0 6,2) t=0 [0] (3,4) tEnd=0 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
791markDoneBinary id=3 (3,4 4,6 1,0 6,2) t=0 [1] (3,4) tEnd=0.317571165 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
792findNextOp chase.append id=3
793activeOp op=sect miFrom=0 miTo=1 suFrom=0 suTo=0 result=0
794markDoneBinary id=1 (0,1 2,6 4,3 6,4) t=0.521137715 [3] (3.12682629,3.99743247) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
795markDoneBinary id=2 (6,4 0,1) t=0 [0] (6,4) tEnd=0.285714286 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
796findNextOp chase.append id=2
797markDoneBinary id=3 (3,4 4,6 1,0 6,2) t=0.317571165 [2] (3.12682629,3.99743247) tEnd=0.333333333 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
798findNextOp from:[3] to:[1] start=3 end=2
799bridgeOp current id=3 from=(3.11111116,3.92592597) to=(3.12682629,3.99743247)
800path.moveTo(4.28571415,3.14285707);
801path.lineTo(3.11111116,3.92592597);
802path.cubicTo(3.11636519,3.9504447, 3.12161922,3.97430134, 3.12682629,3.99743247);
803setSpans unsortable [2] (3,4) [3] (3.12682629,3.99743247)
804setSpans unsortable [3] (3,4) [2] (3.11111116,3.92592597)
805markUnsortable id=1 (0,1 2,6 4,3 6,4) t=0.5 [2] (3,4) tEnd=0.521137715 newWindSum=0 windSum=1 windValue=1
806markUnsortable id=1 (0,1 2,6 4,3 6,4) t=0.5 [1] (3,4) tEnd=0.5 newWindSum=0 windSum=? windValue=1
807markUnsortable id=4 (6,2 3,4) t=0.962962963 [2] (3.11111116,3.92592597) tEnd=1 newWindSum=0 windSum=1 windValue=1
808findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=-1
809debugShowSort [0] *** UNSORTABLE *** {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0.5 tEnd=0.521137715 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
810debugShowSort [1] *** UNSORTABLE *** {{0,1}, {2,6}, {4,3}, {6,4}} tStart=0.5 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=1 tiny=1 opp=0
811debugShowSort [2] *** UNSORTABLE *** {{6,2}, {3,4}} tStart=1 tEnd=0.962962963 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
812path.cubicTo(3.08455086,3.99910641, 3.04227543,4, 3,4);
813markDoneBinary id=1 (0,1 2,6 4,3 6,4) t=0.5 [2] (3,4) tEnd=0.521137715 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
814debugShowActiveSpans id=2 (6,4 0,1) t=0.285714286 (4.28571415,3.14285707) tEnd=0.492387914 other=4 otherT=0.571428571 otherIndex=1 windSum=1 windValue=1 oppValue=0
815debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.580941393 (3.04567242,2.52283621) tEnd=1 other=2 otherT=0.492387914 otherIndex=2 windSum=-1 windValue=1 oppValue=0
816debugShowActiveSpans id=4 (6,2 3,4) t=0 (6,2) tEnd=0.571428571 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
817activeOp op=sect miFrom=0 miTo=1 suFrom=1 suTo=1 result=1
818findNextOp debugShowSort contourWinding=1 oppContourWinding=-1 sign=1
819debugShowSort [3] {{6,4}, {0,1}} tStart=0.492387914 tEnd=0.285714286 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
820debugShowSort [0] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.580941393 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
821debugShowSort [1] {{6,4}, {0,1}} tStart=0.492387914 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
822debugShowSort [2] {{3,4}, {4,6}, {1,0}, {6,2}} tStart=0.580941393 tEnd=0.333333333 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
823findNextOp firstIndex=[3] sign=1
824activeOp op=sect miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
825activeOp op=sect miFrom=0 miTo=1 suFrom=0 suTo=0 result=0
826activeOp op=sect miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
827markDoneBinary id=2 (6,4 0,1) t=0.285714286 [1] (4.28571415,3.14285707) tEnd=0.492387914 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
828findNextOp from:[2] to:[3] start=4 end=3
829bridgeOp current id=2 from=(4.28571415,3.14285707) to=(3.04567242,2.52283621)
830path.moveTo(4.28571415,3.14285707);
831path.lineTo(3.04567242,2.52283621);
832setSpans unsortable [1] (3,4) [2] (3.12682629,3.99743247)
833setSpans all tiny unsortable [1] (3,4) [0] (0,1)
834setSpans unsortable [3] (3,4) [2] (3.11111116,3.92592597)
835setSpans unsortable [2] (3,4) [3] (3.12682629,3.99743247)
836setSpans unsortable [1] (3,4) [2] (3.12682629,3.99743247)
837setSpans unsortable [3] (3,4) [2] (3.11111116,3.92592597)
838setSpans unsortable [3] (3,4) [2] (3.11111116,3.92592597)
839setSpans unsortable [2] (3,4) [3] (3.12682629,3.99743247)
840setSpans unsortable [1] (3,4) [2] (3.12682629,3.99743247)
841debugShowActiveSpans id=3 (3,4 4,6 1,0 6,2) t=0.580941393 (3.04567242,2.52283621) tEnd=1 other=2 otherT=0.492387914 otherIndex=2 windSum=-1 windValue=1 oppValue=0
842debugShowActiveSpans id=4 (6,2 3,4) t=0 (6,2) tEnd=0.571428571 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
843activeOp op=sect miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
844markDoneBinary id=3 (3,4 4,6 1,0 6,2) t=0.580941393 [4] (3.04567242,2.52283621) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
845markDoneBinary id=4 (6,2 3,4) t=0 [0] (6,2) tEnd=0.571428571 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
846</div>
847
848<div id="cubicOp42d">
849 SimplifyNew_Test [cubicOp42d]
850{{0,1}, {1,2}, {6,5}, {5,4}},
851{{5,4}, {0,1}},
852op difference
853{{5,6}, {4,5}, {1,0}, {2,1}},
854{{2,1}, {5,6}},
855debugShowCubicIntersection no self intersect {{5,6}, {4,5}, {1,0}, {2,1}}
856debugShowCubicLineIntersection wtTs[0]=0 {{5,6}, {4,5}, {1,0}, {2,1}} {{5,6}} wtTs[1]=1 {{2,1}} wnTs[0]=1 {{2,1}, {5,6}} wnTs[1]=0
857debugShowCubicIntersection no intersect {{5,6}, {4,5}, {1,0}, {2,1}} {{0,1}, {1,2}, {6,5}, {5,4}}
858debugShowCubicLineIntersection wtTs[0]=0.520955385 {{5,6}, {4,5}, {1,0}, {2,1}} {{2.6570733652881806,2.5942440191729084}} wnTs[0]=0.468585 {{5,4}, {0,1}}
859debugShowCubicLineIntersection wtTs[0]=0.520955385 {{0,1}, {1,2}, {6,5}, {5,4}} {{3.4057559808270916,3.3429266347118194}} wnTs[0]=0.468585 {{2,1}, {5,6}}
860debugShowLineIntersection wtTs[0]=0.375 {{2,1}, {5,6}} {{3.125,2.875}} wnTs[0]=0.375 {{5,4}, {0,1}}
861debugShowCubicIntersection no self intersect {{0,1}, {1,2}, {6,5}, {5,4}}
862debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {1,2}, {6,5}, {5,4}} {{0,1}} wtTs[1]=1 {{5,4}} wnTs[0]=1 {{5,4}, {0,1}} wnTs[1]=0
863debugShowActiveSpans id=3 (5,6 4,5 1,0 2,1) t=0 (5,6) tEnd=0.520955385 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
864debugShowActiveSpans id=3 (5,6 4,5 1,0 2,1) t=0.520955385 (2.65707326,2.594244) tEnd=1 other=2 otherT=0.468585327 otherIndex=2 windSum=? windValue=1 oppValue=0
865debugShowActiveSpans id=4 (2,1 5,6) t=0 (2,1) tEnd=0.375 other=3 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
866debugShowActiveSpans id=4 (2,1 5,6) t=0.375 (3.125,2.875) tEnd=0.468585327 other=2 otherT=0.375 otherIndex=1 windSum=? windValue=1 oppValue=0
867debugShowActiveSpans id=4 (2,1 5,6) t=0.468585327 (3.405756,3.34292674) tEnd=1 other=1 otherT=0.520955385 otherIndex=1 windSum=? windValue=1 oppValue=0
868debugShowActiveSpans id=1 (0,1 1,2 6,5 5,4) t=0 (0,1) tEnd=0.520955385 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
869debugShowActiveSpans id=1 (0,1 1,2 6,5 5,4) t=0.520955385 (3.405756,3.34292674) tEnd=1 other=4 otherT=0.468585327 otherIndex=2 windSum=? windValue=1 oppValue=0
870debugShowActiveSpans id=2 (5,4 0,1) t=0 (5,4) tEnd=0.375 other=1 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
871debugShowActiveSpans id=2 (5,4 0,1) t=0.375 (3.125,2.875) tEnd=0.468585327 other=4 otherT=0.375 otherIndex=1 windSum=? windValue=1 oppValue=0
872debugShowActiveSpans id=2 (5,4 0,1) t=0.468585327 (2.65707326,2.594244) tEnd=1 other=3 otherT=0.520955385 otherIndex=1 windSum=? windValue=1 oppValue=0
873findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
874debugShowSort [0] {{0,1}, {1,2}, {6,5}, {5,4}} tStart=0 tEnd=0.520955385 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
875debugShowSort [1] {{5,4}, {0,1}} tStart=1 tEnd=0.468585327 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
876findTop xyE=(0,1) xyS=(3.405756,3.34292674)
877findTop dxyE=(3,3) dxyS=(7.361094,4.36636353) cross=-8.98419189 bumpsUp=false
878markWinding id=1 (0,1 1,2 6,5 5,4) t=0 [0] (0,1) tEnd=0.520955385 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
879markWinding id=2 (5,4 0,1) t=0.468585327 [2] (2.65707326,2.594244) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
880markWinding id=1 (0,1 1,2 6,5 5,4) t=0 [0] (0,1) tEnd=0.520955385 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
881activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
882findNextOp simple
883markDoneBinary id=1 (0,1 1,2 6,5 5,4) t=0 [0] (0,1) tEnd=0.520955385 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
884bridgeOp current id=1 from=(3.405756,3.34292674) to=(0,1)
885path.moveTo(3.405756,3.34292674);
886path.cubicTo(2.12748885,2.58469963, 0.520955384,1.52095544, 0,1);
887findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
888debugShowSort [1] {{5,4}, {0,1}} tStart=0.468585327 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
889debugShowSort [2] {{5,6}, {4,5}, {1,0}, {2,1}} tStart=0.520955385 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
890debugShowSort [3] {{5,4}, {0,1}} tStart=0.468585327 tEnd=0.375 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
891debugShowSort [0] {{5,6}, {4,5}, {1,0}, {2,1}} tStart=0.520955385 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
892findNextOp firstIndex=[1] sign=-1
893activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
894markWinding id=3 (5,6 4,5 1,0 2,1) t=0 [0] (5,6) tEnd=0.520955385 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
895markWinding id=4 (2,1 5,6) t=0.468585327 [2] (3.405756,3.34292674) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
896findNextOp chase.append id=4
897activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
898markDoneBinary id=2 (5,4 0,1) t=0.375 [1] (3.125,2.875) tEnd=0.468585327 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
899findNextOp chase.append id=2
900activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
901markDoneBinary id=3 (5,6 4,5 1,0 2,1) t=0.520955385 [1] (2.65707326,2.594244) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
902markDoneBinary id=4 (2,1 5,6) t=0 [0] (2,1) tEnd=0.375 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
903findNextOp chase.append id=4
904markDoneBinary id=2 (5,4 0,1) t=0.468585327 [2] (2.65707326,2.594244) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
905findNextOp from:[2] to:[3] start=1 end=0
906bridgeOp current id=2 from=(0,1) to=(2.65707326,2.594244)
907findNextOp simple
908markDoneBinary id=3 (5,6 4,5 1,0 2,1) t=0 [0] (5,6) tEnd=0.520955385 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
909bridgeOp current id=3 from=(2.65707326,2.594244) to=(5,6)
910path.lineTo(2.65707326,2.594244);
911path.cubicTo(3.41530037,3.87251115, 4.47904444,5.47904444, 5,6);
912findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
913debugShowSort [2] {{2,1}, {5,6}} tStart=0.468585327 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
914debugShowSort [3] {{0,1}, {1,2}, {6,5}, {5,4}} tStart=0.520955385 tEnd=1 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=1
915debugShowSort [0] {{2,1}, {5,6}} tStart=0.468585327 tEnd=0.375 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
916debugShowSort [1] {{0,1}, {1,2}, {6,5}, {5,4}} tStart=0.520955385 tEnd=0 sign=1 windValue=1 windSum=1 2->1 (max=2) done=1 tiny=0 opp=1
917findNextOp firstIndex=[2] sign=-1
918activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
919markDoneBinary id=1 (0,1 1,2 6,5 5,4) t=0.520955385 [1] (3.405756,3.34292674) tEnd=1 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
920markDoneBinary id=2 (5,4 0,1) t=0 [0] (5,4) tEnd=0.375 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
921findNextOp chase.append id=2
922activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
923markWinding id=4 (2,1 5,6) t=0.375 [1] (3.125,2.875) tEnd=0.468585327 newWindSum=-1 newOppSum=2 oppSum=? windSum=? windValue=1
924findNextOp chase.append id=4
925activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
926markDoneBinary id=4 (2,1 5,6) t=0.468585327 [2] (3.405756,3.34292674) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
927findNextOp from:[4] to:[4] start=2 end=1
928bridgeOp current id=4 from=(5,6) to=(3.405756,3.34292674)
929path.lineTo(3.405756,3.34292674);
930path.close();
931debugShowActiveSpans id=4 (2,1 5,6) t=0.375 (3.125,2.875) tEnd=0.468585327 other=2 otherT=0.375 otherIndex=1 windSum=-1 windValue=1 oppValue=0
932activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
933findNextOp debugShowSort contourWinding=0 oppContourWinding=2 sign=1
934debugShowSort [0] {{2,1}, {5,6}} tStart=0.468585327 tEnd=0.375 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
935debugShowSort [1] {{0,1}, {1,2}, {6,5}, {5,4}} tStart=0.520955385 tEnd=0 sign=1 windValue=1 windSum=1 2->1 (max=2) done=1 tiny=0 opp=1
936debugShowSort [2] {{2,1}, {5,6}} tStart=0.468585327 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
937debugShowSort [3] {{0,1}, {1,2}, {6,5}, {5,4}} tStart=0.520955385 tEnd=1 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=1 tiny=0 opp=1
938findNextOp firstIndex=[0] sign=1
939activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
940activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
941activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
942markDoneBinary id=4 (2,1 5,6) t=0.375 [1] (3.125,2.875) tEnd=0.468585327 newWindSum=-1 newOppSum=2 oppSum=2 windSum=-1 windValue=1
943findNextOp from:[4] to:[4] start=2 end=3
944bridgeOp current id=4 from=(3.125,2.875) to=(3.405756,3.34292674)
945</div>
946
947<div id="cubicOp42da">
948computed quadratics given
949 {{0,1}, {1,2}, {6,5}, {5,4}},
950 {{5,6}, {4,5}, {1,0}, {2,1}},
951computed quadratics set 1
952 {{0,1}, {0.4140625,1.3984375}, {1.34375,2.03125}},
953 {{1.34375,2.03125}, {2.2734375,2.6640625}, {3.25,3.25}},
954 {{3.25,3.25}, {4.2265625,3.8359375}, {4.78125,4.09375}},
955 {{4.78125,4.09375}, {5.3359375,4.3515625}, {5,4}},
956computed quadratics set 2
957 {{5,6}, {4.6015625,5.5859375}, {3.96875,4.65625}},
958 {{3.96875,4.65625}, {3.3359375,3.7265625}, {2.75,2.75}},
959 {{2.75,2.75}, {2.1640625,1.7734375}, {1.90625,1.21875}},
960 {{1.90625,1.21875}, {1.6484375,0.6640625}, {2,1}},
961</div>
962
963<div id="cubicOp42db">
964 {{1.34375,2.03125}, {2.2734375,2.6640625}, {3.25,3.25}},
965 {{3.96875,4.65625}, {3.3359375,3.7265625}, {2.75,2.75}},
966</div>
967
968<div id="cubicOp43d">
969 SimplifyNew_Test [cubicOp43d]
970{{0,2}, {1,2}, {4,0}, {3,1}},
971{{3,1}, {0,2}},
972op difference
973{{0,4}, {1,3}, {2,0}, {2,1}},
974{{2,1}, {0,4}},
975debugShowCubicIntersection no self intersect {{0,2}, {1,2}, {4,0}, {3,1}}
976debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {1,2}, {4,0}, {3,1}} {{0,2}} wtTs[1]=0.333333333 {{1.4444444444444446,1.5185185185185186}} wtTs[2]=1 {{3,1}} wnTs[0]=1 {{3,1}, {0,2}} wnTs[1]=0.518518519 wnTs[2]=0
977debugShowCubicIntersection wtTs[0]=0.345547542 {{0,2}, {1,2}, {4,0}, {3,1}} {{1.5055045552472988,1.4898786220870244}} wnTs[0]=0.560544 {{0,4}, {1,3}, {2,0}, {2,1}}
978debugShowCubicLineIntersection wtTs[0]=0.395188999 {{0,2}, {1,2}, {4,0}, {3,1}} {{1.7523027701818603,1.3715458447272095}} wnTs[0]=0.123849 {{2,1}, {0,4}}
979debugShowCubicLineIntersection wtTs[0]=0.558102564 {{0,4}, {1,3}, {2,0}, {2,1}} {{1.5004707573680853,1.4998430808773049}} wnTs[0]=0.499843 {{3,1}, {0,2}}
980debugShowLineIntersection wtTs[0]=0.428571429 {{3,1}, {0,2}} {{1.7142857142857142,1.4285714285714284}} wnTs[0]=0.142857 {{2,1}, {0,4}}
981debugShowCubicIntersection no self intersect {{0,4}, {1,3}, {2,0}, {2,1}}
982debugShowCubicLineIntersection wtTs[0]=0 {{0,4}, {1,3}, {2,0}, {2,1}} {{0,4}} wtTs[1]=0.333333333 {{0.96296296296296258,2.5555555555555562}} wtTs[2]=1 {{2,1}} wnTs[0]=1 {{2,1}, {0,4}} wnTs[1]=0.518518519 wnTs[2]=0
983debugShowActiveSpans id=1 (0,2 1,2 4,0 3,1) t=0 (0,2) tEnd=0.333333333 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
984debugShowActiveSpans id=1 (0,2 1,2 4,0 3,1) t=0.333333333 (1.44444442,1.51851857) tEnd=0.345547542 other=2 otherT=0.518518519 otherIndex=3 windSum=? windValue=1 oppValue=0
985debugShowActiveSpans id=1 (0,2 1,2 4,0 3,1) t=0.345547542 (1.50550461,1.48987865) tEnd=0.395188999 other=3 otherT=0.560544414 otherIndex=3 windSum=? windValue=1 oppValue=0
986debugShowActiveSpans id=1 (0,2 1,2 4,0 3,1) t=0.395188999 (1.75230277,1.37154579) tEnd=1 other=4 otherT=0.123848615 otherIndex=1 windSum=? windValue=1 oppValue=0
987debugShowActiveSpans id=2 (3,1 0,2) t=0 (3,1) tEnd=0.428571429 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
988debugShowActiveSpans id=2 (3,1 0,2) t=0.428571429 (1.71428573,1.42857146) tEnd=0.499843081 other=4 otherT=0.142857143 otherIndex=2 windSum=? windValue=1 oppValue=0
989debugShowActiveSpans id=2 (3,1 0,2) t=0.499843081 (1.50047076,1.49984312) tEnd=0.518518519 other=3 otherT=0.558102564 otherIndex=2 windSum=? windValue=1 oppValue=0
990debugShowActiveSpans id=2 (3,1 0,2) t=0.518518519 (1.44444442,1.51851857) tEnd=1 other=1 otherT=0.333333333 otherIndex=1 windSum=? windValue=1 oppValue=0
991debugShowActiveSpans id=3 (0,4 1,3 2,0 2,1) t=0 (0,4) tEnd=0.333333333 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
992debugShowActiveSpans id=3 (0,4 1,3 2,0 2,1) t=0.333333333 (0.962962985,2.55555558) tEnd=0.558102564 other=4 otherT=0.518518519 otherIndex=3 windSum=? windValue=1 oppValue=0
993debugShowActiveSpans id=3 (0,4 1,3 2,0 2,1) t=0.558102564 (1.50047076,1.49984312) tEnd=0.560544414 other=2 otherT=0.499843081 otherIndex=2 windSum=? windValue=1 oppValue=0
994debugShowActiveSpans id=3 (0,4 1,3 2,0 2,1) t=0.560544414 (1.50550461,1.48987865) tEnd=1 other=1 otherT=0.345547542 otherIndex=2 windSum=? windValue=1 oppValue=0
995debugShowActiveSpans id=4 (2,1 0,4) t=0 (2,1) tEnd=0.123848615 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
996debugShowActiveSpans id=4 (2,1 0,4) t=0.123848615 (1.75230277,1.37154579) tEnd=0.142857143 other=1 otherT=0.395188999 otherIndex=3 windSum=? windValue=1 oppValue=0
997debugShowActiveSpans id=4 (2,1 0,4) t=0.142857143 (1.71428573,1.42857146) tEnd=0.518518519 other=2 otherT=0.428571429 otherIndex=1 windSum=? windValue=1 oppValue=0
998debugShowActiveSpans id=4 (2,1 0,4) t=0.518518519 (0.962962985,2.55555558) tEnd=1 other=3 otherT=0.333333333 otherIndex=1 windSum=? windValue=1 oppValue=0
999findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1000debugShowSort [0] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=1 tEnd=0.395188999 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1001debugShowSort [1] {{3,1}, {0,2}} tStart=0 tEnd=0.428571429 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1002findTop xyE=(3,1) xyS=(1.75230277,1.37154579)
1003findTop dxyE=(-3,3) dxyS=(4.93112993,-2.39965272) cross=-7.59443188 bumpsUp=true
1004findTop cross bump disagree
1005findTop swap
1006markWinding id=1 (0,2 1,2 4,0 3,1) t=0.395188999 [3] (1.75230277,1.37154579) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1007markWinding id=1 (0,2 1,2 4,0 3,1) t=0.395188999 [3] (1.75230277,1.37154579) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1008markWinding id=2 (3,1 0,2) t=0 [0] (3,1) tEnd=0.428571429 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1009activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1010findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1011debugShowSort [0] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=0.395188999 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
1012debugShowSort [1] {{2,1}, {0,4}} tStart=0.123848615 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1013debugShowSort [2] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=0.395188999 tEnd=0.345547542 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1014debugShowSort [3] {{2,1}, {0,4}} tStart=0.123848615 tEnd=0.142857143 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1015findNextOp firstIndex=[0] sign=-1
1016activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1017markWinding id=4 (2,1 0,4) t=0 [0] (2,1) tEnd=0.123848615 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1018markWinding id=3 (0,4 1,3 2,0 2,1) t=0.560544414 [3] (1.50550461,1.48987865) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1019findNextOp chase.append id=3
1020activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1021markDoneBinary id=1 (0,2 1,2 4,0 3,1) t=0.345547542 [2] (1.50550461,1.48987865) tEnd=0.395188999 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1022findNextOp chase.append id=1
1023activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1024markDoneBinary id=4 (2,1 0,4) t=0.123848615 [1] (1.75230277,1.37154579) tEnd=0.142857143 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1025findNextOp chase.append id=4
1026markDoneBinary id=1 (0,2 1,2 4,0 3,1) t=0.395188999 [3] (1.75230277,1.37154579) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1027findNextOp from:[1] to:[4] start=1 end=0
1028bridgeOp current id=1 from=(3,1) to=(1.75230277,1.37154579)
1029path.moveTo(3,1);
1030path.cubicTo(3.60481095,0.395188987, 2.7464366,0.887767076, 1.75230277,1.37154579);
1031findNextOp simple
1032markDoneBinary id=4 (2,1 0,4) t=0 [0] (2,1) tEnd=0.123848615 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1033bridgeOp current id=4 from=(1.75230277,1.37154579) to=(2,1)
1034findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1035debugShowSort [1] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.560544414 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1036debugShowSort [2] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=0.345547542 tEnd=0.333333333 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
1037debugShowSort [3] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.560544414 tEnd=0.558102564 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1038debugShowSort [0] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=0.345547542 tEnd=0.395188999 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
1039findNextOp firstIndex=[1] sign=-1
1040activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1041markWinding id=1 (0,2 1,2 4,0 3,1) t=0.333333333 [1] (1.44444442,1.51851857) tEnd=0.345547542 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1042findNextOp chase.append id=1
1043activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1044markDoneBinary id=3 (0,4 1,3 2,0 2,1) t=0.558102564 [2] (1.50047076,1.49984312) tEnd=0.560544414 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1045findNextOp chase.append id=3
1046activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1047markDoneBinary id=3 (0,4 1,3 2,0 2,1) t=0.560544414 [3] (1.50550461,1.48987865) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1048findNextOp from:[3] to:[1] start=2 end=1
1049bridgeOp current id=3 from=(2,1) to=(1.50550461,1.48987865)
1050path.lineTo(2,1);
1051path.cubicTo(2,0.560544431, 1.80687881,0.893573642, 1.50550461,1.48987865);
1052findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1053debugShowSort [1] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=0.333333333 tEnd=0.345547542 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
1054debugShowSort [2] {{3,1}, {0,2}} tStart=0.518518519 tEnd=1 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=0
1055debugShowSort [3] {{0,2}, {1,2}, {4,0}, {3,1}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
1056debugShowSort [0] {{3,1}, {0,2}} tStart=0.518518519 tEnd=0.499843081 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1057findNextOp firstIndex=[1] sign=-1
1058activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1059markDoneBinary id=2 (3,1 0,2) t=0.518518519 [3] (1.44444442,1.51851857) tEnd=1 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1060markDoneBinary id=1 (0,2 1,2 4,0 3,1) t=0 [0] (0,2) tEnd=0.333333333 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1061findNextOp chase.append id=1
1062activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1063activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1064markWinding id=2 (3,1 0,2) t=0.499843081 [2] (1.50047076,1.49984312) tEnd=0.518518519 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1065findNextOp chase.append id=2
1066markDoneBinary id=1 (0,2 1,2 4,0 3,1) t=0.333333333 [1] (1.44444442,1.51851857) tEnd=0.345547542 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1067findNextOp from:[1] to:[2] start=3 end=2
1068bridgeOp current id=1 from=(1.50550461,1.48987865) to=(1.44444442,1.51851857)
1069path.cubicTo(1.48515844,1.49946892, 1.46480155,1.50901854, 1.44444442,1.51851857);
1070findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1071debugShowSort [2] {{3,1}, {0,2}} tStart=0.499843081 tEnd=0.518518519 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
1072debugShowSort [3] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.558102564 tEnd=0.333333333 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1073debugShowSort [0] {{3,1}, {0,2}} tStart=0.499843081 tEnd=0.428571429 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1074debugShowSort [1] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.558102564 tEnd=0.560544414 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
1075findNextOp firstIndex=[2] sign=-1
1076activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1077markWinding id=3 (0,4 1,3 2,0 2,1) t=0.333333333 [1] (0.962962985,2.55555558) tEnd=0.558102564 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1078findNextOp chase.append id=3
1079activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1080markDoneBinary id=2 (3,1 0,2) t=0.428571429 [1] (1.71428573,1.42857146) tEnd=0.499843081 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1081findNextOp chase.append id=2
1082activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1083markDoneBinary id=2 (3,1 0,2) t=0.499843081 [2] (1.50047076,1.49984312) tEnd=0.518518519 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1084findNextOp from:[2] to:[3] start=2 end=1
1085bridgeOp current id=2 from=(1.44444442,1.51851857) to=(1.50047076,1.49984312)
1086findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1087debugShowSort [1] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.333333333 tEnd=0.558102564 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1088debugShowSort [2] {{2,1}, {0,4}} tStart=0.518518519 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
1089debugShowSort [3] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1090debugShowSort [0] {{2,1}, {0,4}} tStart=0.518518519 tEnd=0.142857143 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1091findNextOp firstIndex=[1] sign=-1
1092activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1093markWinding id=4 (2,1 0,4) t=0.518518519 [3] (0.962962985,2.55555558) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
1094markWinding id=3 (0,4 1,3 2,0 2,1) t=0 [0] (0,4) tEnd=0.333333333 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
1095findNextOp chase.append id=3
1096activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1097activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1098markWinding id=4 (2,1 0,4) t=0.142857143 [2] (1.71428573,1.42857146) tEnd=0.518518519 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1099findNextOp chase.append id=4
1100markDoneBinary id=3 (0,4 1,3 2,0 2,1) t=0.333333333 [1] (0.962962985,2.55555558) tEnd=0.558102564 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1101findNextOp from:[3] to:[4] start=3 end=4
1102bridgeOp current id=3 from=(1.50047076,1.49984312) to=(0.962962985,2.55555558)
1103path.lineTo(1.50047076,1.49984312);
1104path.cubicTo(1.3457123,1.80632472, 1.16275787,2.18094015, 0.962962985,2.55555558);
1105findNextOp simple
1106markDoneBinary id=4 (2,1 0,4) t=0.518518519 [3] (0.962962985,2.55555558) tEnd=1 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
1107bridgeOp current id=4 from=(0.962962985,2.55555558) to=(0,4)
1108findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
1109debugShowSort [3] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
1110debugShowSort [0] {{2,1}, {0,4}} tStart=0.518518519 tEnd=0.142857143 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1111debugShowSort [1] {{0,4}, {1,3}, {2,0}, {2,1}} tStart=0.333333333 tEnd=0.558102564 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1112debugShowSort [2] {{2,1}, {0,4}} tStart=0.518518519 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
1113findNextOp firstIndex=[3] sign=1
1114activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1115activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1116activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1117markDoneBinary id=3 (0,4 1,3 2,0 2,1) t=0 [0] (0,4) tEnd=0.333333333 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
1118findNextOp from:[3] to:[4] start=3 end=2
1119bridgeOp current id=3 from=(0,4) to=(0.962962985,2.55555558)
1120path.lineTo(0,4);
1121path.cubicTo(0.333333343,3.66666675, 0.666666627,3.11111116, 0.962962985,2.55555558);
1122findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1123debugShowSort [3] {{2,1}, {0,4}} tStart=0.142857143 tEnd=0.518518519 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1124debugShowSort [0] {{3,1}, {0,2}} tStart=0.428571429 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=1
1125debugShowSort [1] {{2,1}, {0,4}} tStart=0.142857143 tEnd=0.123848615 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
1126debugShowSort [2] {{3,1}, {0,2}} tStart=0.428571429 tEnd=0.499843081 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
1127findNextOp firstIndex=[3] sign=-1
1128activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1129activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1130activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1131markDoneBinary id=4 (2,1 0,4) t=0.142857143 [2] (1.71428573,1.42857146) tEnd=0.518518519 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1132findNextOp from:[4] to:[2] start=1 end=0
1133bridgeOp current id=4 from=(0.962962985,2.55555558) to=(1.71428573,1.42857146)
1134findNextOp simple
1135markDoneBinary id=2 (3,1 0,2) t=0 [0] (3,1) tEnd=0.428571429 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1136bridgeOp current id=2 from=(1.71428573,1.42857146) to=(3,1)
1137path.lineTo(1.71428573,1.42857146);
1138path.lineTo(3,1);
1139path.close();
1140assemble
1141assemble contour start=(3,1) end=(3,1)
1142</div>
1143
1144<div id="cubicOp44d">
1145 SimplifyNew_Test [cubicOp44d]
1146{{0,2}, {3,6}, {4,0}, {3,2}},
1147{{3,2}, {0,2}},
1148op difference
1149{{0,4}, {2,3}, {2,0}, {6,3}},
1150{{6,3}, {0,4}},
1151debugShowCubicIntersection no self intersect {{0,2}, {3,6}, {4,0}, {3,2}}
1152debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {3,6}, {4,0}, {3,2}} {{0,2}} wtTs[1]=1 {{3,2}} wnTs[0]=1 {{3,2}, {0,2}} wnTs[1]=0
1153debugShowCubicIntersection wtTs[0]=0.135342164 {{0,2}, {3,6}, {4,0}, {3,2}} {{1.1081744689414279,3.1192052729330815}} wtTs[1]=0.754165096 {{3.3748959118747366,1.708000079031383}} wtTs[2]=0.93333707 {{3.1733251116708114,1.7013446943452044}} wnTs[0]=0.223477 {{0,4}, {2,3}, {2,0}, {6,3}} wnTs[1]=0.708782366 wnTs[2]=0.67692927
1154debugShowCubicLineIntersection no intersect {{0,2}, {3,6}, {4,0}, {3,2}} {{6,3}, {0,4}}
1155debugShowCubicLineIntersection wtTs[0]=0.5 {{0,4}, {2,3}, {2,0}, {6,3}} {{2.25,2}} wnTs[0]=0.25 {{3,2}, {0,2}}
1156debugShowCubicIntersection no self intersect {{0,4}, {2,3}, {2,0}, {6,3}}
1157debugShowCubicLineIntersection wtTs[0]=0 {{0,4}, {2,3}, {2,0}, {6,3}} {{0,4}} wtTs[1]=1 {{6,3}} wnTs[0]=1 {{6,3}, {0,4}} wnTs[1]=0
1158debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0 (0,2) tEnd=0.135342164 other=2 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
1159debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.135342164 (1.10817444,3.11920524) tEnd=0.754165096 other=3 otherT=0.223476766 otherIndex=1 windSum=? windValue=1 oppValue=0
1160debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.754165096 (3.37489581,1.70800006) tEnd=0.93333707 other=3 otherT=0.708782366 otherIndex=4 windSum=? windValue=1 oppValue=0
1161debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.93333707 (3.17332506,1.70134473) tEnd=1 other=3 otherT=0.67692927 otherIndex=3 windSum=? windValue=1 oppValue=0
1162debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.25 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1163debugShowActiveSpans id=2 (3,2 0,2) t=0.25 (2.25,2) tEnd=1 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1164debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0 (0,4) tEnd=0.223476766 other=4 otherT=1 otherIndex=1 windSum=? windValue=1 oppValue=0
1165debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.223476766 (1.10817444,3.11920524) tEnd=0.5 other=1 otherT=0.135342164 otherIndex=1 windSum=? windValue=1 oppValue=0
1166debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.5 (2.25,2) tEnd=0.67692927 other=2 otherT=0.25 otherIndex=1 windSum=? windValue=1 oppValue=0
1167debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.67692927 (3.17332506,1.70134473) tEnd=0.708782366 other=1 otherT=0.93333707 otherIndex=3 windSum=? windValue=1 oppValue=0
1168debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.708782366 (3.37489581,1.70800006) tEnd=1 other=1 otherT=0.754165096 otherIndex=2 windSum=? windValue=1 oppValue=0
1169debugShowActiveSpans id=4 (6,3 0,4) t=0 (6,3) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1170findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1171debugShowSort [0] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.67692927 tEnd=0.708782366 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
1172debugShowSort [1] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.93333707 tEnd=0.754165096 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1173debugShowSort [2] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.67692927 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1174debugShowSort [3] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.93333707 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1175findTop swap
1176markWinding id=3 (0,4 2,3 2,0 6,3) t=0.67692927 [3] (3.17332506,1.70134473) tEnd=0.708782366 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1177markWinding id=3 (0,4 2,3 2,0 6,3) t=0.67692927 [3] (3.17332506,1.70134473) tEnd=0.708782366 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1178activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1179markDoneBinary id=3 (0,4 2,3 2,0 6,3) t=0.67692927 [3] (3.17332506,1.70134473) tEnd=0.708782366 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1180findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=-1
1181debugShowSort [0] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.754165096 tEnd=0.93333707 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1182debugShowSort [1] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.708782366 tEnd=0.67692927 sign=1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
1183debugShowSort [2] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.754165096 tEnd=0.135342164 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1184debugShowSort [3] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.708782366 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
1185findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1186debugShowSort [1] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.708782366 tEnd=0.67692927 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
1187debugShowSort [2] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.754165096 tEnd=0.135342164 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1188debugShowSort [3] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.708782366 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1189debugShowSort [0] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.754165096 tEnd=0.93333707 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1190markWinding id=1 (0,2 3,6 4,0 3,2) t=0.135342164 [1] (1.10817444,3.11920524) tEnd=0.754165096 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1191markWinding id=3 (0,4 2,3 2,0 6,3) t=0.708782366 [4] (3.37489581,1.70800006) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1192markWinding id=4 (6,3 0,4) t=0 [0] (6,3) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1193markWinding id=3 (0,4 2,3 2,0 6,3) t=0 [0] (0,4) tEnd=0.223476766 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1194markWinding id=1 (0,2 3,6 4,0 3,2) t=0.754165096 [2] (3.37489581,1.70800006) tEnd=0.93333707 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1195debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0 (0,2) tEnd=0.135342164 other=2 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
1196debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.135342164 (1.10817444,3.11920524) tEnd=0.754165096 other=3 otherT=0.223476766 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1197debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.754165096 (3.37489581,1.70800006) tEnd=0.93333707 other=3 otherT=0.708782366 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1198debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.93333707 (3.17332506,1.70134473) tEnd=1 other=3 otherT=0.67692927 otherIndex=3 windSum=? windValue=1 oppValue=0
1199debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.25 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1200debugShowActiveSpans id=2 (3,2 0,2) t=0.25 (2.25,2) tEnd=1 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1201debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0 (0,4) tEnd=0.223476766 other=4 otherT=1 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1202debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.223476766 (1.10817444,3.11920524) tEnd=0.5 other=1 otherT=0.135342164 otherIndex=1 windSum=? windValue=1 oppValue=0
1203debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.5 (2.25,2) tEnd=0.67692927 other=2 otherT=0.25 otherIndex=1 windSum=? windValue=1 oppValue=0
1204debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.708782366 (3.37489581,1.70800006) tEnd=1 other=1 otherT=0.754165096 otherIndex=2 windSum=-1 windValue=1 oppValue=0
1205debugShowActiveSpans id=4 (6,3 0,4) t=0 (6,3) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
1206activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1207markDoneBinary id=1 (0,2 3,6 4,0 3,2) t=0.135342164 [1] (1.10817444,3.11920524) tEnd=0.754165096 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
1208debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0 (0,2) tEnd=0.135342164 other=2 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
1209debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.754165096 (3.37489581,1.70800006) tEnd=0.93333707 other=3 otherT=0.708782366 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1210debugShowActiveSpans id=1 (0,2 3,6 4,0 3,2) t=0.93333707 (3.17332506,1.70134473) tEnd=1 other=3 otherT=0.67692927 otherIndex=3 windSum=? windValue=1 oppValue=0
1211debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.25 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1212debugShowActiveSpans id=2 (3,2 0,2) t=0.25 (2.25,2) tEnd=1 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1213debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0 (0,4) tEnd=0.223476766 other=4 otherT=1 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1214debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.223476766 (1.10817444,3.11920524) tEnd=0.5 other=1 otherT=0.135342164 otherIndex=1 windSum=? windValue=1 oppValue=0
1215debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.5 (2.25,2) tEnd=0.67692927 other=2 otherT=0.25 otherIndex=1 windSum=? windValue=1 oppValue=0
1216debugShowActiveSpans id=3 (0,4 2,3 2,0 6,3) t=0.708782366 (3.37489581,1.70800006) tEnd=1 other=1 otherT=0.754165096 otherIndex=2 windSum=-1 windValue=1 oppValue=0
1217debugShowActiveSpans id=4 (6,3 0,4) t=0 (6,3) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
1218activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1219findNextOp simple
1220markDoneBinary id=3 (0,4 2,3 2,0 6,3) t=0 [0] (0,4) tEnd=0.223476766 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
1221bridgeOp current id=3 from=(1.10817444,3.11920524) to=(0,4)
1222path.moveTo(1.10817444,3.11920524);
1223path.cubicTo(0.794023395,3.45316267, 0.446953505,3.77652311, 0,4);
1224findNextOp simple
1225markDoneBinary id=4 (6,3 0,4) t=0 [0] (6,3) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
1226bridgeOp current id=4 from=(0,4) to=(6,3)
1227findNextOp debugShowSort contourWinding=-1 oppContourWinding=-1 sign=-1
1228debugShowSort [3] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.708782366 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1229debugShowSort [0] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.754165096 tEnd=0.93333707 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
1230debugShowSort [1] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.708782366 tEnd=0.67692927 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
1231debugShowSort [2] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.754165096 tEnd=0.135342164 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
1232findNextOp firstIndex=[3] sign=-1
1233activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1234activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1235activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1236markDoneBinary id=3 (0,4 2,3 2,0 6,3) t=0.708782366 [4] (3.37489581,1.70800006) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
1237findNextOp from:[3] to:[1] start=2 end=3
1238bridgeOp current id=3 from=(6,3) to=(3.37489581,1.70800006)
1239path.lineTo(6,3);
1240path.cubicTo(4.83512926,2.12634706, 4.00949001,1.76154041, 3.37489581,1.70800006);
1241findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1242debugShowSort [1] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.93333707 tEnd=0.754165096 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1243debugShowSort [2] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.67692927 tEnd=0.5 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1244debugShowSort [3] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.93333707 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1245debugShowSort [0] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.67692927 tEnd=0.708782366 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
1246findNextOp firstIndex=[1] sign=1
1247activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1248markWinding id=3 (0,4 2,3 2,0 6,3) t=0.5 [2] (2.25,2) tEnd=0.67692927 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1249findNextOp chase.append id=3
1250activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1251markDoneBinary id=1 (0,2 3,6 4,0 3,2) t=0.93333707 [3] (3.17332506,1.70134473) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1252markDoneBinary id=2 (3,2 0,2) t=0 [0] (3,2) tEnd=0.25 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
1253findNextOp chase.append id=2
1254activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1255markDoneBinary id=1 (0,2 3,6 4,0 3,2) t=0.754165096 [2] (3.37489581,1.70800006) tEnd=0.93333707 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1256findNextOp from:[1] to:[3] start=3 end=2
1257bridgeOp current id=1 from=(3.37489581,1.70800006) to=(3.17332506,1.70134473)
1258path.cubicTo(3.37191081,1.55650449, 3.30472064,1.51977468, 3.17332506,1.70134473);
1259findNextOp debugShowSort contourWinding=-1 oppContourWinding=-1 sign=-1
1260debugShowSort [0] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.5 tEnd=0.67692927 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1261debugShowSort [1] {{3,2}, {0,2}} tStart=0.25 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1262debugShowSort [2] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.5 tEnd=0.223476766 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1263debugShowSort [3] {{3,2}, {0,2}} tStart=0.25 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
1264findNextOp firstIndex=[0] sign=-1
1265activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1266markWinding id=2 (3,2 0,2) t=0.25 [1] (2.25,2) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1267markWinding id=1 (0,2 3,6 4,0 3,2) t=0 [0] (0,2) tEnd=0.135342164 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1268findNextOp chase.append id=1
1269activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1270markDoneBinary id=3 (0,4 2,3 2,0 6,3) t=0.223476766 [1] (1.10817444,3.11920524) tEnd=0.5 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1271findNextOp chase.append id=3
1272activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1273markDoneBinary id=3 (0,4 2,3 2,0 6,3) t=0.5 [2] (2.25,2) tEnd=0.67692927 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
1274findNextOp from:[3] to:[2] start=1 end=2
1275bridgeOp current id=3 from=(3.17332506,1.70134473) to=(2.25,2)
1276path.cubicTo(2.81209183,1.70874941, 2.51539397,1.82307076, 2.25,2);
1277findNextOp simple
1278markDoneBinary id=2 (3,2 0,2) t=0.25 [1] (2.25,2) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1279bridgeOp current id=2 from=(2.25,2) to=(0,2)
1280findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1281debugShowSort [1] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.135342164 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1282debugShowSort [2] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.223476766 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
1283debugShowSort [3] {{0,2}, {3,6}, {4,0}, {3,2}} tStart=0.135342164 tEnd=0.754165096 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1284debugShowSort [0] {{0,4}, {2,3}, {2,0}, {6,3}} tStart=0.223476766 tEnd=0.5 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
1285findNextOp firstIndex=[1] sign=1
1286activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1287activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1288activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1289markDoneBinary id=1 (0,2 3,6 4,0 3,2) t=0 [0] (0,2) tEnd=0.135342164 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1290findNextOp from:[1] to:[3] start=1 end=0
1291bridgeOp current id=1 from=(0,2) to=(1.10817444,3.11920524)
1292path.lineTo(0,2);
1293path.cubicTo(0.406026483,2.54136872, 0.775417984,2.89956236, 1.10817444,3.11920524);
1294path.close();
1295assemble
1296assemble contour start=(1.10817444,3.11920524) end=(1.10817444,3.11920524)
1297</div>
1298
1299<div id="cubicOp45d">
1300 SimplifyNew_Test [cubicOp45d]
1301{{0,2}, {2,4}, {4,0}, {3,2}},
1302{{3,2}, {0,2}},
1303op difference
1304{{0,4}, {2,3}, {2,0}, {4,2}},
1305{{4,2}, {0,4}},
1306debugShowCubicIntersection no self intersect {{0,4}, {2,3}, {2,0}, {4,2}}
1307debugShowCubicLineIntersection wtTs[0]=0 {{0,4}, {2,3}, {2,0}, {4,2}} {{0,4}} wtTs[1]=1 {{4,2}} wnTs[0]=1 {{4,2}, {0,4}} wnTs[1]=0
1308debugShowCubicIntersection wtTs[0]=0.341662805 {{0,4}, {2,3}, {2,0}, {4,2}} {{1.5091099386066631,2.5537951499735922}} wtTs[1]=0.856247521 {{3.2495913270767485,1.4266624658205882}} wtTs[2]=0.859816875 {{3.2657899721435943,1.4343874043112959}} wnTs[0]=0.260341 {{0,2}, {2,4}, {4,0}, {3,2}} wnTs[1]=0.768795564 wnTs[2]=0.821660252
1309debugShowCubicLineIntersection wtTs[0]=0.467845317 {{0,4}, {2,3}, {2,0}, {4,2}} {{1.9034029684653309,1.9999999999999998}} wnTs[0]=0.365532 {{3,2}, {0,2}}
1310debugShowCubicLineIntersection no intersect {{0,2}, {2,4}, {4,0}, {3,2}} {{4,2}, {0,4}}
1311debugShowLineIntersection no intersect {{4,2}, {0,4}} {{3,2}, {0,2}}
1312debugShowCubicIntersection no self intersect {{0,2}, {2,4}, {4,0}, {3,2}}
1313debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {2,4}, {4,0}, {3,2}} {{0,2}} wtTs[1]=0.5 {{2.625,2}} wtTs[2]=1 {{3,2}} wnTs[0]=1 {{3,2}, {0,2}} wnTs[1]=0.125 wnTs[2]=0
1314debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0 (0,4) tEnd=0.341662805 other=4 otherT=1 otherIndex=1 windSum=? windValue=1 oppValue=0
1315debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.341662805 (1.50910997,2.5537951) tEnd=0.467845317 other=1 otherT=0.260340927 otherIndex=1 windSum=? windValue=1 oppValue=0
1316debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.467845317 (1.90340292,2) tEnd=0.856247521 other=2 otherT=0.365532344 otherIndex=2 windSum=? windValue=1 oppValue=0
1317debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.856247521 (3.24959135,1.42666245) tEnd=0.859816875 other=1 otherT=0.768795564 otherIndex=3 windSum=? windValue=1 oppValue=0
1318debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.859816875 (3.26578999,1.43438745) tEnd=1 other=1 otherT=0.821660252 otherIndex=4 windSum=? windValue=1 oppValue=0
1319debugShowActiveSpans id=4 (4,2 0,4) t=0 (4,2) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1320debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0 (0,2) tEnd=0.260340927 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1321debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.260340927 (1.50910997,2.5537951) tEnd=0.5 other=3 otherT=0.341662805 otherIndex=1 windSum=? windValue=1 oppValue=0
1322debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.5 (2.625,2) tEnd=0.768795564 other=2 otherT=0.125 otherIndex=1 windSum=? windValue=1 oppValue=0
1323debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.768795564 (3.24959135,1.42666245) tEnd=0.821660252 other=3 otherT=0.856247521 otherIndex=3 windSum=? windValue=1 oppValue=0
1324debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.821660252 (3.26578999,1.43438745) tEnd=1 other=3 otherT=0.859816875 otherIndex=4 windSum=? windValue=1 oppValue=0
1325debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1326debugShowActiveSpans id=2 (3,2 0,2) t=0.125 (2.625,2) tEnd=0.365532344 other=1 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1327debugShowActiveSpans id=2 (3,2 0,2) t=0.365532344 (1.90340292,2) tEnd=1 other=3 otherT=0.467845317 otherIndex=2 windSum=? windValue=1 oppValue=0
1328findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1329debugShowSort [1] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=0.856247521 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1330debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
1331debugShowSort [3] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1332debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=0.768795564 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
1333markWinding id=3 (0,4 2,3 2,0 4,2) t=0.856247521 [3] (3.24959135,1.42666245) tEnd=0.859816875 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1334markWinding id=3 (0,4 2,3 2,0 4,2) t=0.856247521 [3] (3.24959135,1.42666245) tEnd=0.859816875 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1335activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1336markDoneBinary id=3 (0,4 2,3 2,0 4,2) t=0.856247521 [3] (3.24959135,1.42666245) tEnd=0.859816875 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1337findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
1338debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=0.768795564 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1339debugShowSort [1] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=0.856247521 sign=1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
1340debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1341debugShowSort [3] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
1342findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1343debugShowSort [1] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=0.856247521 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
1344debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
1345debugShowSort [3] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1346debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=0.768795564 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
1347markWinding id=1 (0,2 2,4 4,0 3,2) t=0.821660252 [4] (3.26578999,1.43438745) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1348markWinding id=2 (3,2 0,2) t=0 [0] (3,2) tEnd=0.125 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1349markWinding id=3 (0,4 2,3 2,0 4,2) t=0.859816875 [4] (3.26578999,1.43438745) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1350markWinding id=4 (4,2 0,4) t=0 [0] (4,2) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1351markWinding id=3 (0,4 2,3 2,0 4,2) t=0 [0] (0,4) tEnd=0.341662805 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1352markWinding id=1 (0,2 2,4 4,0 3,2) t=0.768795564 [3] (3.24959135,1.42666245) tEnd=0.821660252 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1353debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0 (0,4) tEnd=0.341662805 other=4 otherT=1 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1354debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.341662805 (1.50910997,2.5537951) tEnd=0.467845317 other=1 otherT=0.260340927 otherIndex=1 windSum=? windValue=1 oppValue=0
1355debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.467845317 (1.90340292,2) tEnd=0.856247521 other=2 otherT=0.365532344 otherIndex=2 windSum=? windValue=1 oppValue=0
1356debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.859816875 (3.26578999,1.43438745) tEnd=1 other=1 otherT=0.821660252 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1357debugShowActiveSpans id=4 (4,2 0,4) t=0 (4,2) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
1358debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0 (0,2) tEnd=0.260340927 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1359debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.260340927 (1.50910997,2.5537951) tEnd=0.5 other=3 otherT=0.341662805 otherIndex=1 windSum=? windValue=1 oppValue=0
1360debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.5 (2.625,2) tEnd=0.768795564 other=2 otherT=0.125 otherIndex=1 windSum=? windValue=1 oppValue=0
1361debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.768795564 (3.24959135,1.42666245) tEnd=0.821660252 other=3 otherT=0.856247521 otherIndex=3 windSum=1 windValue=1 oppValue=0
1362debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.821660252 (3.26578999,1.43438745) tEnd=1 other=3 otherT=0.859816875 otherIndex=4 windSum=1 windValue=1 oppValue=0
1363debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=1 windValue=1 oppValue=0
1364debugShowActiveSpans id=2 (3,2 0,2) t=0.125 (2.625,2) tEnd=0.365532344 other=1 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1365debugShowActiveSpans id=2 (3,2 0,2) t=0.365532344 (1.90340292,2) tEnd=1 other=3 otherT=0.467845317 otherIndex=2 windSum=? windValue=1 oppValue=0
1366activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1367markDoneBinary id=1 (0,2 2,4 4,0 3,2) t=0.821660252 [4] (3.26578999,1.43438745) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1368markDoneBinary id=2 (3,2 0,2) t=0 [0] (3,2) tEnd=0.125 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1369findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=-1
1370debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.5 tEnd=0.768795564 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1371debugShowSort [1] {{3,2}, {0,2}} tStart=0.125 tEnd=0.365532344 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1372debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.5 tEnd=0.260340927 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1373debugShowSort [3] {{3,2}, {0,2}} tStart=0.125 tEnd=0 sign=1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=0
1374findChaseOp debugShowSort contourWinding=1 oppContourWinding=-1 sign=1
1375debugShowSort [3] {{3,2}, {0,2}} tStart=0.125 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
1376debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.5 tEnd=0.768795564 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
1377debugShowSort [1] {{3,2}, {0,2}} tStart=0.125 tEnd=0.365532344 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=0
1378debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.5 tEnd=0.260340927 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
1379markWinding id=1 (0,2 2,4 4,0 3,2) t=0.5 [2] (2.625,2) tEnd=0.768795564 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1380markWinding id=2 (3,2 0,2) t=0.125 [1] (2.625,2) tEnd=0.365532344 newWindSum=2 newOppSum=-1 oppSum=? windSum=? windValue=1
1381markWinding id=1 (0,2 2,4 4,0 3,2) t=0.260340927 [1] (1.50910997,2.5537951) tEnd=0.5 newWindSum=2 newOppSum=-1 oppSum=? windSum=? windValue=1
1382debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0 (0,4) tEnd=0.341662805 other=4 otherT=1 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1383debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.341662805 (1.50910997,2.5537951) tEnd=0.467845317 other=1 otherT=0.260340927 otherIndex=1 windSum=? windValue=1 oppValue=0
1384debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.467845317 (1.90340292,2) tEnd=0.856247521 other=2 otherT=0.365532344 otherIndex=2 windSum=? windValue=1 oppValue=0
1385debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.859816875 (3.26578999,1.43438745) tEnd=1 other=1 otherT=0.821660252 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1386debugShowActiveSpans id=4 (4,2 0,4) t=0 (4,2) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
1387debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0 (0,2) tEnd=0.260340927 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1388debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.260340927 (1.50910997,2.5537951) tEnd=0.5 other=3 otherT=0.341662805 otherIndex=1 windSum=2 windValue=1 oppValue=0
1389debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.5 (2.625,2) tEnd=0.768795564 other=2 otherT=0.125 otherIndex=1 windSum=1 windValue=1 oppValue=0
1390debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.768795564 (3.24959135,1.42666245) tEnd=0.821660252 other=3 otherT=0.856247521 otherIndex=3 windSum=1 windValue=1 oppValue=0
1391debugShowActiveSpans id=2 (3,2 0,2) t=0.125 (2.625,2) tEnd=0.365532344 other=1 otherT=0.5 otherIndex=2 windSum=2 windValue=1 oppValue=0
1392debugShowActiveSpans id=2 (3,2 0,2) t=0.365532344 (1.90340292,2) tEnd=1 other=3 otherT=0.467845317 otherIndex=2 windSum=? windValue=1 oppValue=0
1393activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1394markDoneBinary id=1 (0,2 2,4 4,0 3,2) t=0.5 [2] (2.625,2) tEnd=0.768795564 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1395debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0 (0,4) tEnd=0.341662805 other=4 otherT=1 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1396debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.341662805 (1.50910997,2.5537951) tEnd=0.467845317 other=1 otherT=0.260340927 otherIndex=1 windSum=? windValue=1 oppValue=0
1397debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.467845317 (1.90340292,2) tEnd=0.856247521 other=2 otherT=0.365532344 otherIndex=2 windSum=? windValue=1 oppValue=0
1398debugShowActiveSpans id=3 (0,4 2,3 2,0 4,2) t=0.859816875 (3.26578999,1.43438745) tEnd=1 other=1 otherT=0.821660252 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1399debugShowActiveSpans id=4 (4,2 0,4) t=0 (4,2) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
1400debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0 (0,2) tEnd=0.260340927 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1401debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.260340927 (1.50910997,2.5537951) tEnd=0.5 other=3 otherT=0.341662805 otherIndex=1 windSum=2 windValue=1 oppValue=0
1402debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.768795564 (3.24959135,1.42666245) tEnd=0.821660252 other=3 otherT=0.856247521 otherIndex=3 windSum=1 windValue=1 oppValue=0
1403debugShowActiveSpans id=2 (3,2 0,2) t=0.125 (2.625,2) tEnd=0.365532344 other=1 otherT=0.5 otherIndex=2 windSum=2 windValue=1 oppValue=0
1404debugShowActiveSpans id=2 (3,2 0,2) t=0.365532344 (1.90340292,2) tEnd=1 other=3 otherT=0.467845317 otherIndex=2 windSum=? windValue=1 oppValue=0
1405activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
1406findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
1407debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=0.768795564 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
1408debugShowSort [1] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=0.856247521 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
1409debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.821660252 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
1410debugShowSort [3] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.859816875 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
1411findNextOp firstIndex=[0] sign=1
1412activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1413activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1414activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1415markDoneBinary id=1 (0,2 2,4 4,0 3,2) t=0.768795564 [3] (3.24959135,1.42666245) tEnd=0.821660252 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1416findNextOp from:[1] to:[3] start=4 end=5
1417bridgeOp current id=1 from=(3.24959135,1.42666245) to=(3.26578999,1.43438745)
1418path.moveTo(3.24959135,1.42666245);
1419path.cubicTo(3.26158428,1.4196322, 3.26713157,1.42161608, 3.26578999,1.43438745);
1420findNextOp simple
1421markDoneBinary id=3 (0,4 2,3 2,0 4,2) t=0.859816875 [4] (3.26578999,1.43438745) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1422bridgeOp current id=3 from=(3.26578999,1.43438745) to=(4,2)
1423path.cubicTo(3.47857022,1.53752398, 3.71963382,1.71963382, 4,2);
1424findNextOp simple
1425markDoneBinary id=4 (4,2 0,4) t=0 [0] (4,2) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1426bridgeOp current id=4 from=(4,2) to=(0,4)
1427findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
1428debugShowSort [3] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.341662805 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1429debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.260340927 tEnd=0.5 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=0 tiny=0 opp=1
1430debugShowSort [1] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.341662805 tEnd=0.467845317 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1431debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.260340927 tEnd=0 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=1
1432findNextOp firstIndex=[3] sign=1
1433activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1434activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1435markWinding id=3 (0,4 2,3 2,0 4,2) t=0.341662805 [1] (1.50910997,2.5537951) tEnd=0.467845317 newWindSum=-1 newOppSum=2 oppSum=? windSum=? windValue=1
1436findNextOp chase.append id=3
1437activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1438markDoneBinary id=1 (0,2 2,4 4,0 3,2) t=0 [0] (0,2) tEnd=0.260340927 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1439markDoneBinary id=2 (3,2 0,2) t=0.365532344 [2] (1.90340292,2) tEnd=1 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1440findNextOp chase.append id=2
1441markDoneBinary id=3 (0,4 2,3 2,0 4,2) t=0 [0] (0,4) tEnd=0.341662805 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1442findNextOp from:[3] to:[3] start=1 end=2
1443bridgeOp current id=3 from=(0,4) to=(1.50910997,2.5537951)
1444path.lineTo(0,4);
1445path.cubicTo(0.683325648,3.65833712, 1.13318419,3.08320737, 1.50910997,2.5537951);
1446findNextOp debugShowSort contourWinding=0 oppContourWinding=2 sign=1
1447debugShowSort [2] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.467845317 tEnd=0.341662805 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1448debugShowSort [3] {{3,2}, {0,2}} tStart=0.365532344 tEnd=0.125 sign=1 windValue=1 windSum=2 2->1 (max=2) done=0 tiny=0 opp=1
1449debugShowSort [0] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.467845317 tEnd=0.856247521 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1450debugShowSort [1] {{3,2}, {0,2}} tStart=0.365532344 tEnd=1 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=1 tiny=0 opp=1
1451findNextOp firstIndex=[2] sign=1
1452activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1453activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1454markWinding id=3 (0,4 2,3 2,0 4,2) t=0.467845317 [2] (1.90340292,2) tEnd=0.856247521 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1455findNextOp chase.append id=3
1456activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1457markDoneBinary id=3 (0,4 2,3 2,0 4,2) t=0.341662805 [1] (1.50910997,2.5537951) tEnd=0.467845317 newWindSum=-1 newOppSum=2 oppSum=2 windSum=-1 windValue=1
1458findNextOp from:[3] to:[3] start=2 end=3
1459bridgeOp current id=3 from=(1.50910997,2.5537951) to=(1.90340292,2)
1460path.cubicTo(1.64794636,2.35827327, 1.77669871,2.16898704, 1.90340292,2);
1461findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
1462debugShowSort [1] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.856247521 tEnd=0.467845317 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1463debugShowSort [2] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.768795564 tEnd=0.5 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
1464debugShowSort [3] {{0,4}, {2,3}, {2,0}, {4,2}} tStart=0.856247521 tEnd=0.859816875 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1465debugShowSort [0] {{0,2}, {2,4}, {4,0}, {3,2}} tStart=0.768795564 tEnd=0.821660252 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
1466findNextOp firstIndex=[1] sign=1
1467activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1468activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1469activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
1470markDoneBinary id=3 (0,4 2,3 2,0 4,2) t=0.467845317 [2] (1.90340292,2) tEnd=0.856247521 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1471findNextOp from:[3] to:[1] start=3 end=4
1472bridgeOp current id=3 from=(1.90340292,2) to=(3.24959135,1.42666245)
1473path.cubicTo(2.29341149,1.47984147, 2.66401696,1.15201211, 3.24959135,1.42666245);
1474path.close();
1475debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.260340927 (1.50910997,2.5537951) tEnd=0.5 other=3 otherT=0.341662805 otherIndex=1 windSum=2 windValue=1 oppValue=0
1476debugShowActiveSpans id=2 (3,2 0,2) t=0.125 (2.625,2) tEnd=0.365532344 other=1 otherT=0.5 otherIndex=2 windSum=2 windValue=1 oppValue=0
1477activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1478markDoneBinary id=2 (3,2 0,2) t=0.125 [1] (2.625,2) tEnd=0.365532344 newWindSum=2 newOppSum=-1 oppSum=-1 windSum=2 windValue=1
1479debugShowActiveSpans id=1 (0,2 2,4 4,0 3,2) t=0.260340927 (1.50910997,2.5537951) tEnd=0.5 other=3 otherT=0.341662805 otherIndex=1 windSum=2 windValue=1 oppValue=0
1480activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1481markDoneBinary id=1 (0,2 2,4 4,0 3,2) t=0.260340927 [1] (1.50910997,2.5537951) tEnd=0.5 newWindSum=2 newOppSum=-1 oppSum=-1 windSum=2 windValue=1
1482</div>
1483
1484<div id="cubicOp46d">
1485 SimplifyNew_Test [cubicOp46d]
1486{{0,2}, {3,5}, {5,0}, {4,2}},
1487{{4,2}, {0,2}},
1488op difference
1489{{0,5}, {2,4}, {2,0}, {5,3}},
1490{{5,3}, {0,5}},
1491debugShowCubicIntersection no self intersect {{0,2}, {3,5}, {5,0}, {4,2}}
1492debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {3,5}, {5,0}, {4,2}} {{0,2}} wtTs[1]=0.6 {{3.887999999999999,2.0000000000000013}} wtTs[2]=1 {{4,2}} wnTs[0]=1 {{4,2}, {0,2}} wnTs[1]=0.028 wnTs[2]=0
1493debugShowCubicIntersection wtTs[0]=0.215060475 {{0,2}, {3,5}, {5,0}, {4,2}} {{1.7768977226209808,2.9747215410507057}} wtTs[1]=0.578517386 {{3.8153702411617676,2.0785732044555085}} wnTs[0]=0.404694 {{0,5}, {2,4}, {2,0}, {5,3}} wnTs[1]=0.846938928
1494debugShowCubicLineIntersection wtTs[0]=0.64696132 {{0,5}, {2,4}, {2,0}, {5,3}} {{2.7243714728959709,2}} wtTs[1]=0.819132784 {{3.6370281018311013,1.9999999999999996}} wnTs[0]=0.318907 {{4,2}, {0,2}} wnTs[1]=0.0907429745
1495debugShowCubicIntersection no self intersect {{0,5}, {2,4}, {2,0}, {5,3}}
1496debugShowCubicLineIntersection wtTs[0]=0 {{0,5}, {2,4}, {2,0}, {5,3}} {{0,5}} wtTs[1]=1 {{5,3}} wnTs[0]=1 {{5,3}, {0,5}} wnTs[1]=0
1497debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0 (0,2) tEnd=0.215060475 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1498debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0.215060475 (1.77689767,2.97472143) tEnd=0.578517386 other=3 otherT=0.404693629 otherIndex=1 windSum=? windValue=1 oppValue=0
1499debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0.578517386 (3.81537032,2.07857323) tEnd=0.6 other=3 otherT=0.846938928 otherIndex=4 windSum=? windValue=1 oppValue=0
1500debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0.6 (3.88800001,2) tEnd=1 other=2 otherT=0.028 otherIndex=1 windSum=? windValue=1 oppValue=0
1501debugShowActiveSpans id=2 (4,2 0,2) t=0 (4,2) tEnd=0.028 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1502debugShowActiveSpans id=2 (4,2 0,2) t=0.028 (3.88800001,2) tEnd=0.0907429745 other=1 otherT=0.6 otherIndex=3 windSum=? windValue=1 oppValue=0
1503debugShowActiveSpans id=2 (4,2 0,2) t=0.0907429745 (3.63702822,2) tEnd=0.318907132 other=3 otherT=0.819132784 otherIndex=3 windSum=? windValue=1 oppValue=0
1504debugShowActiveSpans id=2 (4,2 0,2) t=0.318907132 (2.72437143,2) tEnd=1 other=3 otherT=0.64696132 otherIndex=2 windSum=? windValue=1 oppValue=0
1505debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0 (0,5) tEnd=0.404693629 other=4 otherT=1 otherIndex=1 windSum=? windValue=1 oppValue=0
1506debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.404693629 (1.77689767,2.97472143) tEnd=0.64696132 other=1 otherT=0.215060475 otherIndex=1 windSum=? windValue=1 oppValue=0
1507debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.64696132 (2.72437143,2) tEnd=0.819132784 other=2 otherT=0.318907132 otherIndex=3 windSum=? windValue=1 oppValue=0
1508debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.819132784 (3.63702822,2) tEnd=0.846938928 other=2 otherT=0.0907429745 otherIndex=2 windSum=? windValue=1 oppValue=0
1509debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.846938928 (3.81537032,2.07857323) tEnd=1 other=1 otherT=0.578517386 otherIndex=2 windSum=? windValue=1 oppValue=0
1510debugShowActiveSpans id=4 (5,3 0,5) t=0 (5,3) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1511findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1512debugShowSort [0] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=1 tEnd=0.6 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1513debugShowSort [1] {{4,2}, {0,2}} tStart=0 tEnd=0.028 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1514findTop swap
1515markWinding id=1 (0,2 3,5 5,0 4,2) t=0.6 [3] (3.88800001,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1516markWinding id=1 (0,2 3,5 5,0 4,2) t=0.6 [3] (3.88800001,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1517markWinding id=2 (4,2 0,2) t=0 [0] (4,2) tEnd=0.028 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1518activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1519findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1520debugShowSort [0] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.6 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
1521debugShowSort [1] {{4,2}, {0,2}} tStart=0.028 tEnd=0.0907429745 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=0
1522debugShowSort [2] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.6 tEnd=0.578517386 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
1523debugShowSort [3] {{4,2}, {0,2}} tStart=0.028 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
1524findNextOp firstIndex=[0] sign=-1
1525activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1526markDoneBinary id=2 (4,2 0,2) t=0.028 [1] (3.88800001,2) tEnd=0.0907429745 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1527findNextOp chase.append id=2
1528activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1529markDoneBinary id=1 (0,2 3,5 5,0 4,2) t=0.578517386 [2] (3.81537032,2.07857323) tEnd=0.6 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1530findNextOp chase.append id=1
1531activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1532markDoneBinary id=1 (0,2 3,5 5,0 4,2) t=0.6 [3] (3.88800001,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1533findNextOp from:[1] to:[2] start=1 end=0
1534bridgeOp current id=1 from=(4,2) to=(3.88800001,2)
1535path.moveTo(4,2);
1536path.cubicTo(4.4000001,1.20000005, 4.32000017,1.51999998, 3.88800001,2);
1537findNextOp simple
1538markDoneBinary id=2 (4,2 0,2) t=0 [0] (4,2) tEnd=0.028 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1539bridgeOp current id=2 from=(3.88800001,2) to=(4,2)
1540path.lineTo(4,2);
1541path.close();
1542findChaseOp debugShowSort contourWinding=1 oppContourWinding=0 sign=-1
1543debugShowSort [0] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.578517386 tEnd=0.6 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=1 tiny=0 opp=0
1544debugShowSort [1] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.846938928 tEnd=0.819132784 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1545debugShowSort [2] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.578517386 tEnd=0.215060475 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
1546debugShowSort [3] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.846938928 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1547findChaseOp debugShowSort contourWinding=1 oppContourWinding=0 sign=-1
1548debugShowSort [0] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.578517386 tEnd=0.6 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=1 tiny=0 opp=0
1549debugShowSort [1] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.846938928 tEnd=0.819132784 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1550debugShowSort [2] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.578517386 tEnd=0.215060475 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
1551debugShowSort [3] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.846938928 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1552markWinding id=3 (0,5 2,4 2,0 5,3) t=0.819132784 [3] (3.63702822,2) tEnd=0.846938928 newWindSum=-1 newOppSum=2 oppSum=? windSum=? windValue=1
1553markWinding id=1 (0,2 3,5 5,0 4,2) t=0.215060475 [1] (1.77689767,2.97472143) tEnd=0.578517386 newWindSum=2 newOppSum=-1 oppSum=? windSum=? windValue=1
1554markWinding id=3 (0,5 2,4 2,0 5,3) t=0.846938928 [4] (3.81537032,2.07857323) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1555markWinding id=4 (5,3 0,5) t=0 [0] (5,3) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1556markWinding id=3 (0,5 2,4 2,0 5,3) t=0 [0] (0,5) tEnd=0.404693629 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1557debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0 (0,2) tEnd=0.215060475 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1558debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0.215060475 (1.77689767,2.97472143) tEnd=0.578517386 other=3 otherT=0.404693629 otherIndex=1 windSum=2 windValue=1 oppValue=0
1559debugShowActiveSpans id=2 (4,2 0,2) t=0.0907429745 (3.63702822,2) tEnd=0.318907132 other=3 otherT=0.819132784 otherIndex=3 windSum=? windValue=1 oppValue=0
1560debugShowActiveSpans id=2 (4,2 0,2) t=0.318907132 (2.72437143,2) tEnd=1 other=3 otherT=0.64696132 otherIndex=2 windSum=? windValue=1 oppValue=0
1561debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0 (0,5) tEnd=0.404693629 other=4 otherT=1 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1562debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.404693629 (1.77689767,2.97472143) tEnd=0.64696132 other=1 otherT=0.215060475 otherIndex=1 windSum=? windValue=1 oppValue=0
1563debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.64696132 (2.72437143,2) tEnd=0.819132784 other=2 otherT=0.318907132 otherIndex=3 windSum=? windValue=1 oppValue=0
1564debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.819132784 (3.63702822,2) tEnd=0.846938928 other=2 otherT=0.0907429745 otherIndex=2 windSum=-1 windValue=1 oppValue=0
1565debugShowActiveSpans id=3 (0,5 2,4 2,0 5,3) t=0.846938928 (3.81537032,2.07857323) tEnd=1 other=1 otherT=0.578517386 otherIndex=2 windSum=-1 windValue=1 oppValue=0
1566debugShowActiveSpans id=4 (5,3 0,5) t=0 (5,3) tEnd=1 other=3 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
1567activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1568findNextOp debugShowSort contourWinding=-1 oppContourWinding=2 sign=-1
1569debugShowSort [2] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.819132784 tEnd=0.846938928 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1570debugShowSort [3] {{4,2}, {0,2}} tStart=0.0907429745 tEnd=0.028 sign=1 windValue=1 windSum=2 2->1 (max=2) done=1 tiny=0 opp=1
1571debugShowSort [0] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.819132784 tEnd=0.64696132 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1572debugShowSort [1] {{4,2}, {0,2}} tStart=0.0907429745 tEnd=0.318907132 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=1
1573findNextOp firstIndex=[2] sign=-1
1574activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1575activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1576markWinding id=3 (0,5 2,4 2,0 5,3) t=0.64696132 [2] (2.72437143,2) tEnd=0.819132784 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1577findNextOp chase.append id=3
1578activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1579markDoneBinary id=2 (4,2 0,2) t=0.0907429745 [2] (3.63702822,2) tEnd=0.318907132 newWindSum=2 newOppSum=-1 oppSum=? windSum=? windValue=1
1580findNextOp chase.append id=2
1581markDoneBinary id=3 (0,5 2,4 2,0 5,3) t=0.819132784 [3] (3.63702822,2) tEnd=0.846938928 newWindSum=-1 newOppSum=2 oppSum=2 windSum=-1 windValue=1
1582findNextOp from:[3] to:[3] start=3 end=2
1583bridgeOp current id=3 from=(3.81537032,2.07857323) to=(3.63702822,2)
1584path.moveTo(3.81537032,2.07857323);
1585path.cubicTo(3.75423074,2.04822493, 3.69481921,2.02210546, 3.63702822,2);
1586findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1587debugShowSort [0] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.64696132 tEnd=0.819132784 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1588debugShowSort [1] {{4,2}, {0,2}} tStart=0.318907132 tEnd=1 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=1
1589debugShowSort [2] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.64696132 tEnd=0.404693629 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1590debugShowSort [3] {{4,2}, {0,2}} tStart=0.318907132 tEnd=0.0907429745 sign=1 windValue=1 windSum=2 2->1 (max=2) done=1 tiny=0 opp=1
1591findNextOp firstIndex=[0] sign=-1
1592activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1593markDoneBinary id=2 (4,2 0,2) t=0.318907132 [3] (2.72437143,2) tEnd=1 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1594markDoneBinary id=1 (0,2 3,5 5,0 4,2) t=0 [0] (0,2) tEnd=0.215060475 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1595findNextOp chase.append id=1
1596activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1597markWinding id=3 (0,5 2,4 2,0 5,3) t=0.404693629 [1] (1.77689767,2.97472143) tEnd=0.64696132 newWindSum=-1 newOppSum=2 oppSum=? windSum=? windValue=1
1598findNextOp chase.append id=3
1599activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1600markDoneBinary id=3 (0,5 2,4 2,0 5,3) t=0.64696132 [2] (2.72437143,2) tEnd=0.819132784 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1601findNextOp from:[3] to:[3] start=2 end=1
1602bridgeOp current id=3 from=(3.63702822,2) to=(2.72437143,2)
1603path.cubicTo(3.2791934,1.86312568, 2.98348093,1.88013792, 2.72437143,2);
1604findNextOp debugShowSort contourWinding=-1 oppContourWinding=2 sign=-1
1605debugShowSort [0] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.404693629 tEnd=0.64696132 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1606debugShowSort [1] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.215060475 tEnd=0 sign=1 windValue=1 windSum=2 2->1 (max=2) done=1 tiny=0 opp=1
1607debugShowSort [2] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.404693629 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1608debugShowSort [3] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.215060475 tEnd=0.578517386 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=0 tiny=0 opp=1
1609findNextOp firstIndex=[0] sign=-1
1610activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1611activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1612activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1613markDoneBinary id=3 (0,5 2,4 2,0 5,3) t=0.404693629 [1] (1.77689767,2.97472143) tEnd=0.64696132 newWindSum=-1 newOppSum=2 oppSum=2 windSum=-1 windValue=1
1614findNextOp from:[3] to:[3] start=1 end=0
1615bridgeOp current id=3 from=(2.72437143,2) to=(1.77689767,2.97472143)
1616path.cubicTo(2.35977101,2.16866159, 2.06764531,2.54096746, 1.77689767,2.97472143);
1617findNextOp simple
1618markDoneBinary id=3 (0,5 2,4 2,0 5,3) t=0 [0] (0,5) tEnd=0.404693629 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1619bridgeOp current id=3 from=(1.77689767,2.97472143) to=(0,5)
1620path.cubicTo(1.29122055,3.69928193, 0.809387267,4.5953064, 0,5);
1621findNextOp simple
1622markDoneBinary id=4 (5,3 0,5) t=0 [0] (5,3) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1623bridgeOp current id=4 from=(0,5) to=(5,3)
1624findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1625debugShowSort [3] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.846938928 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1626debugShowSort [0] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.578517386 tEnd=0.6 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=1 tiny=0 opp=1
1627debugShowSort [1] {{0,5}, {2,4}, {2,0}, {5,3}} tStart=0.846938928 tEnd=0.819132784 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
1628debugShowSort [2] {{0,2}, {3,5}, {5,0}, {4,2}} tStart=0.578517386 tEnd=0.215060475 sign=1 windValue=1 windSum=2 2->1 (max=2) done=0 tiny=0 opp=1
1629findNextOp firstIndex=[3] sign=-1
1630activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1631activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1632activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1633markDoneBinary id=3 (0,5 2,4 2,0 5,3) t=0.846938928 [4] (3.81537032,2.07857323) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1634findNextOp from:[3] to:[3] start=4 end=3
1635bridgeOp current id=3 from=(5,3) to=(3.81537032,2.07857323)
1636path.lineTo(5,3);
1637path.cubicTo(4.54081678,2.54081678, 4.1519165,2.2456274, 3.81537032,2.07857323);
1638path.close();
1639debugShowActiveSpans id=1 (0,2 3,5 5,0 4,2) t=0.215060475 (1.77689767,2.97472143) tEnd=0.578517386 other=3 otherT=0.404693629 otherIndex=1 windSum=2 windValue=1 oppValue=0
1640activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1641markDoneBinary id=1 (0,2 3,5 5,0 4,2) t=0.215060475 [1] (1.77689767,2.97472143) tEnd=0.578517386 newWindSum=2 newOppSum=-1 oppSum=-1 windSum=2 windValue=1
1642assemble
1643assemble contour start=(4,2) end=(4,2)
1644</div>
1645
1646<div id="cubicOp46da">
1647 {{0,2}, {3,5}, {5,0}, {4,2}},
1648
1649 {{0,2}, {1.1328125,3.06640625}, {2.03125,2.984375}},
1650 {{2.03125,2.984375}, {2.9296875,2.90234375}, {3.5,2.375}},
1651 {{3.5,2.375}, {4.0703125,1.84765625}, {4.21875,1.578125}},
1652 {{4.21875,1.578125}, {4.3671875,1.30859375}, {4,2}},
1653</div>
1654
1655<div id="cubicOp46db">
1656{{x = 3, y = 4}, {x = 4.0000000000000009, y = 6}, {x = 0.99999999999999845, y = 7.894919286223335e-16}, {x = 6, y = 2}}
1657</div>
1658
1659<div id="cubicOp47d">
1660 SimplifyNew_Test [cubicOp47d]
1661{{0,1}, {1,6}, {6,2}, {5,4}},
1662{{5,4}, {0,1}},
1663op difference
1664{{2,6}, {4,5}, {1,0}, {6,1}},
1665{{6,1}, {2,6}},
1666debugShowCubicIntersection no self intersect {{2,6}, {4,5}, {1,0}, {6,1}}
1667debugShowCubicLineIntersection wtTs[0]=0 {{2,6}, {4,5}, {1,0}, {6,1}} {{2,6}} wtTs[1]=0.171428571 {{2.6532478134110784,5.1834402332361513}} wtTs[2]=1 {{6,1}} wnTs[0]=1 {{6,1}, {2,6}} wnTs[1]=0.836688047 wnTs[2]=0
1668debugShowCubicIntersection no intersect {{2,6}, {4,5}, {1,0}, {6,1}} {{0,1}, {1,6}, {6,2}, {5,4}}
1669debugShowCubicLineIntersection wtTs[0]=0.503145036 {{2,6}, {4,5}, {1,0}, {6,1}} {{2.8774036920020918,2.7264422152012551}} wnTs[0]=0.424519 {{5,4}, {0,1}}
1670debugShowCubicLineIntersection wtTs[0]=0.604274731 {{0,1}, {1,6}, {6,2}, {5,4}} {{3.9881028045490883,3.5148714943136397}} wnTs[0]=0.502974 {{6,1}, {2,6}}
1671debugShowLineIntersection wtTs[0]=0.486486486 {{6,1}, {2,6}} {{4.0540540540540535,3.4324324324324329}} wnTs[0]=0.189189 {{5,4}, {0,1}}
1672debugShowCubicIntersection no self intersect {{0,1}, {1,6}, {6,2}, {5,4}}
1673debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {1,6}, {6,2}, {5,4}} {{0,1}} wtTs[1]=0.628571429 {{4.1434402332361522,3.486064139941691}} wtTs[2]=1 {{5,4}} wnTs[0]=1 {{5,4}, {0,1}} wnTs[1]=0.171311953 wnTs[2]=0
1674debugShowActiveSpans id=3 (2,6 4,5 1,0 6,1) t=0 (2,6) tEnd=0.171428571 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1675debugShowActiveSpans id=3 (2,6 4,5 1,0 6,1) t=0.171428571 (2.65324783,5.18344021) tEnd=0.503145036 other=4 otherT=0.836688047 otherIndex=3 windSum=? windValue=1 oppValue=0
1676debugShowActiveSpans id=3 (2,6 4,5 1,0 6,1) t=0.503145036 (2.87740374,2.7264421) tEnd=1 other=2 otherT=0.424519262 otherIndex=3 windSum=? windValue=1 oppValue=0
1677debugShowActiveSpans id=4 (6,1 2,6) t=0 (6,1) tEnd=0.486486486 other=3 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1678debugShowActiveSpans id=4 (6,1 2,6) t=0.486486486 (4.05405426,3.43243241) tEnd=0.502974299 other=2 otherT=0.189189189 otherIndex=2 windSum=? windValue=1 oppValue=0
1679debugShowActiveSpans id=4 (6,1 2,6) t=0.502974299 (3.98810291,3.5148716) tEnd=0.836688047 other=1 otherT=0.604274731 otherIndex=1 windSum=? windValue=1 oppValue=0
1680debugShowActiveSpans id=4 (6,1 2,6) t=0.836688047 (2.65324783,5.18344021) tEnd=1 other=3 otherT=0.171428571 otherIndex=1 windSum=? windValue=1 oppValue=0
1681debugShowActiveSpans id=1 (0,1 1,6 6,2 5,4) t=0 (0,1) tEnd=0.604274731 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1682debugShowActiveSpans id=1 (0,1 1,6 6,2 5,4) t=0.604274731 (3.98810291,3.5148716) tEnd=0.628571429 other=4 otherT=0.502974299 otherIndex=2 windSum=? windValue=1 oppValue=0
1683debugShowActiveSpans id=1 (0,1 1,6 6,2 5,4) t=0.628571429 (4.14344025,3.4860642) tEnd=1 other=2 otherT=0.171311953 otherIndex=1 windSum=? windValue=1 oppValue=0
1684debugShowActiveSpans id=2 (5,4 0,1) t=0 (5,4) tEnd=0.171311953 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1685debugShowActiveSpans id=2 (5,4 0,1) t=0.171311953 (4.14344025,3.4860642) tEnd=0.189189189 other=1 otherT=0.628571429 otherIndex=2 windSum=? windValue=1 oppValue=0
1686debugShowActiveSpans id=2 (5,4 0,1) t=0.189189189 (4.05405426,3.43243241) tEnd=0.424519262 other=4 otherT=0.486486486 otherIndex=1 windSum=? windValue=1 oppValue=0
1687debugShowActiveSpans id=2 (5,4 0,1) t=0.424519262 (2.87740374,2.7264421) tEnd=1 other=3 otherT=0.503145036 otherIndex=2 windSum=? windValue=1 oppValue=0
1688findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1689debugShowSort [0] {{0,1}, {1,6}, {6,2}, {5,4}} tStart=0 tEnd=0.604274731 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
1690debugShowSort [1] {{5,4}, {0,1}} tStart=1 tEnd=0.424519262 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1691markWinding id=1 (0,1 1,6 6,2 5,4) t=0 [0] (0,1) tEnd=0.604274731 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1692markWinding id=2 (5,4 0,1) t=0.424519262 [3] (2.87740374,2.7264421) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1693markWinding id=1 (0,1 1,6 6,2 5,4) t=0 [0] (0,1) tEnd=0.604274731 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1694activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
1695findNextOp simple
1696markDoneBinary id=1 (0,1 1,6 6,2 5,4) t=0 [0] (0,1) tEnd=0.604274731 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1697bridgeOp current id=1 from=(3.98810291,3.5148716) to=(0,1)
1698path.moveTo(3.98810291,3.5148716);
1699path.cubicTo(2.66914129,3.75641561, 0.60427475,4.02137375, 0,1);
1700findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
1701debugShowSort [1] {{5,4}, {0,1}} tStart=0.424519262 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
1702debugShowSort [2] {{2,6}, {4,5}, {1,0}, {6,1}} tStart=0.503145036 tEnd=0.171428571 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
1703debugShowSort [3] {{5,4}, {0,1}} tStart=0.424519262 tEnd=0.189189189 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1704debugShowSort [0] {{2,6}, {4,5}, {1,0}, {6,1}} tStart=0.503145036 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
1705findNextOp firstIndex=[1] sign=-1
1706activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1707markWinding id=3 (2,6 4,5 1,0 6,1) t=0.171428571 [1] (2.65324783,5.18344021) tEnd=0.503145036 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1708findNextOp chase.append id=3
1709activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1710markDoneBinary id=2 (5,4 0,1) t=0.189189189 [2] (4.05405426,3.43243241) tEnd=0.424519262 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1711findNextOp chase.append id=2
1712activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1713markDoneBinary id=3 (2,6 4,5 1,0 6,1) t=0.503145036 [2] (2.87740374,2.7264421) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1714markDoneBinary id=4 (6,1 2,6) t=0 [0] (6,1) tEnd=0.486486486 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1715findNextOp chase.append id=4
1716markDoneBinary id=2 (5,4 0,1) t=0.424519262 [3] (2.87740374,2.7264421) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1717findNextOp from:[2] to:[3] start=2 end=1
1718bridgeOp current id=2 from=(0,1) to=(2.87740374,2.7264421)
1719findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1720debugShowSort [1] {{2,6}, {4,5}, {1,0}, {6,1}} tStart=0.171428571 tEnd=0.503145036 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1721debugShowSort [2] {{6,1}, {2,6}} tStart=0.836688047 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
1722debugShowSort [3] {{2,6}, {4,5}, {1,0}, {6,1}} tStart=0.171428571 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
1723debugShowSort [0] {{6,1}, {2,6}} tStart=0.836688047 tEnd=0.502974299 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1724findNextOp firstIndex=[1] sign=-1
1725activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1726markWinding id=4 (6,1 2,6) t=0.836688047 [3] (2.65324783,5.18344021) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
1727markWinding id=3 (2,6 4,5 1,0 6,1) t=0 [0] (2,6) tEnd=0.171428571 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
1728findNextOp chase.append id=3
1729activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1730activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1731markWinding id=4 (6,1 2,6) t=0.502974299 [2] (3.98810291,3.5148716) tEnd=0.836688047 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1732findNextOp chase.append id=4
1733markDoneBinary id=3 (2,6 4,5 1,0 6,1) t=0.171428571 [1] (2.65324783,5.18344021) tEnd=0.503145036 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1734findNextOp from:[3] to:[4] start=3 end=4
1735bridgeOp current id=3 from=(2.87740374,2.7264421) to=(2.65324783,5.18344021)
1736path.lineTo(2.87740374,2.7264421);
1737path.cubicTo(2.7913022,3.55361414, 2.87475324,4.49428225, 2.65324783,5.18344021);
1738findNextOp simple
1739markDoneBinary id=4 (6,1 2,6) t=0.836688047 [3] (2.65324783,5.18344021) tEnd=1 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
1740bridgeOp current id=4 from=(2.65324783,5.18344021) to=(2,6)
1741findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
1742debugShowSort [3] {{2,6}, {4,5}, {1,0}, {6,1}} tStart=0.171428571 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
1743debugShowSort [0] {{6,1}, {2,6}} tStart=0.836688047 tEnd=0.502974299 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1744debugShowSort [1] {{2,6}, {4,5}, {1,0}, {6,1}} tStart=0.171428571 tEnd=0.503145036 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1745debugShowSort [2] {{6,1}, {2,6}} tStart=0.836688047 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
1746findNextOp firstIndex=[3] sign=1
1747activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1748activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1749activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1750markDoneBinary id=3 (2,6 4,5 1,0 6,1) t=0 [0] (2,6) tEnd=0.171428571 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
1751findNextOp from:[3] to:[4] start=3 end=2
1752bridgeOp current id=3 from=(2,6) to=(2.65324783,5.18344021)
1753path.lineTo(2,6);
1754path.cubicTo(2.34285712,5.82857132, 2.53877544,5.53959179, 2.65324783,5.18344021);
1755findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
1756debugShowSort [3] {{6,1}, {2,6}} tStart=0.502974299 tEnd=0.836688047 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
1757debugShowSort [0] {{0,1}, {1,6}, {6,2}, {5,4}} tStart=0.604274731 tEnd=0.628571429 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=1
1758debugShowSort [1] {{6,1}, {2,6}} tStart=0.502974299 tEnd=0.486486486 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1759debugShowSort [2] {{0,1}, {1,6}, {6,2}, {5,4}} tStart=0.604274731 tEnd=0 sign=1 windValue=1 windSum=1 2->1 (max=2) done=1 tiny=0 opp=1
1760findNextOp firstIndex=[3] sign=-1
1761activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1762markDoneBinary id=1 (0,1 1,6 6,2 5,4) t=0.604274731 [1] (3.98810291,3.5148716) tEnd=0.628571429 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
1763findNextOp chase.append id=1
1764activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
1765markWinding id=4 (6,1 2,6) t=0.486486486 [1] (4.05405426,3.43243241) tEnd=0.502974299 newWindSum=-1 newOppSum=2 oppSum=? windSum=? windValue=1
1766findNextOp chase.append id=4
1767activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1768markDoneBinary id=4 (6,1 2,6) t=0.502974299 [2] (3.98810291,3.5148716) tEnd=0.836688047 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1769findNextOp from:[4] to:[4] start=2 end=1
1770bridgeOp current id=4 from=(2.65324783,5.18344021) to=(3.98810291,3.5148716)
1771path.lineTo(3.98810291,3.5148716);
1772path.close();
1773debugShowActiveSpans id=4 (6,1 2,6) t=0.486486486 (4.05405426,3.43243241) tEnd=0.502974299 other=2 otherT=0.189189189 otherIndex=2 windSum=-1 windValue=1 oppValue=0
1774debugShowActiveSpans id=1 (0,1 1,6 6,2 5,4) t=0.628571429 (4.14344025,3.4860642) tEnd=1 other=2 otherT=0.171311953 otherIndex=1 windSum=? windValue=1 oppValue=0
1775debugShowActiveSpans id=2 (5,4 0,1) t=0 (5,4) tEnd=0.171311953 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1776debugShowActiveSpans id=2 (5,4 0,1) t=0.171311953 (4.14344025,3.4860642) tEnd=0.189189189 other=1 otherT=0.628571429 otherIndex=2 windSum=? windValue=1 oppValue=0
1777activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1778findNextOp debugShowSort contourWinding=0 oppContourWinding=2 sign=1
1779debugShowSort [1] {{6,1}, {2,6}} tStart=0.502974299 tEnd=0.486486486 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1780debugShowSort [2] {{0,1}, {1,6}, {6,2}, {5,4}} tStart=0.604274731 tEnd=0 sign=1 windValue=1 windSum=1 2->1 (max=2) done=1 tiny=0 opp=1
1781debugShowSort [3] {{6,1}, {2,6}} tStart=0.502974299 tEnd=0.836688047 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1782debugShowSort [0] {{0,1}, {1,6}, {6,2}, {5,4}} tStart=0.604274731 tEnd=0.628571429 sign=-1 windValue=1 windSum=2 1->2 (max=2) done=1 tiny=0 opp=1
1783findNextOp firstIndex=[1] sign=1
1784activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1785activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1786activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1787markDoneBinary id=4 (6,1 2,6) t=0.486486486 [1] (4.05405426,3.43243241) tEnd=0.502974299 newWindSum=-1 newOppSum=2 oppSum=2 windSum=-1 windValue=1
1788findNextOp from:[4] to:[4] start=2 end=3
1789bridgeOp current id=4 from=(4.05405426,3.43243241) to=(3.98810291,3.5148716)
1790debugShowActiveSpans id=1 (0,1 1,6 6,2 5,4) t=0.628571429 (4.14344025,3.4860642) tEnd=1 other=2 otherT=0.171311953 otherIndex=1 windSum=? windValue=1 oppValue=0
1791debugShowActiveSpans id=2 (5,4 0,1) t=0 (5,4) tEnd=0.171311953 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1792debugShowActiveSpans id=2 (5,4 0,1) t=0.171311953 (4.14344025,3.4860642) tEnd=0.189189189 other=1 otherT=0.628571429 otherIndex=2 windSum=? windValue=1 oppValue=0
1793</div>
1794
1795<div id="cubicOp47da">
1796computed quadratics given
1797 {{2,6}, {4,5}, {1,0}, {6,1}},
1798 {{0,1}, {1,6}, {6,2}, {5,4}},
1799computed quadratics set 1
1800 {{2,6}, {2.2404737,5.87759298}, {2.39345162,5.68487367}},
1801 {{2.39345162,5.68487367}, {2.67348969,5.31541246}, {2.74792918,4.77711896}},
1802 {{2.74792918,4.77711896}, {2.82236867,4.23882547}, {2.82848144,3.63729341}},
1803 {{2.82848144,3.63729341}, {2.83027876,3.57616472}, {2.83215462,3.51498289}},
1804 {{2.83215462,3.51498289}, {2.78850872,2.32758859}, {3.26769775,1.50382966}},
1805 {{3.26769775,1.50382966}, {3.55499101,1.08453908}, {4.20162956,0.930553195}},
1806 {{4.20162956,0.930553195}, {4.84826812,0.776567313}, {6,1}},
1807computed quadratics set 2
1808 {{0,1}, {0.337189878,2.53658624}, {1.06305813,3.09524088}},
1809 {{1.06305813,3.09524088}, {1.78892639,3.65389552}, {2.62772567,3.64823958}},
1810 {{2.62772567,3.64823958}, {3.46652495,3.64258364}, {4.1425079,3.48623815}},
1811 {{4.1425079,3.48623815}, {4.88772835,3.3075243}, {5.09137748,3.46764237}},
1812 {{5.09137748,3.46764237}, {5.20611277,3.58418013}, {5,4}},
1813</div>
1814
1815<div id="cubicOp47db">
1816 {{2.74792918,4.77711896}, {2.82236867,4.23882547}, {2.82848144,3.63729341}},
1817 {{2.62772567,3.64823958}, {3.46652495,3.64258364}, {4.1425079,3.48623815}},
1818</div>
1819
1820<div id="cubicOp48d">
1821 SimplifyNew_Test [cubicOp48d]
1822{{0,2}, {2,3}, {5,1}, {3,2}},
1823{{3,2}, {0,2}},
1824op difference
1825{{1,5}, {2,3}, {2,0}, {3,2}},
1826{{3,2}, {1,5}},
1827debugShowCubicIntersection no self intersect {{1,5}, {2,3}, {2,0}, {3,2}}
1828debugShowCubicLineIntersection wtTs[0]=0 {{1,5}, {2,3}, {2,0}, {3,2}} {{1,5}} wtTs[1]=1 {{3,2}} wnTs[0]=1 {{3,2}, {1,5}} wnTs[1]=0
1829debugShowCubicIntersection wtTs[0]=0.447821962 {{1,5}, {2,3}, {2,0}, {3,2}} {{1.921448828321461,2.2502841146969206}} wtTs[1]=1 {{3,2}} wnTs[0]=0.302178 {{0,2}, {2,3}, {5,1}, {3,2}} wnTs[1]=1
1830debugShowCubicLineIntersection wtTs[0]=0.5 {{1,5}, {2,3}, {2,0}, {3,2}} {{2,2}} wtTs[1]=1 {{3,2}} wnTs[0]=0.333333 {{3,2}, {0,2}} wnTs[1]=0
1831debugShowCubicLineIntersection wtTs[0]=0.5 {{0,2}, {2,3}, {5,1}, {3,2}} {{3,2}} wtTs[1]=1 {{3,2}} wnTs[0]=0 {{3,2}, {1,5}} wnTs[1]=0
1832debugShowLineIntersection wtTs[0]=0 {{3,2}, {1,5}} {{3,2}} wnTs[0]=0 {{3,2}, {0,2}}
1833debugShowCubicIntersection wtTs[0]=0.5 {{0,2}, {2,3}, {5,1}, {3,2}} {{3,2}} wtTs[1]=1
1834debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {2,3}, {5,1}, {3,2}} {{0,2}} wtTs[1]=0.5 {{3,2}} wtTs[2]=1 {{3,2}} wnTs[0]=1 {{3,2}, {0,2}} wnTs[1]=0 wnTs[2]=0
1835debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0 (1,5) tEnd=0.447821962 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
1836debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0.447821962 (1.92144883,2.25028419) tEnd=0.5 other=1 otherT=0.302178051 otherIndex=1 windSum=? windValue=1 oppValue=0
1837debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0.5 (2,2) tEnd=1 other=2 otherT=0.333333333 otherIndex=4 windSum=? windValue=1 oppValue=0
1838debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=1 other=3 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
1839debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0 (0,2) tEnd=0.302178051 other=2 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1840debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.302178051 (1.92144883,2.25028419) tEnd=0.5 other=3 otherT=0.447821962 otherIndex=1 windSum=? windValue=1 oppValue=0
1841debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.5 (3,2) tEnd=1 other=4 otherT=0 otherIndex=1 windSum=? windValue=1 oppValue=0
1842debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.333333333 other=3 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1843debugShowActiveSpans id=2 (3,2 0,2) t=0.333333333 (2,2) tEnd=1 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1844findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1845debugShowSort [1] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1846debugShowSort [2] {{3,2}, {0,2}} tStart=0 tEnd=0.333333333 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
1847debugShowSort [3] {{3,2}, {1,5}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1848debugShowSort [0] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
1849markWinding id=3 (1,5 2,3 2,0 3,2) t=0.5 [2] (2,2) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
1850markWinding id=3 (1,5 2,3 2,0 3,2) t=0.5 [2] (2,2) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1851activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1852markDoneBinary id=3 (1,5 2,3 2,0 3,2) t=0.5 [2] (2,2) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
1853findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
1854debugShowSort [0] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1855debugShowSort [1] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
1856debugShowSort [2] {{3,2}, {0,2}} tStart=0 tEnd=0.333333333 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
1857debugShowSort [3] {{3,2}, {1,5}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
1858findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
1859debugShowSort [1] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
1860debugShowSort [2] {{3,2}, {0,2}} tStart=0 tEnd=0.333333333 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
1861debugShowSort [3] {{3,2}, {1,5}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
1862debugShowSort [0] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
1863markWinding id=2 (3,2 0,2) t=0 [0] (3,2) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1864markWinding id=2 (3,2 0,2) t=0 [1] (3,2) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1865markWinding id=2 (3,2 0,2) t=0 [2] (3,2) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1866markWinding id=2 (3,2 0,2) t=0 [3] (3,2) tEnd=0.333333333 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1867markWinding id=4 (3,2 1,5) t=0 [0] (3,2) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1868markWinding id=4 (3,2 1,5) t=0 [1] (3,2) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1869markWinding id=4 (3,2 1,5) t=0 [2] (3,2) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1870markWinding id=4 (3,2 1,5) t=0 [3] (3,2) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1871markWinding id=3 (1,5 2,3 2,0 3,2) t=0 [0] (1,5) tEnd=0.447821962 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1872markWinding id=1 (0,2 2,3 5,1 3,2) t=0.5 [3] (3,2) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1873markWinding id=1 (0,2 2,3 5,1 3,2) t=0.5 [2] (3,2) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1874markWinding id=1 (0,2 2,3 5,1 3,2) t=0.5 [4] (3,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1875debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0 (1,5) tEnd=0.447821962 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1876debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0.447821962 (1.92144883,2.25028419) tEnd=0.5 other=1 otherT=0.302178051 otherIndex=1 windSum=? windValue=1 oppValue=0
1877debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=1 other=3 otherT=1 otherIndex=3 windSum=-1 windValue=1 oppValue=0
1878debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0 (0,2) tEnd=0.302178051 other=2 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
1879debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.302178051 (1.92144883,2.25028419) tEnd=0.5 other=3 otherT=0.447821962 otherIndex=1 windSum=? windValue=1 oppValue=0
1880debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.5 (3,2) tEnd=1 other=4 otherT=0 otherIndex=1 windSum=1 windValue=1 oppValue=0
1881debugShowActiveSpans id=2 (3,2 0,2) t=0 (3,2) tEnd=0.333333333 other=3 otherT=1 otherIndex=5 windSum=1 windValue=1 oppValue=0
1882debugShowActiveSpans id=2 (3,2 0,2) t=0.333333333 (2,2) tEnd=1 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
1883activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1884markDoneBinary id=2 (3,2 0,2) t=0 [0] (3,2) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1885markDoneBinary id=2 (3,2 0,2) t=0 [1] (3,2) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1886markDoneBinary id=2 (3,2 0,2) t=0 [2] (3,2) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1887markDoneBinary id=2 (3,2 0,2) t=0 [3] (3,2) tEnd=0.333333333 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
1888findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
1889debugShowSort [0] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1890debugShowSort [1] {{3,2}, {0,2}} tStart=0.333333333 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
1891debugShowSort [2] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.5 tEnd=0.447821962 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1892debugShowSort [3] {{3,2}, {0,2}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
1893findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
1894debugShowSort [0] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1895debugShowSort [1] {{3,2}, {0,2}} tStart=0.333333333 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
1896debugShowSort [2] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.5 tEnd=0.447821962 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
1897debugShowSort [3] {{3,2}, {0,2}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
1898markWinding id=2 (3,2 0,2) t=0.333333333 [4] (2,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1899markWinding id=1 (0,2 2,3 5,1 3,2) t=0 [0] (0,2) tEnd=0.302178051 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
1900markWinding id=3 (1,5 2,3 2,0 3,2) t=0.447821962 [1] (1.92144883,2.25028419) tEnd=0.5 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
1901debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0 (1,5) tEnd=0.447821962 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1902debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0.447821962 (1.92144883,2.25028419) tEnd=0.5 other=1 otherT=0.302178051 otherIndex=1 windSum=-1 windValue=1 oppValue=0
1903debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=1 other=3 otherT=1 otherIndex=3 windSum=-1 windValue=1 oppValue=0
1904debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0 (0,2) tEnd=0.302178051 other=2 otherT=1 otherIndex=5 windSum=1 windValue=1 oppValue=0
1905debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.302178051 (1.92144883,2.25028419) tEnd=0.5 other=3 otherT=0.447821962 otherIndex=1 windSum=? windValue=1 oppValue=0
1906debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.5 (3,2) tEnd=1 other=4 otherT=0 otherIndex=1 windSum=1 windValue=1 oppValue=0
1907debugShowActiveSpans id=2 (3,2 0,2) t=0.333333333 (2,2) tEnd=1 other=3 otherT=0.5 otherIndex=2 windSum=1 windValue=1 oppValue=0
1908activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
1909findNextOp simple
1910markDoneBinary id=2 (3,2 0,2) t=0.333333333 [4] (2,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1911bridgeOp current id=2 from=(2,2) to=(0,2)
1912findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
1913debugShowSort [2] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=0.302178051 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
1914debugShowSort [3] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.447821962 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=1
1915debugShowSort [0] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=0.302178051 tEnd=0.5 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
1916debugShowSort [1] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.447821962 tEnd=0.5 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
1917findNextOp firstIndex=[2] sign=1
1918activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1919activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1920markDoneBinary id=1 (0,2 2,3 5,1 3,2) t=0.302178051 [1] (1.92144883,2.25028419) tEnd=0.5 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
1921findNextOp chase.append id=1
1922activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1923markDoneBinary id=1 (0,2 2,3 5,1 3,2) t=0 [0] (0,2) tEnd=0.302178051 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1924findNextOp from:[1] to:[3] start=1 end=2
1925bridgeOp current id=1 from=(0,2) to=(1.92144883,2.25028419)
1926path.moveTo(2,2);
1927path.lineTo(0,2);
1928path.cubicTo(0.60435605,2.30217814, 1.30002379,2.33042121, 1.92144883,2.25028419);
1929findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
1930debugShowSort [2] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.5 tEnd=0.447821962 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1931debugShowSort [3] {{3,2}, {0,2}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
1932debugShowSort [0] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1933debugShowSort [1] {{3,2}, {0,2}} tStart=0.333333333 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
1934findNextOp firstIndex=[2] sign=1
1935activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1936activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1937activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
1938markDoneBinary id=3 (1,5 2,3 2,0 3,2) t=0.447821962 [1] (1.92144883,2.25028419) tEnd=0.5 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1939findNextOp from:[3] to:[2] start=4 end=5
1940bridgeOp current id=3 from=(1.92144883,2.25028419) to=(2,2)
1941path.cubicTo(1.94782197,2.1619792, 1.97391093,2.0782671, 2,2);
1942path.close();
1943debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0 (1,5) tEnd=0.447821962 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1944debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=1 other=3 otherT=1 otherIndex=3 windSum=-1 windValue=1 oppValue=0
1945debugShowActiveSpans id=1 (0,2 2,3 5,1 3,2) t=0.5 (3,2) tEnd=1 other=4 otherT=0 otherIndex=1 windSum=1 windValue=1 oppValue=0
1946activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
1947findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
1948debugShowSort [1] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
1949debugShowSort [2] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
1950debugShowSort [3] {{3,2}, {0,2}} tStart=0 tEnd=0.333333333 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
1951debugShowSort [4] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=0.5 tEnd=0.302178051 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
1952debugShowSort [5] {{3,2}, {1,5}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
1953debugShowSort [0] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
1954findNextOp firstIndex=[1] sign=1
1955activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
1956activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
1957activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
1958activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
1959activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
1960markDoneBinary id=1 (0,2 2,3 5,1 3,2) t=0.5 [2] (3,2) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1961markDoneBinary id=1 (0,2 2,3 5,1 3,2) t=0.5 [3] (3,2) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1962markDoneBinary id=1 (0,2 2,3 5,1 3,2) t=0.5 [4] (3,2) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
1963findNextOp from:[1] to:[1] start=3 end=5
1964bridgeOp current id=1 from=(3,2) to=(3,2)
1965path.moveTo(3,2);
1966path.cubicTo(3.75,1.75, 4,1.5, 3,2);
1967path.close();
1968debugShowActiveSpans id=3 (1,5 2,3 2,0 3,2) t=0 (1,5) tEnd=0.447821962 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
1969debugShowActiveSpans id=4 (3,2 1,5) t=0 (3,2) tEnd=1 other=3 otherT=1 otherIndex=3 windSum=-1 windValue=1 oppValue=0
1970activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1971findNextOp simple
1972markDoneBinary id=4 (3,2 1,5) t=0 [0] (3,2) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1973markDoneBinary id=4 (3,2 1,5) t=0 [1] (3,2) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1974markDoneBinary id=4 (3,2 1,5) t=0 [2] (3,2) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1975markDoneBinary id=4 (3,2 1,5) t=0 [3] (3,2) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1976bridgeOp current id=4 from=(3,2) to=(1,5)
1977findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
1978debugShowSort [3] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.447821962 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
1979debugShowSort [0] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=0.302178051 tEnd=0.5 sign=-1 windValue=1 windSum=1 1->2 (max=2) done=1 tiny=0 opp=1
1980debugShowSort [1] {{1,5}, {2,3}, {2,0}, {3,2}} tStart=0.447821962 tEnd=0.5 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
1981debugShowSort [2] {{0,2}, {2,3}, {5,1}, {3,2}} tStart=0.302178051 tEnd=0 sign=1 windValue=1 windSum=1 2->1 (max=2) done=1 tiny=0 opp=1
1982findNextOp firstIndex=[3] sign=1
1983activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
1984activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
1985activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=0 result=0
1986markDoneBinary id=3 (1,5 2,3 2,0 3,2) t=0 [0] (1,5) tEnd=0.447821962 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
1987findNextOp from:[3] to:[3] start=1 end=2
1988bridgeOp current id=3 from=(1,5) to=(1.92144883,2.25028419)
1989path.moveTo(3,2);
1990path.lineTo(1,5);
1991path.cubicTo(1.44782197,4.10435629, 1.69509947,3.00816751, 1.92144883,2.25028419);
1992</div>
1993
1994<div id="cubicOp48da">
1995 {{0,2}, {2,3}, {5,1}, {3,2}},
1996
1997 {{0,2}, {0.796711951,2.36012932}, {1.63878124,2.27837338}},
1998 {{1.63878124,2.27837338}, {2.48085053,2.19661745}, {3.06246392,1.97878949}},
1999 {{3.06246392,1.97878949}, {3.64407731,1.76096154}, {3.65942155,1.71287481}},
2000 {{3.65942155,1.71287481}, {3.66835761,1.67480112}, {3,2}},
2001</div>
2002
2003<div id="cubicOp32d">
2004 SimplifyNew_Test [cubicOp32d]
2005{{0,1}, {1,2}, {6,0}, {3,1}},
2006{{3,1}, {0,1}},
2007op difference
2008{{0,6}, {1,3}, {1,0}, {2,1}},
2009{{2,1}, {0,6}},
2010insert t=0.5 pts roughly equal
2011insert t=0.5 pts roughly equal
2012insert t=0.5 pts roughly equal
2013debugShowCubicIntersection wtTs[0]=1 {{0,1}, {1,2}, {6,0}, {3,1}} {{3,1}} wtTs[1]=0.5
2014insert t=0.5 pts roughly equal
2015debugShowCubicLineIntersection wtTs[0]=0 {{0,1}, {1,2}, {6,0}, {3,1}} {{0,1}} wtTs[1]=0.5 {{3,1}} wtTs[2]=1 {{3,1}} wnTs[0]=1 {{3,1}, {0,1}} wnTs[1]=0 wnTs[2]=0
2016debugShowCubicIntersection wtTs[0]=0.235702334 {{0,1}, {1,2}, {6,0}, {3,1}} {{1.2166390977965289,1.2856741834504377}} wnTs[0]=0.640711 {{0,6}, {1,3}, {1,0}, {2,1}}
2017debugShowCubicLineIntersection wtTs[0]=0.336702456 {{0,1}, {1,2}, {6,0}, {3,1}} {{1.9124722896380537,1.2188192759048657}} wnTs[0]=0.0437639 {{2,1}, {0,6}}
2018debugShowCubicLineIntersection wtTs[0]=0.724744871 {{0,6}, {1,3}, {1,0}, {2,1}} {{1.359821149611685,1.0000000000000004}} wtTs[1]=1 {{2,1}} wnTs[0]=0.546726 {{3,1}, {0,1}} wnTs[1]=0.333333333
2019debugShowLineIntersection wtTs[0]=0 {{3,1}, {0,1}} {{2,1}} wnTs[0]=0.333333 {{2,1}, {0,6}}
2020debugShowCubicIntersection no self intersect {{0,6}, {1,3}, {1,0}, {2,1}}
2021debugShowCubicLineIntersection wtTs[0]=0 {{0,6}, {1,3}, {1,0}, {2,1}} {{0,6}} wtTs[1]=1 {{2,1}} wnTs[0]=1 {{2,1}, {0,6}} wnTs[1]=0
2022debugShowActiveSpans id=1 (0,1 1,2 6,0 3,1) t=0 (0,1) tEnd=0.235702334 other=2 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
2023debugShowActiveSpans id=1 (0,1 1,2 6,0 3,1) t=0.235702334 (1.21663904,1.28567421) tEnd=0.336702456 other=3 otherT=0.640711351 otherIndex=1 windSum=? windValue=1 oppValue=0
2024debugShowActiveSpans id=1 (0,1 1,2 6,0 3,1) t=0.336702456 (1.91247225,1.21881926) tEnd=0.5 other=4 otherT=0.0437638552 otherIndex=2 windSum=? windValue=1 oppValue=0
2025</div>
2026
2027<div id="cubicOp48db">
2028computed quadratics given
2029 {{0,2}, {2,3}, {5,1}, {3,2}},
2030 {{1,5}, {2,3}, {2,0}, {3,2}},
2031computed quadratics set 1
2032 {{0,2}, {0.796711951,2.36012932}, {1.63878124,2.27837338}},
2033 {{1.63878124,2.27837338}, {2.48085053,2.19661745}, {3.06246392,1.97878949}},
2034 {{3.06246392,1.97878949}, {3.64407731,1.76096154}, {3.65942155,1.71287481}},
2035 {{3.65942155,1.71287481}, {3.66835761,1.67480112}, {3,2}},
2036computed quadratics set 2
2037 {{1,5}, {1.50173477,3.89061296}, {1.76597918,2.79793753}},
2038 {{1.76597918,2.79793753}, {2.0153684,1.78464605}, {2.27205088,1.42969352}},
2039 {{2.27205088,1.42969352}, {2.52873337,1.07474099}, {3,2}},
2040</div>
2041
2042<div id="cubicOp48dc">
2043 {{1.63878124,2.27837338}, {2.48085053,2.19661745}, {3.06246392,1.97878949}},
2044 {{2.27205088,1.42969352}, {2.52873337,1.07474099}, {3,2}},
2045</div>
2046
2047<div id="cubicOp49d">
2048 SimplifyNew_Test [cubicOp49d]
2049{{0,2}, {1,5}, {3,2}, {4,1}},
2050{{4,1}, {0,2}},
2051op difference
2052{{2,3}, {1,4}, {2,0}, {5,1}},
2053{{5,1}, {2,3}},
2054debugShowCubicIntersection no self intersect {{2,3}, {1,4}, {2,0}, {5,1}}
2055debugShowCubicLineIntersection wtTs[0]=0 {{2,3}, {1,4}, {2,0}, {5,1}} {{2,3}} wtTs[1]=1 {{5,1}} wnTs[0]=1 {{5,1}, {2,3}} wnTs[1]=0
2056debugShowCubicIntersection wtTs[0]=1.74609417e-09 {{2,3}, {1,4}, {2,0}, {5,1}} {{1.9999999947617175,3.0000000052382827}} wtTs[1]=0.122781788 {{1.7221068406383582,3.1607246577308117}} wnTs[0]=0.5 {{0,2}, {1,5}, {3,2}, {4,1}} wnTs[1]=0.438140761
2057debugShowCubicLineIntersection wtTs[0]=0.651913155 {{2,3}, {1,4}, {2,0}, {5,1}} {{2.5942051033446676,1.3514487241638331}} wnTs[0]=0.351449 {{4,1}, {0,2}}
2058debugShowCubicLineIntersection wtTs[0]=0.5 {{0,2}, {1,5}, {3,2}, {4,1}} {{2,3}} wnTs[0]=1 {{5,1}, {2,3}}
2059debugShowLineIntersection no intersect {{5,1}, {2,3}} {{4,1}, {0,2}}
2060debugShowCubicIntersection no self intersect {{0,2}, {1,5}, {3,2}, {4,1}}
2061debugShowCubicLineIntersection wtTs[0]=0 {{0,2}, {1,5}, {3,2}, {4,1}} {{0,2}} wtTs[1]=1 {{4,1}} wnTs[0]=1 {{4,1}, {0,2}} wnTs[1]=0
2062debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=1.74609417e-09 (2,3) tEnd=0.122781788 other=1 otherT=0.499999999 otherIndex=2 windSum=? windValue=1 oppValue=0
2063debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=0.122781788 (1.72210681,3.16072464) tEnd=0.651913155 other=1 otherT=0.438140761 otherIndex=1 windSum=? windValue=1 oppValue=0
2064debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=0.651913155 (2.59420514,1.35144877) tEnd=1 other=2 otherT=0.351448724 otherIndex=1 windSum=? windValue=1 oppValue=0
2065debugShowActiveSpans id=4 (5,1 2,3) t=0 (5,1) tEnd=1 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2066debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0 (0,2) tEnd=0.438140761 other=2 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
2067debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0.438140761 (1.72210681,3.16072464) tEnd=0.499999999 other=3 otherT=0.122781788 otherIndex=2 windSum=? windValue=1 oppValue=0
2068debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0.5 (2,3) tEnd=1 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
2069debugShowActiveSpans id=2 (4,1 0,2) t=0 (4,1) tEnd=0.351448724 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2070debugShowActiveSpans id=2 (4,1 0,2) t=0.351448724 (2.59420514,1.35144877) tEnd=1 other=3 otherT=0.651913155 otherIndex=3 windSum=? windValue=1 oppValue=0
2071findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2072debugShowSort [1] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.122781788 tEnd=0.651913155 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2073debugShowSort [2] {{0,2}, {1,5}, {3,2}, {4,1}} tStart=0.438140761 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
2074debugShowSort [3] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.122781788 tEnd=1.74609417e-09 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2075debugShowSort [0] {{0,2}, {1,5}, {3,2}, {4,1}} tStart=0.438140761 tEnd=0.499999999 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
2076findTop swap
2077markWinding id=3 (2,3 1,4 2,0 5,1) t=0.122781788 [2] (1.72210681,3.16072464) tEnd=0.651913155 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2078markWinding id=3 (2,3 1,4 2,0 5,1) t=0.122781788 [2] (1.72210681,3.16072464) tEnd=0.651913155 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2079activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2080markDoneBinary id=3 (2,3 1,4 2,0 5,1) t=0.122781788 [2] (1.72210681,3.16072464) tEnd=0.651913155 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2081findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
2082debugShowSort [0] {{4,1}, {0,2}} tStart=0.351448724 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
2083debugShowSort [1] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.651913155 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
2084debugShowSort [2] {{4,1}, {0,2}} tStart=0.351448724 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
2085debugShowSort [3] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.651913155 tEnd=0.122781788 sign=1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
2086findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2087debugShowSort [3] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.651913155 tEnd=0.122781788 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2088debugShowSort [0] {{4,1}, {0,2}} tStart=0.351448724 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
2089debugShowSort [1] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.651913155 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2090debugShowSort [2] {{4,1}, {0,2}} tStart=0.351448724 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
2091markWinding id=2 (4,1 0,2) t=0 [0] (4,1) tEnd=0.351448724 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
2092markWinding id=1 (0,2 1,5 3,2 4,1) t=0.5 [3] (2,3) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
2093markWinding id=3 (2,3 1,4 2,0 5,1) t=0.651913155 [3] (2.59420514,1.35144877) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
2094markWinding id=4 (5,1 2,3) t=0 [0] (5,1) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
2095markWinding id=2 (4,1 0,2) t=0.351448724 [1] (2.59420514,1.35144877) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2096markWinding id=1 (0,2 1,5 3,2 4,1) t=0 [0] (0,2) tEnd=0.438140761 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2097debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=1.74609417e-09 (2,3) tEnd=0.122781788 other=1 otherT=0.499999999 otherIndex=2 windSum=? windValue=1 oppValue=0
2098debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=0.651913155 (2.59420514,1.35144877) tEnd=1 other=2 otherT=0.351448724 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2099debugShowActiveSpans id=4 (5,1 2,3) t=0 (5,1) tEnd=1 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2100debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0 (0,2) tEnd=0.438140761 other=2 otherT=1 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2101debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0.438140761 (1.72210681,3.16072464) tEnd=0.499999999 other=3 otherT=0.122781788 otherIndex=2 windSum=? windValue=1 oppValue=0
2102debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0.5 (2,3) tEnd=1 other=4 otherT=1 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2103debugShowActiveSpans id=2 (4,1 0,2) t=0 (4,1) tEnd=0.351448724 other=1 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2104debugShowActiveSpans id=2 (4,1 0,2) t=0.351448724 (2.59420514,1.35144877) tEnd=1 other=3 otherT=0.651913155 otherIndex=3 windSum=-1 windValue=1 oppValue=0
2105activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2106markDoneBinary id=2 (4,1 0,2) t=0 [0] (4,1) tEnd=0.351448724 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
2107markDoneBinary id=1 (0,2 1,5 3,2 4,1) t=0.5 [3] (2,3) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
2108setSpans unsortable [1] (2,3) [2] (1.72210681,3.16072464)
2109debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=1.74609417e-09 (2,3) tEnd=0.122781788 other=1 otherT=0.499999999 otherIndex=2 windSum=? windValue=1 oppValue=0
2110debugShowActiveSpans id=3 (2,3 1,4 2,0 5,1) t=0.651913155 (2.59420514,1.35144877) tEnd=1 other=2 otherT=0.351448724 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2111debugShowActiveSpans id=4 (5,1 2,3) t=0 (5,1) tEnd=1 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2112debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0 (0,2) tEnd=0.438140761 other=2 otherT=1 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2113debugShowActiveSpans id=1 (0,2 1,5 3,2 4,1) t=0.438140761 (1.72210681,3.16072464) tEnd=0.499999999 other=3 otherT=0.122781788 otherIndex=2 windSum=? windValue=1 oppValue=0
2114debugShowActiveSpans id=2 (4,1 0,2) t=0.351448724 (2.59420514,1.35144877) tEnd=1 other=3 otherT=0.651913155 otherIndex=3 windSum=-1 windValue=1 oppValue=0
2115activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2116findNextOp simple
2117markDoneBinary id=4 (5,1 2,3) t=0 [0] (5,1) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
2118bridgeOp current id=4 from=(2,3) to=(5,1)
2119findNextOp debugShowSort contourWinding=-1 oppContourWinding=-1 sign=-1
2120debugShowSort [1] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.651913155 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
2121debugShowSort [2] {{4,1}, {0,2}} tStart=0.351448724 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=1
2122debugShowSort [3] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.651913155 tEnd=0.122781788 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2123debugShowSort [0] {{4,1}, {0,2}} tStart=0.351448724 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
2124findNextOp firstIndex=[1] sign=-1
2125activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2126activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2127activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2128markDoneBinary id=3 (2,3 1,4 2,0 5,1) t=0.651913155 [3] (2.59420514,1.35144877) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
2129findNextOp from:[3] to:[2] start=1 end=2
2130bridgeOp current id=3 from=(5,1) to=(2.59420514,1.35144877)
2131path.moveTo(2,3);
2132path.lineTo(5,1);
2133path.cubicTo(3.9557395,0.651913166, 3.15380788,0.909648538, 2.59420514,1.35144877);
2134findNextOp simple
2135markDoneBinary id=2 (4,1 0,2) t=0.351448724 [1] (2.59420514,1.35144877) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2136bridgeOp current id=2 from=(2.59420514,1.35144877) to=(0,2)
2137findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2138debugShowSort [2] {{0,2}, {1,5}, {3,2}, {4,1}} tStart=0.438140761 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
2139debugShowSort [3] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.122781788 tEnd=1.74609417e-09 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
2140debugShowSort [0] {{0,2}, {1,5}, {3,2}, {4,1}} tStart=0.438140761 tEnd=0.499999999 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2141debugShowSort [1] {{2,3}, {1,4}, {2,0}, {5,1}} tStart=0.122781788 tEnd=0.651913155 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
2142findNextOp firstIndex=[2] sign=1
2143activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2144markWinding id=3 (2,3 1,4 2,0 5,1) t=1.74609417e-09 [1] (2,3) tEnd=0.122781788 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
2145findNextOp chase.append id=3
2146activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2147markDoneBinary id=1 (0,2 1,5 3,2 4,1) t=0.438140761 [1] (1.72210681,3.16072464) tEnd=0.499999999 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
2148findNextOp chase.append id=1
2149activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2150markDoneBinary id=1 (0,2 1,5 3,2 4,1) t=0 [0] (0,2) tEnd=0.438140761 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2151findNextOp from:[1] to:[3] start=2 end=1
2152bridgeOp current id=1 from=(0,2) to=(1.72210681,3.16072464)
2153path.lineTo(0,2);
2154path.cubicTo(0.43814075,3.31442237, 1.06824887,3.47704053, 1.72210681,3.16072464);
2155setSpans unsortable [1] (2,3) [2] (1.72210681,3.16072464)
2156setSpans all tiny unsortable [2] (2,3) [1] (1.72210681,3.16072464)
2157markUnsortable id=3 (2,3 1,4 2,0 5,1) t=1.74609417e-09 [1] (2,3) tEnd=0.122781788 newWindSum=0 windSum=-1 windValue=1
2158markUnsortable id=3 (2,3 1,4 2,0 5,1) t=0 [0] (2,3) tEnd=1.74609417e-09 newWindSum=0 windSum=? windValue=1
2159markUnsortable id=1 (0,2 1,5 3,2 4,1) t=0.499999999 [2] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
2160markUnsortable id=1 (0,2 1,5 3,2 4,1) t=0.438140761 [1] (1.72210681,3.16072464) tEnd=0.499999999 newWindSum=0 windSum=-1 windValue=1
2161findNextOp debugShowSort contourWinding=-1 oppContourWinding=-1 sign=-1
2162debugShowSort [0] *** UNSORTABLE *** {{2,3}, {1,4}, {2,0}, {5,1}} tStart=1.74609417e-09 tEnd=0.122781788 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
2163debugShowSort [1] *** UNSORTABLE *** {{2,3}, {1,4}, {2,0}, {5,1}} tStart=1.74609417e-09 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=1 tiny=1 opp=0
2164debugShowSort [2] *** UNSORTABLE *** {{0,2}, {1,5}, {3,2}, {4,1}} tStart=0.499999999 tEnd=0.5 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=1 tiny=1 opp=1
2165debugShowSort [3] *** UNSORTABLE *** {{0,2}, {1,5}, {3,2}, {4,1}} tStart=0.499999999 tEnd=0.438140761 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=1
2166path.cubicTo(1.78458714,3.17018676, 1.87721825,3.12278175, 2,3);
2167markDoneBinary id=3 (2,3 1,4 2,0 5,1) t=1.74609417e-09 [1] (2,3) tEnd=0.122781788 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
2168path.close();
2169setSpans all tiny unsortable [2] (2,3) [1] (1.72210681,3.16072464)
2170setSpans unsortable [1] (2,3) [2] (1.72210681,3.16072464)
2171setSpans unsortable [1] (2,3) [2] (1.72210681,3.16072464)
2172setSpans all tiny unsortable [2] (2,3) [1] (1.72210681,3.16072464)
2173setSpans unsortable [1] (2,3) [2] (1.72210681,3.16072464)
2174assemble
2175assemble contour start=(2,3) end=(2,3)
2176</div>
2177
2178<div id="cubicOp50d">
2179 SimplifyNew_Test [cubicOp50d]
2180{{0,3}, {1,6}, {5,0}, {5,1}},
2181{{5,1}, {0,3}},
2182op difference
2183{{0,5}, {1,5}, {3,0}, {6,1}},
2184{{6,1}, {0,5}},
2185debugShowCubicIntersection no self intersect {{0,5}, {1,5}, {3,0}, {6,1}}
2186debugShowCubicLineIntersection wtTs[0]=0 {{0,5}, {1,5}, {3,0}, {6,1}} {{0,5}} wtTs[1]=0.181818182 {{0.64462809917355357,4.5702479338842981}} wtTs[2]=1 {{6,1}} wnTs[0]=1 {{6,1}, {0,5}} wnTs[1]=0.892561983 wnTs[2]=0
2187debugShowCubicIntersection wtTs[0]=0.326064989 {{0,5}, {1,5}, {3,0}, {6,1}} {{1.2971500960309803,3.7865580517965118}} wnTs[0]=0.265062 {{0,3}, {1,6}, {5,0}, {5,1}}
2188debugShowCubicLineIntersection wtTs[0]=0.639696212 {{0,5}, {1,5}, {3,0}, {6,1}} {{3.1467223651509295,1.7413110539396279}} wnTs[0]=0.370656 {{5,1}, {0,3}}
2189debugShowCubicLineIntersection no intersect {{0,3}, {1,6}, {5,0}, {5,1}} {{6,1}, {0,5}}
2190debugShowLineIntersection no intersect {{6,1}, {0,5}} {{5,1}, {0,3}}
2191debugShowCubicIntersection no self intersect {{0,3}, {1,6}, {5,0}, {5,1}}
2192debugShowCubicLineIntersection wtTs[0]=0 {{0,3}, {1,6}, {5,0}, {5,1}} {{0,3}} wtTs[1]=0.772727273 {{4.4623403456048081,1.2150638617580767}} wtTs[2]=1 {{5,1}} wnTs[0]=1 {{5,1}, {0,3}} wnTs[1]=0.107531931 wnTs[2]=0
2193debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0 (0,5) tEnd=0.181818182 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
2194debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0.181818182 (0.644628108,4.57024813) tEnd=0.326064989 other=4 otherT=0.892561983 otherIndex=1 windSum=? windValue=1 oppValue=0
2195debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0.326064989 (1.29715014,3.78655815) tEnd=0.639696212 other=1 otherT=0.26506234 otherIndex=1 windSum=? windValue=1 oppValue=0
2196debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0.639696212 (3.14672232,1.74131107) tEnd=1 other=2 otherT=0.370655527 otherIndex=2 windSum=? windValue=1 oppValue=0
2197debugShowActiveSpans id=4 (6,1 0,5) t=0 (6,1) tEnd=0.892561983 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2198debugShowActiveSpans id=4 (6,1 0,5) t=0.892561983 (0.644628108,4.57024813) tEnd=1 other=3 otherT=0.181818182 otherIndex=1 windSum=? windValue=1 oppValue=0
2199debugShowActiveSpans id=1 (0,3 1,6 5,0 5,1) t=0 (0,3) tEnd=0.26506234 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2200debugShowActiveSpans id=1 (0,3 1,6 5,0 5,1) t=0.26506234 (1.29715014,3.78655815) tEnd=0.772727273 other=3 otherT=0.326064989 otherIndex=2 windSum=? windValue=1 oppValue=0
2201debugShowActiveSpans id=1 (0,3 1,6 5,0 5,1) t=0.772727273 (4.46234035,1.21506381) tEnd=1 other=2 otherT=0.107531931 otherIndex=1 windSum=? windValue=1 oppValue=0
2202debugShowActiveSpans id=2 (5,1 0,3) t=0 (5,1) tEnd=0.107531931 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2203debugShowActiveSpans id=2 (5,1 0,3) t=0.107531931 (4.46234035,1.21506381) tEnd=0.370655527 other=1 otherT=0.772727273 otherIndex=2 windSum=? windValue=1 oppValue=0
2204debugShowActiveSpans id=2 (5,1 0,3) t=0.370655527 (3.14672232,1.74131107) tEnd=1 other=3 otherT=0.639696212 otherIndex=3 windSum=? windValue=1 oppValue=0
2205findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2206debugShowSort [0] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=1 tEnd=0.772727273 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2207debugShowSort [1] {{5,1}, {0,3}} tStart=0 tEnd=0.107531931 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2208markWinding id=1 (0,3 1,6 5,0 5,1) t=0.772727273 [2] (4.46234035,1.21506381) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2209markWinding id=2 (5,1 0,3) t=0 [0] (5,1) tEnd=0.107531931 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2210markWinding id=1 (0,3 1,6 5,0 5,1) t=0.772727273 [2] (4.46234035,1.21506381) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2211activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2212findNextOp simple
2213markDoneBinary id=1 (0,3 1,6 5,0 5,1) t=0.772727273 [2] (4.46234035,1.21506381) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2214bridgeOp current id=1 from=(4.46234035,1.21506381) to=(5,1)
2215path.moveTo(4.46234035,1.21506381);
2216path.cubicTo(4.79338837,0.90702486, 5,0.772727251, 5,1);
2217findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2218debugShowSort [0] {{5,1}, {0,3}} tStart=0.107531931 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
2219debugShowSort [1] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=0.772727273 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
2220debugShowSort [2] {{5,1}, {0,3}} tStart=0.107531931 tEnd=0.370655527 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2221debugShowSort [3] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=0.772727273 tEnd=0.26506234 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2222findNextOp firstIndex=[0] sign=1
2223activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2224activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2225markWinding id=2 (5,1 0,3) t=0.107531931 [1] (4.46234035,1.21506381) tEnd=0.370655527 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2226findNextOp chase.append id=2
2227activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2228markWinding id=1 (0,3 1,6 5,0 5,1) t=0.26506234 [1] (1.29715014,3.78655815) tEnd=0.772727273 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2229findNextOp chase.append id=1
2230markDoneBinary id=2 (5,1 0,3) t=0 [0] (5,1) tEnd=0.107531931 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2231findNextOp from:[2] to:[1] start=2 end=1
2232bridgeOp current id=2 from=(5,1) to=(4.46234035,1.21506381)
2233path.lineTo(4.46234035,1.21506381);
2234path.close();
2235debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0 (0,5) tEnd=0.181818182 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
2236debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0.181818182 (0.644628108,4.57024813) tEnd=0.326064989 other=4 otherT=0.892561983 otherIndex=1 windSum=? windValue=1 oppValue=0
2237debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0.326064989 (1.29715014,3.78655815) tEnd=0.639696212 other=1 otherT=0.26506234 otherIndex=1 windSum=? windValue=1 oppValue=0
2238debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0.639696212 (3.14672232,1.74131107) tEnd=1 other=2 otherT=0.370655527 otherIndex=2 windSum=? windValue=1 oppValue=0
2239debugShowActiveSpans id=4 (6,1 0,5) t=0 (6,1) tEnd=0.892561983 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2240debugShowActiveSpans id=4 (6,1 0,5) t=0.892561983 (0.644628108,4.57024813) tEnd=1 other=3 otherT=0.181818182 otherIndex=1 windSum=? windValue=1 oppValue=0
2241debugShowActiveSpans id=1 (0,3 1,6 5,0 5,1) t=0 (0,3) tEnd=0.26506234 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2242debugShowActiveSpans id=1 (0,3 1,6 5,0 5,1) t=0.26506234 (1.29715014,3.78655815) tEnd=0.772727273 other=3 otherT=0.326064989 otherIndex=2 windSum=1 windValue=1 oppValue=0
2243debugShowActiveSpans id=2 (5,1 0,3) t=0.107531931 (4.46234035,1.21506381) tEnd=0.370655527 other=1 otherT=0.772727273 otherIndex=2 windSum=1 windValue=1 oppValue=0
2244debugShowActiveSpans id=2 (5,1 0,3) t=0.370655527 (3.14672232,1.74131107) tEnd=1 other=3 otherT=0.639696212 otherIndex=3 windSum=? windValue=1 oppValue=0
2245activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2246findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
2247debugShowSort [3] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=0.772727273 tEnd=0.26506234 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2248debugShowSort [0] {{5,1}, {0,3}} tStart=0.107531931 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2249debugShowSort [1] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=0.772727273 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
2250debugShowSort [2] {{5,1}, {0,3}} tStart=0.107531931 tEnd=0.370655527 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2251findNextOp firstIndex=[3] sign=1
2252activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2253activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2254activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2255markDoneBinary id=1 (0,3 1,6 5,0 5,1) t=0.26506234 [1] (1.29715014,3.78655815) tEnd=0.772727273 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2256findNextOp from:[1] to:[2] start=1 end=2
2257bridgeOp current id=1 from=(1.29715014,3.78655815) to=(4.46234035,1.21506381)
2258path.moveTo(1.29715014,3.78655815);
2259path.cubicTo(2.36251926,3.45810199, 3.72286963,1.90313876, 4.46234035,1.21506381);
2260findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
2261debugShowSort [0] {{5,1}, {0,3}} tStart=0.370655527 tEnd=0.107531931 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2262debugShowSort [1] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.639696212 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2263debugShowSort [2] {{5,1}, {0,3}} tStart=0.370655527 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2264debugShowSort [3] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.639696212 tEnd=0.326064989 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2265findNextOp firstIndex=[0] sign=1
2266activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2267markDoneBinary id=3 (0,5 1,5 3,0 6,1) t=0.639696212 [3] (3.14672232,1.74131107) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2268markDoneBinary id=4 (6,1 0,5) t=0 [0] (6,1) tEnd=0.892561983 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2269findNextOp chase.append id=4
2270activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2271markDoneBinary id=2 (5,1 0,3) t=0.370655527 [2] (3.14672232,1.74131107) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2272markDoneBinary id=1 (0,3 1,6 5,0 5,1) t=0 [0] (0,3) tEnd=0.26506234 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2273findNextOp chase.append id=1
2274activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
2275markWinding id=3 (0,5 1,5 3,0 6,1) t=0.326064989 [2] (1.29715014,3.78655815) tEnd=0.639696212 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2276findNextOp chase.append id=3
2277markDoneBinary id=2 (5,1 0,3) t=0.107531931 [1] (4.46234035,1.21506381) tEnd=0.370655527 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2278findNextOp from:[2] to:[3] start=3 end=2
2279bridgeOp current id=2 from=(4.46234035,1.21506381) to=(3.14672232,1.74131107)
2280findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=-1
2281debugShowSort [1] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.326064989 tEnd=0.639696212 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2282debugShowSort [2] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=0.26506234 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
2283debugShowSort [3] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.326064989 tEnd=0.181818182 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2284debugShowSort [0] {{0,3}, {1,6}, {5,0}, {5,1}} tStart=0.26506234 tEnd=0.772727273 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
2285findNextOp firstIndex=[1] sign=-1
2286activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2287activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2288markDoneBinary id=3 (0,5 1,5 3,0 6,1) t=0.181818182 [1] (0.644628108,4.57024813) tEnd=0.326064989 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2289findNextOp chase.append id=3
2290activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2291markDoneBinary id=3 (0,5 1,5 3,0 6,1) t=0.326064989 [2] (1.29715014,3.78655815) tEnd=0.639696212 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
2292findNextOp from:[3] to:[1] start=1 end=2
2293bridgeOp current id=3 from=(3.14672232,1.74131107) to=(1.29715014,3.78655815)
2294path.lineTo(3.14672232,1.74131107);
2295path.cubicTo(2.43183374,2.33584237, 1.81530964,3.13070869, 1.29715014,3.78655815);
2296path.close();
2297findChaseOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
2298debugShowSort [0] {{6,1}, {0,5}} tStart=0.892561983 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2299debugShowSort [1] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.181818182 tEnd=0.326064989 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
2300debugShowSort [2] {{6,1}, {0,5}} tStart=0.892561983 tEnd=1 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=0
2301debugShowSort [3] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.181818182 tEnd=0 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
2302findChaseOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
2303debugShowSort [0] {{6,1}, {0,5}} tStart=0.892561983 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2304debugShowSort [1] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.181818182 tEnd=0.326064989 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
2305debugShowSort [2] {{6,1}, {0,5}} tStart=0.892561983 tEnd=1 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=0 tiny=0 opp=0
2306debugShowSort [3] {{0,5}, {1,5}, {3,0}, {6,1}} tStart=0.181818182 tEnd=0 sign=1 windValue=1 windSum=? 2->1 (max=2) done=0 tiny=0 opp=0
2307markWinding id=4 (6,1 0,5) t=0.892561983 [1] (0.644628108,4.57024813) tEnd=1 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
2308markWinding id=3 (0,5 1,5 3,0 6,1) t=0 [0] (0,5) tEnd=0.181818182 newWindSum=2 newOppSum=0 oppSum=? windSum=? windValue=1
2309markWinding id=3 (0,5 1,5 3,0 6,1) t=0 [0] (0,5) tEnd=0.181818182 newWindSum=2 newOppSum=0 oppSum=0 windSum=2 windValue=1
2310debugShowActiveSpans id=3 (0,5 1,5 3,0 6,1) t=0 (0,5) tEnd=0.181818182 other=4 otherT=1 otherIndex=2 windSum=2 windValue=1 oppValue=0
2311debugShowActiveSpans id=4 (6,1 0,5) t=0.892561983 (0.644628108,4.57024813) tEnd=1 other=3 otherT=0.181818182 otherIndex=1 windSum=2 windValue=1 oppValue=0
2312activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=1 result=0
2313markDoneBinary id=4 (6,1 0,5) t=0.892561983 [1] (0.644628108,4.57024813) tEnd=1 newWindSum=2 newOppSum=0 oppSum=0 windSum=2 windValue=1
2314markDoneBinary id=3 (0,5 1,5 3,0 6,1) t=0 [0] (0,5) tEnd=0.181818182 newWindSum=2 newOppSum=0 oppSum=0 windSum=2 windValue=1
2315assemble
2316assemble contour start=(4.46234035,1.21506381) end=(4.46234035,1.21506381)
2317path.moveTo(4.46234035,1.21506381);
2318path.cubicTo(4.79338837,0.90702486, 5,0.772727251, 5,1);
2319path.lineTo(4.46234035,1.21506381);
2320path.close();
2321assemble contour start=(1.29715014,3.78655815) end=(1.29715014,3.78655815)
2322</div>
2323
2324<div id="cubicOp51d">
2325 SimplifyNew_Test [cubicOp51d]
2326{{0,3}, {1,2}, {4,1}, {6,0}},
2327{{6,0}, {0,3}},
2328op difference
2329{{1,4}, {0,6}, {3,0}, {2,1}},
2330{{2,1}, {1,4}},
2331debugShowCubicIntersection no self intersect {{0,3}, {1,2}, {4,1}, {6,0}}
2332debugShowCubicLineIntersection wtTs[0]=0 {{0,3}, {1,2}, {4,1}, {6,0}} {{0,3}} wtTs[1]=1 {{6,0}} wnTs[0]=1 {{6,0}, {0,3}} wnTs[1]=0
2333debugShowCubicIntersection wtTs[0]=0.397354824 {{0,3}, {1,2}, {4,1}, {6,0}} {{1.9511935265302276,1.8079355291007386}} wnTs[0]=0.661665 {{1,4}, {0,6}, {3,0}, {2,1}}
2334debugShowCubicLineIntersection wtTs[0]=0.355273081 {{0,3}, {1,2}, {4,1}, {6,0}} {{1.6886064138367243,1.9341807584898274}} wnTs[0]=0.311394 {{2,1}, {1,4}}
2335debugShowCubicLineIntersection wtTs[0]=0.6185225 {{1,4}, {0,6}, {3,0}, {2,1}} {{1.8422478636338226,2.0788760681830887}} wnTs[0]=0.692959 {{6,0}, {0,3}}
2336debugShowLineIntersection wtTs[0]=0.733333333 {{6,0}, {0,3}} {{1.6000000000000003,2.1999999999999997}} wnTs[0]=0.4 {{2,1}, {1,4}}
2337debugShowCubicIntersection no self intersect {{1,4}, {0,6}, {3,0}, {2,1}}
2338debugShowCubicLineIntersection wtTs[0]=0 {{1,4}, {0,6}, {3,0}, {2,1}} {{1,4}} wtTs[1]=0.333333333 {{1.0370370370370368,3.8888888888888897}} wtTs[2]=1 {{2,1}} wnTs[0]=1 {{2,1}, {1,4}} wnTs[1]=0.962962963 wnTs[2]=0
2339debugShowActiveSpans id=1 (0,3 1,2 4,1 6,0) t=0 (0,3) tEnd=0.355273081 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2340debugShowActiveSpans id=1 (0,3 1,2 4,1 6,0) t=0.355273081 (1.68860638,1.93418074) tEnd=0.397354824 other=4 otherT=0.311393586 otherIndex=1 windSum=? windValue=1 oppValue=0
2341debugShowActiveSpans id=1 (0,3 1,2 4,1 6,0) t=0.397354824 (1.95119357,1.80793548) tEnd=1 other=3 otherT=0.66166507 otherIndex=3 windSum=? windValue=1 oppValue=0
2342debugShowActiveSpans id=2 (6,0 0,3) t=0 (6,0) tEnd=0.692958689 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2343debugShowActiveSpans id=2 (6,0 0,3) t=0.692958689 (1.84224784,2.07887602) tEnd=0.733333333 other=3 otherT=0.6185225 otherIndex=2 windSum=? windValue=1 oppValue=0
2344debugShowActiveSpans id=2 (6,0 0,3) t=0.733333333 (1.60000002,2.20000005) tEnd=1 other=4 otherT=0.4 otherIndex=2 windSum=? windValue=1 oppValue=0
2345debugShowActiveSpans id=3 (1,4 0,6 3,0 2,1) t=0 (1,4) tEnd=0.333333333 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2346debugShowActiveSpans id=3 (1,4 0,6 3,0 2,1) t=0.333333333 (1.03703701,3.88888884) tEnd=0.6185225 other=4 otherT=0.962962963 otherIndex=3 windSum=? windValue=1 oppValue=0
2347debugShowActiveSpans id=3 (1,4 0,6 3,0 2,1) t=0.6185225 (1.84224784,2.07887602) tEnd=0.66166507 other=2 otherT=0.692958689 otherIndex=1 windSum=? windValue=1 oppValue=0
2348debugShowActiveSpans id=3 (1,4 0,6 3,0 2,1) t=0.66166507 (1.95119357,1.80793548) tEnd=1 other=1 otherT=0.397354824 otherIndex=2 windSum=? windValue=1 oppValue=0
2349debugShowActiveSpans id=4 (2,1 1,4) t=0 (2,1) tEnd=0.311393586 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2350debugShowActiveSpans id=4 (2,1 1,4) t=0.311393586 (1.68860638,1.93418074) tEnd=0.4 other=1 otherT=0.355273081 otherIndex=1 windSum=? windValue=1 oppValue=0
2351debugShowActiveSpans id=4 (2,1 1,4) t=0.4 (1.60000002,2.20000005) tEnd=0.962962963 other=2 otherT=0.733333333 otherIndex=2 windSum=? windValue=1 oppValue=0
2352debugShowActiveSpans id=4 (2,1 1,4) t=0.962962963 (1.03703701,3.88888884) tEnd=1 other=3 otherT=0.333333333 otherIndex=1 windSum=? windValue=1 oppValue=0
2353findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2354debugShowSort [0] {{0,3}, {1,2}, {4,1}, {6,0}} tStart=1 tEnd=0.397354824 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2355debugShowSort [1] {{6,0}, {0,3}} tStart=0 tEnd=0.692958689 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2356findTop swap
2357markWinding id=1 (0,3 1,2 4,1 6,0) t=0.397354824 [2] (1.95119357,1.80793548) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2358markWinding id=1 (0,3 1,2 4,1 6,0) t=0.397354824 [2] (1.95119357,1.80793548) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2359markWinding id=2 (6,0 0,3) t=0 [0] (6,0) tEnd=0.692958689 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2360activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2361findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2362debugShowSort [0] {{0,3}, {1,2}, {4,1}, {6,0}} tStart=0.397354824 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2363debugShowSort [1] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.66166507 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2364debugShowSort [2] {{0,3}, {1,2}, {4,1}, {6,0}} tStart=0.397354824 tEnd=0.355273081 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2365debugShowSort [3] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.66166507 tEnd=0.6185225 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2366findNextOp firstIndex=[0] sign=-1
2367activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2368markWinding id=3 (1,4 0,6 3,0 2,1) t=0.66166507 [3] (1.95119357,1.80793548) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2369markWinding id=4 (2,1 1,4) t=0 [0] (2,1) tEnd=0.311393586 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2370findNextOp chase.append id=4
2371activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2372markDoneBinary id=1 (0,3 1,2 4,1 6,0) t=0.355273081 [1] (1.68860638,1.93418074) tEnd=0.397354824 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2373findNextOp chase.append id=1
2374activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2375markDoneBinary id=3 (1,4 0,6 3,0 2,1) t=0.6185225 [2] (1.84224784,2.07887602) tEnd=0.66166507 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2376findNextOp chase.append id=3
2377markDoneBinary id=1 (0,3 1,2 4,1 6,0) t=0.397354824 [2] (1.95119357,1.80793548) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2378findNextOp from:[1] to:[3] start=3 end=4
2379bridgeOp current id=1 from=(6,0) to=(1.95119357,1.80793548)
2380path.moveTo(6,0);
2381path.cubicTo(4.79470968,0.602645159, 3.22623801,1.20529044, 1.95119357,1.80793548);
2382findNextOp simple
2383markDoneBinary id=3 (1,4 0,6 3,0 2,1) t=0.66166507 [3] (1.95119357,1.80793548) tEnd=1 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
2384bridgeOp current id=3 from=(1.95119357,1.80793548) to=(2,1)
2385path.cubicTo(2.21878767,1.12462389, 2.33833504,0.661665022, 2,1);
2386findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
2387debugShowSort [1] {{2,1}, {1,4}} tStart=0.311393586 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2388debugShowSort [2] {{0,3}, {1,2}, {4,1}, {6,0}} tStart=0.355273081 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2389debugShowSort [3] {{2,1}, {1,4}} tStart=0.311393586 tEnd=0.4 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2390debugShowSort [0] {{0,3}, {1,2}, {4,1}, {6,0}} tStart=0.355273081 tEnd=0.397354824 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
2391findNextOp firstIndex=[1] sign=1
2392activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2393markWinding id=1 (0,3 1,2 4,1 6,0) t=0 [0] (0,3) tEnd=0.355273081 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2394markWinding id=2 (6,0 0,3) t=0.733333333 [2] (1.60000002,2.20000005) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2395findNextOp chase.append id=2
2396activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2397markDoneBinary id=4 (2,1 1,4) t=0.311393586 [1] (1.68860638,1.93418074) tEnd=0.4 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2398findNextOp chase.append id=4
2399activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2400markDoneBinary id=4 (2,1 1,4) t=0 [0] (2,1) tEnd=0.311393586 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
2401findNextOp from:[4] to:[1] start=1 end=0
2402bridgeOp current id=4 from=(2,1) to=(1.68860638,1.93418074)
2403findNextOp simple
2404markDoneBinary id=1 (0,3 1,2 4,1 6,0) t=0 [0] (0,3) tEnd=0.355273081 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2405bridgeOp current id=1 from=(1.68860638,1.93418074) to=(0,3)
2406path.lineTo(1.68860638,1.93418074);
2407path.cubicTo(0.962984085,2.28945374, 0.355273068,2.64472699, 0,3);
2408findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2409debugShowSort [2] {{6,0}, {0,3}} tStart=0.733333333 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2410debugShowSort [3] {{2,1}, {1,4}} tStart=0.4 tEnd=0.962962963 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2411debugShowSort [0] {{6,0}, {0,3}} tStart=0.733333333 tEnd=0.692958689 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2412debugShowSort [1] {{2,1}, {1,4}} tStart=0.4 tEnd=0.311393586 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
2413findNextOp firstIndex=[2] sign=-1
2414activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2415markWinding id=4 (2,1 1,4) t=0.4 [2] (1.60000002,2.20000005) tEnd=0.962962963 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2416findNextOp chase.append id=4
2417activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2418markDoneBinary id=2 (6,0 0,3) t=0.692958689 [1] (1.84224784,2.07887602) tEnd=0.733333333 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2419findNextOp chase.append id=2
2420activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2421markDoneBinary id=2 (6,0 0,3) t=0.733333333 [2] (1.60000002,2.20000005) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2422findNextOp from:[2] to:[4] start=2 end=3
2423bridgeOp current id=2 from=(0,3) to=(1.60000002,2.20000005)
2424findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
2425debugShowSort [1] {{2,1}, {1,4}} tStart=0.962962963 tEnd=0.4 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2426debugShowSort [2] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2427debugShowSort [3] {{2,1}, {1,4}} tStart=0.962962963 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2428debugShowSort [0] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.333333333 tEnd=0.6185225 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2429findNextOp firstIndex=[1] sign=1
2430activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2431markWinding id=3 (1,4 0,6 3,0 2,1) t=0 [0] (1,4) tEnd=0.333333333 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2432markWinding id=4 (2,1 1,4) t=0.962962963 [3] (1.03703701,3.88888884) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2433findNextOp chase.append id=4
2434activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
2435activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2436markWinding id=3 (1,4 0,6 3,0 2,1) t=0.333333333 [1] (1.03703701,3.88888884) tEnd=0.6185225 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2437findNextOp chase.append id=3
2438markDoneBinary id=4 (2,1 1,4) t=0.4 [2] (1.60000002,2.20000005) tEnd=0.962962963 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
2439findNextOp from:[4] to:[3] start=1 end=0
2440bridgeOp current id=4 from=(1.60000002,2.20000005) to=(1.03703701,3.88888884)
2441path.lineTo(1.60000002,2.20000005);
2442findNextOp simple
2443markDoneBinary id=3 (1,4 0,6 3,0 2,1) t=0 [0] (1,4) tEnd=0.333333333 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2444bridgeOp current id=3 from=(1.03703701,3.88888884) to=(1,4)
2445path.lineTo(1.03703701,3.88888884);
2446path.cubicTo(0.777777791,4.44444466, 0.666666687,4.66666651, 1,4);
2447findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
2448debugShowSort [3] {{2,1}, {1,4}} tStart=0.962962963 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
2449debugShowSort [0] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.333333333 tEnd=0.6185225 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2450debugShowSort [1] {{2,1}, {1,4}} tStart=0.962962963 tEnd=0.4 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2451debugShowSort [2] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.333333333 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2452findNextOp firstIndex=[3] sign=-1
2453activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2454activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
2455activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2456markDoneBinary id=4 (2,1 1,4) t=0.962962963 [3] (1.03703701,3.88888884) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2457findNextOp from:[4] to:[3] start=1 end=2
2458bridgeOp current id=4 from=(1,4) to=(1.03703701,3.88888884)
2459findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
2460debugShowSort [3] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.6185225 tEnd=0.333333333 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2461debugShowSort [0] {{6,0}, {0,3}} tStart=0.692958689 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=1
2462debugShowSort [1] {{1,4}, {0,6}, {3,0}, {2,1}} tStart=0.6185225 tEnd=0.66166507 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
2463debugShowSort [2] {{6,0}, {0,3}} tStart=0.692958689 tEnd=0.733333333 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
2464findNextOp firstIndex=[3] sign=1
2465activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2466activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2467activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2468markDoneBinary id=3 (1,4 0,6 3,0 2,1) t=0.333333333 [1] (1.03703701,3.88888884) tEnd=0.6185225 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
2469findNextOp from:[3] to:[2] start=1 end=0
2470bridgeOp current id=3 from=(1.03703701,3.88888884) to=(1.84224784,2.07887602)
2471path.lineTo(1.03703701,3.88888884);
2472path.cubicTo(1.25885081,3.41357374, 1.58910847,2.69425988, 1.84224784,2.07887602);
2473findNextOp simple
2474markDoneBinary id=2 (6,0 0,3) t=0 [0] (6,0) tEnd=0.692958689 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2475bridgeOp current id=2 from=(1.84224784,2.07887602) to=(6,0)
2476path.lineTo(6,0);
2477path.close();
2478assemble
2479assemble contour start=(6,0) end=(6,0)
2480</div>
2481
2482<div id="cubicOp51da">
2483$1 = {{x = 1.9511935265302274, y = 1.8079355291007388}, {x = 3.2262380859340407, y = 1.2052903527338259}, {x = 4.794709647266175, y = 0.60264517636691295}, {x = 6, y = 0}}
2484(gdb) p startEdge
2485$2 = {{x = 1.9511935265302274, y = 1.8079355291007388}, {x = 2.5538387028971403, y = 3.0829800885045522}}
2486(gdb) p endEdge
2487$3 = {{x = 6, y = 0}, {x = 5.3973548236330871, y = -1.205290352733825}}
2488</div>
2489
2490<div id="cubicOp52da">
2491$3 = {{fX = 2.625, fY = 2.25}, {fX = 2.25, fY = 1.25}, {fX = 2, fY = 0.5}, {fX = 2, fY = 1}}
2492</div>
2493
2494<div id="cubicOp52db">
2495$3 = {{x = 1.9511935265302274, y = 1.8079355291007388}, {x = 3.2262380859340407, y = 1.2052903527338259}, {x = 4.794709647266175, y = 0.60264517636691295}, {x = 6, y = 0}}
2496(gdb) p startEdge
2497$4 = {{x = 1.9511935265302274, y = 1.8079355291007388}, {x = 3.7591290556309662, y = 5.8567420025705115}}
2498(gdb) p endEdge
2499$5 = {{x = 6, y = 0}, {x = 7.8079355291007388, y = 4.0488064734697726}}
2500</div>
2501
2502<div id="cubicOp53d">
2503 SimplifyNew_Test [cubicOp53d]
2504{{0,3}, {1,2}, {5,3}, {2,1}},
2505{{2,1}, {0,3}},
2506op difference
2507{{3,5}, {1,2}, {3,0}, {2,1}},
2508{{2,1}, {3,5}},
2509debugShowCubicIntersection no self intersect {{3,5}, {1,2}, {3,0}, {2,1}}
2510debugShowCubicLineIntersection wtTs[0]=0 {{3,5}, {1,2}, {3,0}, {2,1}} {{3,5}} wtTs[1]=0.5 {{2.125,1.5}} wtTs[2]=1 {{2,1}} wnTs[0]=1 {{2,1}, {3,5}} wnTs[1]=0.125 wnTs[2]=0
2511debugShowCubicIntersection wtTs[0]=0.32953467 {{3,5}, {1,2}, {3,0}, {2,1}} {{2.0754128281547217,2.4315376490509659}} wtTs[1]=0.59235675 {{2.2015477442470841,1.1371488033015213}} wtTs[2]=1 {{2,1}} wnTs[0]=0.414081 {{0,3}, {1,2}, {5,3}, {2,1}} wnTs[1]=0.976311205 wnTs[2]=1
2512debugShowCubicLineIntersection wtTs[0]=1 {{3,5}, {1,2}, {3,0}, {2,1}} {{2,1}} wnTs[0]=0 {{2,1}, {0,3}}
2513debugShowCubicLineIntersection wtTs[0]=0.467845317 {{0,3}, {1,2}, {5,3}, {2,1}} {{2.3494328385891112,2.3977313543564462}} wtTs[1]=1 {{2,1}} wnTs[0]=0.349433 {{2,1}, {3,5}} wnTs[1]=0
2514debugShowLineIntersection wtTs[0]=-0 {{2,1}, {3,5}} {{2,1}} wnTs[0]=0 {{2,1}, {0,3}}
2515debugShowCubicIntersection no self intersect {{0,3}, {1,2}, {5,3}, {2,1}}
2516debugShowCubicLineIntersection wtTs[0]=0 {{0,3}, {1,2}, {5,3}, {2,1}} {{0,3}} wtTs[1]=1 {{2,1}} wnTs[0]=1 {{2,1}, {0,3}} wnTs[1]=0
2517debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0 (3,5) tEnd=0.32953467 other=4 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
2518debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.32953467 (2.07541275,2.43153763) tEnd=0.5 other=1 otherT=0.414080655 otherIndex=1 windSum=? windValue=1 oppValue=0
2519debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.5 (2.125,1.5) tEnd=0.59235675 other=4 otherT=0.125 otherIndex=3 windSum=? windValue=1 oppValue=0
2520debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.59235675 (2.20154786,1.13714886) tEnd=1 other=1 otherT=0.976311205 otherIndex=3 windSum=? windValue=1 oppValue=0
2521debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2522debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
2523debugShowActiveSpans id=4 (2,1 3,5) t=-0 (2,1) tEnd=0.125 other=2 otherT=0 otherIndex=1 windSum=? windValue=1 oppValue=0
2524debugShowActiveSpans id=4 (2,1 3,5) t=0.125 (2.125,1.5) tEnd=0.349432839 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
2525debugShowActiveSpans id=4 (2,1 3,5) t=0.349432839 (2.34943295,2.3977313) tEnd=1 other=1 otherT=0.467845317 otherIndex=2 windSum=? windValue=1 oppValue=0
2526debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0 (0,3) tEnd=0.414080655 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2527debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.414080655 (2.07541275,2.43153763) tEnd=0.467845317 other=3 otherT=0.32953467 otherIndex=1 windSum=? windValue=1 oppValue=0
2528debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.467845317 (2.34943295,2.3977313) tEnd=0.976311205 other=4 otherT=0.349432839 otherIndex=4 windSum=? windValue=1 oppValue=0
2529debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.976311205 (2.20154786,1.13714886) tEnd=1 other=3 otherT=0.59235675 otherIndex=3 windSum=? windValue=1 oppValue=0
2530debugShowActiveSpans id=2 (2,1 0,3) t=0 (2,1) tEnd=1 other=3 otherT=1 otherIndex=6 windSum=? windValue=1 oppValue=0
2531debugShowActiveSpans id=2 (2,1 0,3) t=0 (2,1) tEnd=1 other=4 otherT=-0 otherIndex=2 windSum=? windValue=1 oppValue=0
2532debugShowActiveSpans id=2 (2,1 0,3) t=0 (2,1) tEnd=1 other=1 otherT=1 otherIndex=6 windSum=? windValue=1 oppValue=0
2533findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2534debugShowSort [0] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=1 tEnd=0.59235675 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2535debugShowSort [1] {{2,1}, {0,3}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2536debugShowSort [2] {{2,1}, {3,5}} tStart=0 tEnd=0.125 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2537debugShowSort [3] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=1 tEnd=0.976311205 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2538markWinding id=3 (3,5 1,2 3,0 2,1) t=0.59235675 [3] (2.20154786,1.13714886) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2539markWinding id=3 (3,5 1,2 3,0 2,1) t=0.59235675 [3] (2.20154786,1.13714886) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2540activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2541markDoneBinary id=3 (3,5 1,2 3,0 2,1) t=0.59235675 [3] (2.20154786,1.13714886) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2542findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2543debugShowSort [0] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=1 tEnd=0.59235675 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2544debugShowSort [1] {{2,1}, {0,3}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2545debugShowSort [2] {{2,1}, {3,5}} tStart=0 tEnd=0.125 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2546debugShowSort [3] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=1 tEnd=0.976311205 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2547findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2548debugShowSort [0] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=1 tEnd=0.59235675 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2549debugShowSort [1] {{2,1}, {0,3}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2550debugShowSort [2] {{2,1}, {3,5}} tStart=0 tEnd=0.125 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2551debugShowSort [3] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=1 tEnd=0.976311205 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2552markWinding id=2 (2,1 0,3) t=0 [0] (2,1) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
2553markWinding id=2 (2,1 0,3) t=0 [1] (2,1) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
2554markWinding id=2 (2,1 0,3) t=0 [2] (2,1) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
2555markWinding id=1 (0,3 1,2 5,3 2,1) t=0 [0] (0,3) tEnd=0.414080655 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
2556markWinding id=4 (2,1 3,5) t=0 [0] (2,1) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2557markWinding id=4 (2,1 3,5) t=0 [1] (2,1) tEnd=-0 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2558markWinding id=4 (2,1 3,5) t=-0 [2] (2,1) tEnd=0.125 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2559markWinding id=1 (0,3 1,2 5,3 2,1) t=0.976311205 [3] (2.20154786,1.13714886) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2560debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0 (3,5) tEnd=0.32953467 other=4 otherT=1 otherIndex=5 windSum=? windValue=1 oppValue=0
2561debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.32953467 (2.07541275,2.43153763) tEnd=0.5 other=1 otherT=0.414080655 otherIndex=1 windSum=? windValue=1 oppValue=0
2562debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.5 (2.125,1.5) tEnd=0.59235675 other=4 otherT=0.125 otherIndex=3 windSum=? windValue=1 oppValue=0
2563debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2564debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
2565debugShowActiveSpans id=4 (2,1 3,5) t=-0 (2,1) tEnd=0.125 other=2 otherT=0 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2566debugShowActiveSpans id=4 (2,1 3,5) t=0.125 (2.125,1.5) tEnd=0.349432839 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
2567debugShowActiveSpans id=4 (2,1 3,5) t=0.349432839 (2.34943295,2.3977313) tEnd=1 other=1 otherT=0.467845317 otherIndex=2 windSum=? windValue=1 oppValue=0
2568debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0 (0,3) tEnd=0.414080655 other=2 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
2569debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.414080655 (2.07541275,2.43153763) tEnd=0.467845317 other=3 otherT=0.32953467 otherIndex=1 windSum=? windValue=1 oppValue=0
2570debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.467845317 (2.34943295,2.3977313) tEnd=0.976311205 other=4 otherT=0.349432839 otherIndex=4 windSum=? windValue=1 oppValue=0
2571debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.976311205 (2.20154786,1.13714886) tEnd=1 other=3 otherT=0.59235675 otherIndex=3 windSum=1 windValue=1 oppValue=0
2572debugShowActiveSpans id=2 (2,1 0,3) t=0 (2,1) tEnd=1 other=3 otherT=1 otherIndex=6 windSum=1 windValue=1 oppValue=0
2573debugShowActiveSpans id=2 (2,1 0,3) t=0 (2,1) tEnd=1 other=4 otherT=-0 otherIndex=2 windSum=1 windValue=1 oppValue=0
2574debugShowActiveSpans id=2 (2,1 0,3) t=0 (2,1) tEnd=1 other=1 otherT=1 otherIndex=6 windSum=1 windValue=1 oppValue=0
2575activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2576markDoneBinary id=2 (2,1 0,3) t=0 [0] (2,1) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
2577markDoneBinary id=2 (2,1 0,3) t=0 [1] (2,1) tEnd=0 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
2578markDoneBinary id=2 (2,1 0,3) t=0 [2] (2,1) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
2579markDoneBinary id=1 (0,3 1,2 5,3 2,1) t=0 [0] (0,3) tEnd=0.414080655 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
2580findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=-1
2581debugShowSort [0] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=0.414080655 tEnd=0.467845317 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
2582debugShowSort [1] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.32953467 tEnd=0.5 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
2583debugShowSort [2] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=0.414080655 tEnd=0 sign=1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=0
2584debugShowSort [3] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.32953467 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
2585findChaseOp debugShowSort contourWinding=1 oppContourWinding=-1 sign=1
2586debugShowSort [2] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=0.414080655 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2587debugShowSort [3] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.32953467 tEnd=0 sign=1 windValue=1 windSum=? -1->-2 (max=-2) done=0 tiny=0 opp=1
2588debugShowSort [0] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=0.414080655 tEnd=0.467845317 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2589debugShowSort [1] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.32953467 tEnd=0.5 sign=-1 windValue=1 windSum=? -2->-1 (max=-2) done=0 tiny=0 opp=1
2590markWinding id=3 (3,5 1,2 3,0 2,1) t=0 [0] (3,5) tEnd=0.32953467 newWindSum=-2 newOppSum=0 oppSum=? windSum=? windValue=1
2591markWinding id=4 (2,1 3,5) t=0.349432839 [4] (2.34943295,2.3977313) tEnd=1 newWindSum=-2 newOppSum=0 oppSum=? windSum=? windValue=1
2592markWinding id=1 (0,3 1,2 5,3 2,1) t=0.414080655 [1] (2.07541275,2.43153763) tEnd=0.467845317 newWindSum=1 newOppSum=-2 oppSum=? windSum=? windValue=1
2593markWinding id=3 (3,5 1,2 3,0 2,1) t=0.32953467 [1] (2.07541275,2.43153763) tEnd=0.5 newWindSum=-2 newOppSum=1 oppSum=? windSum=? windValue=1
2594debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0 (3,5) tEnd=0.32953467 other=4 otherT=1 otherIndex=5 windSum=-2 windValue=1 oppValue=0
2595debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.32953467 (2.07541275,2.43153763) tEnd=0.5 other=1 otherT=0.414080655 otherIndex=1 windSum=-2 windValue=1 oppValue=0
2596debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.5 (2.125,1.5) tEnd=0.59235675 other=4 otherT=0.125 otherIndex=3 windSum=? windValue=1 oppValue=0
2597debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2598debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
2599debugShowActiveSpans id=4 (2,1 3,5) t=-0 (2,1) tEnd=0.125 other=2 otherT=0 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2600debugShowActiveSpans id=4 (2,1 3,5) t=0.125 (2.125,1.5) tEnd=0.349432839 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
2601debugShowActiveSpans id=4 (2,1 3,5) t=0.349432839 (2.34943295,2.3977313) tEnd=1 other=1 otherT=0.467845317 otherIndex=2 windSum=-2 windValue=1 oppValue=0
2602debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.414080655 (2.07541275,2.43153763) tEnd=0.467845317 other=3 otherT=0.32953467 otherIndex=1 windSum=1 windValue=1 oppValue=0
2603debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.467845317 (2.34943295,2.3977313) tEnd=0.976311205 other=4 otherT=0.349432839 otherIndex=4 windSum=? windValue=1 oppValue=0
2604debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.976311205 (2.20154786,1.13714886) tEnd=1 other=3 otherT=0.59235675 otherIndex=3 windSum=1 windValue=1 oppValue=0
2605activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=1 result=0
2606markDoneBinary id=3 (3,5 1,2 3,0 2,1) t=0 [0] (3,5) tEnd=0.32953467 newWindSum=-2 newOppSum=0 oppSum=0 windSum=-2 windValue=1
2607markDoneBinary id=4 (2,1 3,5) t=0.349432839 [4] (2.34943295,2.3977313) tEnd=1 newWindSum=-2 newOppSum=0 oppSum=0 windSum=-2 windValue=1
2608debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.32953467 (2.07541275,2.43153763) tEnd=0.5 other=1 otherT=0.414080655 otherIndex=1 windSum=-2 windValue=1 oppValue=0
2609debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.5 (2.125,1.5) tEnd=0.59235675 other=4 otherT=0.125 otherIndex=3 windSum=? windValue=1 oppValue=0
2610debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2611debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
2612debugShowActiveSpans id=4 (2,1 3,5) t=-0 (2,1) tEnd=0.125 other=2 otherT=0 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2613debugShowActiveSpans id=4 (2,1 3,5) t=0.125 (2.125,1.5) tEnd=0.349432839 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
2614debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.414080655 (2.07541275,2.43153763) tEnd=0.467845317 other=3 otherT=0.32953467 otherIndex=1 windSum=1 windValue=1 oppValue=0
2615debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.467845317 (2.34943295,2.3977313) tEnd=0.976311205 other=4 otherT=0.349432839 otherIndex=4 windSum=? windValue=1 oppValue=0
2616debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.976311205 (2.20154786,1.13714886) tEnd=1 other=3 otherT=0.59235675 otherIndex=3 windSum=1 windValue=1 oppValue=0
2617activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2618markDoneBinary id=1 (0,3 1,2 5,3 2,1) t=0.414080655 [1] (2.07541275,2.43153763) tEnd=0.467845317 newWindSum=1 newOppSum=-2 oppSum=-2 windSum=1 windValue=1
2619debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.32953467 (2.07541275,2.43153763) tEnd=0.5 other=1 otherT=0.414080655 otherIndex=1 windSum=-2 windValue=1 oppValue=0
2620debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.5 (2.125,1.5) tEnd=0.59235675 other=4 otherT=0.125 otherIndex=3 windSum=? windValue=1 oppValue=0
2621debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2622debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
2623debugShowActiveSpans id=4 (2,1 3,5) t=-0 (2,1) tEnd=0.125 other=2 otherT=0 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2624debugShowActiveSpans id=4 (2,1 3,5) t=0.125 (2.125,1.5) tEnd=0.349432839 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
2625debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.467845317 (2.34943295,2.3977313) tEnd=0.976311205 other=4 otherT=0.349432839 otherIndex=4 windSum=? windValue=1 oppValue=0
2626debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.976311205 (2.20154786,1.13714886) tEnd=1 other=3 otherT=0.59235675 otherIndex=3 windSum=1 windValue=1 oppValue=0
2627activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
2628markDoneBinary id=3 (3,5 1,2 3,0 2,1) t=0.32953467 [1] (2.07541275,2.43153763) tEnd=0.5 newWindSum=-2 newOppSum=1 oppSum=1 windSum=-2 windValue=1
2629debugShowActiveSpans id=3 (3,5 1,2 3,0 2,1) t=0.5 (2.125,1.5) tEnd=0.59235675 other=4 otherT=0.125 otherIndex=3 windSum=? windValue=1 oppValue=0
2630debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=3 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2631debugShowActiveSpans id=4 (2,1 3,5) t=0 (2,1) tEnd=0.125 other=1 otherT=1 otherIndex=5 windSum=-1 windValue=1 oppValue=0
2632debugShowActiveSpans id=4 (2,1 3,5) t=-0 (2,1) tEnd=0.125 other=2 otherT=0 otherIndex=1 windSum=-1 windValue=1 oppValue=0
2633debugShowActiveSpans id=4 (2,1 3,5) t=0.125 (2.125,1.5) tEnd=0.349432839 other=3 otherT=0.5 otherIndex=2 windSum=? windValue=1 oppValue=0
2634debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.467845317 (2.34943295,2.3977313) tEnd=0.976311205 other=4 otherT=0.349432839 otherIndex=4 windSum=? windValue=1 oppValue=0
2635debugShowActiveSpans id=1 (0,3 1,2 5,3 2,1) t=0.976311205 (2.20154786,1.13714886) tEnd=1 other=3 otherT=0.59235675 otherIndex=3 windSum=1 windValue=1 oppValue=0
2636activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2637findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
2638debugShowSort [2] {{2,1}, {3,5}} tStart=-0 tEnd=0.125 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
2639debugShowSort [3] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=1 tEnd=0.976311205 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=1
2640debugShowSort [0] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=1 tEnd=0.59235675 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2641debugShowSort [1] {{2,1}, {0,3}} tStart=0 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
2642findNextOp firstIndex=[2] sign=-1
2643activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2644activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2645activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2646markDoneBinary id=4 (2,1 3,5) t=0 [1] (2,1) tEnd=-0 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2647markDoneBinary id=4 (2,1 3,5) t=0 [0] (2,1) tEnd=0 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2648markDoneBinary id=4 (2,1 3,5) t=-0 [2] (2,1) tEnd=0.125 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2649findNextOp from:[4] to:[1] start=5 end=3
2650bridgeOp current id=4 from=(2.125,1.5) to=(2,1)
2651findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2652debugShowSort [1] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=0.976311205 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2653debugShowSort [2] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.59235675 tEnd=0.5 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
2654debugShowSort [3] {{0,3}, {1,2}, {5,3}, {2,1}} tStart=0.976311205 tEnd=0.467845317 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2655debugShowSort [0] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.59235675 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
2656findNextOp firstIndex=[1] sign=-1
2657activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2658markWinding id=3 (3,5 1,2 3,0 2,1) t=0.5 [2] (2.125,1.5) tEnd=0.59235675 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2659findNextOp chase.append id=3
2660activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2661markDoneBinary id=1 (0,3 1,2 5,3 2,1) t=0.467845317 [2] (2.34943295,2.3977313) tEnd=0.976311205 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
2662findNextOp chase.append id=1
2663activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2664markDoneBinary id=1 (0,3 1,2 5,3 2,1) t=0.976311205 [3] (2.20154786,1.13714886) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2665findNextOp from:[1] to:[3] start=3 end=2
2666bridgeOp current id=1 from=(2,1) to=(2.20154786,1.13714886)
2667path.moveTo(2.125,1.5);
2668path.lineTo(2,1);
2669path.cubicTo(2.07106638,1.04737759, 2.13820457,1.0930717, 2.20154786,1.13714886);
2670findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
2671debugShowSort [0] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.5 tEnd=0.59235675 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
2672debugShowSort [1] {{2,1}, {3,5}} tStart=0.125 tEnd=-0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2673debugShowSort [2] {{3,5}, {1,2}, {3,0}, {2,1}} tStart=0.5 tEnd=0.32953467 sign=1 windValue=1 windSum=-2 -1->-2 (max=-2) done=1 tiny=0 opp=0
2674debugShowSort [3] {{2,1}, {3,5}} tStart=0.125 tEnd=0.349432839 sign=-1 windValue=1 windSum=? -2->-1 (max=-2) done=0 tiny=0 opp=0
2675findNextOp firstIndex=[0] sign=-1
2676activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2677activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
2678activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
2679markDoneBinary id=4 (2,1 3,5) t=0.125 [3] (2.125,1.5) tEnd=0.349432839 newWindSum=-2 newOppSum=1 oppSum=? windSum=? windValue=1
2680findNextOp chase.append id=4
2681markDoneBinary id=3 (3,5 1,2 3,0 2,1) t=0.5 [2] (2.125,1.5) tEnd=0.59235675 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2682findNextOp from:[3] to:[4] start=3 end=2
2683bridgeOp current id=3 from=(2.20154786,1.13714886) to=(2.125,1.5)
2684path.cubicTo(2.17544317,1.23998928, 2.14808917,1.36146486, 2.125,1.5);
2685path.close();
2686assemble
2687assemble contour start=(2.125,1.5) end=(2.125,1.5)
2688</div>
2689
2690<div id="cubicOp53da">
2691$1 = {{fX = 2.20154786, fY = 1.13714886}, {fX = 2.31676745, fY = 0.683232486}, {fX = 2.40764332, fY = 0.592356741}, {fX = 2, fY = 1}}
2692</div>
2693
2694<div id="cubicOp53db">
2695$5 = {{x = 2.2015477442470841, y = 1.1371488033015216}, {x = 2.3167674423028313, y = 0.68323255769716895}, {x = 2.4076432497431508, y = 0.59235675025684875}, {x = 2, y = 1}}
2696(gdb) p startEdge
2697$2 = {{x = 2.2015477442470841, y = 1.1371488033015216}, {x = 2.6554639898514365, y = 1.2523685013572687}}
2698(gdb) p endEdge
2699$3 = {{x = 2, y = 1}, {x = 2.4076432497431512, y = 1.4076432497431508}}
2700</div>
2701
2702<div id="cubicOp54d">
2703 SimplifyNew_Test [cubicOp54d]
2704{{0,4}, {1,3}, {5,4}, {4,2}},
2705{{4,2}, {0,4}},
2706op difference
2707{{4,5}, {2,4}, {4,0}, {3,1}},
2708{{3,1}, {4,5}},
2709debugShowCubicIntersection no self intersect {{4,5}, {2,4}, {4,0}, {3,1}}
2710debugShowCubicLineIntersection wtTs[0]=0 {{4,5}, {2,4}, {4,0}, {3,1}} {{4,5}} wtTs[1]=0.583333333 {{3.1938657407407405,1.7754629629629624}} wtTs[2]=1 {{3,1}} wnTs[0]=1 {{3,1}, {4,5}} wnTs[1]=0.193865741 wnTs[2]=0
2711debugShowCubicIntersection no intersect {{4,5}, {2,4}, {4,0}, {3,1}} {{0,4}, {1,3}, {5,4}, {4,2}}
2712debugShowCubicLineIntersection wtTs[0]=0.467349523 {{4,5}, {2,4}, {4,0}, {3,1}} {{3.1023548730676489,2.4488225634661758}} wnTs[0]=0.224411 {{4,2}, {0,4}}
2713debugShowCubicLineIntersection wtTs[0]=0.649488354 {{0,4}, {1,3}, {5,4}, {4,2}} {{3.5531651685912107,3.2126606743648427}} wnTs[0]=0.553165 {{3,1}, {4,5}}
2714debugShowLineIntersection wtTs[0]=0.333333333 {{3,1}, {4,5}} {{3.333333333333333,2.333333333333333}} wnTs[0]=0.166667 {{4,2}, {0,4}}
2715debugShowCubicIntersection no self intersect {{0,4}, {1,3}, {5,4}, {4,2}}
2716debugShowCubicLineIntersection wtTs[0]=0 {{0,4}, {1,3}, {5,4}, {4,2}} {{0,4}} wtTs[1]=0.166666667 {{0.7129629629629628,3.6435185185185186}} wtTs[2]=1 {{4,2}} wnTs[0]=1 {{4,2}, {0,4}} wnTs[1]=0.821759259 wnTs[2]=0
2717debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0 (4,5) tEnd=0.467349523 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2718debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0.467349523 (3.10235476,2.4488225) tEnd=0.583333333 other=2 otherT=0.224411282 otherIndex=2 windSum=? windValue=1 oppValue=0
2719debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0.583333333 (3.19386578,1.77546299) tEnd=1 other=4 otherT=0.193865741 otherIndex=1 windSum=? windValue=1 oppValue=0
2720debugShowActiveSpans id=4 (3,1 4,5) t=0 (3,1) tEnd=0.193865741 other=3 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2721debugShowActiveSpans id=4 (3,1 4,5) t=0.193865741 (3.19386578,1.77546299) tEnd=0.333333333 other=3 otherT=0.583333333 otherIndex=2 windSum=? windValue=1 oppValue=0
2722debugShowActiveSpans id=4 (3,1 4,5) t=0.333333333 (3.33333325,2.33333325) tEnd=0.553165169 other=2 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2723debugShowActiveSpans id=4 (3,1 4,5) t=0.553165169 (3.5531652,3.21266079) tEnd=1 other=1 otherT=0.649488354 otherIndex=2 windSum=? windValue=1 oppValue=0
2724debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0 (0,4) tEnd=0.166666667 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2725debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.166666667 (0.712962985,3.64351845) tEnd=0.649488354 other=2 otherT=0.821759259 otherIndex=3 windSum=? windValue=1 oppValue=0
2726debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.649488354 (3.5531652,3.21266079) tEnd=1 other=4 otherT=0.553165169 otherIndex=3 windSum=? windValue=1 oppValue=0
2727debugShowActiveSpans id=2 (4,2 0,4) t=0 (4,2) tEnd=0.166666667 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2728debugShowActiveSpans id=2 (4,2 0,4) t=0.166666667 (3.33333325,2.33333325) tEnd=0.224411282 other=4 otherT=0.333333333 otherIndex=2 windSum=? windValue=1 oppValue=0
2729debugShowActiveSpans id=2 (4,2 0,4) t=0.224411282 (3.10235476,2.4488225) tEnd=0.821759259 other=3 otherT=0.467349523 otherIndex=1 windSum=? windValue=1 oppValue=0
2730debugShowActiveSpans id=2 (4,2 0,4) t=0.821759259 (0.712962985,3.64351845) tEnd=1 other=1 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2731findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2732debugShowSort [0] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=1 tEnd=0.583333333 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2733debugShowSort [1] {{3,1}, {4,5}} tStart=0 tEnd=0.193865741 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2734findTop swap serpentine=0
2735markWinding id=3 (4,5 2,4 4,0 3,1) t=0.583333333 [2] (3.19386578,1.77546299) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2736markWinding id=3 (4,5 2,4 4,0 3,1) t=0.583333333 [2] (3.19386578,1.77546299) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2737markWinding id=4 (3,1 4,5) t=0 [0] (3,1) tEnd=0.193865741 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2738activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2739markDoneBinary id=3 (4,5 2,4 4,0 3,1) t=0.583333333 [2] (3.19386578,1.77546299) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2740debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0 (4,5) tEnd=0.467349523 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2741debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0.467349523 (3.10235476,2.4488225) tEnd=0.583333333 other=2 otherT=0.224411282 otherIndex=2 windSum=? windValue=1 oppValue=0
2742debugShowActiveSpans id=4 (3,1 4,5) t=0 (3,1) tEnd=0.193865741 other=3 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
2743debugShowActiveSpans id=4 (3,1 4,5) t=0.193865741 (3.19386578,1.77546299) tEnd=0.333333333 other=3 otherT=0.583333333 otherIndex=2 windSum=? windValue=1 oppValue=0
2744debugShowActiveSpans id=4 (3,1 4,5) t=0.333333333 (3.33333325,2.33333325) tEnd=0.553165169 other=2 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2745debugShowActiveSpans id=4 (3,1 4,5) t=0.553165169 (3.5531652,3.21266079) tEnd=1 other=1 otherT=0.649488354 otherIndex=2 windSum=? windValue=1 oppValue=0
2746debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0 (0,4) tEnd=0.166666667 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2747debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.166666667 (0.712962985,3.64351845) tEnd=0.649488354 other=2 otherT=0.821759259 otherIndex=3 windSum=? windValue=1 oppValue=0
2748debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.649488354 (3.5531652,3.21266079) tEnd=1 other=4 otherT=0.553165169 otherIndex=3 windSum=? windValue=1 oppValue=0
2749debugShowActiveSpans id=2 (4,2 0,4) t=0 (4,2) tEnd=0.166666667 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2750debugShowActiveSpans id=2 (4,2 0,4) t=0.166666667 (3.33333325,2.33333325) tEnd=0.224411282 other=4 otherT=0.333333333 otherIndex=2 windSum=? windValue=1 oppValue=0
2751debugShowActiveSpans id=2 (4,2 0,4) t=0.224411282 (3.10235476,2.4488225) tEnd=0.821759259 other=3 otherT=0.467349523 otherIndex=1 windSum=? windValue=1 oppValue=0
2752debugShowActiveSpans id=2 (4,2 0,4) t=0.821759259 (0.712962985,3.64351845) tEnd=1 other=1 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2753activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2754markDoneBinary id=4 (3,1 4,5) t=0 [0] (3,1) tEnd=0.193865741 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2755findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2756debugShowSort [0] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.583333333 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
2757debugShowSort [1] {{3,1}, {4,5}} tStart=0.193865741 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2758debugShowSort [2] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.583333333 tEnd=0.467349523 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2759debugShowSort [3] {{3,1}, {4,5}} tStart=0.193865741 tEnd=0.333333333 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2760findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2761debugShowSort [0] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.583333333 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
2762debugShowSort [1] {{3,1}, {4,5}} tStart=0.193865741 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2763debugShowSort [2] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.583333333 tEnd=0.467349523 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2764debugShowSort [3] {{3,1}, {4,5}} tStart=0.193865741 tEnd=0.333333333 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2765markWinding id=3 (4,5 2,4 4,0 3,1) t=0.467349523 [1] (3.10235476,2.4488225) tEnd=0.583333333 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2766markWinding id=4 (3,1 4,5) t=0.193865741 [1] (3.19386578,1.77546299) tEnd=0.333333333 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2767debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0 (4,5) tEnd=0.467349523 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2768debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0.467349523 (3.10235476,2.4488225) tEnd=0.583333333 other=2 otherT=0.224411282 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2769debugShowActiveSpans id=4 (3,1 4,5) t=0.193865741 (3.19386578,1.77546299) tEnd=0.333333333 other=3 otherT=0.583333333 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2770debugShowActiveSpans id=4 (3,1 4,5) t=0.333333333 (3.33333325,2.33333325) tEnd=0.553165169 other=2 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2771debugShowActiveSpans id=4 (3,1 4,5) t=0.553165169 (3.5531652,3.21266079) tEnd=1 other=1 otherT=0.649488354 otherIndex=2 windSum=? windValue=1 oppValue=0
2772debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0 (0,4) tEnd=0.166666667 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2773debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.166666667 (0.712962985,3.64351845) tEnd=0.649488354 other=2 otherT=0.821759259 otherIndex=3 windSum=? windValue=1 oppValue=0
2774debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.649488354 (3.5531652,3.21266079) tEnd=1 other=4 otherT=0.553165169 otherIndex=3 windSum=? windValue=1 oppValue=0
2775debugShowActiveSpans id=2 (4,2 0,4) t=0 (4,2) tEnd=0.166666667 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2776debugShowActiveSpans id=2 (4,2 0,4) t=0.166666667 (3.33333325,2.33333325) tEnd=0.224411282 other=4 otherT=0.333333333 otherIndex=2 windSum=? windValue=1 oppValue=0
2777debugShowActiveSpans id=2 (4,2 0,4) t=0.224411282 (3.10235476,2.4488225) tEnd=0.821759259 other=3 otherT=0.467349523 otherIndex=1 windSum=? windValue=1 oppValue=0
2778debugShowActiveSpans id=2 (4,2 0,4) t=0.821759259 (0.712962985,3.64351845) tEnd=1 other=1 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2779activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2780markDoneBinary id=3 (4,5 2,4 4,0 3,1) t=0.467349523 [1] (3.10235476,2.4488225) tEnd=0.583333333 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2781findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
2782debugShowSort [0] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.166666667 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
2783debugShowSort [1] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0.583333333 sign=-1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
2784debugShowSort [2] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.821759259 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
2785debugShowSort [3] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
2786findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
2787debugShowSort [1] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0.583333333 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
2788debugShowSort [2] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.821759259 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2789debugShowSort [3] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2790debugShowSort [0] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.166666667 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2791markWinding id=2 (4,2 0,4) t=0.224411282 [2] (3.10235476,2.4488225) tEnd=0.821759259 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2792markWinding id=3 (4,5 2,4 4,0 3,1) t=0 [0] (4,5) tEnd=0.467349523 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2793markWinding id=4 (3,1 4,5) t=0.553165169 [3] (3.5531652,3.21266079) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
2794markWinding id=2 (4,2 0,4) t=0.166666667 [1] (3.33333325,2.33333325) tEnd=0.224411282 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
2795debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0 (4,5) tEnd=0.467349523 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2796debugShowActiveSpans id=4 (3,1 4,5) t=0.193865741 (3.19386578,1.77546299) tEnd=0.333333333 other=3 otherT=0.583333333 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2797debugShowActiveSpans id=4 (3,1 4,5) t=0.333333333 (3.33333325,2.33333325) tEnd=0.553165169 other=2 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2798debugShowActiveSpans id=4 (3,1 4,5) t=0.553165169 (3.5531652,3.21266079) tEnd=1 other=1 otherT=0.649488354 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2799debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0 (0,4) tEnd=0.166666667 other=2 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2800debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.166666667 (0.712962985,3.64351845) tEnd=0.649488354 other=2 otherT=0.821759259 otherIndex=3 windSum=? windValue=1 oppValue=0
2801debugShowActiveSpans id=1 (0,4 1,3 5,4 4,2) t=0.649488354 (3.5531652,3.21266079) tEnd=1 other=4 otherT=0.553165169 otherIndex=3 windSum=? windValue=1 oppValue=0
2802debugShowActiveSpans id=2 (4,2 0,4) t=0 (4,2) tEnd=0.166666667 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2803debugShowActiveSpans id=2 (4,2 0,4) t=0.166666667 (3.33333325,2.33333325) tEnd=0.224411282 other=4 otherT=0.333333333 otherIndex=2 windSum=1 windValue=1 oppValue=0
2804debugShowActiveSpans id=2 (4,2 0,4) t=0.224411282 (3.10235476,2.4488225) tEnd=0.821759259 other=3 otherT=0.467349523 otherIndex=1 windSum=1 windValue=1 oppValue=0
2805debugShowActiveSpans id=2 (4,2 0,4) t=0.821759259 (0.712962985,3.64351845) tEnd=1 other=1 otherT=0.166666667 otherIndex=1 windSum=? windValue=1 oppValue=0
2806activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2807findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
2808debugShowSort [1] {{4,2}, {0,4}} tStart=0.821759259 tEnd=0.224411282 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2809debugShowSort [2] {{0,4}, {1,3}, {5,4}, {4,2}} tStart=0.166666667 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2810debugShowSort [3] {{4,2}, {0,4}} tStart=0.821759259 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2811debugShowSort [0] {{0,4}, {1,3}, {5,4}, {4,2}} tStart=0.166666667 tEnd=0.649488354 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2812findNextOp firstIndex=[1] sign=1
2813activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2814markWinding id=1 (0,4 1,3 5,4 4,2) t=0 [0] (0,4) tEnd=0.166666667 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2815markWinding id=2 (4,2 0,4) t=0.821759259 [3] (0.712962985,3.64351845) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
2816findNextOp chase.append id=2
2817activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2818activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2819markWinding id=1 (0,4 1,3 5,4 4,2) t=0.166666667 [1] (0.712962985,3.64351845) tEnd=0.649488354 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2820findNextOp chase.append id=1
2821markDoneBinary id=2 (4,2 0,4) t=0.224411282 [2] (3.10235476,2.4488225) tEnd=0.821759259 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2822findNextOp from:[2] to:[1] start=1 end=0
2823bridgeOp current id=2 from=(3.10235476,2.4488225) to=(0.712962985,3.64351845)
2824findNextOp simple
2825markDoneBinary id=1 (0,4 1,3 5,4 4,2) t=0 [0] (0,4) tEnd=0.166666667 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2826bridgeOp current id=1 from=(0.712962985,3.64351845) to=(0,4)
2827path.moveTo(3.10235476,2.4488225);
2828path.lineTo(0.712962985,3.64351845);
2829path.cubicTo(0.416666657,3.72222233, 0.166666672,3.83333325, 0,4);
2830findNextOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
2831debugShowSort [3] {{4,2}, {0,4}} tStart=0.821759259 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
2832debugShowSort [0] {{0,4}, {1,3}, {5,4}, {4,2}} tStart=0.166666667 tEnd=0.649488354 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2833debugShowSort [1] {{4,2}, {0,4}} tStart=0.821759259 tEnd=0.224411282 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
2834debugShowSort [2] {{0,4}, {1,3}, {5,4}, {4,2}} tStart=0.166666667 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
2835findNextOp firstIndex=[3] sign=-1
2836activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2837activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2838activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2839markDoneBinary id=2 (4,2 0,4) t=0.821759259 [3] (0.712962985,3.64351845) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2840findNextOp from:[2] to:[1] start=1 end=2
2841bridgeOp current id=2 from=(0,4) to=(0.712962985,3.64351845)
2842findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
2843debugShowSort [2] {{0,4}, {1,3}, {5,4}, {4,2}} tStart=0.649488354 tEnd=0.166666667 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2844debugShowSort [3] {{3,1}, {4,5}} tStart=0.553165169 tEnd=1 sign=-1 windValue=1 windSum=-1 0->1 (max=1) done=0 tiny=0 opp=1
2845debugShowSort [0] {{0,4}, {1,3}, {5,4}, {4,2}} tStart=0.649488354 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
2846debugShowSort [1] {{3,1}, {4,5}} tStart=0.553165169 tEnd=0.333333333 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2847findNextOp firstIndex=[2] sign=1
2848activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2849activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
2850markDoneBinary id=1 (0,4 1,3 5,4 4,2) t=0.649488354 [2] (3.5531652,3.21266079) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2851markDoneBinary id=2 (4,2 0,4) t=0 [0] (4,2) tEnd=0.166666667 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2852findNextOp chase.append id=2
2853activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
2854markWinding id=4 (3,1 4,5) t=0.333333333 [2] (3.33333325,2.33333325) tEnd=0.553165169 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2855findNextOp chase.append id=4
2856markDoneBinary id=1 (0,4 1,3 5,4 4,2) t=0.166666667 [1] (0.712962985,3.64351845) tEnd=0.649488354 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2857findNextOp from:[1] to:[4] start=3 end=2
2858bridgeOp current id=1 from=(0.712962985,3.64351845) to=(3.5531652,3.21266079)
2859path.lineTo(0.712962985,3.64351845);
2860path.cubicTo(1.57131267,3.41551948, 2.81819034,3.45948982, 3.5531652,3.21266079);
2861findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=-1
2862debugShowSort [3] {{3,1}, {4,5}} tStart=0.333333333 tEnd=0.553165169 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2863debugShowSort [0] {{4,2}, {0,4}} tStart=0.166666667 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
2864debugShowSort [1] {{3,1}, {4,5}} tStart=0.333333333 tEnd=0.193865741 sign=1 windValue=1 windSum=-1 1->0 (max=1) done=0 tiny=0 opp=0
2865debugShowSort [2] {{4,2}, {0,4}} tStart=0.166666667 tEnd=0.224411282 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=1
2866findNextOp firstIndex=[3] sign=-1
2867activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2868activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2869activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2870markDoneBinary id=4 (3,1 4,5) t=0.333333333 [2] (3.33333325,2.33333325) tEnd=0.553165169 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
2871findNextOp from:[4] to:[2] start=1 end=2
2872bridgeOp current id=4 from=(3.5531652,3.21266079) to=(3.33333325,2.33333325)
2873findNextOp debugShowSort contourWinding=1 oppContourWinding=-1 sign=1
2874debugShowSort [0] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.166666667 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
2875debugShowSort [1] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0.583333333 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
2876debugShowSort [2] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.821759259 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
2877debugShowSort [3] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=1
2878findNextOp firstIndex=[0] sign=1
2879activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2880activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2881activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2882markDoneBinary id=2 (4,2 0,4) t=0.166666667 [1] (3.33333325,2.33333325) tEnd=0.224411282 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
2883findNextOp from:[2] to:[2] start=2 end=3
2884sharedlibrary apply-load-rules all
2885bridgeOp current id=2 from=(3.33333325,2.33333325) to=(3.10235476,2.4488225)
2886path.lineTo(3.33333325,2.33333325);
2887path.lineTo(3.10235476,2.4488225);
2888path.close();
2889debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0 (4,5) tEnd=0.467349523 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2890debugShowActiveSpans id=4 (3,1 4,5) t=0.193865741 (3.19386578,1.77546299) tEnd=0.333333333 other=3 otherT=0.583333333 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2891debugShowActiveSpans id=4 (3,1 4,5) t=0.553165169 (3.5531652,3.21266079) tEnd=1 other=1 otherT=0.649488354 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2892activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
2893markDoneBinary id=4 (3,1 4,5) t=0.193865741 [1] (3.19386578,1.77546299) tEnd=0.333333333 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
2894debugShowActiveSpans id=3 (4,5 2,4 4,0 3,1) t=0 (4,5) tEnd=0.467349523 other=4 otherT=1 otherIndex=4 windSum=-1 windValue=1 oppValue=0
2895debugShowActiveSpans id=4 (3,1 4,5) t=0.553165169 (3.5531652,3.21266079) tEnd=1 other=1 otherT=0.649488354 otherIndex=2 windSum=-1 windValue=1 oppValue=0
2896activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
2897findNextOp simple
2898markDoneBinary id=4 (3,1 4,5) t=0.553165169 [3] (3.5531652,3.21266079) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2899bridgeOp current id=4 from=(3.5531652,3.21266079) to=(4,5)
2900findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
2901debugShowSort [3] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
2902debugShowSort [0] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.166666667 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
2903debugShowSort [1] {{4,5}, {2,4}, {4,0}, {3,1}} tStart=0.467349523 tEnd=0.583333333 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
2904debugShowSort [2] {{4,2}, {0,4}} tStart=0.224411282 tEnd=0.821759259 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
2905findNextOp firstIndex=[3] sign=1
2906activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
2907activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
2908activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
2909markDoneBinary id=3 (4,5 2,4 4,0 3,1) t=0 [0] (4,5) tEnd=0.467349523 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
2910findNextOp from:[3] to:[2] start=2 end=3
2911bridgeOp current id=3 from=(4,5) to=(3.10235476,2.4488225)
2912path.moveTo(3.5531652,3.21266079);
2913path.lineTo(4,5);
2914path.cubicTo(3.06530094,4.53265047, 3.00426435,3.41005421, 3.10235476,2.4488225);
2915</div>
2916
2917<div id="cubicOp54da">
2918computed quadratics given
2919 {{0,4}, {1,3}, {5,4}, {4,2}},
2920 {{4,5}, {2,4}, {4,0}, {3,1}},
2921computed quadratics set 1
2922 {{0,4}, {0.313151522,3.71221453}, {0.886767898,3.60197476}},
2923 {{0.886767898,3.60197476}, {1.46038427,3.491735}, {2.10714698,3.44196686}},
2924 {{2.10714698,3.44196686}, {3.12180288,3.38575704}, {3.75968569,3.1281838}},
2925 {{3.75968569,3.1281838}, {4.3975685,2.87061055}, {4,2}},
2926computed quadratics set 2
2927 {{4,5}, {3.59856947,4.79217123}, {3.39068129,4.44939202}},
2928 {{3.39068129,4.44939202}, {3.03659239,3.81843234}, {3.06844529,3.02100922}},
2929 {{3.06844529,3.02100922}, {3.09985637,2.22825976}, {3.22177695,1.60368348}},
2930 {{3.22177695,1.60368348}, {3.35239933,0.944897345}, {3.25461667,0.846601983}},
2931 {{3.25461667,0.846601983}, {3.19302952,0.807536747}, {3,1}},
2932</div>
2933
2934<div id="cubicOp54db">
2935 {{3.39068129,4.44939202}, {3.03659239,3.81843234}, {3.06844529,3.02100922}},
2936 {{2.10714698,3.44196686}, {3.12180288,3.38575704}, {3.75968569,3.1281838}},
2937</div>
2938
2939<div id="cubicOp54dc">
2940(gdb) p cSub1
2941$2 = {{x = 3.0774019473063863, y = 3.35198509346713}, {x = 3.0763003260366699, y = 3.3355427495692078}, {x = 3.0753041923884408, y = 3.3190757607779853}, {x = 3.0744102085015879, y = 3.3025879417907196}}
2942(gdb) p cSub2
2943$3 = {{x = 3.053913680774329, y = 3.3310471586283938}, {x = 3.0685526504546785, y = 3.3285797268698434}, {x = 3.0831050944309708, y = 3.3260658459407866}, {x = 3.0975671980059394, y = 3.3235031316554351}}
2944(gdb) p s1
2945$4 = {{x = 3.0774019473063863, y = 3.35198509346713}, {x = 3.0757503498668397, y = 3.327320623945933}, {x = 3.0744102085015879, y = 3.3025879417907196}}
2946(gdb) p s2
2947$5 = {{x = 3.053913680774329, y = 3.3310471586283938}, {x = 3.0758730889691694, y = 3.3273466070370152}, {x = 3.0975671980059394, y = 3.3235031316554351}}
2948</div>
2949
2950<div id="cubicOp54dd">
2951{{x = 3.053913680774329, y = 3.3310471586283938}, {x = 3.0758730889691694, y = 3.3273466070370152}, {x = 3.0975671980059394, y = 3.3235031316554351}}
2952{{x = 3.0744102085015879, y = 3.3025879417907196}, {x = 3.0774019473063863, y = 3.35198509346713}}
2953</div>
2954
2955<div id="cubicOp55d">
2956 SimplifyNew_Test [cubicOp55d]
2957{{0,5}, {1,3}, {3,2}, {5,0}},
2958{{5,0}, {0,5}},
2959op difference
2960{{2,3}, {0,5}, {5,0}, {3,1}},
2961{{3,1}, {2,3}},
2962debugShowCubicIntersection no self intersect {{0,5}, {1,3}, {3,2}, {5,0}}
2963debugShowCubicLineIntersection wtTs[0]=0 {{0,5}, {1,3}, {3,2}, {5,0}} {{0,5}} wtTs[1]=1 {{5,0}} wnTs[0]=1 {{5,0}, {0,5}} wnTs[1]=0
2964debugShowCubicIntersection wtTs[0]=0.658239823 {{0,5}, {1,3}, {3,2}, {5,0}} {{2.9893565350663849,1.7799961946192431}} wnTs[0]=0.613267 {{2,3}, {0,5}, {5,0}, {3,1}}
2965debugShowCubicLineIntersection wtTs[0]=0.540876747 {{0,5}, {1,3}, {3,2}, {5,0}} {{2.3420409812806477,2.3159180374387045}} wnTs[0]=0.657959 {{3,1}, {2,3}}
2966debugShowCubicLineIntersection wtTs[0]=0 {{2,3}, {0,5}, {5,0}, {3,1}} {{2,3}} wnTs[0]=0.6 {{5,0}, {0,5}}
2967debugShowLineIntersection wtTs[0]=0.6 {{5,0}, {0,5}} {{2,3}} wnTs[0]=1 {{3,1}, {2,3}}
2968debugShowCubicIntersection no self intersect {{2,3}, {0,5}, {5,0}, {3,1}}
2969debugShowCubicLineIntersection wtTs[0]=0 {{2,3}, {0,5}, {5,0}, {3,1}} {{2,3}} wtTs[1]=0.4 {{2.0640000000000005,2.871999999999999}} wtTs[2]=1 {{3,1}} wnTs[0]=1 {{3,1}, {2,3}} wnTs[1]=0.936 wnTs[2]=0
2970debugShowActiveSpans id=1 (0,5 1,3 3,2 5,0) t=0 (0,5) tEnd=0.540876747 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2971debugShowActiveSpans id=1 (0,5 1,3 3,2 5,0) t=0.540876747 (2.34204102,2.31591797) tEnd=0.658239823 other=4 otherT=0.657959019 otherIndex=1 windSum=? windValue=1 oppValue=0
2972debugShowActiveSpans id=1 (0,5 1,3 3,2 5,0) t=0.658239823 (2.98935652,1.77999616) tEnd=1 other=3 otherT=0.613266786 otherIndex=3 windSum=? windValue=1 oppValue=0
2973debugShowActiveSpans id=2 (5,0 0,5) t=0 (5,0) tEnd=0.6 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2974debugShowActiveSpans id=2 (5,0 0,5) t=0.6 (2,3) tEnd=1 other=3 otherT=0 otherIndex=0 windSum=? windValue=1 oppValue=0
2975debugShowActiveSpans id=2 (5,0 0,5) t=0.6 (2,3) tEnd=1 other=4 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
2976debugShowActiveSpans id=3 (2,3 0,5 5,0 3,1) t=0 (2,3) tEnd=0.4 other=2 otherT=0.6 otherIndex=1 windSum=? windValue=1 oppValue=0
2977debugShowActiveSpans id=3 (2,3 0,5 5,0 3,1) t=0 (2,3) tEnd=0.4 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2978debugShowActiveSpans id=3 (2,3 0,5 5,0 3,1) t=0.4 (2.06399989,2.87199998) tEnd=0.613266786 other=4 otherT=0.936 otherIndex=2 windSum=? windValue=1 oppValue=0
2979debugShowActiveSpans id=3 (2,3 0,5 5,0 3,1) t=0.613266786 (2.98935652,1.77999616) tEnd=1 other=1 otherT=0.658239823 otherIndex=2 windSum=? windValue=1 oppValue=0
2980debugShowActiveSpans id=4 (3,1 2,3) t=0 (3,1) tEnd=0.657959019 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
2981debugShowActiveSpans id=4 (3,1 2,3) t=0.657959019 (2.34204102,2.31591797) tEnd=0.936 other=1 otherT=0.540876747 otherIndex=1 windSum=? windValue=1 oppValue=0
2982debugShowActiveSpans id=4 (3,1 2,3) t=0.936 (2.06399989,2.87199998) tEnd=1 other=3 otherT=0.4 otherIndex=2 windSum=? windValue=1 oppValue=0
2983findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
2984debugShowSort [0] {{0,5}, {1,3}, {3,2}, {5,0}} tStart=1 tEnd=0.658239823 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
2985debugShowSort [1] {{5,0}, {0,5}} tStart=0 tEnd=0.6 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
2986findTop swap serpentine=0
2987markWinding id=1 (0,5 1,3 3,2 5,0) t=0.658239823 [2] (2.98935652,1.77999616) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2988markWinding id=1 (0,5 1,3 3,2 5,0) t=0.658239823 [2] (2.98935652,1.77999616) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
2989markWinding id=2 (5,0 0,5) t=0 [0] (5,0) tEnd=0.6 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
2990activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
2991findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
2992debugShowSort [0] {{0,5}, {1,3}, {3,2}, {5,0}} tStart=0.658239823 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
2993debugShowSort [1] {{2,3}, {0,5}, {5,0}, {3,1}} tStart=0.613266786 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
2994debugShowSort [2] {{0,5}, {1,3}, {3,2}, {5,0}} tStart=0.658239823 tEnd=0.540876747 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
2995debugShowSort [3] {{2,3}, {0,5}, {5,0}, {3,1}} tStart=0.613266786 tEnd=0.4 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
2996findNextOp firstIndex=[0] sign=-1
2997activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
2998markWinding id=3 (2,3 0,5 5,0 3,1) t=0.613266786 [3] (2.98935652,1.77999616) tEnd=1 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
2999markWinding id=4 (3,1 2,3) t=0 [0] (3,1) tEnd=0.657959019 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
3000findNextOp chase.append id=4
3001activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
3002markDoneBinary id=1 (0,5 1,3 3,2 5,0) t=0.540876747 [1] (2.34204102,2.31591797) tEnd=0.658239823 newWindSum=1 newOppSum=1 oppSum=? windSum=? windValue=1
3003findNextOp chase.append id=1
3004activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
3005markDoneBinary id=3 (2,3 0,5 5,0 3,1) t=0.4 [2] (2.06399989,2.87199998) tEnd=0.613266786 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3006findNextOp chase.append id=3
3007markDoneBinary id=1 (0,5 1,3 3,2 5,0) t=0.658239823 [2] (2.98935652,1.77999616) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3008findNextOp from:[1] to:[3] start=3 end=4
3009bridgeOp current id=1 from=(5,0) to=(2.98935652,1.77999616)
3010path.moveTo(5,0);
3011path.cubicTo(4.31647968,0.683520317, 3.63295937,1.25024068, 2.98935652,1.77999616);
3012findNextOp simple
3013markDoneBinary id=3 (2,3 0,5 5,0 3,1) t=0.613266786 [3] (2.98935652,1.77999616) tEnd=1 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
3014bridgeOp current id=3 from=(2.98935652,1.77999616) to=(3,1)
3015path.cubicTo(3.49999475,1.123909, 3.77346635,0.613266766, 3,1);
3016findNextOp debugShowSort contourWinding=1 oppContourWinding=1 sign=1
3017debugShowSort [1] {{3,1}, {2,3}} tStart=0.657959019 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
3018debugShowSort [2] {{0,5}, {1,3}, {3,2}, {5,0}} tStart=0.540876747 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
3019debugShowSort [3] {{3,1}, {2,3}} tStart=0.657959019 tEnd=0.936 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
3020debugShowSort [0] {{0,5}, {1,3}, {3,2}, {5,0}} tStart=0.540876747 tEnd=0.658239823 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
3021findNextOp firstIndex=[1] sign=1
3022activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
3023markWinding id=1 (0,5 1,3 3,2 5,0) t=0 [0] (0,5) tEnd=0.540876747 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3024markWinding id=2 (5,0 0,5) t=0.6 [1] (2,3) tEnd=0.6 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3025markWinding id=2 (5,0 0,5) t=0.6 [2] (2,3) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3026findNextOp chase.append id=2
3027activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
3028markDoneBinary id=4 (3,1 2,3) t=0.657959019 [1] (2.34204102,2.31591797) tEnd=0.936 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3029findNextOp chase.append id=4
3030activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3031markDoneBinary id=4 (3,1 2,3) t=0 [0] (3,1) tEnd=0.657959019 newWindSum=1 newOppSum=1 oppSum=1 windSum=1 windValue=1
3032findNextOp from:[4] to:[1] start=1 end=0
3033bridgeOp current id=4 from=(3,1) to=(2.34204102,2.31591797)
3034findNextOp simple
3035markDoneBinary id=1 (0,5 1,3 3,2 5,0) t=0 [0] (0,5) tEnd=0.540876747 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3036bridgeOp current id=1 from=(2.34204102,2.31591797) to=(0,5)
3037path.lineTo(2.34204102,2.31591797);
3038path.cubicTo(1.37430108,3.12904072, 0.540876746,3.91824651, 0,5);
3039findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
3040debugShowSort [3] {{5,0}, {0,5}} tStart=0.6 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
3041debugShowSort [0] {{5,0}, {0,5}} tStart=0.6 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
3042debugShowSort [1] {{3,1}, {2,3}} tStart=1 tEnd=0.936 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
3043debugShowSort [2] {{2,3}, {0,5}, {5,0}, {3,1}} tStart=0 tEnd=0.4 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
3044findNextOp firstIndex=[3] sign=-1
3045activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
3046activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
3047markDoneBinary id=4 (3,1 2,3) t=0.936 [2] (2.06399989,2.87199998) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3048findNextOp chase.append id=4
3049activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
3050markDoneBinary id=3 (2,3 0,5 5,0 3,1) t=0 [0] (2,3) tEnd=0 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3051markDoneBinary id=3 (2,3 0,5 5,0 3,1) t=0 [1] (2,3) tEnd=0.4 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3052findNextOp chase.append id=3
3053markDoneBinary id=2 (5,0 0,5) t=0.6 [1] (2,3) tEnd=0.6 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3054markDoneBinary id=2 (5,0 0,5) t=0.6 [2] (2,3) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3055findNextOp from:[2] to:[2] start=2 end=0
3056bridgeOp current id=2 from=(0,5) to=(2,3)
3057findNextOp simple
3058markDoneBinary id=2 (5,0 0,5) t=0 [0] (5,0) tEnd=0.6 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3059bridgeOp current id=2 from=(2,3) to=(5,0)
3060path.lineTo(5,0);
3061path.close();
3062assemble
3063assemble contour start=(5,0) end=(5,0)
3064</div>
3065
3066<div id="cubicOp55da">
3067$1 = {{x = 2.9893565350663844, y = 1.7799961946192431}, {x = 3.6329592934456443, y = 1.250240688218315}, {x = 4.3164796467228257, y = 0.68352035327717708}, {x = 5, y = 0}}
3068</div>
3069
3070<div id="cubicOp56da">
3071$3 = {{x = 3.2077595567431376, y = 1.2121007383531144}, {x = 3.0712003892698903, y = 0.91360430885366861}, {x = 2.6980028578011237, y = 0.76733238073295829}, {x = 2, y = 1}}
3072</div>
3073
3074<div id="cubicOp57da">
3075computed quadratics given
3076 {{0,5}, {0,5}, {5,4}, {6,4}},
3077 {{4,5}, {4,6}, {5,0}, {5,0}},
3078computed quadratics set 1
3079 {{0,5}, {0.0833333333,4.98148148}, {1.33333333,4.74074074}},
3080 {{1.33333333,4.74074074}, {2.58333333,4.5}, {4,4.25925926}},
3081 {{4,4.25925926}, {5.41666667,4.01851852}, {6,4}},
3082computed quadratics set 2
3083 {{4,5}, {4.0078125,5.32421875}, {4.15625,4.640625}},
3084 {{4.15625,4.640625}, {4.3046875,3.95703125}, {4.5,2.875}},
3085 {{4.5,2.875}, {4.6953125,1.79296875}, {4.84375,0.921875}},
3086 {{4.84375,0.921875}, {4.9921875,0.05078125}, {5,0}},
3087</div>
3088
3089<div id="cubicOp58d">
3090 SimplifyNew_Test [cubicOp58d]
3091{{0,5}, {3,4}, {6,5}, {5,3}},
3092{{5,3}, {0,5}},
3093op difference
3094{{5,6}, {3,5}, {5,0}, {4,3}},
3095{{4,3}, {5,6}},
3096debugShowCubicIntersection no self intersect {{5,6}, {3,5}, {5,0}, {4,3}}
3097debugShowCubicLineIntersection wtTs[0]=0 {{5,6}, {3,5}, {5,0}, {4,3}} {{5,6}} wtTs[1]=0.454545455 {{4.0946656649135988,3.2839969947407956}} wtTs[2]=1 {{4,3}} wnTs[0]=1 {{4,3}, {5,6}} wnTs[1]=0.0946656649 wnTs[2]=0
3098debugShowCubicIntersection wtTs[0]=0.297296392 {{5,6}, {3,5}, {5,0}, {4,3}} {{4.0929072920341625,4.362808103638363}} wnTs[0]=0.515735 {{0,5}, {3,4}, {6,5}, {5,3}}
3099debugShowCubicLineIntersection wtTs[0]=0.442158094 {{5,6}, {3,5}, {5,0}, {4,3}} {{4.0879917456946373,3.3648033017221453}} wnTs[0]=0.182402 {{5,3}, {0,5}}
3100debugShowCubicLineIntersection wtTs[0]=0.579011103 {{0,5}, {3,4}, {6,5}, {5,3}} {{4.4346371023199076,4.3039113069597246}} wnTs[0]=0.434637 {{4,3}, {5,6}}
3101debugShowLineIntersection wtTs[0]=0.117647059 {{4,3}, {5,6}} {{4.117647058823529,3.3529411764705879}} wnTs[0]=0.176471 {{5,3}, {0,5}}
3102debugShowCubicIntersection no self intersect {{0,5}, {3,4}, {6,5}, {5,3}}
3103debugShowCubicLineIntersection wtTs[0]=0 {{0,5}, {3,4}, {6,5}, {5,3}} {{0,5}} wtTs[1]=1 {{5,3}} wnTs[0]=1 {{5,3}, {0,5}} wnTs[1]=0
3104debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3105debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.297296392 (4.09290743,4.36280823) tEnd=0.442158094 other=1 otherT=0.515734731 otherIndex=1 windSum=? windValue=1 oppValue=0
3106debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.442158094 (4.08799171,3.36480331) tEnd=0.454545455 other=2 otherT=0.182401651 otherIndex=2 windSum=? windValue=1 oppValue=0
3107debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.454545455 (4.09466553,3.28399706) tEnd=1 other=4 otherT=0.0946656649 otherIndex=1 windSum=? windValue=1 oppValue=0
3108debugShowActiveSpans id=4 (4,3 5,6) t=0 (4,3) tEnd=0.0946656649 other=3 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3109debugShowActiveSpans id=4 (4,3 5,6) t=0.0946656649 (4.09466553,3.28399706) tEnd=0.117647059 other=3 otherT=0.454545455 otherIndex=3 windSum=? windValue=1 oppValue=0
3110debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3111debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=? windValue=1 oppValue=0
3112debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0 (0,5) tEnd=0.515734731 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3113debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=? windValue=1 oppValue=0
3114debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3115debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3116debugShowActiveSpans id=2 (5,3 0,5) t=0.176470588 (4.11764717,3.35294127) tEnd=0.182401651 other=4 otherT=0.117647059 otherIndex=2 windSum=? windValue=1 oppValue=0
3117debugShowActiveSpans id=2 (5,3 0,5) t=0.182401651 (4.08799171,3.36480331) tEnd=1 other=3 otherT=0.442158094 otherIndex=2 windSum=? windValue=1 oppValue=0
3118findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
3119debugShowSort [0] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=1 tEnd=0.454545455 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
3120debugShowSort [1] {{4,3}, {5,6}} tStart=0 tEnd=0.0946656649 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
3121markWinding id=3 (5,6 3,5 5,0 4,3) t=0.454545455 [3] (4.09466553,3.28399706) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3122markWinding id=4 (4,3 5,6) t=0 [0] (4,3) tEnd=0.0946656649 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3123markWinding id=3 (5,6 3,5 5,0 4,3) t=0.454545455 [3] (4.09466553,3.28399706) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3124activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
3125markDoneBinary id=3 (5,6 3,5 5,0 4,3) t=0.454545455 [3] (4.09466553,3.28399706) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3126markDoneBinary id=4 (4,3 5,6) t=0 [0] (4,3) tEnd=0.0946656649 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3127findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
3128debugShowSort [0] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.454545455 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
3129debugShowSort [1] {{4,3}, {5,6}} tStart=0.0946656649 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
3130debugShowSort [2] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.454545455 tEnd=0.442158094 sign=1 windValue=1 windSum=? -1->-2 (max=-2) done=0 tiny=0 opp=0
3131debugShowSort [3] {{4,3}, {5,6}} tStart=0.0946656649 tEnd=0.117647059 sign=-1 windValue=1 windSum=? -2->-1 (max=-2) done=0 tiny=0 opp=0
3132findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
3133debugShowSort [0] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.454545455 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
3134debugShowSort [1] {{4,3}, {5,6}} tStart=0.0946656649 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
3135debugShowSort [2] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.454545455 tEnd=0.442158094 sign=1 windValue=1 windSum=? -1->-2 (max=-2) done=0 tiny=0 opp=0
3136debugShowSort [3] {{4,3}, {5,6}} tStart=0.0946656649 tEnd=0.117647059 sign=-1 windValue=1 windSum=? -2->-1 (max=-2) done=0 tiny=0 opp=0
3137markWinding id=3 (5,6 3,5 5,0 4,3) t=0.442158094 [2] (4.08799171,3.36480331) tEnd=0.454545455 newWindSum=-2 newOppSum=0 oppSum=? windSum=? windValue=1
3138markWinding id=4 (4,3 5,6) t=0.0946656649 [1] (4.09466553,3.28399706) tEnd=0.117647059 newWindSum=-2 newOppSum=0 oppSum=? windSum=? windValue=1
3139debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3140debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.297296392 (4.09290743,4.36280823) tEnd=0.442158094 other=1 otherT=0.515734731 otherIndex=1 windSum=? windValue=1 oppValue=0
3141debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.442158094 (4.08799171,3.36480331) tEnd=0.454545455 other=2 otherT=0.182401651 otherIndex=2 windSum=-2 windValue=1 oppValue=0
3142debugShowActiveSpans id=4 (4,3 5,6) t=0.0946656649 (4.09466553,3.28399706) tEnd=0.117647059 other=3 otherT=0.454545455 otherIndex=3 windSum=-2 windValue=1 oppValue=0
3143debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3144debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=? windValue=1 oppValue=0
3145debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0 (0,5) tEnd=0.515734731 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3146debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=? windValue=1 oppValue=0
3147debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3148debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3149debugShowActiveSpans id=2 (5,3 0,5) t=0.176470588 (4.11764717,3.35294127) tEnd=0.182401651 other=4 otherT=0.117647059 otherIndex=2 windSum=? windValue=1 oppValue=0
3150debugShowActiveSpans id=2 (5,3 0,5) t=0.182401651 (4.08799171,3.36480331) tEnd=1 other=3 otherT=0.442158094 otherIndex=2 windSum=? windValue=1 oppValue=0
3151activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=1 result=0
3152markDoneBinary id=3 (5,6 3,5 5,0 4,3) t=0.442158094 [2] (4.08799171,3.36480331) tEnd=0.454545455 newWindSum=-2 newOppSum=0 oppSum=0 windSum=-2 windValue=1
3153findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
3154debugShowSort [0] {{5,3}, {0,5}} tStart=0.182401651 tEnd=0.176470588 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3155debugShowSort [1] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.442158094 tEnd=0.454545455 sign=-1 windValue=1 windSum=-2 ?->? (max=?) done=1 tiny=0 opp=1
3156debugShowSort [2] {{5,3}, {0,5}} tStart=0.182401651 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3157debugShowSort [3] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.442158094 tEnd=0.297296392 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
3158findChaseOp debugShowSort contourWinding=-2 oppContourWinding=0 sign=-1
3159debugShowSort [1] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.442158094 tEnd=0.454545455 sign=-1 windValue=1 windSum=-2 -2->-1 (max=-2) done=1 tiny=0 opp=0
3160debugShowSort [2] {{5,3}, {0,5}} tStart=0.182401651 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
3161debugShowSort [3] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.442158094 tEnd=0.297296392 sign=1 windValue=1 windSum=? -1->-2 (max=-2) done=0 tiny=0 opp=0
3162debugShowSort [0] {{5,3}, {0,5}} tStart=0.182401651 tEnd=0.176470588 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
3163markWinding id=2 (5,3 0,5) t=0.182401651 [2] (4.08799171,3.36480331) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3164markWinding id=1 (0,5 3,4 6,5 5,3) t=0 [0] (0,5) tEnd=0.515734731 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3165markWinding id=3 (5,6 3,5 5,0 4,3) t=0.297296392 [1] (4.09290743,4.36280823) tEnd=0.442158094 newWindSum=-2 newOppSum=1 oppSum=? windSum=? windValue=1
3166markWinding id=2 (5,3 0,5) t=0.176470588 [1] (4.11764717,3.35294127) tEnd=0.182401651 newWindSum=1 newOppSum=-2 oppSum=? windSum=? windValue=1
3167debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3168debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.297296392 (4.09290743,4.36280823) tEnd=0.442158094 other=1 otherT=0.515734731 otherIndex=1 windSum=-2 windValue=1 oppValue=0
3169debugShowActiveSpans id=4 (4,3 5,6) t=0.0946656649 (4.09466553,3.28399706) tEnd=0.117647059 other=3 otherT=0.454545455 otherIndex=3 windSum=-2 windValue=1 oppValue=0
3170debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3171debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=? windValue=1 oppValue=0
3172debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0 (0,5) tEnd=0.515734731 other=2 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
3173debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=? windValue=1 oppValue=0
3174debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3175debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3176debugShowActiveSpans id=2 (5,3 0,5) t=0.176470588 (4.11764717,3.35294127) tEnd=0.182401651 other=4 otherT=0.117647059 otherIndex=2 windSum=1 windValue=1 oppValue=0
3177debugShowActiveSpans id=2 (5,3 0,5) t=0.182401651 (4.08799171,3.36480331) tEnd=1 other=3 otherT=0.442158094 otherIndex=2 windSum=1 windValue=1 oppValue=0
3178activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3179markDoneBinary id=2 (5,3 0,5) t=0.182401651 [2] (4.08799171,3.36480331) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
3180markDoneBinary id=1 (0,5 3,4 6,5 5,3) t=0 [0] (0,5) tEnd=0.515734731 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
3181debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3182debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0.297296392 (4.09290743,4.36280823) tEnd=0.442158094 other=1 otherT=0.515734731 otherIndex=1 windSum=-2 windValue=1 oppValue=0
3183debugShowActiveSpans id=4 (4,3 5,6) t=0.0946656649 (4.09466553,3.28399706) tEnd=0.117647059 other=3 otherT=0.454545455 otherIndex=3 windSum=-2 windValue=1 oppValue=0
3184debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3185debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=? windValue=1 oppValue=0
3186debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=? windValue=1 oppValue=0
3187debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3188debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3189debugShowActiveSpans id=2 (5,3 0,5) t=0.176470588 (4.11764717,3.35294127) tEnd=0.182401651 other=4 otherT=0.117647059 otherIndex=2 windSum=1 windValue=1 oppValue=0
3190activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
3191markDoneBinary id=3 (5,6 3,5 5,0 4,3) t=0.297296392 [1] (4.09290743,4.36280823) tEnd=0.442158094 newWindSum=-2 newOppSum=1 oppSum=1 windSum=-2 windValue=1
3192debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3193debugShowActiveSpans id=4 (4,3 5,6) t=0.0946656649 (4.09466553,3.28399706) tEnd=0.117647059 other=3 otherT=0.454545455 otherIndex=3 windSum=-2 windValue=1 oppValue=0
3194debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3195debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=? windValue=1 oppValue=0
3196debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=? windValue=1 oppValue=0
3197debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3198debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3199debugShowActiveSpans id=2 (5,3 0,5) t=0.176470588 (4.11764717,3.35294127) tEnd=0.182401651 other=4 otherT=0.117647059 otherIndex=2 windSum=1 windValue=1 oppValue=0
3200activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
3201markDoneBinary id=2 (5,3 0,5) t=0.176470588 [1] (4.11764717,3.35294127) tEnd=0.182401651 newWindSum=1 newOppSum=-2 oppSum=-2 windSum=1 windValue=1
3202debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3203debugShowActiveSpans id=4 (4,3 5,6) t=0.0946656649 (4.09466553,3.28399706) tEnd=0.117647059 other=3 otherT=0.454545455 otherIndex=3 windSum=-2 windValue=1 oppValue=0
3204debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3205debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=? windValue=1 oppValue=0
3206debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=? windValue=1 oppValue=0
3207debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3208debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3209activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=1 result=0
3210markDoneBinary id=4 (4,3 5,6) t=0.0946656649 [1] (4.09466553,3.28399706) tEnd=0.117647059 newWindSum=-2 newOppSum=0 oppSum=0 windSum=-2 windValue=1
3211findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=-1
3212debugShowSort [0] {{0,5}, {3,4}, {6,5}, {5,3}} tStart=0.515734731 tEnd=0.579011103 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3213debugShowSort [1] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.297296392 tEnd=0.442158094 sign=-1 windValue=1 windSum=-2 ?->? (max=?) done=1 tiny=0 opp=1
3214debugShowSort [2] {{0,5}, {3,4}, {6,5}, {5,3}} tStart=0.515734731 tEnd=0 sign=1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=0
3215debugShowSort [3] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.297296392 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
3216findChaseOp debugShowSort contourWinding=-2 oppContourWinding=1 sign=-1
3217debugShowSort [1] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.297296392 tEnd=0.442158094 sign=-1 windValue=1 windSum=-2 -2->-1 (max=-2) done=1 tiny=0 opp=0
3218debugShowSort [2] {{0,5}, {3,4}, {6,5}, {5,3}} tStart=0.515734731 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
3219debugShowSort [3] {{5,6}, {3,5}, {5,0}, {4,3}} tStart=0.297296392 tEnd=0 sign=1 windValue=1 windSum=? -1->-2 (max=-2) done=0 tiny=0 opp=0
3220debugShowSort [0] {{0,5}, {3,4}, {6,5}, {5,3}} tStart=0.515734731 tEnd=0.579011103 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
3221markWinding id=3 (5,6 3,5 5,0 4,3) t=0 [0] (5,6) tEnd=0.297296392 newWindSum=-2 newOppSum=0 oppSum=? windSum=? windValue=1
3222markWinding id=4 (4,3 5,6) t=0.434637102 [3] (4.43463707,4.30391121) tEnd=1 newWindSum=-2 newOppSum=0 oppSum=? windSum=? windValue=1
3223markWinding id=1 (0,5 3,4 6,5 5,3) t=0.515734731 [1] (4.09290743,4.36280823) tEnd=0.579011103 newWindSum=1 newOppSum=-2 oppSum=? windSum=? windValue=1
3224debugShowActiveSpans id=3 (5,6 3,5 5,0 4,3) t=0 (5,6) tEnd=0.297296392 other=4 otherT=1 otherIndex=4 windSum=-2 windValue=1 oppValue=0
3225debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3226debugShowActiveSpans id=4 (4,3 5,6) t=0.434637102 (4.43463707,4.30391121) tEnd=1 other=1 otherT=0.579011103 otherIndex=2 windSum=-2 windValue=1 oppValue=0
3227debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=1 windValue=1 oppValue=0
3228debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3229debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3230activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=1 result=0
3231markDoneBinary id=3 (5,6 3,5 5,0 4,3) t=0 [0] (5,6) tEnd=0.297296392 newWindSum=-2 newOppSum=0 oppSum=0 windSum=-2 windValue=1
3232markDoneBinary id=4 (4,3 5,6) t=0.434637102 [3] (4.43463707,4.30391121) tEnd=1 newWindSum=-2 newOppSum=0 oppSum=0 windSum=-2 windValue=1
3233debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=? windValue=1 oppValue=0
3234debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.515734731 (4.09290743,4.36280823) tEnd=0.579011103 other=3 otherT=0.297296392 otherIndex=1 windSum=1 windValue=1 oppValue=0
3235debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=? windValue=1 oppValue=0
3236debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3237activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
3238markDoneBinary id=1 (0,5 3,4 6,5 5,3) t=0.515734731 [1] (4.09290743,4.36280823) tEnd=0.579011103 newWindSum=1 newOppSum=-2 oppSum=-2 windSum=1 windValue=1
3239findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
3240debugShowSort [0] {{5,3}, {0,5}} tStart=0.176470588 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3241debugShowSort [1] {{4,3}, {5,6}} tStart=0.117647059 tEnd=0.0946656649 sign=1 windValue=1 windSum=-2 ?->? (max=?) done=1 tiny=0 opp=1
3242debugShowSort [2] {{5,3}, {0,5}} tStart=0.176470588 tEnd=0.182401651 sign=-1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=0
3243debugShowSort [3] {{4,3}, {5,6}} tStart=0.117647059 tEnd=0.434637102 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
3244findChaseOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=1
3245debugShowSort [1] {{4,3}, {5,6}} tStart=0.117647059 tEnd=0.0946656649 sign=1 windValue=1 windSum=-2 -1->-2 (max=-2) done=1 tiny=0 opp=0
3246debugShowSort [2] {{5,3}, {0,5}} tStart=0.176470588 tEnd=0.182401651 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=1
3247debugShowSort [3] {{4,3}, {5,6}} tStart=0.117647059 tEnd=0.434637102 sign=-1 windValue=1 windSum=? -2->-1 (max=-2) done=0 tiny=0 opp=0
3248debugShowSort [0] {{5,3}, {0,5}} tStart=0.176470588 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
3249markWinding id=4 (4,3 5,6) t=0.117647059 [2] (4.11764717,3.35294127) tEnd=0.434637102 newWindSum=-2 newOppSum=1 oppSum=? windSum=? windValue=1
3250markWinding id=2 (5,3 0,5) t=0 [0] (5,3) tEnd=0.176470588 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3251markWinding id=1 (0,5 3,4 6,5 5,3) t=0.579011103 [2] (4.43463707,4.30391121) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3252debugShowActiveSpans id=4 (4,3 5,6) t=0.117647059 (4.11764717,3.35294127) tEnd=0.434637102 other=2 otherT=0.176470588 otherIndex=1 windSum=-2 windValue=1 oppValue=0
3253debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=1 windValue=1 oppValue=0
3254debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
3255activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=1 result=0
3256markDoneBinary id=4 (4,3 5,6) t=0.117647059 [2] (4.11764717,3.35294127) tEnd=0.434637102 newWindSum=-2 newOppSum=1 oppSum=1 windSum=-2 windValue=1
3257debugShowActiveSpans id=1 (0,5 3,4 6,5 5,3) t=0.579011103 (4.43463707,4.30391121) tEnd=1 other=4 otherT=0.434637102 otherIndex=3 windSum=1 windValue=1 oppValue=0
3258debugShowActiveSpans id=2 (5,3 0,5) t=0 (5,3) tEnd=0.176470588 other=1 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
3259activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3260markDoneBinary id=1 (0,5 3,4 6,5 5,3) t=0.579011103 [2] (4.43463707,4.30391121) tEnd=1 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
3261markDoneBinary id=2 (5,3 0,5) t=0 [0] (5,3) tEnd=0.176470588 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
3262assemble
3263</div>
3264
3265<div id="cubicOp58da">
3266$1 = {{fX = 4.09466553, fY = 3.28399706}, {fX = 4.19834709, fY = 2.10743785}, {fX = 4.5454545, fY = 1.36363637}, {fX = 4, fY = 3}}
3267</div>
3268
3269<div id="cubicOp61d">
3270 SimplifyNew_Test [cubicOp61d]
3271{{1,2}, {0,5}, {3,2}, {6,1}},
3272{{6,1}, {1,2}},
3273op difference
3274{{2,3}, {1,6}, {2,1}, {5,0}},
3275{{5,0}, {2,3}},
3276debugShowCubicIntersection wtTs[0]=0 {{2,3}, {1,6}, {2,1}, {5,0}} {{2,3}} wtTs[1]=0.5
3277debugShowCubicLineIntersection wtTs[0]=0 {{2,3}, {1,6}, {2,1}, {5,0}} {{2,3}} wtTs[1]=0.5 {{2,3}} wtTs[2]=1 {{5,0}} wnTs[0]=1 {{5,0}, {2,3}} wnTs[1]=1 wnTs[2]=0
3278debugShowCubicIntersection wtTs[0]=0 {{2,3}, {1,6}, {2,1}, {5,0}} {{2,3}} wtTs[1]=0.5 {{2.0000000000728706,2.9999999998542584}} wnTs[0]=0.5 {{1,2}, {0,5}, {3,2}, {6,1}} wnTs[1]=0.500000029
3279debugShowCubicLineIntersection wtTs[0]=0.704088595 {{2,3}, {1,6}, {2,1}, {5,0}} {{2.8621787139852466,1.6275642572029505}} wnTs[0]=0.627564 {{6,1}, {1,2}}
3280debugShowCubicLineIntersection wtTs[0]=0.5 {{1,2}, {0,5}, {3,2}, {6,1}} {{2,3}} wnTs[0]=1 {{5,0}, {2,3}}
3281debugShowLineIntersection wtTs[0]=0.5 {{5,0}, {2,3}} {{3.5,1.5}} wnTs[0]=0.5 {{6,1}, {1,2}}
3282debugShowCubicIntersection no self intersect {{1,2}, {0,5}, {3,2}, {6,1}}
3283debugShowCubicLineIntersection wtTs[0]=0 {{1,2}, {0,5}, {3,2}, {6,1}} {{1,2}} wtTs[1]=1 {{6,1}} wnTs[0]=1 {{6,1}, {1,2}} wnTs[1]=0
3284debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3285debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3286debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3287debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0.5 (2,3) tEnd=0.704088595 other=1 otherT=0.500000029 otherIndex=3 windSum=? windValue=1 oppValue=0
3288debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0.704088595 (2.8621788,1.62756431) tEnd=1 other=2 otherT=0.627564257 otherIndex=2 windSum=? windValue=1 oppValue=0
3289debugShowActiveSpans id=4 (5,0 2,3) t=0 (5,0) tEnd=0.5 other=3 otherT=1 otherIndex=7 windSum=? windValue=1 oppValue=0
3290debugShowActiveSpans id=4 (5,0 2,3) t=0.5 (3.5,1.5) tEnd=1 other=2 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3291debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0 (1,2) tEnd=0.5 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3292debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0.500000029 (2,3) tEnd=1 other=3 otherT=0.5 otherIndex=5 windSum=? windValue=1 oppValue=0
3293debugShowActiveSpans id=2 (6,1 1,2) t=0 (6,1) tEnd=0.5 other=1 otherT=1 otherIndex=4 windSum=? windValue=1 oppValue=0
3294debugShowActiveSpans id=2 (6,1 1,2) t=0.5 (3.5,1.5) tEnd=0.627564257 other=4 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3295debugShowActiveSpans id=2 (6,1 1,2) t=0.627564257 (2.8621788,1.62756431) tEnd=1 other=3 otherT=0.704088595 otherIndex=6 windSum=? windValue=1 oppValue=0
3296(gdb) continue
3297findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=1
3298debugShowSort [0] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=1 tEnd=0.704088595 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
3299debugShowSort [1] {{5,0}, {2,3}} tStart=0 tEnd=0.5 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
3300markWinding id=3 (2,3 1,6 2,1 5,0) t=0.704088595 [6] (2.8621788,1.62756431) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3301markWinding id=4 (5,0 2,3) t=0 [0] (5,0) tEnd=0.5 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3302markWinding id=3 (2,3 1,6 2,1 5,0) t=0.704088595 [6] (2.8621788,1.62756431) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3303activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
3304markDoneBinary id=3 (2,3 1,6 2,1 5,0) t=0.704088595 [6] (2.8621788,1.62756431) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3305markDoneBinary id=4 (5,0 2,3) t=0 [0] (5,0) tEnd=0.5 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3306findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
3307debugShowSort [0] {{6,1}, {1,2}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3308debugShowSort [1] {{5,0}, {2,3}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
3309debugShowSort [2] {{6,1}, {1,2}} tStart=0.5 tEnd=0.627564257 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3310debugShowSort [3] {{5,0}, {2,3}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
3311findChaseOp debugShowSort contourWinding=0 oppContourWinding=0 sign=1
3312debugShowSort [1] {{5,0}, {2,3}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
3313debugShowSort [2] {{6,1}, {1,2}} tStart=0.5 tEnd=0.627564257 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
3314debugShowSort [3] {{5,0}, {2,3}} tStart=0.5 tEnd=1 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
3315debugShowSort [0] {{6,1}, {1,2}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
3316markWinding id=2 (6,1 1,2) t=0.5 [1] (3.5,1.5) tEnd=0.627564257 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3317markWinding id=4 (5,0 2,3) t=0.5 [1] (3.5,1.5) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
3318markWinding id=2 (6,1 1,2) t=0 [0] (6,1) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3319markWinding id=1 (1,2 0,5 3,2 6,1) t=0.500000029 [3] (2,3) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3320debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3321debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3322debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3323debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0.5 (2,3) tEnd=0.704088595 other=1 otherT=0.500000029 otherIndex=3 windSum=? windValue=1 oppValue=0
3324debugShowActiveSpans id=4 (5,0 2,3) t=0.5 (3.5,1.5) tEnd=1 other=2 otherT=0.5 otherIndex=1 windSum=-1 windValue=1 oppValue=0
3325debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0 (1,2) tEnd=0.5 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3326debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0.500000029 (2,3) tEnd=1 other=3 otherT=0.5 otherIndex=5 windSum=1 windValue=1 oppValue=0
3327debugShowActiveSpans id=2 (6,1 1,2) t=0 (6,1) tEnd=0.5 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
3328debugShowActiveSpans id=2 (6,1 1,2) t=0.5 (3.5,1.5) tEnd=0.627564257 other=4 otherT=0.5 otherIndex=1 windSum=1 windValue=1 oppValue=0
3329debugShowActiveSpans id=2 (6,1 1,2) t=0.627564257 (2.8621788,1.62756431) tEnd=1 other=3 otherT=0.704088595 otherIndex=6 windSum=? windValue=1 oppValue=0
3330activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3331markDoneBinary id=2 (6,1 1,2) t=0.5 [1] (3.5,1.5) tEnd=0.627564257 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
3332findChaseOp debugShowSort contourWinding=1 oppContourWinding=-1 sign=1
3333debugShowSort [0] {{6,1}, {1,2}} tStart=0.627564257 tEnd=0.5 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
3334debugShowSort [1] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.704088595 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
3335debugShowSort [2] {{6,1}, {1,2}} tStart=0.627564257 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
3336debugShowSort [3] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.704088595 tEnd=0.5 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
3337findChaseOp debugShowSort contourWinding=1 oppContourWinding=-1 sign=1
3338debugShowSort [0] {{6,1}, {1,2}} tStart=0.627564257 tEnd=0.5 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
3339debugShowSort [1] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.704088595 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
3340debugShowSort [2] {{6,1}, {1,2}} tStart=0.627564257 tEnd=1 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
3341debugShowSort [3] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.704088595 tEnd=0.5 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
3342markWinding id=2 (6,1 1,2) t=0.627564257 [2] (2.8621788,1.62756431) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3343markWinding id=1 (1,2 0,5 3,2 6,1) t=0 [0] (1,2) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3344markWinding id=3 (2,3 1,6 2,1 5,0) t=0.5 [5] (2,3) tEnd=0.704088595 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
3345debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3346debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3347debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3348debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0.5 (2,3) tEnd=0.704088595 other=1 otherT=0.500000029 otherIndex=3 windSum=-1 windValue=1 oppValue=0
3349debugShowActiveSpans id=4 (5,0 2,3) t=0.5 (3.5,1.5) tEnd=1 other=2 otherT=0.5 otherIndex=1 windSum=-1 windValue=1 oppValue=0
3350debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0 (1,2) tEnd=0.5 other=2 otherT=1 otherIndex=3 windSum=1 windValue=1 oppValue=0
3351debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0.500000029 (2,3) tEnd=1 other=3 otherT=0.5 otherIndex=5 windSum=1 windValue=1 oppValue=0
3352debugShowActiveSpans id=2 (6,1 1,2) t=0 (6,1) tEnd=0.5 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
3353debugShowActiveSpans id=2 (6,1 1,2) t=0.627564257 (2.8621788,1.62756431) tEnd=1 other=3 otherT=0.704088595 otherIndex=6 windSum=1 windValue=1 oppValue=0
3354activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
3355findNextOp simple
3356markDoneBinary id=2 (6,1 1,2) t=0.627564257 [2] (2.8621788,1.62756431) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3357bridgeOp current id=2 from=(2.8621788,1.62756431) to=(1,2)
3358setSpans all tiny unsortable [1] (2,3) [0] (1,2)
3359setSpans all tiny unsortable [1] (2,3) [3] (2.00000024,3)
3360markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0 [0] (1,2) tEnd=0.5 newWindSum=0 windSum=1 windValue=1
3361markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.5 [1] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3362markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0 [2] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3363markUnsortable id=4 (5,0 2,3) t=1 [3] (2,3) tEnd=1 newWindSum=0 windSum=? windValue=1
3364findNextOp debugShowSort contourWinding=1 oppContourWinding=0 sign=1
3365debugShowSort [0] *** UNSORTABLE *** {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=0 tiny=0 opp=0
3366debugShowSort [1] *** UNSORTABLE *** {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.5 tEnd=0.500000029 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=1 tiny=1 opp=0
3367debugShowSort [2] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0 tEnd=0.5 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
3368debugShowSort [3] {{5,0}, {2,3}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=-1 1->0 (max=1) done=0 tiny=0 opp=1
3369path.moveTo(2.8621788,1.62756431);
3370path.lineTo(1,2);
3371path.cubicTo(0.5,3.5, 1,3.5, 2,3);
3372markDoneBinary id=1 (1,2 0,5 3,2 6,1) t=0 [0] (1,2) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3373debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3374debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3375debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3376debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0.5 (2,3) tEnd=0.704088595 other=1 otherT=0.500000029 otherIndex=3 windSum=-1 windValue=1 oppValue=0
3377debugShowActiveSpans id=4 (5,0 2,3) t=0.5 (3.5,1.5) tEnd=1 other=2 otherT=0.5 otherIndex=1 windSum=-1 windValue=1 oppValue=0
3378debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0.500000029 (2,3) tEnd=1 other=3 otherT=0.5 otherIndex=5 windSum=1 windValue=1 oppValue=0
3379debugShowActiveSpans id=2 (6,1 1,2) t=0 (6,1) tEnd=0.5 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
3380activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
3381setSpans unsortable [2] (2,3) [3] (2,3)
3382setSpans all tiny unsortable [4] (2,3) [2] (2,3)
3383setSpans all tiny unsortable [2] (2,3) [3] (2.00000024,3)
3384setSpans all tiny unsortable [2] (2,3) [0] (1,2)
3385markUnsortable id=4 (5,0 2,3) t=0.5 [1] (3.5,1.5) tEnd=1 newWindSum=0 windSum=-1 windValue=1
3386markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0 [1] (2,3) tEnd=0 newWindSum=0 windSum=? windValue=1
3387markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0.5 [4] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3388markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0.5 [3] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3389markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.5 [2] (2,3) tEnd=0.500000029 newWindSum=0 windSum=? windValue=1
3390markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.5 [1] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3391findNextOp debugShowSort contourWinding=0 oppContourWinding=1 sign=1
3392debugShowSort [0] {{5,0}, {2,3}} tStart=1 tEnd=0.5 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=0
3393debugShowSort [1] *** UNSORTABLE *** {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0 tEnd=0.5 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
3394debugShowSort [2] *** UNSORTABLE *** {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.5 tEnd=0.5 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=1 tiny=1 opp=0
3395debugShowSort [3] *** UNSORTABLE *** {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
3396debugShowSort [4] *** UNSORTABLE *** {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.5 tEnd=0.500000029 sign=-1 windValue=1 windSum=? 1->2 (max=2) done=1 tiny=1 opp=1
3397debugShowSort [5] *** UNSORTABLE *** {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.5 tEnd=0 sign=1 windValue=1 windSum=1 2->1 (max=2) done=1 tiny=0 opp=1
3398markDoneBinary id=4 (5,0 2,3) t=0.5 [1] (3.5,1.5) tEnd=1 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
3399path.moveTo(3.5,1.5);
3400path.lineTo(2,3);
3401debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3402debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3403debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3404debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0.5 (2,3) tEnd=0.704088595 other=1 otherT=0.500000029 otherIndex=3 windSum=-1 windValue=1 oppValue=0
3405debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0.500000029 (2,3) tEnd=1 other=3 otherT=0.5 otherIndex=5 windSum=1 windValue=1 oppValue=0
3406debugShowActiveSpans id=2 (6,1 1,2) t=0 (6,1) tEnd=0.5 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
3407activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
3408markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0.5 [5] (2,3) tEnd=0.704088595 newWindSum=0 windSum=-1 windValue=1
3409markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0.5 [4] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3410markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.500000029 [3] (2,3) tEnd=1 newWindSum=0 windSum=1 windValue=1
3411markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.5 [2] (2,3) tEnd=0.500000029 newWindSum=0 windSum=? windValue=1
3412findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
3413debugShowSort [0] {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.5 tEnd=0.704088595 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
3414debugShowSort [1] *** UNSORTABLE *** {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.5 tEnd=0.5 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=1 tiny=1 opp=0
3415debugShowSort [2] {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.500000029 tEnd=1 sign=-1 windValue=1 windSum=1 1->2 (max=2) done=0 tiny=0 opp=1
3416debugShowSort [3] {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.500000029 tEnd=0.5 sign=1 windValue=1 windSum=? 2->1 (max=2) done=1 tiny=1 opp=1
3417path.moveTo(2.8621788,1.62756431);
3418path.cubicTo(2.49148154,2.10034132, 2.20408869,2.59182286, 2,3);
3419markDoneBinary id=3 (2,3 1,6 2,1 5,0) t=0.5 [5] (2,3) tEnd=0.704088595 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
3420debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3421debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3422debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3423debugShowActiveSpans id=1 (1,2 0,5 3,2 6,1) t=0.500000029 (2,3) tEnd=1 other=3 otherT=0.5 otherIndex=5 windSum=1 windValue=1 oppValue=0
3424debugShowActiveSpans id=2 (6,1 1,2) t=0 (6,1) tEnd=0.5 other=1 otherT=1 otherIndex=4 windSum=1 windValue=1 oppValue=0
3425activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
3426findNextOp simple
3427markDoneBinary id=2 (6,1 1,2) t=0 [0] (6,1) tEnd=0.5 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3428bridgeOp current id=2 from=(3.5,1.5) to=(6,1)
3429setSpans unsortable [3] (2.00000024,3) [4] (6,1)
3430setSpans unsortable [3] (2.00000024,3) [2] (2,3)
3431setSpans unsortable [5] (2,3) [6] (2.8621788,1.62756431)
3432markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.500000029 [3] (2,3) tEnd=1 newWindSum=0 windSum=1 windValue=1
3433markUnsortable id=1 (1,2 0,5 3,2 6,1) t=0.5 [2] (2,3) tEnd=0.500000029 newWindSum=0 windSum=? windValue=1
3434markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0.5 [5] (2,3) tEnd=0.704088595 newWindSum=0 windSum=-1 windValue=1
3435markUnsortable id=3 (2,3 1,6 2,1 5,0) t=0.5 [4] (2,3) tEnd=0.5 newWindSum=0 windSum=? windValue=1
3436findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
3437debugShowSort [0] *** UNSORTABLE *** {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.500000029 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
3438debugShowSort [1] *** UNSORTABLE *** {{1,2}, {0,5}, {3,2}, {6,1}} tStart=0.500000029 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=1 tiny=1 opp=0
3439debugShowSort [2] *** UNSORTABLE *** {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.5 tEnd=0.704088595 sign=-1 windValue=1 windSum=-1 0->1 (max=1) done=1 tiny=0 opp=1
3440debugShowSort [3] *** UNSORTABLE *** {{2,3}, {1,6}, {2,1}, {5,0}} tStart=0.5 tEnd=0.5 sign=1 windValue=1 windSum=? 1->0 (max=1) done=1 tiny=1 opp=1
3441path.moveTo(3.5,1.5);
3442path.lineTo(6,1);
3443path.cubicTo(4.5,1.5, 3.00000024,2.49999976, 2,3);
3444markDoneBinary id=1 (1,2 0,5 3,2 6,1) t=0.500000029 [3] (2,3) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3445debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=3 otherT=0.5 otherIndex=3 windSum=? windValue=1 oppValue=0
3446debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=4 otherT=1 otherIndex=2 windSum=? windValue=1 oppValue=0
3447debugShowActiveSpans id=3 (2,3 1,6 2,1 5,0) t=0 (2,3) tEnd=0.5 other=1 otherT=0.5 otherIndex=1 windSum=? windValue=1 oppValue=0
3448</div>
3449
caryclark@google.com996d78b2013-03-14 16:24:30 +00003450<div id="cubicOp62d">
3451 SimplifyNew_Test [cubicOp62d]
3452{{1,3}, {5,6}, {5,3}, {5,4}},
3453{{5,4}, {1,3}},
3454op difference
3455{{3,5}, {4,5}, {3,1}, {6,5}},
3456{{6,5}, {3,5}},
3457debugShowCubicIntersection no self intersect {{1,3}, {5,6}, {5,3}, {5,4}}
3458debugShowCubicLineIntersection wtTs[0]=0 {{1,3}, {5,6}, {5,3}, {5,4}} {{1,3}} wtTs[1]=0.666666667 {{4.8518518518518512,3.9629629629629628}} wtTs[2]=1 {{5,4}} wnTs[0]=1 {{5,4}, {1,3}} wnTs[1]=0.037037037 wnTs[2]=0
3459debugShowCubicIntersection wtTs[0]=0.278899971 {{1,3}, {5,6}, {5,3}, {5,4}} {{3.5001544800676263,4.3269091333431628}} wtTs[1]=0.855895664 {{4.9880300830066844,3.7869549154423883}} wtTs[2]=0.865207906 {{4.9902038991416013,3.7891603690182212}} wtTs[3]=0.865213351 {{4.9902050861407137,3.789162057358868}} wnTs[0]=0.2789 {{3,5}, {4,5}, {3,1}, {6,5}} wnTs[1]=0.864850875 wnTs[2]=0.865207887 wnTs[3]=0.865208087
3460debugShowCubicLineIntersection wtTs[0]=0.448187637 {{3,5}, {4,5}, {3,1}, {6,5}} {{3.6795004703683416,3.6698751175920856}} wnTs[0]=0.330125 {{5,4}, {1,3}}
3461debugShowCubicIntersection no self intersect {{3,5}, {4,5}, {3,1}, {6,5}}
3462debugShowCubicLineIntersection wtTs[0]=0 {{3,5}, {4,5}, {3,1}, {6,5}} {{3,5}} wtTs[1]=1 {{6,5}} wnTs[0]=1 {{6,5}, {3,5}} wnTs[1]=0
3463debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0 (1,3) tEnd=0.278899971 other=2 otherT=1 otherIndex=3 windSum=? windValue=1 oppValue=0
3464debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.278899971 (3.5001545,4.32690907) tEnd=0.666666667 other=3 otherT=0.278899971 otherIndex=1 windSum=? windValue=1 oppValue=0
3465debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.666666667 (4.85185194,3.96296287) tEnd=0.855895664 other=2 otherT=0.037037037 otherIndex=1 windSum=? windValue=1 oppValue=0
3466debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.855895664 (4.98802996,3.78695488) tEnd=0.865207906 other=3 otherT=0.864850875 otherIndex=3 windSum=? windValue=1 oppValue=0
3467debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.865207906 (4.99020386,3.78916025) tEnd=0.865213351 other=3 otherT=0.865207887 otherIndex=4 windSum=? windValue=1 oppValue=0
3468debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.865213351 (4.99020529,3.78916216) tEnd=1 other=3 otherT=0.865208087 otherIndex=5 windSum=? windValue=1 oppValue=0
3469debugShowActiveSpans id=2 (5,4 1,3) t=0 (5,4) tEnd=0.037037037 other=1 otherT=1 otherIndex=6 windSum=? windValue=1 oppValue=0
3470debugShowActiveSpans id=2 (5,4 1,3) t=0.037037037 (4.85185194,3.96296287) tEnd=0.330124882 other=1 otherT=0.666666667 otherIndex=2 windSum=? windValue=1 oppValue=0
3471debugShowActiveSpans id=2 (5,4 1,3) t=0.330124882 (3.67950058,3.66987514) tEnd=1 other=3 otherT=0.448187637 otherIndex=2 windSum=? windValue=1 oppValue=0
3472debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0 (3,5) tEnd=0.278899971 other=4 otherT=1 otherIndex=1 windSum=? windValue=1 oppValue=0
3473debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.278899971 (3.5001545,4.32690907) tEnd=0.448187637 other=1 otherT=0.278899971 otherIndex=1 windSum=? windValue=1 oppValue=0
3474debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.448187637 (3.67950058,3.66987514) tEnd=0.864850875 other=2 otherT=0.330124882 otherIndex=2 windSum=? windValue=1 oppValue=0
3475debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.864850875 (4.98802996,3.78695488) tEnd=0.865207887 other=1 otherT=0.855895664 otherIndex=3 windSum=? windValue=1 oppValue=0
3476debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.865207887 (4.99020386,3.78916025) tEnd=0.865208087 other=1 otherT=0.865207906 otherIndex=4 windSum=? windValue=1 oppValue=0
3477debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.865208087 (4.99020529,3.78916216) tEnd=1 other=1 otherT=0.865213351 otherIndex=5 windSum=? windValue=1 oppValue=0
3478debugShowActiveSpans id=4 (6,5 3,5) t=0 (6,5) tEnd=1 other=3 otherT=1 otherIndex=6 windSum=? windValue=1 oppValue=0
3479findTop debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
3480debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0 tEnd=0.278899971 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=0
3481debugShowSort [1] {{5,4}, {1,3}} tStart=1 tEnd=0.330124882 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
3482markWinding id=1 (1,3 5,6 5,3 5,4) t=0 [0] (1,3) tEnd=0.278899971 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3483markWinding id=2 (5,4 1,3) t=0.330124882 [2] (3.67950058,3.66987514) tEnd=1 newWindSum=1 newOppSum=0 oppSum=? windSum=? windValue=1
3484markWinding id=1 (1,3 5,6 5,3 5,4) t=0 [0] (1,3) tEnd=0.278899971 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3485activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
3486findNextOp simple
3487markDoneBinary id=1 (1,3 5,6 5,3 5,4) t=0 [0] (1,3) tEnd=0.278899971 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3488bridgeOp current id=1 from=(3.5001545,4.32690907) to=(1,3)
3489path.moveTo(3.5001545,4.32690907);
3490path.cubicTo(2.92005897,4.20668888, 2.11559987,3.83669996, 1,3);
3491findNextOp debugShowSort contourWinding=0 oppContourWinding=0 sign=-1
3492debugShowSort [1] {{5,4}, {1,3}} tStart=0.330124882 tEnd=1 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
3493debugShowSort [2] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.448187637 tEnd=0.278899971 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
3494debugShowSort [3] {{5,4}, {1,3}} tStart=0.330124882 tEnd=0.037037037 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=0
3495debugShowSort [0] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.448187637 tEnd=0.864850875 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=1
3496findNextOp firstIndex=[1] sign=-1
3497activeOp op=diff miFrom=1 miTo=1 suFrom=0 suTo=1 result=1
3498markWinding id=3 (3,5 4,5 3,1 6,5) t=0.278899971 [1] (3.5001545,4.32690907) tEnd=0.448187637 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
3499findNextOp chase.append id=3
3500activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
3501markDoneBinary id=2 (5,4 1,3) t=0.037037037 [1] (4.85185194,3.96296287) tEnd=0.330124882 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3502findNextOp chase.append id=2
3503activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
3504markDoneBinary id=3 (3,5 4,5 3,1 6,5) t=0.448187637 [2] (3.67950058,3.66987514) tEnd=0.864850875 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3505findNextOp chase.append id=3
3506markDoneBinary id=2 (5,4 1,3) t=0.330124882 [2] (3.67950058,3.66987514) tEnd=1 newWindSum=1 newOppSum=0 oppSum=0 windSum=1 windValue=1
3507findNextOp from:[2] to:[3] start=2 end=1
3508bridgeOp current id=2 from=(1,3) to=(3.67950058,3.66987514)
3509findNextOp debugShowSort contourWinding=-1 oppContourWinding=1 sign=-1
3510debugShowSort [0] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.278899971 tEnd=0.448187637 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
3511debugShowSort [1] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.278899971 tEnd=0 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=1
3512debugShowSort [2] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.278899971 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
3513debugShowSort [3] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.278899971 tEnd=0.666666667 sign=-1 windValue=1 windSum=? 0->1 (max=1) done=0 tiny=0 opp=1
3514findNextOp firstIndex=[0] sign=-1
3515activeOp op=diff miFrom=1 miTo=0 suFrom=0 suTo=0 result=1
3516activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
3517markDoneBinary id=3 (3,5 4,5 3,1 6,5) t=0 [0] (3,5) tEnd=0.278899971 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3518markDoneBinary id=4 (6,5 3,5) t=0 [0] (6,5) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3519markDoneBinary id=3 (3,5 4,5 3,1 6,5) t=0.865208087 [5] (4.99020529,3.78916216) tEnd=1 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3520findNextOp chase.append id=3
3521activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3522markDoneBinary id=1 (1,3 5,6 5,3 5,4) t=0.278899971 [1] (3.5001545,4.32690907) tEnd=0.666666667 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3523findNextOp chase.append id=1
3524markDoneBinary id=3 (3,5 4,5 3,1 6,5) t=0.278899971 [1] (3.5001545,4.32690907) tEnd=0.448187637 newWindSum=-1 newOppSum=1 oppSum=1 windSum=-1 windValue=1
3525findNextOp from:[3] to:[1] start=1 end=0
3526bridgeOp current id=3 from=(3.67950058,3.66987514) to=(3.5001545,4.32690907)
3527path.lineTo(3.67950058,3.66987514);
3528path.cubicTo(3.60967231,3.86879396, 3.5595932,4.10721159, 3.5001545,4.32690907);
3529path.close();
3530findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=-1
3531debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.666666667 tEnd=0.855895664 sign=-1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3532debugShowSort [1] {{5,4}, {1,3}} tStart=0.037037037 tEnd=0.330124882 sign=-1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=0
3533debugShowSort [2] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.666666667 tEnd=0.278899971 sign=1 windValue=1 windSum=1 ?->? (max=?) done=1 tiny=0 opp=0
3534debugShowSort [3] {{5,4}, {1,3}} tStart=0.037037037 tEnd=0 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3535findChaseOp debugShowSort contourWinding=0 oppContourWinding=-1 sign=-1
3536debugShowSort [1] {{5,4}, {1,3}} tStart=0.037037037 tEnd=0.330124882 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
3537debugShowSort [2] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.666666667 tEnd=0.278899971 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
3538debugShowSort [3] {{5,4}, {1,3}} tStart=0.037037037 tEnd=0 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
3539debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.666666667 tEnd=0.855895664 sign=-1 windValue=1 windSum=? -1->0 (max=-1) done=0 tiny=0 opp=0
3540markWinding id=2 (5,4 1,3) t=0 [0] (5,4) tEnd=0.037037037 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
3541markWinding id=1 (1,3 5,6 5,3 5,4) t=0.865213351 [5] (4.99020529,3.78916216) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
3542markWinding id=1 (1,3 5,6 5,3 5,4) t=0.666666667 [2] (4.85185194,3.96296287) tEnd=0.855895664 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
3543debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.666666667 (4.85185194,3.96296287) tEnd=0.855895664 other=2 otherT=0.037037037 otherIndex=1 windSum=-1 windValue=1 oppValue=0
3544debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.855895664 (4.98802996,3.78695488) tEnd=0.865207906 other=3 otherT=0.864850875 otherIndex=3 windSum=? windValue=1 oppValue=0
3545debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.865207906 (4.99020386,3.78916025) tEnd=0.865213351 other=3 otherT=0.865207887 otherIndex=4 windSum=? windValue=1 oppValue=0
3546debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.865213351 (4.99020529,3.78916216) tEnd=1 other=3 otherT=0.865208087 otherIndex=5 windSum=-1 windValue=1 oppValue=0
3547debugShowActiveSpans id=2 (5,4 1,3) t=0 (5,4) tEnd=0.037037037 other=1 otherT=1 otherIndex=6 windSum=-1 windValue=1 oppValue=0
3548debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.864850875 (4.98802996,3.78695488) tEnd=0.865207887 other=1 otherT=0.855895664 otherIndex=3 windSum=? windValue=1 oppValue=0
3549debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.865207887 (4.99020386,3.78916025) tEnd=0.865208087 other=1 otherT=0.865207906 otherIndex=4 windSum=? windValue=1 oppValue=0
3550activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3551markDoneBinary id=2 (5,4 1,3) t=0 [0] (5,4) tEnd=0.037037037 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
3552markDoneBinary id=1 (1,3 5,6 5,3 5,4) t=0.865213351 [5] (4.99020529,3.78916216) tEnd=1 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
3553findChaseOp debugShowSort contourWinding=? oppContourWinding=? sign=1
3554debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.865213351 tEnd=0.865207906 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=0
3555debugShowSort [1] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.865208087 tEnd=0.865207887 sign=1 windValue=1 windSum=? ?->? (max=?) done=0 tiny=0 opp=1
3556debugShowSort [2] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.865213351 tEnd=1 sign=-1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=0
3557debugShowSort [3] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.865208087 tEnd=1 sign=-1 windValue=1 windSum=-1 ?->? (max=?) done=1 tiny=0 opp=1
3558findChaseOp debugShowSort contourWinding=-1 oppContourWinding=-1 sign=-1
3559debugShowSort [2] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.865213351 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=0
3560debugShowSort [3] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.865208087 tEnd=1 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
3561debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.865213351 tEnd=0.865207906 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
3562debugShowSort [1] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.865208087 tEnd=0.865207887 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=1
3563markWinding id=1 (1,3 5,6 5,3 5,4) t=0.865207906 [4] (4.99020386,3.78916025) tEnd=0.865213351 newWindSum=-1 newOppSum=0 oppSum=? windSum=? windValue=1
3564markWinding id=3 (3,5 4,5 3,1 6,5) t=0.865207887 [4] (4.99020386,3.78916025) tEnd=0.865208087 newWindSum=-1 newOppSum=-1 oppSum=? windSum=? windValue=1
3565debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.666666667 (4.85185194,3.96296287) tEnd=0.855895664 other=2 otherT=0.037037037 otherIndex=1 windSum=-1 windValue=1 oppValue=0
3566debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.855895664 (4.98802996,3.78695488) tEnd=0.865207906 other=3 otherT=0.864850875 otherIndex=3 windSum=? windValue=1 oppValue=0
3567debugShowActiveSpans id=1 (1,3 5,6 5,3 5,4) t=0.865207906 (4.99020386,3.78916025) tEnd=0.865213351 other=3 otherT=0.865207887 otherIndex=4 windSum=-1 windValue=1 oppValue=0
3568debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.864850875 (4.98802996,3.78695488) tEnd=0.865207887 other=1 otherT=0.855895664 otherIndex=3 windSum=? windValue=1 oppValue=0
3569debugShowActiveSpans id=3 (3,5 4,5 3,1 6,5) t=0.865207887 (4.99020386,3.78916025) tEnd=0.865208087 other=1 otherT=0.865207906 otherIndex=4 windSum=-1 windValue=1 oppValue=0
3570activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
3571findNextOp debugShowSort contourWinding=-1 oppContourWinding=0 sign=-1
3572debugShowSort [2] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.865207906 tEnd=0.865213351 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
3573debugShowSort [3] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.865207887 tEnd=0.865208087 sign=-1 windValue=1 windSum=-1 0->1 (max=1) done=0 tiny=0 opp=1
3574debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.865207906 tEnd=0.855895664 sign=1 windValue=1 windSum=? 0->-1 (max=-1) done=0 tiny=0 opp=0
3575debugShowSort [1] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.865207887 tEnd=0.864850875 sign=1 windValue=1 windSum=? 1->0 (max=1) done=0 tiny=0 opp=1
3576findNextOp firstIndex=[2] sign=-1
3577activeOp op=diff miFrom=0 miTo=0 suFrom=0 suTo=1 result=0
3578activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3579markDoneBinary id=1 (1,3 5,6 5,3 5,4) t=0.855895664 [3] (4.98802996,3.78695488) tEnd=0.865207906 newWindSum=-1 newOppSum=1 oppSum=? windSum=? windValue=1
3580findNextOp chase.append id=1
3581activeOp op=diff miFrom=1 miTo=1 suFrom=1 suTo=0 result=1
3582markWinding id=3 (3,5 4,5 3,1 6,5) t=0.864850875 [3] (4.98802996,3.78695488) tEnd=0.865207887 newWindSum=1 newOppSum=-1 oppSum=? windSum=? windValue=1
3583findNextOp chase.append id=3
3584markDoneBinary id=1 (1,3 5,6 5,3 5,4) t=0.865207906 [4] (4.99020386,3.78916025) tEnd=0.865213351 newWindSum=-1 newOppSum=0 oppSum=0 windSum=-1 windValue=1
3585findNextOp from:[1] to:[3] start=4 end=3
3586bridgeOp current id=1 from=(4.99020529,3.78916216) to=(4.99020386,3.78916025)
3587path.moveTo(4.99020529,3.78916216);
3588path.cubicTo(4.99020433,3.78916144, 4.99020433,3.78916097, 4.99020386,3.78916025);
3589findNextOp debugShowSort contourWinding=0 oppContourWinding=-1 sign=-1
3590debugShowSort [2] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.864850875 tEnd=0.865207887 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=0 tiny=0 opp=0
3591debugShowSort [3] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.855895664 tEnd=0.865207906 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=1 tiny=0 opp=1
3592debugShowSort [0] {{3,5}, {4,5}, {3,1}, {6,5}} tStart=0.864850875 tEnd=0.448187637 sign=1 windValue=1 windSum=-1 1->0 (max=1) done=1 tiny=0 opp=0
3593debugShowSort [1] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.855895664 tEnd=0.666666667 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=0 tiny=0 opp=1
3594findNextOp firstIndex=[2] sign=-1
3595activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
3596activeOp op=diff miFrom=0 miTo=0 suFrom=1 suTo=0 result=0
3597activeOp op=diff miFrom=0 miTo=1 suFrom=0 suTo=0 result=1
3598markDoneBinary id=3 (3,5 4,5 3,1 6,5) t=0.864850875 [3] (4.98802996,3.78695488) tEnd=0.865207887 newWindSum=1 newOppSum=-1 oppSum=-1 windSum=1 windValue=1
3599findNextOp from:[3] to:[1] start=3 end=2
3600bridgeOp current id=3 from=(4.99020386,3.78916025) to=(4.98802996,3.78695488)
3601path.cubicTo(4.98947859,3.78842425, 4.98875427,3.78768921, 4.98802996,3.78695488);
3602findNextOp debugShowSort contourWinding=-1 oppContourWinding=-1 sign=-1
3603debugShowSort [0] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.666666667 tEnd=0.855895664 sign=-1 windValue=1 windSum=-1 -1->0 (max=-1) done=0 tiny=0 opp=0
3604debugShowSort [1] {{5,4}, {1,3}} tStart=0.037037037 tEnd=0.330124882 sign=-1 windValue=1 windSum=1 0->1 (max=1) done=1 tiny=0 opp=0
3605debugShowSort [2] {{1,3}, {5,6}, {5,3}, {5,4}} tStart=0.666666667 tEnd=0.278899971 sign=1 windValue=1 windSum=1 1->0 (max=1) done=1 tiny=0 opp=0
3606debugShowSort [3] {{5,4}, {1,3}} tStart=0.037037037 tEnd=0 sign=1 windValue=1 windSum=-1 0->-1 (max=-1) done=1 tiny=0 opp=0
3607findNextOp firstIndex=[0] sign=-1
3608activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3609activeOp op=diff miFrom=1 miTo=0 suFrom=1 suTo=1 result=0
3610activeOp op=diff miFrom=0 miTo=1 suFrom=1 suTo=1 result=0
3611markDoneBinary id=1 (1,3 5,6 5,3 5,4) t=0.666666667 [2] (4.85185194,3.96296287) tEnd=0.855895664 newWindSum=-1 newOppSum=-1 oppSum=-1 windSum=-1 windValue=1
3612path.cubicTo(4.97231197,3.77658033, 4.93595362,3.85783577, 4.85185194,3.96296287);
3613</div>
3614
caryclark@google.comf839c032012-10-26 21:03:50 +00003615</div>
3616
3617<script type="text/javascript">
3618
3619var testDivs = [
caryclark@google.com996d78b2013-03-14 16:24:30 +00003620 cubicOp62d,
caryclark@google.com1304bb22013-03-13 20:29:41 +00003621 cubicOp61d,
3622 cubicOp58da,
3623 cubicOp58d,
3624 cubicOp57da,
3625 cubicOp56da,
3626 cubicOp55da,
3627 cubicOp55d,
3628 cubicOp54dd,
3629 cubicOp54dc,
3630 cubicOp54db,
3631 cubicOp54da,
3632 cubicOp54d,
3633 cubicOp53db,
3634 cubicOp53da,
3635 cubicOp53d,
3636 cubicOp52db,
3637 cubicOp52da,
3638 cubicOp51da,
3639 cubicOp51d,
3640 cubicOp50d,
3641 cubicOp49d,
3642 cubicOp48dc,
3643 cubicOp48db,
3644 cubicOp48da,
3645 cubicOp48d,
3646 cubicOp47db,
3647 cubicOp47da,
3648 cubicOp47d,
3649 cubicOp46db,
3650 cubicOp46da,
3651 cubicOp46d,
3652 cubicOp45d,
3653 cubicOp44d,
3654 cubicOp43d,
3655 cubicOp42d,
3656 cubicOp42da,
3657 cubicOp42db,
3658 cubicOp41i,
3659 cubicOp40d,
3660 cubicOp39da,
3661 cubicOp39d,
3662 cubicOp38d,
3663 cubicOp38da,
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003664 cubicOp36u,
3665 cubicOp35da,
caryclark@google.com1304bb22013-03-13 20:29:41 +00003666 cubicOp32d,
caryclark@google.comf839c032012-10-26 21:03:50 +00003667];
3668
3669var decimal_places = 3; // make this 3 to show more precision
3670
3671var tests = [];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003672var testLines = [];
caryclark@google.comf839c032012-10-26 21:03:50 +00003673var testTitles = [];
3674var testIndex = 0;
3675var ctx;
3676
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003677var xmin, xmax;
3678var ymin, ymax;
caryclark@google.comf839c032012-10-26 21:03:50 +00003679var scale;
3680var mouseX, mouseY;
3681var srcLeft, srcTop;
caryclark@google.comf839c032012-10-26 21:03:50 +00003682var screenWidth, screenHeight;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003683var drawnPts, drawnLines, drawnQuads, drawnCubics;
3684var curveT = 0;
caryclark@google.comf839c032012-10-26 21:03:50 +00003685
caryclark@google.com1304bb22013-03-13 20:29:41 +00003686var pt_labels = 2;
3687var control_lines = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003688var curve_t = false;
caryclark@google.comf839c032012-10-26 21:03:50 +00003689var debug_xy = false;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003690var step_limit = 0;
3691var draw_active = false;
3692var draw_add = false;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003693var draw_deriviatives = 0;
3694var draw_hints = false;
3695var draw_hodo = 0;
3696var draw_intersection = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003697var draw_intersectT = false;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003698var draw_legend = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003699var draw_log = false;
3700var draw_mark = false;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003701var draw_midpoint = false;
3702var draw_sequence = false;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003703var draw_sort = false;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003704var draw_path = 3;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003705var draw_computed = 0;
caryclark@google.comf839c032012-10-26 21:03:50 +00003706
caryclark@google.com1304bb22013-03-13 20:29:41 +00003707var activeCount = 0;
3708var addCount = 0;
3709var sectCount = 0;
3710var sortCount = 0;
3711var markCount = 0;
3712var activeMax = 0;
3713var addMax = 0;
3714var sectMax = 0;
3715var sectMax2 = 0;
3716var sortMax = 0;
3717var markMax = 0;
3718var stepMax = 0;
3719var lastIndex = 0;
3720var hasPath = false;
3721var hasComputedPath = false;
3722
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003723var SPAN_ID = 0;
3724var SPAN_X1 = SPAN_ID + 1;
3725var SPAN_Y1 = SPAN_X1 + 1;
3726var SPAN_X2 = SPAN_Y1 + 1;
3727var SPAN_Y2 = SPAN_X2 + 1;
3728var SPAN_L_T = SPAN_Y2 + 1;
3729var SPAN_L_TX = SPAN_L_T + 1;
3730var SPAN_L_TY = SPAN_L_TX + 1;
3731var SPAN_L_TEND = SPAN_L_TY + 1;
3732var SPAN_L_OTHER = SPAN_L_TEND + 1;
3733var SPAN_L_OTHERT = SPAN_L_OTHER + 1;
3734var SPAN_L_OTHERI = SPAN_L_OTHERT + 1;
3735var SPAN_L_SUM = SPAN_L_OTHERI + 1;
3736var SPAN_L_VAL = SPAN_L_SUM + 1;
3737var SPAN_L_OPP = SPAN_L_VAL + 1;
caryclark@google.comf839c032012-10-26 21:03:50 +00003738
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003739var SPAN_X3 = SPAN_Y2 + 1;
3740var SPAN_Y3 = SPAN_X3 + 1;
3741var SPAN_Q_T = SPAN_Y3 + 1;
3742var SPAN_Q_TX = SPAN_Q_T + 1;
3743var SPAN_Q_TY = SPAN_Q_TX + 1;
3744var SPAN_Q_TEND = SPAN_Q_TY + 1;
3745var SPAN_Q_OTHER = SPAN_Q_TEND + 1;
3746var SPAN_Q_OTHERT = SPAN_Q_OTHER + 1;
3747var SPAN_Q_OTHERI = SPAN_Q_OTHERT + 1;
3748var SPAN_Q_SUM = SPAN_Q_OTHERI + 1;
3749var SPAN_Q_VAL = SPAN_Q_SUM + 1;
3750var SPAN_Q_OPP = SPAN_Q_VAL + 1;
caryclark@google.com47d73da2013-02-17 01:41:25 +00003751
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003752var SPAN_X4 = SPAN_Y3 + 1;
3753var SPAN_Y4 = SPAN_X4 + 1;
3754var SPAN_C_T = SPAN_Y4 + 1;
3755var SPAN_C_TX = SPAN_C_T + 1;
3756var SPAN_C_TY = SPAN_C_TX + 1;
3757var SPAN_C_TEND = SPAN_C_TY + 1;
3758var SPAN_C_OTHER = SPAN_C_TEND + 1;
3759var SPAN_C_OTHERT = SPAN_C_OTHER + 1;
3760var SPAN_C_OTHERI = SPAN_C_OTHERT + 1;
3761var SPAN_C_SUM = SPAN_C_OTHERI + 1;
3762var SPAN_C_VAL = SPAN_C_SUM + 1;
3763var SPAN_C_OPP = SPAN_C_VAL + 1;
caryclark@google.comf839c032012-10-26 21:03:50 +00003764
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003765var ACTIVE_LINE_SPAN = 1;
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003766var ACTIVE_QUAD_SPAN = ACTIVE_LINE_SPAN + 1;
3767var ACTIVE_CUBIC_SPAN = ACTIVE_QUAD_SPAN + 1;
3768
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003769var ADD_MOVETO = ACTIVE_CUBIC_SPAN + 1;
3770var ADD_LINETO = ADD_MOVETO + 1;
3771var ADD_QUADTO = ADD_LINETO + 1;
3772var ADD_CUBICTO = ADD_QUADTO + 1;
3773var ADD_CLOSE = ADD_CUBICTO + 1;
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003774
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003775var PATH_LINE = ADD_CLOSE + 1;
3776var PATH_QUAD = PATH_LINE + 1;
3777var PATH_CUBIC = PATH_QUAD + 1;
3778
3779var INTERSECT_LINE = PATH_CUBIC + 1;
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003780var INTERSECT_LINE_2 = INTERSECT_LINE + 1;
3781var INTERSECT_LINE_NO = INTERSECT_LINE_2 + 1;
3782var INTERSECT_QUAD_LINE = INTERSECT_LINE_NO + 1;
3783var INTERSECT_QUAD_LINE_2 = INTERSECT_QUAD_LINE + 1;
3784var INTERSECT_QUAD_LINE_NO = INTERSECT_QUAD_LINE_2 + 1;
3785var INTERSECT_QUAD = INTERSECT_QUAD_LINE_NO + 1;
3786var INTERSECT_QUAD_2 = INTERSECT_QUAD + 1;
3787var INTERSECT_QUAD_NO = INTERSECT_QUAD_2 + 1;
3788var INTERSECT_SELF_CUBIC = INTERSECT_QUAD_NO + 1;
3789var INTERSECT_SELF_CUBIC_NO = INTERSECT_SELF_CUBIC + 1;
3790var INTERSECT_CUBIC_LINE = INTERSECT_SELF_CUBIC_NO + 1;
3791var INTERSECT_CUBIC_LINE_2 = INTERSECT_CUBIC_LINE + 1;
3792var INTERSECT_CUBIC_LINE_3 = INTERSECT_CUBIC_LINE_2 + 1;
3793var INTERSECT_CUBIC_LINE_NO = INTERSECT_CUBIC_LINE_3 + 1;
3794// FIXME: add cubic/quad
3795var INTERSECT_CUBIC = INTERSECT_CUBIC_LINE_NO + 1;
3796var INTERSECT_CUBIC_2 = INTERSECT_CUBIC + 1;
3797var INTERSECT_CUBIC_3 = INTERSECT_CUBIC_2 + 1;
3798var INTERSECT_CUBIC_4 = INTERSECT_CUBIC_3 + 1;
3799// FIXME: add cubic 5- 9
3800var INTERSECT_CUBIC_NO = INTERSECT_CUBIC_4 + 1;
3801
3802var SORT_LINE = INTERSECT_CUBIC_NO + 1;
3803var SORT_QUAD = SORT_LINE + 1;
3804var SORT_CUBIC = SORT_QUAD + 1;
3805
caryclark@google.com1304bb22013-03-13 20:29:41 +00003806var SORT_LINE_UNSORTABLE = SORT_CUBIC + 1;
3807var SORT_QUAD_UNSORTABLE = SORT_LINE_UNSORTABLE + 1;
3808var SORT_CUBIC_UNSORTABLE = SORT_QUAD_UNSORTABLE + 1;
3809
3810var SORT_LINE_COMPACT = SORT_CUBIC_UNSORTABLE + 1;
3811var SORT_QUAD_COMPACT = SORT_LINE_COMPACT + 1;
3812var SORT_CUBIC_COMPACT = SORT_QUAD_COMPACT + 1;
3813
3814var OP_DIFFERENCE = SORT_CUBIC_COMPACT + 1;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003815var OP_INTERSECT = OP_DIFFERENCE + 1;
3816var OP_UNION = OP_INTERSECT + 1;
3817var OP_XOR = OP_UNION + 1;
3818
3819var MARK_LINE = OP_XOR + 1;
3820var MARK_QUAD = MARK_LINE + 1;
3821var MARK_CUBIC = MARK_QUAD + 1;
3822var MARK_DONE_LINE = MARK_CUBIC + 1;
3823var MARK_DONE_QUAD = MARK_DONE_LINE + 1;
3824var MARK_DONE_CUBIC = MARK_DONE_QUAD + 1;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003825var MARK_UNSORTABLE_LINE = MARK_DONE_CUBIC + 1;
3826var MARK_UNSORTABLE_QUAD = MARK_UNSORTABLE_LINE + 1;
3827var MARK_UNSORTABLE_CUBIC = MARK_UNSORTABLE_QUAD + 1;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003828
caryclark@google.com1304bb22013-03-13 20:29:41 +00003829var COMPUTED_SET_1 = MARK_UNSORTABLE_CUBIC + 1;
3830var COMPUTED_SET_2 = COMPUTED_SET_1 + 1;
3831var FRAG_TYPE_LAST = COMPUTED_SET_2;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003832
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003833var REC_TYPE_UNKNOWN = -1;
3834var REC_TYPE_PATH = 0;
3835var REC_TYPE_SECT = 1;
3836var REC_TYPE_ACTIVE = 2;
3837var REC_TYPE_ADD = 3;
3838var REC_TYPE_SORT = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003839var REC_TYPE_OP = 5;
3840var REC_TYPE_MARK = 6;
3841var REC_TYPE_COMPUTED = 7;
3842var REC_TYPE_LAST = REC_TYPE_COMPUTED;
caryclark@google.comf839c032012-10-26 21:03:50 +00003843
3844function strs_to_nums(strs) {
3845 var result = [];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003846 for (var idx = 1; idx < strs.length; ++idx) {
caryclark@google.comf839c032012-10-26 21:03:50 +00003847 var str = strs[idx];
3848 var num = parseFloat(str);
3849 if (isNaN(num)) {
3850 result.push(str);
3851 } else {
3852 result.push(num);
3853 }
3854 }
3855 return result;
3856}
3857
caryclark@google.com0b7da432012-10-31 19:00:20 +00003858function filter_str_by(id, str, regex, array) {
3859 if (regex.test(str)) {
3860 var strs = regex.exec(str);
3861 var result = strs_to_nums(strs);
3862 array.push(id);
3863 array.push(result);
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003864 return true;
caryclark@google.com0b7da432012-10-31 19:00:20 +00003865 }
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003866 return false;
caryclark@google.com0b7da432012-10-31 19:00:20 +00003867}
3868
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003869function construct_regexp2(pattern) {
3870 var escape = pattern.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&');
caryclark@google.com1304bb22013-03-13 20:29:41 +00003871 escape = escape.replace(/UNSORTABLE/g, "\\*\\*\\* UNSORTABLE \\*\\*\\*");
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003872 escape = escape.replace(/CUBIC_VAL/g, "\\(P_VAL P_VAL P_VAL P_VAL\\)");
3873 escape = escape.replace(/QUAD_VAL/g, "\\(P_VAL P_VAL P_VAL\\)");
3874 escape = escape.replace(/LINE_VAL/g, "\\(P_VAL P_VAL\\)");
3875 escape = escape.replace(/PT_VAL/g, "\\(P_VAL\\)");
caryclark@google.com996d78b2013-03-14 16:24:30 +00003876 escape = escape.replace(/P_VAL/g, "(-?\\d+\\.?\\d*(?:e-?\\d+)?),(-?\\d+\\.?\\d*(?:e-?\\d+)?)");
3877 escape = escape.replace(/T_VAL/g, "(-?\\d+\\.?\\d*(?:e-?\\d+)?)");
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003878 escape = escape.replace(/IDX/g, "(\\d+)");
3879 escape = escape.replace(/NUM/g, "(-?\\d+)");
3880 escape = escape.replace(/OPT/g, "(\\?|-?\\d+)");
3881 return new RegExp(escape, 'i');
3882}
3883
3884function construct_regexp2c(pattern) {
3885 var escape = pattern.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&');
caryclark@google.com1304bb22013-03-13 20:29:41 +00003886 escape = escape.replace(/UNSORTABLE/g, "\\*\\*\\* UNSORTABLE \\*\\*\\*");
3887 escape = escape.replace(/CUBIC_VAL/g, "(?:\\$\\d = )?\\{\\{P_VAL\\}, \\{P_VAL\\}, \\{P_VAL\\}, \\{P_VAL\\}\\}");
3888 escape = escape.replace(/QUAD_VAL/g, "(?:\\$\\d = )?\\{\\{P_VAL\\}, \\{P_VAL\\}, \\{P_VAL\\}\\}");
3889 escape = escape.replace(/LINE_VAL/g, "(?:\\$\\d = )?\\{\\{P_VAL\\}, \\{P_VAL\\}\\}");
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003890 escape = escape.replace(/PT_VAL/g, "\\{\\{P_VAL\\}\\}");
caryclark@google.com996d78b2013-03-14 16:24:30 +00003891 escape = escape.replace(/P_VAL/g, "(?:f?[xX] = )?(-?\\d+\\.?\\d*(?:e-?\\d+)?),(?: f?[yY] = )?(-?\\d+\\.?\\d*(?:e-?\\d+)?)");
3892 escape = escape.replace(/T_VAL/g, "(-?\\d+\\.?\\d*(?:e-?\\d+)?)");
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003893 escape = escape.replace(/IDX/g, "(\\d+)");
3894 escape = escape.replace(/NUM/g, "(-?\\d+)");
3895 escape = escape.replace(/OPT/g, "(\\?|-?\\d+)");
3896 return new RegExp(escape, 'i');
3897}
3898
3899function match_regexp(str, lineNo, array, id, pattern) {
3900 var regex = construct_regexp2(pattern);
3901 if (filter_str_by(id, str, regex, array)) {
3902 return true;
3903 }
3904 regex = construct_regexp2c(pattern);
3905 return filter_str_by(id, str, regex, array);
3906}
3907
caryclark@google.com1304bb22013-03-13 20:29:41 +00003908function parse_all(test) {
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003909 var lines = test.match(/[^\r\n]+/g);
3910 var records = []; // a rec can be the original paths, a set of intersections, a set of active spans, a sort, or a path add
3911 var record = [];
3912 var recType = REC_TYPE_UNKNOWN;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003913 var lastLineNo;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003914 var moveX, moveY;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003915 for (var lineNo = 0; lineNo < lines.length; ++lineNo) {
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003916 var line = lines[lineNo];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003917 if (line.length == 0) {
3918 continue;
3919 }
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003920 var type = line.lastIndexOf("debugShowSort", 0) === 0 ? REC_TYPE_SORT
3921 : line.lastIndexOf("debugShowActiveSpans", 0) === 0 ? REC_TYPE_ACTIVE
3922 : line.lastIndexOf("debugShow", 0) === 0 ? REC_TYPE_SECT
caryclark@google.com1304bb22013-03-13 20:29:41 +00003923 : line.lastIndexOf("computed", 0) === 0 ? REC_TYPE_COMPUTED
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003924 : line.lastIndexOf("path.", 0) === 0 ? REC_TYPE_ADD
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003925 : line.lastIndexOf("mark", 0) === 0 ? REC_TYPE_MARK
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003926 : line.lastIndexOf(" {{", 0) === 0 ? REC_TYPE_COMPUTED
caryclark@google.com1304bb22013-03-13 20:29:41 +00003927 : line.lastIndexOf("{{", 0) === 0 ? REC_TYPE_PATH
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003928 : line.lastIndexOf("op", 0) === 0 ? REC_TYPE_OP
caryclark@google.com1304bb22013-03-13 20:29:41 +00003929 : line.lastIndexOf("$", 0) === 0 ? REC_TYPE_PATH
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003930 : REC_TYPE_UNKNOWN;
caryclark@google.com1304bb22013-03-13 20:29:41 +00003931 if (recType != type || recType == REC_TYPE_ADD || recType == REC_TYPE_SECT) {
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003932 if (recType != REC_TYPE_UNKNOWN) {
3933 records.push(recType);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003934 records.push(lastLineNo);
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003935 records.push(record);
3936 }
3937 record = [];
3938 recType = type;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003939 lastLineNo = lineNo;
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003940 }
3941 var found = false;
3942 switch (recType) {
3943 case REC_TYPE_ACTIVE:
3944 found = match_regexp(line, lineNo, record, ACTIVE_LINE_SPAN, "debugShowActiveSpans" +
3945" id=IDX LINE_VAL t=T_VAL PT_VAL tEnd=T_VAL other=IDX otherT=T_VAL otherIndex=IDX windSum=OPT windValue=IDX oppValue=IDX"
3946 ) || match_regexp(line, lineNo, record, ACTIVE_QUAD_SPAN, "debugShowActiveSpans" +
3947" id=IDX QUAD_VAL t=T_VAL PT_VAL tEnd=T_VAL other=IDX otherT=T_VAL otherIndex=IDX windSum=OPT windValue=IDX oppValue=IDX"
3948 ) || match_regexp(line, lineNo, record, ACTIVE_CUBIC_SPAN, "debugShowActiveSpans" +
3949" id=IDX CUBIC_VAL t=T_VAL PT_VAL tEnd=T_VAL other=IDX otherT=T_VAL otherIndex=IDX windSum=OPT windValue=IDX oppValue=IDX"
3950 );
3951 break;
3952 case REC_TYPE_ADD:
caryclark@google.com1304bb22013-03-13 20:29:41 +00003953 if (match_regexp(line, lineNo, record, ADD_MOVETO, "path.moveTo(P_VAL);")) {
3954 moveX = record[1][0];
3955 moveY = record[1][1];
3956 found = true;
3957 } else if (match_regexp(line, lineNo, record, ADD_LINETO, "path.lineTo(P_VAL);")) {
3958 record[1].unshift(moveY);
3959 record[1].unshift(moveX);
3960 moveX = record[1][2];
3961 moveY = record[1][3];
3962 found = true;
3963 } else if (match_regexp(line, lineNo, record, ADD_QUADTO, "path.quadTo(P_VAL, P_VAL);")) {
3964 record[1].unshift(moveY);
3965 record[1].unshift(moveX);
3966 moveX = record[1][4];
3967 moveY = record[1][5];
3968 found = true;
3969 } else if (match_regexp(line, lineNo, record, ADD_CUBICTO, "path.cubicTo(P_VAL, P_VAL, P_VAL);")) {
3970 record[1].unshift(moveY);
3971 record[1].unshift(moveX);
3972 moveX = record[1][6];
3973 moveY = record[1][7];
3974 found = true;
3975 } else {
3976 found = match_regexp(line, lineNo, record, ADD_CLOSE, "path.close();");
3977 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003978 break;
3979 case REC_TYPE_COMPUTED:
caryclark@google.com1304bb22013-03-13 20:29:41 +00003980 found = line == "computed quadratics given"
3981 || match_regexp(line, lineNo, record, COMPUTED_SET_1, "computed quadratics set 1"
3982 ) || match_regexp(line, lineNo, record, COMPUTED_SET_2, "computed quadratics set 2"
3983 ) || match_regexp(line, lineNo, record, PATH_QUAD, " QUAD_VAL,"
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00003984 ) || match_regexp(line, lineNo, record, PATH_CUBIC, " CUBIC_VAL,"
3985 );
3986 break;
3987 case REC_TYPE_PATH:
3988 found = match_regexp(line, lineNo, record, PATH_LINE, "LINE_VAL"
3989 ) || match_regexp(line, lineNo, record, PATH_QUAD, "QUAD_VAL"
3990 ) || match_regexp(line, lineNo, record, PATH_CUBIC, "CUBIC_VAL"
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00003991 );
3992 break;
3993 case REC_TYPE_SECT:
3994 found = match_regexp(line, lineNo, record, INTERSECT_LINE, "debugShowLineIntersection" +
3995" wtTs[0]=T_VAL LINE_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL"
3996 ) || match_regexp(line, lineNo, record, INTERSECT_LINE_2, "debugShowLineIntersection" +
3997" wtTs[0]=T_VAL LINE_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL wnTs[1]=T_VAL"
3998 ) || match_regexp(line, lineNo, record, INTERSECT_LINE_NO, "debugShowLineIntersection" +
3999" no intersect LINE_VAL LINE_VAL"
4000 ) || match_regexp(line, lineNo, record, INTERSECT_QUAD_LINE, "debugShowQuadLineIntersection" +
4001" wtTs[0]=T_VAL QUAD_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL"
4002 ) || match_regexp(line, lineNo, record, INTERSECT_QUAD_LINE_2, "debugShowQuadLineIntersection" +
4003" wtTs[0]=T_VAL QUAD_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL wnTs[1]=T_VAL"
4004 ) || match_regexp(line, lineNo, record, INTERSECT_QUAD_LINE_NO, "debugShowQuadLineIntersection" +
4005" no intersect QUAD_VAL LINE_VAL"
4006 ) || match_regexp(line, lineNo, record, INTERSECT_QUAD, "debugShowQuadIntersection" +
4007" wtTs[0]=T_VAL QUAD_VAL PT_VAL wnTs[0]=T_VAL QUAD_VAL"
4008 ) || match_regexp(line, lineNo, record, INTERSECT_QUAD_2, "debugShowQuadIntersection" +
4009" wtTs[0]=T_VAL QUAD_VAL PT_VAL wtTs[1]=T_VAL wnTs[0]=T_VAL QUAD_VAL wnTs[1]=T_VAL"
4010 ) || match_regexp(line, lineNo, record, INTERSECT_QUAD_NO, "debugShowQuadIntersection" +
4011" no intersect QUAD_VAL QUAD_VAL"
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004012 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_LINE, "debugShowCubicLineIntersection" +
4013" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL"
4014 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_LINE_2, "debugShowCubicLineIntersection" +
4015" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL wnTs[1]=T_VAL"
4016 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_LINE_3, "debugShowCubicLineIntersection" +
4017" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wtTs[2]=T_VAL PT_VAL wnTs[0]=T_VAL LINE_VAL wnTs[1]=T_VAL wnTs[2]=T_VAL"
4018 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_LINE_NO, "debugShowCubicLineIntersection" +
4019" no intersect CUBIC_VAL LINE_VAL"
4020 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC, "debugShowCubicIntersection" +
4021" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wnTs[0]=T_VAL CUBIC_VAL"
4022 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_2, "debugShowCubicIntersection" +
4023" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wnTs[0]=T_VAL CUBIC_VAL wnTs[1]=T_VAL"
4024 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_3, "debugShowCubicIntersection" +
4025" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wtTs[2]=T_VAL PT_VAL wnTs[0]=T_VAL CUBIC_VAL wnTs[1]=T_VAL wnTs[2]=T_VAL"
4026 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_4, "debugShowCubicIntersection" +
4027" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wtTs[1]=T_VAL PT_VAL wtTs[2]=T_VAL PT_VAL wtTs[3]=T_VAL PT_VAL wnTs[0]=T_VAL CUBIC_VAL wnTs[1]=T_VAL wnTs[2]=T_VAL wnTs[3]=T_VAL"
4028 ) || match_regexp(line, lineNo, record, INTERSECT_CUBIC_NO, "debugShowCubicIntersection" +
4029" no intersect CUBIC_VAL CUBIC_VAL"
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004030 ) || match_regexp(line, lineNo, record, INTERSECT_SELF_CUBIC, "debugShowCubicIntersection" +
4031" wtTs[0]=T_VAL CUBIC_VAL PT_VAL wtTs[1]=T_VAL"
4032 ) || match_regexp(line, lineNo, record, INTERSECT_SELF_CUBIC_NO, "debugShowCubicIntersection" +
4033" no self intersect CUBIC_VAL"
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004034 );
4035 break;
4036 case REC_TYPE_SORT:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004037 found = match_regexp(line, lineNo, record, SORT_LINE, "debugShowSort" +
caryclark@google.com1304bb22013-03-13 20:29:41 +00004038" [IDX] LINE_VAL tStart=T_VAL tEnd=T_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004039 ) || match_regexp(line, lineNo, record, SORT_QUAD, "debugShowSort" +
caryclark@google.com1304bb22013-03-13 20:29:41 +00004040" [IDX] QUAD_VAL tStart=T_VAL tEnd=T_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004041 ) || match_regexp(line, lineNo, record, SORT_CUBIC, "debugShowSort" +
caryclark@google.com1304bb22013-03-13 20:29:41 +00004042" [IDX] CUBIC_VAL tStart=T_VAL tEnd=T_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
4043 ) || match_regexp(line, lineNo, record, SORT_LINE_UNSORTABLE, "debugShowSort" +
4044" [IDX] UNSORTABLE LINE_VAL tStart=T_VAL tEnd=T_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
4045 ) || match_regexp(line, lineNo, record, SORT_QUAD_UNSORTABLE, "debugShowSort" +
4046" [IDX] UNSORTABLE QUAD_VAL tStart=T_VAL tEnd=T_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
4047 ) || match_regexp(line, lineNo, record, SORT_CUBIC_UNSORTABLE, "debugShowSort" +
4048" [IDX] UNSORTABLE CUBIC_VAL tStart=T_VAL tEnd=T_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004049 ) || match_regexp(line, lineNo, record, SORT_LINE_COMPACT, "debugShowSort" +
caryclark@google.com1304bb22013-03-13 20:29:41 +00004050" [IDX] id=IDX line start=IDX PT_VAL end=IDX PT_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004051 ) || match_regexp(line, lineNo, record, SORT_QUAD_COMPACT, "debugShowSort" +
caryclark@google.com1304bb22013-03-13 20:29:41 +00004052" [IDX] id=IDX quad start=IDX PT_VAL end=IDX PT_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004053 ) || match_regexp(line, lineNo, record, SORT_CUBIC_COMPACT, "debugShowSort" +
caryclark@google.com1304bb22013-03-13 20:29:41 +00004054" [IDX] id=IDX cubic start=IDX PT_VAL end=IDX PT_VAL sign=NUM windValue=IDX windSum=OPT OPT->OPT (max=OPT) done=IDX tiny=IDX opp=IDX"
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004055 );
4056 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004057 case REC_TYPE_MARK:
4058 found = match_regexp(line, lineNo, record, MARK_LINE, "markWinding" +
4059" id=IDX LINE_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM newOppSum=NUM oppSum=OPT windSum=OPT windValue=IDX"
4060 ) || match_regexp(line, lineNo, record, MARK_QUAD, "markWinding" +
4061" id=IDX QUAD_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM newOppSum=NUM oppSum=OPT windSum=OPT windValue=IDX"
4062 ) || match_regexp(line, lineNo, record, MARK_CUBIC, "markWinding" +
4063" id=IDX CUBIC_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM newOppSum=NUM oppSum=OPT windSum=OPT windValue=IDX"
4064 ) || match_regexp(line, lineNo, record, MARK_DONE_LINE, "markDoneBinary" +
4065" id=IDX LINE_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM newOppSum=NUM oppSum=OPT windSum=OPT windValue=IDX"
4066 ) || match_regexp(line, lineNo, record, MARK_DONE_QUAD, "markDoneBinary" +
4067" id=IDX QUAD_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM newOppSum=NUM oppSum=OPT windSum=OPT windValue=IDX"
4068 ) || match_regexp(line, lineNo, record, MARK_DONE_CUBIC, "markDoneBinary" +
4069" id=IDX CUBIC_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM newOppSum=NUM oppSum=OPT windSum=OPT windValue=IDX"
caryclark@google.com1304bb22013-03-13 20:29:41 +00004070 ) || match_regexp(line, lineNo, record, MARK_UNSORTABLE_LINE, "markUnsortable" +
4071" id=IDX LINE_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM windSum=OPT windValue=IDX"
4072 ) || match_regexp(line, lineNo, record, MARK_UNSORTABLE_QUAD, "markUnsortable" +
4073" id=IDX QUAD_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM windSum=OPT windValue=IDX"
4074 ) || match_regexp(line, lineNo, record, MARK_UNSORTABLE_CUBIC, "markUnsortable" +
4075" id=IDX CUBIC_VAL t=T_VAL [IDX] PT_VAL tEnd=T_VAL newWindSum=NUM windSum=OPT windValue=IDX"
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004076 );
4077 break;
4078 case REC_TYPE_OP:
4079 found = match_regexp(line, lineNo, record, OP_DIFFERENCE, "op difference"
4080 ) || match_regexp(line, lineNo, record, OP_INTERSECT, "op intersect"
4081 ) || match_regexp(line, lineNo, record, OP_UNION, "op union"
4082 ) || match_regexp(line, lineNo, record, OP_XOR, "op xor"
4083 );
4084 break;
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004085 case REC_TYPE_UNKNOWN:
4086 found = true;
4087 break;
4088 }
4089 if (!found) {
4090 console.log(line + " [" + lineNo + "] of type " + type + " not found");
4091 }
4092 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004093 if (recType != REC_TYPE_UNKNOWN) {
4094 records.push(recType);
4095 records.push(lastLineNo);
4096 records.push(record);
4097 }
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004098 if (records.length >= 1) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00004099 tests[testIndex] = records;
4100 testLines[testIndex] = lines;
caryclark@google.com4aaaaea2013-02-28 16:12:39 +00004101 }
4102}
4103
caryclark@google.comf839c032012-10-26 21:03:50 +00004104function init(test) {
4105 var canvas = document.getElementById('canvas');
4106 if (!canvas.getContext) return;
4107 screenWidth = canvas.width = window.innerWidth - 20;
4108 screenHeight = canvas.height = window.innerHeight - 20;
4109 ctx = canvas.getContext('2d');
4110 xmin = Infinity;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004111 xmax = -Infinity;
caryclark@google.comf839c032012-10-26 21:03:50 +00004112 ymin = Infinity;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004113 ymax = -Infinity;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004114 hasPath = hasComputedPath = false;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004115 for (var testIndex = 0; testIndex < test.length; testIndex += 3) {
4116 var recType = test[testIndex];
4117 if (!typeof recType == 'number' || recType < REC_TYPE_UNKNOWN || recType > REC_TYPE_LAST) {
4118 console.log("unknown rec type: " + recType);
4119 throw "stop execution";
caryclark@google.comf839c032012-10-26 21:03:50 +00004120 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004121 var records = test[testIndex + 2];
4122 for (var recordIndex = 0; recordIndex < records.length; recordIndex += 2) {
4123 var fragType = records[recordIndex];
caryclark@google.com1304bb22013-03-13 20:29:41 +00004124 if (!typeof fragType == 'number' || fragType < 1 || fragType > FRAG_TYPE_LAST) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004125 console.log("unknown in range frag type: " + fragType);
4126 throw "stop execution";
caryclark@google.com0b7da432012-10-31 19:00:20 +00004127 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004128 var frags = records[recordIndex + 1];
4129 var first = 0;
4130 var last = -1;
4131 var first2 = 0;
4132 var last2 = 0;
4133 switch (recType) {
4134 case REC_TYPE_COMPUTED:
caryclark@google.com1304bb22013-03-13 20:29:41 +00004135 if (fragType == COMPUTED_SET_1 || fragType == COMPUTED_SET_2) {
4136 break;
4137 }
4138 hasComputedPath = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004139 case REC_TYPE_PATH:
4140 switch (fragType) {
4141 case PATH_LINE:
4142 last = 4;
4143 break;
4144 case PATH_QUAD:
4145 last = 6;
4146 break;
4147 case PATH_CUBIC:
4148 last = 8;
4149 break;
4150 default:
4151 console.log("unknown " + (recType == REC_TYPE_PATH ? "REC_TYPE_PATH"
4152 : "REC_TYPE_COMPUTED") + " frag type:" + fragType);
4153 throw "stop execution";
4154 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00004155 if (recType == REC_TYPE_PATH) {
4156 hasPath = true;
4157 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004158 break;
4159 case REC_TYPE_ACTIVE:
4160 first = 1;
4161 switch (fragType) {
4162 case ACTIVE_LINE_SPAN:
4163 last = 5;
4164 break;
4165 case ACTIVE_QUAD_SPAN:
4166 last = 7;
4167 break;
4168 case ACTIVE_CUBIC_SPAN:
4169 last = 9;
4170 break;
4171 default:
4172 console.log("unknown REC_TYPE_ACTIVE frag type: " + fragType);
4173 throw "stop execution";
4174 }
4175 break;
4176 case REC_TYPE_ADD:
4177 switch (fragType) {
4178 case ADD_MOVETO:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004179 break;
4180 case ADD_LINETO:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004181 last = 4;
4182 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004183 case ADD_QUADTO:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004184 last = 6;
4185 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004186 case ADD_CUBICTO:
4187 last = 8;
4188 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004189 case ADD_CLOSE:
4190 break;
4191 default:
4192 console.log("unknown REC_TYPE_ADD frag type: " + fragType);
4193 throw "stop execution";
4194 }
4195 break;
4196 case REC_TYPE_SECT:
4197 switch (fragType) {
4198 case INTERSECT_LINE:
4199 first = 1; last = 5; first2 = 8; last2 = 12;
4200 break;
4201 case INTERSECT_LINE_2:
4202 first = 1; last = 5; first2 = 11; last2 = 15;
4203 break;
4204 case INTERSECT_LINE_NO:
4205 first = 0; last = 4; first2 = 4; last2 = 8;
4206 break;
4207 case INTERSECT_QUAD_LINE:
4208 first = 1; last = 7; first2 = 10; last2 = 14;
4209 break;
4210 case INTERSECT_QUAD_LINE_2:
4211 first = 1; last = 7; first2 = 13; last2 = 17;
4212 break;
4213 case INTERSECT_QUAD_LINE_NO:
4214 first = 0; last = 6; first2 = 6; last2 = 10;
4215 break;
4216 case INTERSECT_QUAD:
4217 first = 1; last = 7; first2 = 10; last2 = 16;
4218 break;
4219 case INTERSECT_QUAD_2:
4220 first = 1; last = 7; first2 = 13; last2 = 19;
4221 break;
4222 case INTERSECT_QUAD_NO:
4223 first = 0; last = 6; first2 = 6; last2 = 12;
4224 break;
4225 case INTERSECT_SELF_CUBIC:
4226 first = 1; last = 9;
4227 break;
4228 case INTERSECT_SELF_CUBIC_NO:
4229 first = 0; last = 8;
4230 break;
4231 case INTERSECT_CUBIC_LINE:
4232 first = 1; last = 9; first2 = 12; last2 = 16;
4233 break;
4234 case INTERSECT_CUBIC_LINE_2:
4235 first = 1; last = 9; first2 = 15; last2 = 19;
4236 break;
4237 case INTERSECT_CUBIC_LINE_3:
4238 first = 1; last = 9; first2 = 18; last2 = 22;
4239 break;
4240 case INTERSECT_CUBIC_LINE_NO:
4241 first = 0; last = 8; first2 = 8; last2 = 12;
4242 break;
4243 case INTERSECT_CUBIC:
4244 first = 1; last = 9; first2 = 12; last2 = 20;
4245 break;
4246 case INTERSECT_CUBIC_2:
4247 first = 1; last = 9; first2 = 15; last2 = 23;
4248 break;
4249 case INTERSECT_CUBIC_3:
4250 first = 1; last = 9; first2 = 18; last2 = 26;
4251 break;
4252 case INTERSECT_CUBIC_4:
4253 first = 1; last = 9; first2 = 21; last2 = 29;
4254 break;
4255 case INTERSECT_CUBIC_NO:
4256 first = 0; last = 8; first2 = 8; last2 = 16;
4257 break;
4258 default:
4259 console.log("unknown REC_TYPE_SECT frag type: " + fragType);
4260 throw "stop execution";
4261 }
4262 break;
4263 default:
4264 continue;
caryclark@google.com0b7da432012-10-31 19:00:20 +00004265 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004266 for (var idx = first; idx < last; idx += 2) {
4267 xmin = Math.min(xmin, frags[idx]);
4268 xmax = Math.max(xmax, frags[idx]);
4269 ymin = Math.min(ymin, frags[idx + 1]);
4270 ymax = Math.max(ymax, frags[idx + 1]);
caryclark@google.com0b7da432012-10-31 19:00:20 +00004271 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004272 for (var idx = first2; idx < last2; idx += 2) {
4273 xmin = Math.min(xmin, frags[idx]);
4274 xmax = Math.max(xmax, frags[idx]);
4275 ymin = Math.min(ymin, frags[idx + 1]);
4276 ymax = Math.max(ymax, frags[idx + 1]);
caryclark@google.com0b7da432012-10-31 19:00:20 +00004277 }
4278 }
caryclark@google.comf839c032012-10-26 21:03:50 +00004279 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004280 setScale();
caryclark@google.com1304bb22013-03-13 20:29:41 +00004281 if (hasPath == false && hasComputedPath == true && !draw_computed) {
4282 draw_computed = 3; // show both quadratics and cubics
4283 }
4284 if (hasPath == true && hasComputedPath == false && draw_computed) {
4285 draw_computed = 0;
4286 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004287}
4288
4289function setScale() {
4290 var srcWidth = xmax - xmin;
4291 var srcHeight = ymax - ymin;
caryclark@google.comf839c032012-10-26 21:03:50 +00004292 var hscale = ctx.canvas.width / srcWidth;
4293 var vscale = ctx.canvas.height / srcHeight;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004294 scale = Math.min(hscale, vscale);
4295 var invScale = 1 / scale;
4296 var sxmin = xmin - invScale * 5;
4297 var symin = ymin - invScale * 10;
4298 var sxmax = xmax + invScale * (6 * decimal_places + 10);
4299 var symax = ymax + invScale * 10;
4300 srcWidth = sxmax - sxmin;
4301 srcHeight = symax - symin;
4302 hscale = ctx.canvas.width / srcWidth;
4303 vscale = ctx.canvas.height / srcHeight;
4304 scale = Math.min(hscale, vscale);
4305 srcLeft = sxmin;
4306 srcTop = symin;
caryclark@google.comf839c032012-10-26 21:03:50 +00004307}
4308
caryclark@google.com1304bb22013-03-13 20:29:41 +00004309function drawPoint(px, py, end) {
caryclark@google.comf839c032012-10-26 21:03:50 +00004310 for (var pts = 0; pts < drawnPts.length; pts += 2) {
4311 var x = drawnPts[pts];
4312 var y = drawnPts[pts + 1];
4313 if (px == x && py == y) {
4314 return;
4315 }
4316 }
4317 drawnPts.push(px);
4318 drawnPts.push(py);
4319 var label = px.toFixed(decimal_places) + ", " + py.toFixed(decimal_places);
caryclark@google.com1304bb22013-03-13 20:29:41 +00004320 var _px = (px - srcLeft) * scale;
caryclark@google.comf839c032012-10-26 21:03:50 +00004321 var _py = (py - srcTop) * scale;
4322 ctx.beginPath();
4323 ctx.arc(_px, _py, 3, 0, Math.PI*2, true);
4324 ctx.closePath();
caryclark@google.com1304bb22013-03-13 20:29:41 +00004325 if (end) {
4326 ctx.fill();
4327 } else {
4328 ctx.stroke();
4329 }
4330 ctx.textAlign = "left";
caryclark@google.comf839c032012-10-26 21:03:50 +00004331 ctx.fillText(label, _px + 5, _py);
4332}
4333
caryclark@google.com1304bb22013-03-13 20:29:41 +00004334function drawPoints(ptArray, curveType, drawControls) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004335 var count = (curveType - PATH_LINE + 2) * 2;
4336 for (var idx = 0; idx < count; idx += 2) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00004337 if (!drawControls && idx != 0 && idx != count - 2) {
4338 continue;
4339 }
4340 drawPoint(ptArray[idx], ptArray[idx + 1], idx == 0 || idx == count - 2);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004341 }
4342}
4343
caryclark@google.com1304bb22013-03-13 20:29:41 +00004344function drawControlLines(curve, curveType, drawEnd) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004345 if (curveType == PATH_LINE) {
4346 return;
4347 }
4348 ctx.strokeStyle = "rgba(0,0,0, 0.3)";
4349 drawLine(curve[0], curve[1], curve[2], curve[3]);
4350 drawLine(curve[2], curve[3], curve[4], curve[5]);
caryclark@google.com1304bb22013-03-13 20:29:41 +00004351 if (curveType == PATH_CUBIC) {
4352 drawLine(curve[4], curve[5], curve[6], curve[7]);
4353 if (drawEnd > 1) {
4354 drawLine(curve[6], curve[7], curve[0], curve[1]);
4355 if (drawEnd > 2) {
4356 drawLine(curve[0], curve[1], curve[4], curve[5]);
4357 drawLine(curve[6], curve[7], curve[2], curve[3]);
4358 }
4359 }
4360 } else if (drawEnd > 1) {
4361 drawLine(curve[4], curve[5], curve[0], curve[1]);
4362 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004363}
4364
caryclark@google.com1304bb22013-03-13 20:29:41 +00004365function pointAtT(curve, curveType, t) {
4366 var xy = {};
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004367 switch (curveType) {
4368 case PATH_LINE:
4369 var a = 1 - t;
4370 var b = t;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004371 xy.x = a * curve[0] + b * curve[2];
4372 xy.y = a * curve[1] + b * curve[3];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004373 break;
4374 case PATH_QUAD:
4375 var one_t = 1 - t;
4376 var a = one_t * one_t;
4377 var b = 2 * one_t * t;
4378 var c = t * t;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004379 xy.x = a * curve[0] + b * curve[2] + c * curve[4];
4380 xy.y = a * curve[1] + b * curve[3] + c * curve[5];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004381 break;
4382 case PATH_CUBIC:
4383 var one_t = 1 - t;
4384 var one_t2 = one_t * one_t;
4385 var a = one_t2 * one_t;
4386 var b = 3 * one_t2 * t;
4387 var t2 = t * t;
4388 var c = 3 * one_t * t2;
4389 var d = t2 * t;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004390 xy.x = a * curve[0] + b * curve[2] + c * curve[4] + d * curve[6];
4391 xy.y = a * curve[1] + b * curve[3] + c * curve[5] + d * curve[7];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004392 break;
4393 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00004394 return xy;
4395}
4396
4397function drawPointAtT(curve, curveType) {
4398 var x, y;
4399 var xy = pointAtT(curve, curveType, curveT);
4400 drawPoint(xy.x, xy.y, true);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004401 if (!draw_intersectT) {
4402 return;
4403 }
4404 ctx.fillStyle = "red";
caryclark@google.com1304bb22013-03-13 20:29:41 +00004405 drawTAtPointUp(xy.x, xy.y, curveT);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004406}
4407
4408function drawTAtPointUp(px, py, t) {
4409 var label = t.toFixed(decimal_places);
4410 var _px = (px - srcLeft)* scale;
4411 var _py = (py - srcTop) * scale;
4412 ctx.fillText(label, _px + 5, _py - 10);
4413}
4414
4415function drawTAtPointDown(px, py, t) {
4416 var label = t.toFixed(decimal_places);
4417 var _px = (px - srcLeft)* scale;
4418 var _py = (py - srcTop) * scale;
4419 ctx.fillText(label, _px + 5, _py + 10);
4420}
4421
caryclark@google.com1304bb22013-03-13 20:29:41 +00004422function alreadyDrawnLine(x1, y1, x2, y2) {
caryclark@google.com0b7da432012-10-31 19:00:20 +00004423 for (var pts = 0; pts < drawnLines.length; pts += 4) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00004424 if (x1 == drawnLines[pts] && y1 == drawnLines[pts + 1]
4425 && x2 == drawnLines[pts + 2] && y2 == drawnLines[pts + 3]) {
4426 return true;
caryclark@google.com0b7da432012-10-31 19:00:20 +00004427 }
4428 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004429 drawnLines.push(x1);
4430 drawnLines.push(y1);
4431 drawnLines.push(x2);
4432 drawnLines.push(y2);
caryclark@google.com1304bb22013-03-13 20:29:41 +00004433 return false;
4434}
4435
4436function drawLine(x1, y1, x2, y2) {
4437 if (alreadyDrawnLine(x1, y1, x2, y2)) {
4438 return;
4439 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004440 ctx.beginPath();
4441 ctx.moveTo((x1 - srcLeft) * scale,
4442 (y1 - srcTop) * scale);
4443 ctx.lineTo((x2 - srcLeft) * scale,
4444 (y2 - srcTop) * scale);
4445 ctx.stroke();
caryclark@google.com0b7da432012-10-31 19:00:20 +00004446}
4447
caryclark@google.com1304bb22013-03-13 20:29:41 +00004448function linePartial(x1, y1, x2, y2, t1, t2) {
caryclark@google.com47d73da2013-02-17 01:41:25 +00004449 var dx = x1 - x2;
4450 var dy = y1 - y2;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004451 var array = [
4452 x1 - t1 * dx,
4453 y1 - t1 * dy,
4454 x1 - t2 * dx,
4455 y1 - t2 * dy
4456 ];
4457 return array;
4458}
4459
4460function drawLinePartial(x1, y1, x2, y2, t1, t2) {
4461 var a = linePartial(x1, y1, x2, y2, t1, t2);
4462 var ax = a[0];
4463 var ay = a[1];
4464 var bx = a[2];
4465 var by = a[3];
4466 if (alreadyDrawnLine(ax, ay, bx, by)) {
4467 return;
4468 }
caryclark@google.com47d73da2013-02-17 01:41:25 +00004469 ctx.beginPath();
4470 ctx.moveTo((ax - srcLeft) * scale,
4471 (ay - srcTop) * scale);
4472 ctx.lineTo((bx - srcLeft) * scale,
4473 (by - srcTop) * scale);
4474 ctx.stroke();
4475}
4476
caryclark@google.com1304bb22013-03-13 20:29:41 +00004477function alreadyDrawnQuad(x1, y1, x2, y2, x3, y3) {
caryclark@google.com0b7da432012-10-31 19:00:20 +00004478 for (var pts = 0; pts < drawnQuads.length; pts += 6) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00004479 if (x1 == drawnQuads[pts] && y1 == drawnQuads[pts + 1]
4480 && x2 == drawnQuads[pts + 2] && y2 == drawnQuads[pts + 3]
4481 && x3 == drawnQuads[pts + 4] && x3 == drawnQuads[pts + 5]) {
4482 return true;
caryclark@google.com0b7da432012-10-31 19:00:20 +00004483 }
4484 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004485 drawnQuads.push(x1);
4486 drawnQuads.push(y1);
4487 drawnQuads.push(x2);
4488 drawnQuads.push(y2);
4489 drawnQuads.push(x3);
4490 drawnQuads.push(y3);
caryclark@google.com1304bb22013-03-13 20:29:41 +00004491 return false;
4492}
4493
4494function drawQuad(x1, y1, x2, y2, x3, y3) {
4495 if (alreadyDrawnQuad(x1, y1, x2, y2, x3, y3)) {
4496 return;
4497 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004498 ctx.beginPath();
4499 ctx.moveTo((x1 - srcLeft) * scale,
4500 (y1 - srcTop) * scale);
4501 ctx.quadraticCurveTo((x2 - srcLeft) * scale,
4502 (y2 - srcTop) * scale,
4503 (x3 - srcLeft) * scale,
4504 (y3 - srcTop) * scale);
4505 ctx.stroke();
caryclark@google.com0b7da432012-10-31 19:00:20 +00004506}
4507
caryclark@google.com47d73da2013-02-17 01:41:25 +00004508function interp(A, B, t) {
4509 return A + (B - A) * t;
4510}
4511
4512function interp_quad_coords(x1, x2, x3, t)
4513{
4514 var ab = interp(x1, x2, t);
4515 var bc = interp(x2, x3, t);
4516 var abc = interp(ab, bc, t);
4517 return abc;
4518}
4519
caryclark@google.com1304bb22013-03-13 20:29:41 +00004520function quadPartial(x1, y1, x2, y2, x3, y3, t1, t2) {
caryclark@google.com47d73da2013-02-17 01:41:25 +00004521 var ax = interp_quad_coords(x1, x2, x3, t1);
4522 var ay = interp_quad_coords(y1, y2, y3, t1);
4523 var dx = interp_quad_coords(x1, x2, x3, (t1 + t2) / 2);
4524 var dy = interp_quad_coords(y1, y2, y3, (t1 + t2) / 2);
4525 var cx = interp_quad_coords(x1, x2, x3, t2);
4526 var cy = interp_quad_coords(y1, y2, y3, t2);
4527 var bx = 2*dx - (ax + cx)/2;
4528 var by = 2*dy - (ay + cy)/2;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004529 var array = [
4530 ax, ay, bx, by, cx, cy
4531 ];
4532 return array;
4533}
4534
4535function drawQuadPartial(x1, y1, x2, y2, x3, y3, t1, t2) {
4536 var a = quadPartial(x1, y1, x2, y2, x3, y3, t1, t2);
4537 var ax = a[0];
4538 var ay = a[1];
4539 var bx = a[2];
4540 var by = a[3];
4541 var cx = a[4];
4542 var cy = a[5];
4543 if (alreadyDrawnQuad(ax, ay, bx, by, cx, cy)) {
4544 return;
4545 }
caryclark@google.com47d73da2013-02-17 01:41:25 +00004546 ctx.beginPath();
4547 ctx.moveTo((ax - srcLeft) * scale,
4548 (ay - srcTop) * scale);
4549 ctx.quadraticCurveTo((bx - srcLeft) * scale,
4550 (by - srcTop) * scale,
4551 (cx - srcLeft) * scale,
4552 (cy - srcTop) * scale);
4553 ctx.stroke();
4554}
4555
caryclark@google.com1304bb22013-03-13 20:29:41 +00004556function alreadyDrawnCubic(x1, y1, x2, y2, x3, y3, x4, y4) {
caryclark@google.com47d73da2013-02-17 01:41:25 +00004557 for (var pts = 0; pts < drawnCubics.length; pts += 8) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00004558 if (x1 == drawnCubics[pts] && y1 == drawnCubics[pts + 1]
4559 && x2 == drawnCubics[pts + 2] && y2 == drawnCubics[pts + 3]
4560 && x3 == drawnCubics[pts + 4] && y3 == drawnCubics[pts + 5]
4561 && x4 == drawnCubics[pts + 6] && y4 == drawnCubics[pts + 7]) {
4562 return true;
caryclark@google.com47d73da2013-02-17 01:41:25 +00004563 }
4564 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004565 drawnCubics.push(x1);
4566 drawnCubics.push(y1);
4567 drawnCubics.push(x2);
4568 drawnCubics.push(y2);
4569 drawnCubics.push(x3);
4570 drawnCubics.push(y3);
4571 drawnCubics.push(x4);
4572 drawnCubics.push(y4);
caryclark@google.com1304bb22013-03-13 20:29:41 +00004573 return false;
4574}
4575
4576function drawCubic(x1, y1, x2, y2, x3, y3, x4, y4) {
4577 if (alreadyDrawnCubic(x1, y1, x2, y2, x3, y3, x4, y4)) {
4578 return;
4579 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004580 ctx.beginPath();
4581 ctx.moveTo((x1 - srcLeft) * scale,
4582 (y1 - srcTop) * scale);
4583 ctx.bezierCurveTo((x2 - srcLeft) * scale,
4584 (y2 - srcTop) * scale,
4585 (x3 - srcLeft) * scale,
4586 (y3 - srcTop) * scale,
4587 (x4 - srcLeft) * scale,
4588 (y4 - srcTop) * scale);
4589 ctx.stroke();
caryclark@google.com47d73da2013-02-17 01:41:25 +00004590}
4591
4592function interp_cubic_coords(x1, x2, x3, x4, t)
4593{
4594 var ab = interp(x1, x2, t);
4595 var bc = interp(x2, x3, t);
4596 var cd = interp(x3, x4, t);
4597 var abc = interp(ab, bc, t);
4598 var bcd = interp(bc, cd, t);
4599 var abcd = interp(abc, bcd, t);
4600 return abcd;
4601}
4602
caryclark@google.com1304bb22013-03-13 20:29:41 +00004603function cubicPartial(x1, y1, x2, y2, x3, y3, x4, y4, t1, t2) {
caryclark@google.com47d73da2013-02-17 01:41:25 +00004604 var ax = interp_cubic_coords(x1, x2, x3, x4, t1);
4605 var ay = interp_cubic_coords(y1, y2, y3, y4, t1);
4606 var ex = interp_cubic_coords(x1, x2, x3, x4, (t1*2+t2)/3);
4607 var ey = interp_cubic_coords(y1, y2, y3, y4, (t1*2+t2)/3);
4608 var fx = interp_cubic_coords(x1, x2, x3, x4, (t1+t2*2)/3);
4609 var fy = interp_cubic_coords(y1, y2, y3, y4, (t1+t2*2)/3);
4610 var dx = interp_cubic_coords(x1, x2, x3, x4, t2);
4611 var dy = interp_cubic_coords(y1, y2, y3, y4, t2);
4612 var mx = ex * 27 - ax * 8 - dx;
4613 var my = ey * 27 - ay * 8 - dy;
4614 var nx = fx * 27 - ax - dx * 8;
4615 var ny = fy * 27 - ay - dy * 8;
4616 var bx = (mx * 2 - nx) / 18;
4617 var by = (my * 2 - ny) / 18;
4618 var cx = (nx * 2 - mx) / 18;
4619 var cy = (ny * 2 - my) / 18;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004620 var array = [
4621 ax, ay, bx, by, cx, cy, dx, dy
4622 ];
4623 return array;
4624}
4625
4626function drawCubicPartial(x1, y1, x2, y2, x3, y3, x4, y4, t1, t2) {
4627 var a = cubicPartial(x1, y1, x2, y2, x3, y3, x4, y4, t1, t2);
4628 var ax = a[0];
4629 var ay = a[1];
4630 var bx = a[2];
4631 var by = a[3];
4632 var cx = a[4];
4633 var cy = a[5];
4634 var dx = a[6];
4635 var dy = a[7];
4636 if (alreadyDrawnCubic(ax, ay, bx, by, cx, cy, dx, dy)) {
4637 return;
4638 }
caryclark@google.com47d73da2013-02-17 01:41:25 +00004639 ctx.beginPath();
4640 ctx.moveTo((ax - srcLeft) * scale,
4641 (ay - srcTop) * scale);
4642 ctx.bezierCurveTo((bx - srcLeft) * scale,
4643 (by - srcTop) * scale,
4644 (cx - srcLeft) * scale,
4645 (cy - srcTop) * scale,
4646 (dx - srcLeft) * scale,
caryclark@google.com1304bb22013-03-13 20:29:41 +00004647 (dy - srcTop) * scale);
caryclark@google.com47d73da2013-02-17 01:41:25 +00004648 ctx.stroke();
4649}
4650
caryclark@google.com1304bb22013-03-13 20:29:41 +00004651function boundsWidth(pts) {
4652 var min = pts[0];
4653 var max = pts[0];
4654 for (var idx = 2; idx < pts.length; idx += 2) {
4655 min = Math.min(min, pts[idx]);
4656 max = Math.max(max, pts[idx]);
4657 }
4658 return max - min;
4659}
4660
4661function boundsHeight(pts) {
4662 var min = pts[1];
4663 var max = pts[1];
4664 for (var idx = 3; idx < pts.length; idx += 2) {
4665 min = Math.min(min, pts[idx]);
4666 max = Math.max(max, pts[idx]);
4667 }
4668 return max - min;
4669}
4670
4671function tangent(pts) {
4672 var dx = pts[2] - pts[0];
4673 var dy = pts[3] - pts[1];
4674 if (dx == 0 && dy == 0 && pts.length > 4) {
4675 dx = pts[4] - pts[0];
4676 dy = pts[5] - pts[1];
4677 if (dx == 0 && dy == 0 && pts.length > 6) {
4678 dx = pts[6] - pts[0];
4679 dy = pts[7] - pts[1];
4680 }
4681 }
4682 return Math.atan2(-dy, dx);
4683}
4684
4685function hodograph(cubic) {
4686 var hodo = [];
4687 hodo[0] = 3 * (cubic[2] - cubic[0]);
4688 hodo[1] = 3 * (cubic[3] - cubic[1]);
4689 hodo[2] = 3 * (cubic[4] - cubic[2]);
4690 hodo[3] = 3 * (cubic[5] - cubic[3]);
4691 hodo[4] = 3 * (cubic[6] - cubic[4]);
4692 hodo[5] = 3 * (cubic[7] - cubic[5]);
4693 return hodo;
4694}
4695
4696function hodograph2(cubic) {
4697 var quad = hodograph(cubic);
4698 var hodo = [];
4699 hodo[0] = 2 * (quad[2] - quad[0]);
4700 hodo[1] = 2 * (quad[3] - quad[1]);
4701 hodo[2] = 2 * (quad[4] - quad[2]);
4702 hodo[3] = 2 * (quad[5] - quad[3]);
4703 return hodo;
4704}
4705
4706function quadraticRootsReal(A, B, C, s) {
4707 if (A == 0) {
4708 if (B == 0) {
4709 s[0] = 0;
4710 return C == 0;
4711 }
4712 s[0] = -C / B;
4713 return 1;
4714 }
4715 /* normal form: x^2 + px + q = 0 */
4716 var p = B / (2 * A);
4717 var q = C / A;
4718 var p2 = p * p;
4719 if (p2 < q) {
4720 return 0;
4721 }
4722 var sqrt_D = 0;
4723 if (p2 > q) {
4724 sqrt_D = sqrt(p2 - q);
4725 }
4726 s[0] = sqrt_D - p;
4727 s[1] = -sqrt_D - p;
4728 return 1 + s[0] != s[1];
4729}
4730
4731function add_valid_ts(s, realRoots, t) {
4732 var foundRoots = 0;
4733 for (var index = 0; index < realRoots; ++index) {
4734 var tValue = s[index];
4735 if (tValue >= 0 && tValue <= 1) {
4736 for (var idx2 = 0; idx2 < foundRoots; ++idx2) {
4737 if (t[idx2] != tValue) {
4738 t[foundRoots++] = tValue;
4739 }
4740 }
4741 }
4742 }
4743 return foundRoots;
4744}
4745
4746function quadraticRootsValidT(a, b, c, t) {
4747 var s = [];
4748 var realRoots = quadraticRootsReal(A, B, C, s);
4749 var foundRoots = add_valid_ts(s, realRoots, t);
4750 return foundRoots != 0;
4751}
4752
4753function find_cubic_inflections(cubic, tValues) {
4754 var Ax = src[2] - src[0];
4755 var Ay = src[3] - src[1];
4756 var Bx = src[4] - 2 * src[2] + src[0];
4757 var By = src[5] - 2 * src[3] + src[1];
4758 var Cx = src[6] + 3 * (src[2] - src[4]) - src[0];
4759 var Cy = src[7] + 3 * (src[3] - src[5]) - src[1];
4760 return quadraticRootsValidT(Bx * Cy - By * Cx, (Ax * Cy - Ay * Cx),
4761 Ax * By - Ay * Bx, tValues);
4762}
4763
4764function dxy_at_t(curve, type, t) {
4765 var dxy = {};
4766 if (type == PATH_QUAD) {
4767 var a = t - 1;
4768 var b = 1 - 2 * t;
4769 var c = t;
4770 dxy.x = a * curve[0] + b * curve[2] + c * curve[4];
4771 dxy.y = a * curve[1] + b * curve[3] + c * curve[5];
4772 } else if (type == PATH_CUBIC) {
4773 var one_t = 1 - t;
4774 var a = curve[0];
4775 var b = curve[2];
4776 var c = curve[4];
4777 var d = curve[6];
4778 dxy.x = 3 * ((b - a) * one_t * one_t + 2 * (c - b) * t * one_t + (d - c) * t * t);
4779 a = curve[1];
4780 b = curve[3];
4781 c = curve[5];
4782 d = curve[7];
4783 dxy.y = 3 * ((b - a) * one_t * one_t + 2 * (c - b) * t * one_t + (d - c) * t * t);
4784 }
4785 return dxy;
4786}
4787
4788function drawLabel(num, px, py) {
4789 ctx.beginPath();
4790 ctx.arc(px, py, 8, 0, Math.PI*2, true);
4791 ctx.closePath();
4792 ctx.strokeStyle = "rgba(0,0,0, 0.4)";
4793 ctx.lineWidth = num == 0 || num == 3 ? 2 : 1;
4794 ctx.stroke();
4795 ctx.fillStyle = "black";
4796 ctx.font = "normal 10px Arial";
4797 // ctx.rotate(0.001);
4798 ctx.fillText(num, px - 2, py + 3);
4799 // ctx.rotate(-0.001);
4800}
4801
4802function drawLabelX(ymin, num, loc) {
4803 var px = (loc - srcLeft) * scale;
4804 var py = (ymin - srcTop) * scale - 20;
4805 drawLabel(num, px, py);
4806}
4807
4808function drawLabelY(xmin, num, loc) {
4809 var px = (xmin - srcLeft) * scale - 20;
4810 var py = (loc - srcTop) * scale;
4811 drawLabel(num, px, py);
4812}
4813
4814function drawHodoOrigin(hx, hy, hMinX, hMinY, hMaxX, hMaxY) {
4815 ctx.beginPath();
4816 ctx.moveTo(hx, hy - 100);
4817 ctx.lineTo(hx, hy);
4818 ctx.strokeStyle = hMinY < 0 ? "green" : "blue";
4819 ctx.stroke();
4820 ctx.beginPath();
4821 ctx.moveTo(hx, hy);
4822 ctx.lineTo(hx, hy + 100);
4823 ctx.strokeStyle = hMaxY > 0 ? "green" : "blue";
4824 ctx.stroke();
4825 ctx.beginPath();
4826 ctx.moveTo(hx - 100, hy);
4827 ctx.lineTo(hx, hy);
4828 ctx.strokeStyle = hMinX < 0 ? "green" : "blue";
4829 ctx.stroke();
4830 ctx.beginPath();
4831 ctx.moveTo(hx, hy);
4832 ctx.lineTo(hx + 100, hy);
4833 ctx.strokeStyle = hMaxX > 0 ? "green" : "blue";
4834 ctx.stroke();
4835}
4836
4837function scalexy(x, y, mag) {
4838 var length = Math.sqrt(x * x + y * y);
4839 return mag / length;
4840}
4841
4842function drawArrow(x, y, dx, dy) {
4843 var dscale = scalexy(dx, dy, 1 / scale * 100);
4844 dx *= dscale;
4845 dy *= dscale;
4846 ctx.beginPath();
4847 ctx.moveTo((x - srcLeft) * scale, (y - srcTop) * scale);
4848 x += dx;
4849 y += dy;
4850 ctx.lineTo((x - srcLeft) * scale, (y - srcTop) * scale);
4851 dx /= 10;
4852 dy /= 10;
4853 ctx.lineTo((x - dy - srcLeft) * scale, (y + dx - srcTop) * scale);
4854 ctx.lineTo((x + dx * 2 - srcLeft) * scale, (y + dy * 2 - srcTop) * scale);
4855 ctx.lineTo((x + dy - srcLeft) * scale, (y - dx - srcTop) * scale);
4856 ctx.lineTo((x - srcLeft) * scale, (y - srcTop) * scale);
4857 ctx.strokeStyle = "rgba(0,75,0, 0.4)";
4858 ctx.stroke();
4859}
4860
4861function drawCurveSpecials(curve, type) {
4862 if (pt_labels) {
4863 drawPoints(curve, type, pt_labels == 2);
4864 }
4865 if (control_lines != 0) {
4866 drawControlLines(curve, type, control_lines);
4867 }
4868 if (curve_t) {
4869 drawPointAtT(curve, type);
4870 }
4871 if (draw_midpoint) {
4872 var mid = pointAtT(curve, type, 0.5);
4873 drawPoint(mid.x, mid.y, true);
4874 }
4875 if (type == PATH_LINE) {
4876 return;
4877 }
4878 if (draw_deriviatives > 0) {
4879 var d = dxy_at_t(curve, type, 0);
4880 drawArrow(curve[0], curve[1], d.x, d.y);
4881 if (draw_deriviatives == 2) {
4882 d = dxy_at_t(curve, type, 1);
4883 if (type == PATH_CUBIC) {
4884 drawArrow(curve[6], curve[7], d.x, d.y);
4885 } else {
4886 drawArrow(curve[4], curve[5], d.x, d.y);
4887 }
4888 }
4889 if (draw_midpoint) {
4890 var mid = pointAtT(curve, 0.5);
4891 d = dxy_at_t(curve, type, 0.5);
4892 drawArrow(mid.x, mid.y, d.x, d.y);
4893 }
4894 }
4895 if (type != PATH_CUBIC) {
4896 return;
4897 }
4898 if (draw_hodo == 1 || draw_hodo == 2) {
4899 var hodo = hodograph(curve);
4900 var hMinX = Math.min(0, hodo[0], hodo[2], hodo[4]);
4901 var hMinY = Math.min(0, hodo[1], hodo[3], hodo[5]);
4902 var hMaxX = Math.max(0, hodo[0], hodo[2], hodo[4]);
4903 var hMaxY = Math.max(0, hodo[1], hodo[3], hodo[5]);
4904 var hScaleX = hMaxX - hMinX > 0 ? ctx.canvas.width / (hMaxX - hMinX) : 1;
4905 var hScaleY = hMaxY - hMinY > 0 ? ctx.canvas.height / (hMaxY - hMinY) : 1;
4906 var hUnit = Math.min(hScaleX, hScaleY);
4907 hUnit /= 2;
4908 var hx = xoffset - hMinX * hUnit;
4909 var hy = yoffset - hMinY * hUnit;
4910 ctx.moveTo(hx + hodo[0] * hUnit, hy + hodo[1] * hUnit);
4911 ctx.quadraticCurveTo(
4912 hx + hodo[2] * hUnit, hy + hodo[3] * hUnit,
4913 hx + hodo[4] * hUnit, hy + hodo[5] * hUnit);
4914 ctx.strokeStyle = "red";
4915 ctx.stroke();
4916 if (draw_hodo == 1) {
4917 drawHodoOrigin(hx, hy, hMinX, hMinY, hMaxX, hMaxY);
4918 }
4919 }
4920 if (draw_hodo == 3) {
4921 var hodo = hodograph2(curve);
4922 var hMinX = Math.min(0, hodo[0], hodo[2]);
4923 var hMinY = Math.min(0, hodo[1], hodo[3]);
4924 var hMaxX = Math.max(0, hodo[0], hodo[2]);
4925 var hMaxY = Math.max(0, hodo[1], hodo[3]);
4926 var hScaleX = hMaxX - hMinX > 0 ? ctx.canvas.width / (hMaxX - hMinX) : 1;
4927 var hScaleY = hMaxY - hMinY > 0 ? ctx.canvas.height / (hMaxY - hMinY) : 1;
4928 var hUnit = Math.min(hScaleX, hScaleY);
4929 hUnit /= 2;
4930 var hx = xoffset - hMinX * hUnit;
4931 var hy = yoffset - hMinY * hUnit;
4932 ctx.moveTo(hx + hodo[0] * hUnit, hy + hodo[1] * hUnit);
4933 ctx.lineTo(hx + hodo[2] * hUnit, hy + hodo[3] * hUnit);
4934 ctx.strokeStyle = "red";
4935 ctx.stroke();
4936 drawHodoOrigin(hx, hy, hMinX, hMinY, hMaxX, hMaxY);
4937 }
4938 if (draw_sequence) {
4939 var ymin = Math.min(curve[1], curve[3], curve[5], curve[7]);
4940 for (var i = 0; i < 8; i+= 2) {
4941 drawLabelX(ymin, i >> 1, curve[i]);
4942 }
4943 var xmin = Math.min(curve[0], curve[2], curve[4], curve[6]);
4944 for (var i = 1; i < 8; i+= 2) {
4945 drawLabelY(xmin, i >> 1, curve[i]);
4946 }
4947 }
4948}
4949
4950function logCurves(test) {
4951 for (curves in test) {
4952 var curve = test[curves];
4953 if (curve.length != 8) {
4954 continue;
4955 }
4956 var str = "{{";
4957 for (i = 0; i < 8; i += 2) {
4958 str += curve[i].toFixed(decimal_places) + "," + curve[i + 1].toFixed(decimal_places);
4959 if (i < 6) {
4960 str += "}, {";
4961 }
4962 }
4963 str += "}}";
4964 console.log(str);
4965 }
4966}
4967
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004968function draw(test, lines, title) {
caryclark@google.comf839c032012-10-26 21:03:50 +00004969 ctx.fillStyle = "rgba(0,0,0, 0.1)";
4970 ctx.font = "normal 50px Arial";
caryclark@google.com1304bb22013-03-13 20:29:41 +00004971 ctx.textAlign = "left";
caryclark@google.comf839c032012-10-26 21:03:50 +00004972 ctx.fillText(title, 50, 50);
4973 ctx.font = "normal 10px Arial";
4974 ctx.lineWidth = "1.001"; "0.999";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004975 var secondPath = test.length;
4976 var closeCount = 0;
4977 var logStart = -1;
4978 var logRange = 0;
4979 // find last active rec type at this step
4980 var curType = test[0];
4981 var curStep = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004982 var hasOp = false;
4983 var lastActive = 0;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004984 var lastAdd = 0;
4985 var lastSect = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00004986 var lastSort = 0;
4987 var lastMark = 0;
caryclark@google.com1304bb22013-03-13 20:29:41 +00004988 activeCount = 0;
4989 addCount = 0;
4990 sectCount = 0;
4991 sortCount = 0;
4992 markCount = 0;
4993 activeMax = 0;
4994 addMax = 0;
4995 sectMax = 0;
4996 sectMax2 = 0;
4997 sortMax = 0;
4998 markMax = 0;
4999 lastIndex = test.length - 3;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005000 for (var testIndex = 0; testIndex < test.length; testIndex += 3) {
5001 var recType = test[testIndex];
5002 if (!typeof recType == 'number' || recType < REC_TYPE_UNKNOWN || recType > REC_TYPE_LAST) {
5003 console.log("unknown rec type: " + recType);
5004 throw "stop execution";
5005 }
5006 // if (curType == recType && curType != REC_TYPE_ADD) {
5007 // continue;
5008 // }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005009 var inStepRange = step_limit == 0 || curStep < step_limit;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005010 curType = recType;
5011 if (recType == REC_TYPE_OP) {
5012 hasOp = true;
5013 continue;
5014 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005015 if (recType == REC_TYPE_UNKNOWN) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005016 // these types do not advance step
5017 continue;
5018 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005019 var bumpStep = false;
5020 var records = test[testIndex + 2];
5021 var fragType = records[0];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005022 if (recType == REC_TYPE_ADD) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005023 if (records.length != 2) {
5024 console.log("expect only two elements: " + records.length);
5025 throw "stop execution";
5026 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005027 if (fragType == ADD_MOVETO || fragType == ADD_CLOSE) {
5028 continue;
5029 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005030 ++addMax;
5031 if (!draw_add || !inStepRange) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005032 continue;
5033 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005034 lastAdd = testIndex;
5035 ++addCount;
5036 bumpStep = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005037 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005038 if (recType == REC_TYPE_PATH && hasOp) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005039 secondPath = testIndex;
5040 }
5041 if (recType == REC_TYPE_ACTIVE) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005042 ++activeMax;
5043 if (!draw_active || !inStepRange) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005044 continue;
5045 }
5046 lastActive = testIndex;
5047 ++activeCount;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005048 bumpStep = true;
5049 }
5050 if (recType == REC_TYPE_SECT) {
5051 if (records.length != 2) {
5052 console.log("expect only two elements: " + records.length);
5053 throw "stop execution";
5054 }
5055 ++sectMax;
5056 var sectBump = 1;
5057 switch (fragType) {
5058 case INTERSECT_LINE:
5059 case INTERSECT_QUAD_LINE:
5060 case INTERSECT_QUAD:
5061 case INTERSECT_SELF_CUBIC:
5062 case INTERSECT_CUBIC_LINE:
5063 case INTERSECT_CUBIC:
5064 sectBump = 1;
5065 break;
5066 case INTERSECT_LINE_2:
5067 case INTERSECT_QUAD_LINE_2:
5068 case INTERSECT_QUAD_2:
5069 case INTERSECT_CUBIC_LINE_2:
5070 case INTERSECT_CUBIC_2:
5071 sectBump = 2;
5072 break;
5073 case INTERSECT_LINE_NO:
5074 case INTERSECT_QUAD_LINE_NO:
5075 case INTERSECT_QUAD_NO:
5076 case INTERSECT_SELF_CUBIC_NO:
5077 case INTERSECT_CUBIC_LINE_NO:
5078 case INTERSECT_CUBIC_NO:
5079 sectBump = 0;
5080 break;
5081 case INTERSECT_CUBIC_LINE_3:
5082 case INTERSECT_CUBIC_3:
5083 sectBump = 3;
5084 break;
5085 case INTERSECT_CUBIC_4:
5086 sectBump = 4;
5087 break;
5088 default:
5089 console.log("missing case " + records.length);
5090 throw "stop execution";
5091 }
5092 sectMax2 += sectBump;
5093 if (draw_intersection <= 1 || !inStepRange) {
5094 continue;
5095 }
5096 lastSect = testIndex;
5097 sectCount += sectBump;
5098 bumpStep = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005099 }
5100 if (recType == REC_TYPE_SORT) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005101 ++sortMax;
5102 if (!draw_sort || !inStepRange) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005103 continue;
5104 }
5105 lastSort = testIndex;
5106 ++sortCount;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005107 bumpStep = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005108 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005109 if (recType == REC_TYPE_MARK) {
5110 ++markMax;
5111 if (!draw_mark || !inStepRange) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005112 continue;
5113 }
5114 lastMark = testIndex;
5115 ++markCount;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005116 bumpStep = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005117 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005118 if (bumpStep) {
5119 lastIndex = testIndex;
5120 logStart = test[testIndex + 1];
5121 logRange = records.length / 2;
5122 ++curStep;
5123 }
5124 }
5125 stepMax = (draw_add ? addMax : 0) + (draw_active ? activeMax : 0)
5126 + (draw_sort ? sortMax : 0) + (draw_mark ? markMax : 0)
5127 + (draw_intersection == 2 ? sectMax : draw_intersection == 3 ? sectMax2 : 0);
5128 if (stepMax == 0) {
5129 stepMax = addMax + activeMax + sortMax + markMax;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005130 }
caryclark@google.comf839c032012-10-26 21:03:50 +00005131 drawnPts = [];
caryclark@google.com0b7da432012-10-31 19:00:20 +00005132 drawnLines = [];
5133 drawnQuads = [];
caryclark@google.com47d73da2013-02-17 01:41:25 +00005134 drawnCubics = [];
caryclark@google.com1304bb22013-03-13 20:29:41 +00005135 var pathIndex = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005136 var opLetter = 'S';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005137 for (var testIndex = lastIndex; testIndex >= 0; testIndex -= 3) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005138 var recType = test[testIndex];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005139 var records = test[testIndex + 2];
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005140 for (var recordIndex = 0; recordIndex < records.length; recordIndex += 2) {
5141 var fragType = records[recordIndex];
caryclark@google.com1304bb22013-03-13 20:29:41 +00005142 if (!typeof fragType == 'number' || fragType < 1 || fragType > FRAG_TYPE_LAST) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005143 console.log("unknown in range frag type: " + fragType);
5144 throw "stop execution";
caryclark@google.com0b7da432012-10-31 19:00:20 +00005145 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005146 var frags = records[recordIndex + 1];
5147 switch (recType) {
5148 case REC_TYPE_COMPUTED:
5149 if (draw_computed == 0) {
5150 continue;
5151 }
5152 ctx.lineWidth = 1;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005153 ctx.strokeStyle = pathIndex == 0 ? "black" : "red";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005154 ctx.fillStyle = "blue";
caryclark@google.com1304bb22013-03-13 20:29:41 +00005155 var drawThis = false;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005156 switch (fragType) {
5157 case PATH_QUAD:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005158 if ((draw_computed & 5) == 1 || ((draw_computed & 4) != 0
5159 && (draw_computed & 1) == pathIndex)) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005160 drawQuad(frags[0], frags[1], frags[2], frags[3],
5161 frags[4], frags[5]);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005162 drawThis = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005163 }
5164 break;
5165 case PATH_CUBIC:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005166 if ((draw_computed & 6) == 2 || ((draw_computed & 4) != 0
5167 && (draw_computed & 1) != pathIndex)) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005168 drawCubic(frags[0], frags[1], frags[2], frags[3],
5169 frags[4], frags[5], frags[6], frags[7]);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005170 drawThis = true;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005171 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005172 ++pathIndex;
5173 break;
5174 case COMPUTED_SET_1:
5175 pathIndex = 0;
5176 break;
5177 case COMPUTED_SET_2:
5178 pathIndex = 1;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005179 break;
5180 default:
5181 console.log("unknown REC_TYPE_COMPUTED frag type: " + fragType);
5182 throw "stop execution";
5183 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005184 if (!drawThis) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005185 break;
5186 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005187 drawCurveSpecials(frags, fragType);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005188 break;
5189 case REC_TYPE_PATH:
5190 if (!draw_path) {
5191 continue;
5192 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005193 var firstPath = testIndex < secondPath;
5194 if ((draw_path & (firstPath ? 1 : 2)) == 0) {
5195 continue;
5196 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005197 ctx.lineWidth = 1;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005198 ctx.strokeStyle = firstPath ? "black" : "red";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005199 ctx.fillStyle = "blue";
5200 switch (fragType) {
5201 case PATH_LINE:
5202 drawLine(frags[0], frags[1], frags[2], frags[3]);
5203 break;
5204 case PATH_QUAD:
5205 drawQuad(frags[0], frags[1], frags[2], frags[3],
5206 frags[4], frags[5]);
5207 break;
5208 case PATH_CUBIC:
5209 drawCubic(frags[0], frags[1], frags[2], frags[3],
5210 frags[4], frags[5], frags[6], frags[7]);
5211 break;
5212 default:
5213 console.log("unknown REC_TYPE_PATH frag type: " + fragType);
5214 throw "stop execution";
5215 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005216 drawCurveSpecials(frags, fragType);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005217 break;
5218 case REC_TYPE_OP:
5219 switch (fragType) {
5220 case OP_INTERSECT: opLetter = 'I'; break;
5221 case OP_DIFFERENCE: opLetter = 'D'; break;
5222 case OP_UNION: opLetter = 'U'; break;
5223 case OP_XOR: opLetter = 'X'; break;
5224 default:
5225 console.log("unknown REC_TYPE_OP frag type: " + fragType);
5226 throw "stop execution";
5227 }
5228 break;
5229 case REC_TYPE_ACTIVE:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005230 if (!draw_active || (step_limit > 0 && testIndex < lastActive)) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005231 continue;
5232 }
5233 var x1 = frags[SPAN_X1];
5234 var y1 = frags[SPAN_Y1];
5235 var x2 = frags[SPAN_X2];
5236 var y2 = frags[SPAN_Y2];
5237 var x3, y3, x3, y4, t1, t2;
5238 ctx.lineWidth = 3;
5239 ctx.strokeStyle = "rgba(0,0,255, 0.3)";
5240 switch (fragType) {
5241 case ACTIVE_LINE_SPAN:
5242 t1 = frags[SPAN_L_T];
5243 t2 = frags[SPAN_L_TEND];
5244 drawLinePartial(x1, y1, x2, y2, t1, t2);
5245 break;
5246 case ACTIVE_QUAD_SPAN:
5247 x3 = frags[SPAN_X3];
5248 y3 = frags[SPAN_Y3];
5249 t1 = frags[SPAN_Q_T];
5250 t2 = frags[SPAN_Q_TEND];
5251 drawQuadPartial(x1, y1, x2, y2, x3, y3, t1, t2);
5252 break;
5253 case ACTIVE_CUBIC_SPAN:
5254 x3 = frags[SPAN_X3];
5255 y3 = frags[SPAN_Y3];
5256 x4 = frags[SPAN_X4];
5257 y4 = frags[SPAN_Y4];
5258 t1 = frags[SPAN_C_T];
5259 t2 = frags[SPAN_C_TEND];
5260 drawCubicPartial(x1, y1, x2, y2, x3, y3, x4, y4, t1, t2);
5261 break;
5262 default:
5263 console.log("unknown REC_TYPE_ACTIVE frag type: " + fragType);
5264 throw "stop execution";
5265 }
5266 break;
5267 case REC_TYPE_ADD:
5268 if (!draw_add) {
5269 continue;
5270 }
5271 ctx.lineWidth = 3;
5272 ctx.strokeStyle = closeCount == 0 ? "rgba(0,0,255, 0.3)"
5273 : closeCount == 1 ? "rgba(0,127,0, 0.3)"
5274 : closeCount == 2 ? "rgba(0,127,127, 0.3)"
5275 : closeCount == 3 ? "rgba(127,127,0, 0.3)"
5276 : "rgba(127,0,127, 0.3)";
5277 switch (fragType) {
5278 case ADD_MOVETO:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005279 break;
5280 case ADD_LINETO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005281 if (step_limit == 0 || testIndex >= lastAdd) {
5282 drawLine(frags[0], frags[1], frags[2], frags[3]);
5283 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005284 break;
5285 case ADD_QUADTO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005286 if (step_limit == 0 || testIndex >= lastAdd) {
5287 drawQuad(frags[0], frags[1], frags[2], frags[3], frags[4], frags[5]);
5288 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005289 break;
5290 case ADD_CUBICTO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005291 if (step_limit == 0 || testIndex >= lastAdd) {
5292 drawCubic(frags[0], frags[1], frags[2], frags[3],
5293 frags[4], frags[5], frags[6], frags[7]);
5294 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005295 break;
5296 case ADD_CLOSE:
5297 ++closeCount;
5298 break;
5299 default:
5300 console.log("unknown REC_TYPE_ADD frag type: " + fragType);
5301 throw "stop execution";
5302 }
5303 break;
5304 case REC_TYPE_SECT:
5305 if (!draw_intersection) {
5306 continue;
5307 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005308 if (draw_intersection != 1 && (step_limit > 0 && testIndex < lastSect)) {
5309 continue;
5310 }
5311 // draw_intersection == 1 : show all
5312 // draw_intersection == 2 : step == 0 ? show all : show intersection line #step
5313 // draw_intersection == 3 : step == 0 ? show all : show intersection #step
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005314 ctx.lineWidth = 1;
5315 ctx.strokeStyle = "rgba(0,0,255, 0.3)";
5316 ctx.fillStyle = "blue";
5317 var f = [];
caryclark@google.com1304bb22013-03-13 20:29:41 +00005318 var c1s;
5319 var c1l;
5320 var c2s;
5321 var c2l;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005322 switch (fragType) {
5323 case INTERSECT_LINE:
5324 f.push(5, 6, 0, 7);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005325 c1s = 1; c1l = 4; c2s = 8; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005326 break;
5327 case INTERSECT_LINE_2:
5328 f.push(5, 6, 0, 10);
5329 f.push(8, 9, 7, 15);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005330 c1s = 1; c1l = 4; c2s = 11; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005331 break;
5332 case INTERSECT_LINE_NO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005333 c1s = 0; c1l = 4; c2s = 4; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005334 break;
5335 case INTERSECT_QUAD_LINE:
5336 f.push(7, 8, 0, 9);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005337 c1s = 1; c1l = 6; c2s = 10; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005338 break;
5339 case INTERSECT_QUAD_LINE_2:
5340 f.push(7, 8, 0, 12);
5341 f.push(10, 11, 9, 17);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005342 c1s = 1; c1l = 6; c2s = 13; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005343 break;
5344 case INTERSECT_QUAD_LINE_NO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005345 c1s = 0; c1l = 6; c2s = 6; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005346 break;
5347 case INTERSECT_QUAD:
5348 f.push(7, 8, 0, 9);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005349 c1s = 1; c1l = 6; c2s = 10; c2l = 6;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005350 break;
5351 case INTERSECT_QUAD_2:
5352 f.push(7, 8, 0, 12);
5353 f.push(10, 11, 9, 19);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005354 c1s = 1; c1l = 6; c2s = 13; c2l = 6;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005355 break;
5356 case INTERSECT_QUAD_NO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005357 c1s = 0; c1l = 6; c2s = 6; c2l = 6;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005358 break;
5359 case INTERSECT_SELF_CUBIC:
5360 f.push(9, 10, 0, 11);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005361 c1s = 1; c1l = 8; c2s = 0; c2l = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005362 break;
5363 case INTERSECT_SELF_CUBIC_NO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005364 c1s = 0; c1l = 8; c2s = 0; c2l = 0;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005365 break;
5366 case INTERSECT_CUBIC_LINE:
5367 f.push(9, 10, 0, 11);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005368 c1s = 1; c1l = 8; c2s = 12; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005369 break;
5370 case INTERSECT_CUBIC_LINE_2:
5371 f.push(9, 10, 0, 14);
5372 f.push(12, 13, 11, 19);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005373 c1s = 1; c1l = 8; c2s = 15; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005374 break;
5375 case INTERSECT_CUBIC_LINE_3:
5376 f.push(9, 10, 0, 17);
5377 f.push(12, 13, 11, 22);
5378 f.push(15, 16, 14, 23);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005379 c1s = 1; c1l = 8; c2s = 18; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005380 break;
5381 case INTERSECT_CUBIC_LINE_NO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005382 c1s = 0; c1l = 8; c2s = 8; c2l = 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005383 break;
5384 case INTERSECT_CUBIC:
5385 f.push(9, 10, 0, 11);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005386 c1s = 1; c1l = 8; c2s = 12; c2l = 8;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005387 break;
5388 case INTERSECT_CUBIC_2:
5389 f.push(9, 10, 0, 14);
5390 f.push(12, 13, 11, 23);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005391 c1s = 1; c1l = 8; c2s = 15; c2l = 8;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005392 break;
5393 case INTERSECT_CUBIC_3:
5394 f.push(9, 10, 0, 17);
5395 f.push(12, 13, 11, 26);
5396 f.push(15, 16, 14, 27);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005397 c1s = 1; c1l = 8; c2s = 18; c2l = 8;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005398 break;
5399 case INTERSECT_CUBIC_4:
5400 f.push(9, 10, 0, 20);
5401 f.push(12, 13, 11, 29);
5402 f.push(15, 16, 14, 30);
5403 f.push(18, 19, 17, 31);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005404 c1s = 1; c1l = 8; c2s = 21; c2l = 8;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005405 break;
5406 case INTERSECT_CUBIC_NO:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005407 c1s = 0; c1l = 8; c2s = 8; c2l = 8;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005408 break;
5409 default:
5410 console.log("unknown REC_TYPE_SECT frag type: " + fragType);
5411 throw "stop execution";
5412 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005413 if (draw_intersection != 1) {
5414 switch (c1l) {
5415 case 4:
5416 drawLine(frags[c1s], frags[c1s + 1], frags[c1s + 2], frags[c1s + 3]);
5417 break;
5418 case 6:
5419 drawQuad(frags[c1s], frags[c1s + 1], frags[c1s + 2], frags[c1s + 3],
5420 frags[c1s + 4], frags[c1s + 5]);
5421 break;
5422 case 8:
5423 drawCubic(frags[c1s], frags[c1s + 1], frags[c1s + 2], frags[c1s + 3],
5424 frags[c1s + 4], frags[c1s + 5], frags[c1s + 6], frags[c1s + 7]);
5425 break;
5426 }
5427 switch (c2l) {
5428 case 0:
5429 break;
5430 case 4:
5431 drawLine(frags[c2s], frags[c2s + 1], frags[c2s + 2], frags[c2s + 3]);
5432 break;
5433 case 6:
5434 drawQuad(frags[c2s], frags[c2s + 1], frags[c2s + 2], frags[c2s + 3],
5435 frags[c2s + 4], frags[c2s + 5]);
5436 break;
5437 case 8:
5438 drawCubic(frags[c2s], frags[c2s + 1], frags[c2s + 2], frags[c2s + 3],
5439 frags[c2s + 4], frags[c2s + 5], frags[c2s + 6], frags[c2s + 7]);
5440 break;
5441 }
5442 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005443 for (var idx = 0; idx < f.length; idx += 4) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005444 if (draw_intersection != 3 || idx == lastSect - testIndex) {
5445 drawPoint(frags[f[idx]], frags[f[idx + 1]], true);
5446 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005447 }
5448 if (!draw_intersectT) {
5449 break;
5450 }
5451 ctx.fillStyle = "red";
5452 for (var idx = 0; idx < f.length; idx += 4) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005453 if (draw_intersection != 3 || idx == lastSect - testIndex) {
5454 drawTAtPointUp(frags[f[idx]], frags[f[idx + 1]], frags[f[idx + 2]]);
5455 drawTAtPointDown(frags[f[idx]], frags[f[idx + 1]], frags[f[idx + 3]]);
5456 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005457 }
5458 break;
5459 case REC_TYPE_SORT:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005460 if (!draw_sort || (step_limit > 0 && testIndex < lastSort)) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005461 continue;
5462 }
5463 ctx.lineWidth = 3;
5464 ctx.strokeStyle = "rgba(127,127,0, 0.5)";
5465 switch (fragType) {
5466 case SORT_LINE:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005467 case SORT_LINE_UNSORTABLE:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005468 drawLinePartial(frags[1], frags[2], frags[3], frags[4],
5469 frags[5], frags[6]);
5470 break;
5471 case SORT_QUAD:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005472 case SORT_QUAD_UNSORTABLE:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005473 drawQuadPartial(frags[1], frags[2], frags[3], frags[4],
5474 frags[5], frags[6], frags[7], frags[8]);
5475 break;
5476 case SORT_CUBIC:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005477 case SORT_CUBIC_UNSORTABLE:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005478 drawCubicPartial(frags[1], frags[2], frags[3], frags[4],
5479 frags[5], frags[6], frags[7], frags[8], frags[9], frags[10]);
5480 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005481 case SORT_LINE_COMPACT:
5482 case SORT_QUAD_COMPACT:
5483 case SORT_CUBIC_COMPACT:
5484 // unsupported
5485 break;
5486 default:
5487 console.log("unknown REC_TYPE_SORT frag type: " + fragType);
5488 throw "stop execution";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005489 }
5490 break;
5491 case REC_TYPE_MARK:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005492 if (!draw_mark || (step_limit > 0 && testIndex < lastMark)) {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005493 continue;
5494 }
5495 ctx.lineWidth = 3;
5496 ctx.strokeStyle = fragType >= MARK_DONE_LINE ?
5497 "rgba(127,0,127, 0.5)" : "rgba(127,127,0, 0.5)";
5498 switch (fragType) {
5499 case MARK_LINE:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005500 case MARK_DONE_LINE:
5501 case MARK_UNSORTABLE_LINE:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005502 drawLinePartial(frags[1], frags[2], frags[3], frags[4],
5503 frags[5], frags[9]);
5504 break;
5505 case MARK_QUAD:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005506 case MARK_DONE_QUAD:
5507 case MARK_UNSORTABLE_QUAD:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005508 drawQuadPartial(frags[1], frags[2], frags[3], frags[4],
5509 frags[5], frags[6], frags[7], frags[11]);
5510 break;
5511 case MARK_CUBIC:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005512 case MARK_DONE_CUBIC:
caryclark@google.com1304bb22013-03-13 20:29:41 +00005513 case MARK_UNSORTABLE_CUBIC:
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005514 drawCubicPartial(frags[1], frags[2], frags[3], frags[4],
5515 frags[5], frags[6], frags[7], frags[8], frags[9], frags[13]);
5516 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005517 default:
5518 console.log("unknown REC_TYPE_MARK frag type: " + fragType);
5519 throw "stop execution";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005520 }
5521 break;
5522 default:
5523 continue;
caryclark@google.com0b7da432012-10-31 19:00:20 +00005524 }
5525 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005526 switch (recType) {
5527 case REC_TYPE_SORT:
5528 if (!draw_sort || (step_limit > 0 && testIndex < lastSort)) {
5529 break;
5530 }
5531 var angles = []; // use tangent lines to describe arcs
5532 var windFrom = [];
5533 var windTo = [];
5534 var opp = [];
5535 var minXY = Number.MAX_VALUE;
5536 var partial;
5537 for (var recordIndex = 0; recordIndex < records.length; recordIndex += 2) {
5538 var fragType = records[recordIndex];
5539 var frags = records[recordIndex + 1];
5540 var idx = 10;
5541 switch (fragType) {
5542 case SORT_LINE:
5543 case SORT_LINE_UNSORTABLE:
5544 partial = linePartial(frags[1], frags[2], frags[3], frags[4],
5545 frags[5], frags[6]);
5546 break;
5547 case SORT_QUAD:
5548 case SORT_QUAD_UNSORTABLE:
5549 partial = quadPartial(frags[1], frags[2], frags[3], frags[4],
5550 frags[5], frags[6], frags[7], frags[8]);
5551 idx += 2;
5552 break;
5553 case SORT_CUBIC:
5554 case SORT_CUBIC_UNSORTABLE:
5555 partial = cubicPartial(frags[1], frags[2], frags[3], frags[4],
5556 frags[5], frags[6], frags[7], frags[8], frags[9], frags[10]);
5557 idx += 4;
5558 break;
5559 case SORT_LINE_COMPACT:
5560 case SORT_QUAD_COMPACT:
5561 case SORT_CUBIC_COMPACT:
5562 // unsupported
5563 continue;
5564 default:
5565 console.log("unknown REC_TYPE_SORT frag type: " + fragType);
5566 throw "stop execution";
5567 }
5568 var dx = boundsWidth(partial);
5569 var dy = boundsHeight(partial);
5570 minXY = Math.min(minXY, dx * dx + dy * dy);
5571 angles.push(tangent(partial));
5572 windFrom.push(frags[idx]);
5573 windTo.push(frags[idx + 1]);
5574 opp.push(frags[idx + 5]);
5575 }
5576 var radius = Math.sqrt(minXY) / 2 * scale;
5577 radius = Math.min(50, radius);
5578 var centerX = (partial[0] - srcLeft) * scale;
5579 var centerY = (partial[1] - srcTop) * scale;
5580 ctx.lineWidth = 1;
5581 ctx.strokeStyle = "rgba(127,0,171, 0.5)";
5582 ctx.fillStyle = "rgba(0,0,0, 0.5)";
5583 ctx.font = "normal 10px Arial";
5584 ctx.textAlign = "center";
5585 for (var angleIndex = 0; angleIndex < angles.length; ++angleIndex) {
5586 var angleParts = [
5587 angles[(angleIndex + angles.length - 1) % angles.length],
5588 angles[angleIndex],
5589 angles[(angleIndex + 1) % angles.length]
5590 ];
5591 var angleStart = (angleParts[0] + angleParts[1]) / 2;
5592 if (angleParts[0] > angleParts[1]) {
5593 angleStart -= Math.PI;
5594 }
5595 var angleEnd = (angleParts[1] + angleParts[2]) / 2;
5596 if (angleParts[1] > angleParts[2]) {
5597 angleEnd -= Math.PI;
5598 }
5599 ctx.beginPath();
5600 ctx.arc(centerX, centerY, radius + (opp[angleIndex] ? 10 : 0),
5601 Math.PI * 2 - angleStart - Math.PI / 18, Math.PI * 2 - angleEnd + Math.PI / 18, true);
5602 ctx.stroke();
5603 var tx = centerX + Math.cos(angleStart) * (radius + (opp[angleIndex] ? 10 : 0));
5604 var ty = centerY - Math.sin(angleStart) * (radius + (opp[angleIndex] ? 10 : 0));
5605 ctx.fillText(windFrom[angleIndex], tx, ty + 5);
5606 tx = centerX + Math.cos(angleEnd) * (radius + (opp[angleIndex] ? 10 : 0));
5607 ty = centerY - Math.sin(angleEnd) * (radius + (opp[angleIndex] ? 10 : 0));
5608 ctx.fillText(windTo[angleIndex], tx, ty + 5);
5609 }
5610 break;
5611 default:
5612 break;
5613 }
caryclark@google.comf839c032012-10-26 21:03:50 +00005614 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005615 if (draw_log && logStart >= 0) {
5616 ctx.font = "normal 10px Arial";
caryclark@google.com1304bb22013-03-13 20:29:41 +00005617 ctx.textAlign = "left";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005618 ctx.beginPath();
caryclark@google.com1304bb22013-03-13 20:29:41 +00005619 var top = ctx.canvas.height - 20 - (logRange + 2) * 10;
5620 ctx.rect(50, top, ctx.canvas.width-100, (logRange + 2) * 10);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005621 ctx.fillStyle = "white";
5622 ctx.fill();
5623 ctx.fillStyle = "rgba(0,0,0, 0.5)";
5624 if (logStart > 0) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005625 ctx.fillText(lines[logStart - 1], 50, top + 8);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005626 }
5627 ctx.fillStyle = "black";
5628 for (var idx = 0; idx < logRange; ++idx) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005629 ctx.fillText(lines[logStart + idx], 50, top + 18 + 10 * idx);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005630 }
5631 ctx.fillStyle = "rgba(0,0,0, 0.5)";
5632 if (logStart + logRange < lines.length) {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005633 ctx.fillText(lines[logStart + logRange], 50, top + 18 + 10 * logRange);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005634 }
5635 }
5636 if (draw_legend) {
5637 var pos = 0;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005638 var drawSomething = draw_add | draw_active | draw_sort | draw_mark;
5639 // drawBox(pos++, "yellow", "black", opLetter, true, '');
5640 drawBox(pos++, "rgba(0,0,255, 0.3)", "black", draw_intersection > 1 ? sectCount : sectMax2, draw_intersection, intersectionKey);
5641 drawBox(pos++, "rgba(0,0,255, 0.3)", "black", draw_add ? addCount : addMax, draw_add, addKey);
5642 drawBox(pos++, "rgba(0,0,255, 0.3)", "black", draw_active ? activeCount : activeMax, draw_active, activeKey);
5643 drawBox(pos++, "rgba(127,127,0, 0.3)", "black", draw_sort ? sortCount : sortMax, draw_sort, sortKey);
5644 drawBox(pos++, "rgba(127,0,127, 0.3)", "black", draw_mark ? markCount : markMax, draw_mark, markKey);
5645 drawBox(pos++, "black", "white",
5646 (new Array('P', 'P1', 'P2', 'P'))[draw_path], draw_path != 0, pathKey);
5647 drawBox(pos++, "rgba(0,63,0, 0.7)", "white",
5648 (new Array('Q', 'Q', 'C', 'QC', 'Qc', 'Cq'))[draw_computed],
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005649 draw_computed != 0, computedKey);
caryclark@google.com1304bb22013-03-13 20:29:41 +00005650 drawBox(pos++, "green", "black", step_limit, drawSomething, '');
5651 drawBox(pos++, "green", "black", stepMax, drawSomething, '');
5652 drawBox(pos++, "red", "black", lastIndex, drawSomething & draw_log, '');
5653 drawBox(pos++, "red", "black", test.length - 1, drawSomething & draw_log, '');
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005654 if (curve_t) {
5655 drawCurveTControl();
5656 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005657 ctx.font = "normal 20px Arial";
5658 ctx.fillStyle = "rgba(0,0,0, 0.3)";
5659 ctx.textAlign = "right";
5660 ctx.fillText(scale.toFixed(decimal_places) + 'x' , ctx.canvas.width - 10, ctx.canvas.height - 5);
5661 }
5662 if (draw_hints) {
5663 ctx.font = "normal 10px Arial";
5664 ctx.fillStyle = "rgba(0,0,0, 0.5)";
5665 ctx.textAlign = "right";
5666 var y = 4;
5667 ctx.fillText("control lines : " + controlLinesKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5668 ctx.fillText("curve t : " + curveTKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5669 ctx.fillText("deriviatives : " + deriviativesKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5670 ctx.fillText("intersect t : " + intersectTKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5671 ctx.fillText("hodo : " + hodoKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5672 ctx.fillText("log : " + logKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5673 ctx.fillText("log curve : " + logCurvesKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5674 ctx.fillText("mid point : " + midpointKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5675 ctx.fillText("points : " + ptsKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5676 ctx.fillText("sequence : " + sequenceKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
5677 ctx.fillText("xy : " + xyKey, ctx.canvas.width - 10, pos * 50 + y++ * 10);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005678 }
5679}
5680
5681function drawBox(y, backC, foreC, str, enable, label) {
5682 ctx.beginPath();
5683 ctx.fillStyle = backC;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005684 ctx.rect(ctx.canvas.width - 40, y * 50 + 10, 40, 30);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005685 ctx.fill();
5686 ctx.font = "normal 16px Arial";
5687 ctx.fillStyle = foreC;
5688 ctx.textAlign = "center";
caryclark@google.com1304bb22013-03-13 20:29:41 +00005689 ctx.fillText(str, ctx.canvas.width - 20, y * 50 + 32);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005690 if (!enable) {
5691 ctx.fillStyle = "rgba(255,255,255, 0.5)";
5692 ctx.fill();
5693 }
5694 if (label != '') {
5695 ctx.font = "normal 9px Arial";
5696 ctx.fillStyle = "black";
caryclark@google.com1304bb22013-03-13 20:29:41 +00005697 ctx.fillText(label, ctx.canvas.width - 47, y * 50 + 40);
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005698 }
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005699}
5700
5701function drawCurveTControl() {
5702 ctx.lineWidth = 2;
5703 ctx.strokeStyle = "rgba(0,0,0, 0.3)";
5704 ctx.beginPath();
5705 ctx.rect(ctx.canvas.width - 80, 40, 28, ctx.canvas.height - 80);
5706 ctx.stroke();
5707 var ty = 40 + curveT * (ctx.canvas.height - 80);
5708 ctx.beginPath();
5709 ctx.moveTo(ctx.canvas.width - 80, ty);
5710 ctx.lineTo(ctx.canvas.width - 85, ty - 5);
5711 ctx.lineTo(ctx.canvas.width - 85, ty + 5);
5712 ctx.lineTo(ctx.canvas.width - 80, ty);
5713 ctx.fillStyle = "rgba(0,0,0, 0.6)";
5714 ctx.fill();
5715 var num = curveT.toFixed(decimal_places);
5716 ctx.font = "normal 10px Arial";
caryclark@google.com1304bb22013-03-13 20:29:41 +00005717 ctx.textAlign = "left";
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005718 ctx.fillText(num, ctx.canvas.width - 78, ty);
5719}
5720
5721function ptInTControl() {
5722 var e = window.event;
5723 var tgt = e.target || e.srcElement;
5724 var left = tgt.offsetLeft;
5725 var top = tgt.offsetTop;
5726 var x = (e.clientX - left);
5727 var y = (e.clientY - top);
5728 if (x < ctx.canvas.width - 80 || x > ctx.canvas.width - 50) {
5729 return false;
5730 }
5731 if (y < 40 || y > ctx.canvas.height - 80) {
5732 return false;
5733 }
5734 curveT = (y - 40) / (ctx.canvas.height - 120);
5735 if (curveT < 0 || curveT > 1) {
5736 throw "stop execution";
5737 }
5738 return true;
caryclark@google.comf839c032012-10-26 21:03:50 +00005739}
5740
5741function drawTop() {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005742 if (tests[testIndex] == null) {
5743 var str = testDivs[testIndex].firstChild.data;
5744 parse_all(str);
5745 var title = testDivs[testIndex].id.toString();
5746 testTitles[testIndex] = title;
5747 }
caryclark@google.comf839c032012-10-26 21:03:50 +00005748 init(tests[testIndex]);
5749 redraw();
5750}
5751
5752function redraw() {
5753 ctx.beginPath();
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005754 ctx.fillStyle = "white";
caryclark@google.comf839c032012-10-26 21:03:50 +00005755 ctx.rect(0, 0, ctx.canvas.width, ctx.canvas.height);
caryclark@google.comf839c032012-10-26 21:03:50 +00005756 ctx.fill();
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005757 draw(tests[testIndex], testLines[testIndex], testTitles[testIndex]);
caryclark@google.comf839c032012-10-26 21:03:50 +00005758}
5759
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005760var activeKey = 'a';
5761var addKey = 'd';
5762var centerKey = 'c';
5763var computedKey = 'q';
5764var computedBackKey = 'Q';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005765var controlLinesBackKey = 'V';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005766var controlLinesKey = 'v';
5767var curveTKey = 'u';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005768var deriviativesKey = 'f';
5769var hodoKey = 'h';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005770var intersectTKey = 't';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005771var intersectionBackKey = 'I';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005772var intersectionKey = 'i';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005773var logKey = 'l';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005774var logCurvesKey = 'z';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005775var markKey = 'm';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005776var midpointKey = 'k';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005777var pathKey = 'b';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005778var pathBackKey = 'B';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005779var ptsKey = 'x';
caryclark@google.com1304bb22013-03-13 20:29:41 +00005780var sequenceKey = 'j';
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005781var sortKey = 'o';
5782var stepBackKey = 'S';
5783var stepKey = 's';
5784var xyKey = 'y';
5785
caryclark@google.comf839c032012-10-26 21:03:50 +00005786function doKeyPress(evt) {
5787 var char = String.fromCharCode(evt.charCode);
5788 switch (char) {
5789 case '0':
5790 case '1':
5791 case '2':
5792 case '3':
5793 case '4':
5794 case '5':
5795 case '6':
5796 case '7':
5797 case '8':
5798 case '9':
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005799 decimal_places = char - '0';
caryclark@google.comf839c032012-10-26 21:03:50 +00005800 redraw();
5801 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005802 case activeKey:
5803 draw_active ^= true;
5804 redraw();
caryclark@google.comf839c032012-10-26 21:03:50 +00005805 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005806 case addKey:
5807 draw_add ^= true;
5808 redraw();
5809 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005810 case centerKey:
5811 setScale();
5812 redraw();
5813 break;
5814 case controlLinesBackKey:
5815 control_lines = (control_lines + 3) % 4;
5816 redraw();
5817 break;
5818 case controlLinesKey:
5819 control_lines = (control_lines + 1) % 4;
5820 redraw();
5821 break;
5822 case computedBackKey:
5823 draw_computed = (draw_computed + 5) % 6;
5824 redraw();
5825 break;
5826 case computedKey:
5827 draw_computed = (draw_computed + 1) % 6;
5828 redraw();
5829 break;
5830 case curveTKey:
5831 curve_t ^= true;
5832 if (curve_t) {
5833 draw_legend = true;
5834 }
caryclark@google.comf839c032012-10-26 21:03:50 +00005835 redraw();
5836 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005837 case deriviativesKey:
5838 draw_deriviatives = (draw_deriviatives + 1) % 3;
5839 redraw();
5840 break;
5841 case hodoKey:
5842 draw_hodo = (draw_hodo + 1) % 4;
5843 redraw();
5844 break;
5845 case intersectionBackKey:
5846 draw_intersection = (draw_intersection + 3) % 4;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005847 redraw();
5848 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005849 case intersectionKey:
5850 draw_intersection = (draw_intersection + 1) % 4;
5851 redraw();
5852 break;
5853 case intersectTKey:
5854 draw_intersectT ^= true;
5855 redraw();
5856 break;
5857 case logCurvesKey:
5858 logCurves(tests[testIndex]);
5859 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005860 case logKey:
5861 draw_log ^= true;
caryclark@google.comf839c032012-10-26 21:03:50 +00005862 redraw();
5863 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005864 case markKey:
5865 draw_mark ^= true;
5866 redraw();
5867 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005868 case midpointKey:
5869 draw_midpoint ^= true;
5870 redraw();
caryclark@google.comf839c032012-10-26 21:03:50 +00005871 break;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005872 case pathKey:
5873 draw_path = (draw_path + 1) % 4;
5874 redraw();
5875 break;
5876 case pathBackKey:
5877 draw_path = (draw_path + 3) % 4;
5878 redraw();
5879 break;
5880 case ptsKey:
5881 pt_labels = (pt_labels + 1) % 3;
5882 redraw();
5883 break;
5884 case sequenceKey:
5885 draw_sequence ^= true;
5886 redraw();
5887 break;
5888 case sortKey:
5889 draw_sort ^= true;
5890 redraw();
caryclark@google.comf839c032012-10-26 21:03:50 +00005891 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005892 case stepKey:
5893 step_limit++;
caryclark@google.com1304bb22013-03-13 20:29:41 +00005894 if (step_limit > stepMax) {
5895 step_limit = stepMax;
5896 }
caryclark@google.com0b7da432012-10-31 19:00:20 +00005897 redraw();
5898 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005899 case stepBackKey:
5900 step_limit--;
5901 if (step_limit < 0) {
5902 step_limit = 0;
caryclark@google.com0b7da432012-10-31 19:00:20 +00005903 }
5904 redraw();
caryclark@google.comf839c032012-10-26 21:03:50 +00005905 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005906 case xyKey:
caryclark@google.comf839c032012-10-26 21:03:50 +00005907 debug_xy ^= true;
5908 redraw();
5909 break;
5910 case '-':
5911 scale /= 2;
5912 calcLeftTop();
5913 redraw();
5914 break;
5915 case '=':
5916 case '+':
5917 scale *= 2;
5918 calcLeftTop();
5919 redraw();
5920 break;
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005921 case '?':
caryclark@google.com1304bb22013-03-13 20:29:41 +00005922 draw_hints ^= true;
5923 if (draw_hints && !draw_legend) {
5924 draw_legend = true;
5925 }
5926 redraw();
5927 break;
5928 case '/':
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005929 draw_legend ^= true;
5930 redraw();
5931 break;
caryclark@google.comf839c032012-10-26 21:03:50 +00005932 }
5933}
5934
caryclark@google.com1304bb22013-03-13 20:29:41 +00005935function doKeyDown(evt) {
5936 var char = evt.keyCode;
5937 switch (char) {
5938 case 37: // left arrow
5939 if (evt.shiftKey) {
5940 testIndex -= 9;
5941 }
5942 if (--testIndex < 0)
5943 testIndex = tests.length - 1;
5944 drawTop();
5945 break;
5946 case 39: // right arrow
5947 if (evt.shiftKey) {
5948 testIndex += 9;
5949 }
5950 if (++testIndex >= tests.length)
5951 testIndex = 0;
5952 drawTop();
5953 break;
5954 }
5955}
5956
caryclark@google.comf839c032012-10-26 21:03:50 +00005957function calcXY() {
5958 var e = window.event;
5959 var tgt = e.target || e.srcElement;
5960 var left = tgt.offsetLeft;
5961 var top = tgt.offsetTop;
caryclark@google.comf839c032012-10-26 21:03:50 +00005962 mouseX = (e.clientX - left) / scale + srcLeft;
5963 mouseY = (e.clientY - top) / scale + srcTop;
5964}
5965
5966function calcLeftTop() {
5967 srcLeft = mouseX - screenWidth / 2 / scale;
5968 srcTop = mouseY - screenHeight / 2 / scale;
5969}
5970
5971function handleMouseClick() {
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005972 if (!curve_t || !ptInTControl()) {
5973 calcXY();
5974 calcLeftTop();
5975 }
caryclark@google.comf839c032012-10-26 21:03:50 +00005976 redraw();
5977}
5978
5979function handleMouseOver() {
5980 calcXY();
caryclark@google.comd4c8e1e2013-03-05 14:13:13 +00005981 if (!debug_xy) {
5982 return;
5983 }
caryclark@google.comf839c032012-10-26 21:03:50 +00005984 var num = mouseX.toFixed(decimal_places) + ", " + mouseY.toFixed(decimal_places);
5985 ctx.beginPath();
caryclark@google.com1304bb22013-03-13 20:29:41 +00005986 ctx.rect(300,100,num.length * 6,10);
caryclark@google.comf839c032012-10-26 21:03:50 +00005987 ctx.fillStyle="white";
5988 ctx.fill();
caryclark@google.com1304bb22013-03-13 20:29:41 +00005989 ctx.font = "normal 10px Arial";
caryclark@google.comf839c032012-10-26 21:03:50 +00005990 ctx.fillStyle="black";
caryclark@google.com1304bb22013-03-13 20:29:41 +00005991 ctx.textAlign = "left";
caryclark@google.comf839c032012-10-26 21:03:50 +00005992 ctx.fillText(num, 300, 108);
5993}
5994
5995function start() {
caryclark@google.com1304bb22013-03-13 20:29:41 +00005996 for (var i = 0; i < testDivs.length; ++i) {
5997 tests[i] = null;
caryclark@google.comf839c032012-10-26 21:03:50 +00005998 }
caryclark@google.com1304bb22013-03-13 20:29:41 +00005999 testIndex = 0;
caryclark@google.comf839c032012-10-26 21:03:50 +00006000 drawTop();
6001 window.addEventListener('keypress', doKeyPress, true);
caryclark@google.com1304bb22013-03-13 20:29:41 +00006002 window.addEventListener('keydown', doKeyDown, true);
caryclark@google.comf839c032012-10-26 21:03:50 +00006003 window.onresize = function() {
6004 drawTop();
6005 }
6006}
6007
6008</script>
6009</head>
6010
6011<body onLoad="start();">
6012<canvas id="canvas" width="750" height="500"
6013 onmousemove="handleMouseOver()"
6014 onclick="handleMouseClick()"
6015 ></canvas >
6016</body>
6017</html>