1Math::PlanePath::DragonUCsuerrveC(o3n)tributed Perl DocuMmaetnht:a:tPiloannePath::DragonCurve(3)
2
3
4

NAME

6       Math::PlanePath::DragonCurve -- dragon curve
7

SYNOPSIS

9        use Math::PlanePath::DragonCurve;
10        my $path = Math::PlanePath::DragonCurve->new;
11        my ($x, $y) = $path->n_to_xy (123);
12

DESCRIPTION

14       This is the dragon or paper folding curve by Heighway, Harter, et al.
15
16                        9----8    5---4               2
17                        |    |    |   |
18                       10--11,7---6   3---2           1
19                             |            |
20             17---16   13---12        0---1       <- Y=0
21              |    |    |
22             18-19,15-14,22-23                       -1
23                   |    |    |
24                  20--21,25-24                       -2
25                        |
26                       26---27                       -3
27                             |
28                --32   29---28                       -4
29                   |    |
30                  31---30                            -5
31
32              ^    ^    ^    ^    ^   ^   ^
33             -5   -4   -3   -2   -1  X=0  1 ...
34
35       The curve visits "inside" X,Y points twice.  The first of these is
36       X=-2,Y=1 which is N=7 and also N=11.  The segments N=6,7,8 and
37       N=10,11,12 have touched, but the path doesn't cross itself.  The
38       doubled vertices are all like this, touching but not crossing and no
39       edges repeating.
40
41   Arms
42       The curve fills a quarter of the plane and four copies mesh together
43       perfectly when rotated by 90, 180 and 270 degrees.  The "arms"
44       parameter can choose 1 to 4 curve arms successively advancing.
45
46       For example arms=4 begins as follows, with N=0,4,8,12,etc being the
47       first arm, N=1,5,9,13 the second, N=2,6,10,14 the third and N=3,7,11,15
48       the fourth.
49
50           arms => 4
51
52                   20 ------ 16
53                              |
54                    9 ------5/12 -----  8       23
55                    |         |         |        |
56           17 --- 13/6 --- 0/1/2/3 --- 4/15 --- 19
57            |       |         |         |
58           21      10 ----- 14/7 ----- 11
59                              |
60                             18 ------ 22
61
62       With four arms every X,Y point is visited twice (except the origin 0,0
63       where all four begin) and every edge between the points is traversed
64       once.
65
66   Level Angle
67       The first step N=1 is to the right along the X axis and the path then
68       slowly spirals anti-clockwise and progressively fatter.  The end of
69       each replication is N=2^level which is at level*45 degrees around,
70
71           N       X,Y     angle   radial dist
72          ----    -----    -----   -----------
73            1      1,0        0         1
74            2      1,1       45       sqrt(2)
75            4      0,2       90       sqrt(4)=2
76            8     -2,2      135       sqrt(8)
77           16     -4,0      180       sqrt(16)=4
78           32     -4,-4     225       sqrt(32)
79          ...
80
81       Here's points N=0 to N=2^9=512.  "0" is the origin and "+" is N=512.
82       Notice it's spiralled around full-circle to angle 45 degrees up again,
83       like the initial N=2.
84
85                                           * *     * *
86                                         * * *   * * *
87                                         * * * * * * * * *
88                                         * * * * * * * * *
89                                   * *   * * * *       * *
90                                 * * *   * * * *     + * *
91                                 * * * * * *         * *
92                                 * * * * * * *
93                                 * * * * * * * *
94                                     * * * * * *
95                                     * * * *
96                                         * * * * * * *
97                                   * *   * * * * * * * *
98                                 * * *   * * * * * * * *
99                                 * * * * * * * * * *
100                                 * * * * * * * * * * * * * * *
101                                 * * * * * * * * * * * * * * * *
102                                     * * * * * * * * * * * * * *
103                                     * * * * * * * * * * * *
104               * * * *                   * * * * * * * * * * *
105               * * * * *           * *   * * * *       * * * * *
106           * * * *   0 *         * * *   * * * *   * * * * * * *
107           * * * *               * * * * * *       * * * * *
108             * * *               * * * * * * *       * * * *
109               * * * *     * *   * * * * * * * *
110           * * * * * *   * * *   * * * * * * * *
111           * * * * * * * * * * * * * * * * *
112             * * * * * * * * * * * * * * * * *
113                       * * * * *       * * * * *
114                   * * * * * * *   * * * * * * *
115                   * * * * *       * * * * *
116                     * * * *         * * * *
117
118       At a power of two Nlevel=2^level for N=2 or higher, the curve always
119       goes upward from Nlevel-1 to Nlevel, and then goes to the left for
120       Nlevel+1.  For example at N=16 the curve goes up N=15 to N=16, then
121       left for N=16 to N=17.  Likewise at N=32, etc.  The spiral curls around
122       ever further but the self-similar twist back means the Nlevel endpoint
123       is always at this same up/left orientation.  See "Total Turn" below for
124       the net direction in general.
125
126   Level Ranges
127       The X,Y extents of the path through to Nlevel=2^level can be expressed
128       as a "length" in the direction of the Xlevel,Ylevel endpoint and a
129       "width" across.
130
131           level even, so endpoint is a straight line
132           k = level/2
133
134              +--+      <- Lmax
135              |  |
136              |  E      <- Lend = 2^k at Nlevel=2^level
137              |
138              +-----+
139                    |
140                 O  |   <- Lstart=0
141                 |  |
142                 +--+   <- Lmin
143
144              ^     ^
145           Wmin     Wmax
146
147           Lmax = (7*2^k - 4)/6 if k even
148                  (7*2^k - 2)/6 if k odd
149
150           Lmin = - (2^k - 1)/3 if k even
151                  - (2^k - 2)/3 if k odd
152
153           Wmax = (2*2^k - 2) / 3 if k even
154                  (2*2^k - 1) / 3 if k odd
155
156           Wmin = Lmin
157
158       For example level=2 is to Nlevel=2^2=4 and k=level/2=1 is odd so it
159       measures as follows,
160
161           4      <- Lmax = (7*2^1 - 2)/6 = 2
162           |
163           3--2
164              |
165           0--1   <- Lmin = -(2^1 - 2)/3 = 0
166
167           ^  ^Wmax = (2*2^1 - 1)/3 = 1
168           |
169           Wmin = Lmin = 0
170
171       Or level=4 is to Nlevel=2^4=16 and k=4/2=2 is even.  It measures as
172       follows.  The lengthways "L" measures are in the direction of the N=16
173       endpoint and the "W" measures are across.
174
175                 9----8    5---4        <- Wmax = (2*2^2 - 2)/3 = 2
176                 |    |    |   |
177                10--11,7---6   3---2
178                      |            |
179           16   13---12        0---1
180            |    |
181           15---14                      <- Wmin = -(2^2 - 1)/3 = -1
182
183            ^                      ^Lmin = Wmin = -1
184            |
185            Lmax = (7*2^2 - 4)/6 = 4
186
187       The formulas are all integer values, but the fractions 7/6, 1/3 and 2/3
188       show the limits as the level increases.  If scaled so that length
189       Lend=2^k is reckoned as 1 unit then Lmax extends 1/6 past the end, Lmin
190       and Wmin extend 1/3, and Wmax extends across 2/3.
191
192           +--------+ --
193           | -      | 1/6   total length
194           || |     |          = 1/6+1+1/3 = 3/2
195           || E     | --
196           ||       |
197           ||       |
198           | \      |  1
199           |  \     |
200           |   --\  |
201           |      \ |
202           |       ||
203           |  O    || --
204           |  |    ||
205           |  |    || 1/3
206           |   ---- |
207           +--------+ --
208           1/3|  2/3
209
210           total width = 1/3+2/3 = 1
211
212   Paper Folding
213       The path is called a paper folding curve because it can be generated by
214       thinking of a long strip of paper folded in half repeatedly and then
215       unfolded so each crease is a 90 degree angle.  The effect is that the
216       curve repeats in successive doublings turned by 90 degrees and
217       reversed.
218
219       The first segment unfolds, pivoting at the "1",
220
221                                                 2
222                                            ->   |
223                            unfold         /     |
224                             ===>         |      |
225                                                 |
226           0-------1                     0-------1
227
228       Then the same again with that L shape, pivoting at the "2", then after
229       that pivoting at the "4", and so on.
230
231                                        4
232                                        |
233                                        |
234                                        |
235                                        3--------2
236                  2                              |
237                  |        unfold          ^     |
238                  |         ===>            \_   |
239                  |                              |
240           0------1                     0--------1
241
242       It can be shown that this unfolding doesn't overlap itself but the
243       corners may touch, such as at the X=-2,Y=1 etc noted above.
244

FUNCTIONS

246       See "FUNCTIONS" in Math::PlanePath for behaviour common to all path
247       classes.
248
249       "$path = Math::PlanePath::DragonCurve->new ()"
250       "$path = Math::PlanePath::DragonCurve->new (arms => $int)"
251           Create and return a new path object.
252
253           The optional "arms" parameter can make 1 to 4 copies of the curve,
254           each arm successively advancing.
255
256       "($x,$y) = $path->n_to_xy ($n)"
257           Return the X,Y coordinates of point number $n on the path.  Points
258           begin at 0 and if "$n < 0" then the return is an empty list.
259
260           Fractional $n gives an X,Y position along a straight line between
261           the integer positions.
262
263       "$n = $path->xy_to_n ($x,$y)"
264           Return the point number for coordinates "$x,$y".  If there's
265           nothing at "$x,$y" then return "undef".
266
267           The curve visits an "$x,$y" twice for various points (all the
268           "inside" points).  The smaller of the two N values is returned.
269
270       "@n_list = $path->xy_to_n_list ($x,$y)"
271           Return a list of N point numbers for coordinates "$x,$y".
272
273           The origin 0,0 has "arms_count()" many N since it's the starting
274           point for each arm.  Other points have up to two Ns for a given
275           "$x,$y".  If arms=4 then every "$x,$y" except the origin has
276           exactly two Ns.
277
278       "$n = $path->n_start()"
279           Return 0, the first N in the path.
280
281   Level Methods
282       "($n_lo, $n_hi) = $path->level_to_n_range($level)"
283           Return "(0, 2**$level)", or for multiple arms return "(0, $arms *
284           2**$level + ($arms-1))".
285
286           There are 2^level segments in a curve level, so 2^level+1 points
287           numbered from 0.  For multiple arms there are arms*(2^level+1)
288           points, numbered from 0 so n_hi = arms*(2^level+1)-1.
289

FORMULAS

291       Various formulas for coordinates, lengths and area can be found in the
292       author's long mathematical write-up
293
294           <http://user42.tuxfamily.org/dragon/index.html>
295
296   X,Y to N
297       The current code uses the "DragonMidpoint" "xy_to_n()" by rotating -45
298       degrees and offsetting to the midpoints of the four edges around the
299       target X,Y.  The "DragonMidpoint" algorithm then gives four candidate N
300       values and those which convert back to the desired X,Y in the
301       "DragonCurve" "n_to_xy()" are the results for "xy_to_n_list()".
302
303           Xmid,Ymid = X+Y, Y-X    # rotate -45 degrees
304           for dx = 0 or -1
305             for dy = 0 or 1
306               N candidate = DragonMidpoint xy_to_n(Xmid+dx,Ymid+dy)
307
308       Since there's at most two "DragonCurve" Ns at a given X,Y the loop can
309       stop when two Ns are found.
310
311       Only the "leaving" edges will convert back to the target N, so only two
312       of the four edges actually need to be considered.  Is there a way to
313       identify them?  For arm 1 and 3 the leaving edges are up,down on odd
314       points (meaning sum X+Y odd) and right,left for even points (meaning
315       sum X+Y even).  But for arm 2 and 4 it's the other way around.  Without
316       an easy way to determine the arm this doesn't seem to help.
317
318   X,Y is Visited
319       Whether a given X,Y is visited by the curve can be determined from one
320       or two segments (rather then up to four for X,Y to N).
321
322                   |             S midpoint Xmid = X+Y
323                   |                        Ymid = Y-X
324           *---T--X,Y--S---*
325                   |             T midpoint Xmid-1
326                   |                        Ymid+1
327
328       Segment S is to the East of X,Y.  The arm it falls on can be determined
329       as per "X,Y to N" in Math::PlanePath::DragonMidpoint.  Numbering arm(S)
330       = 0,1,2,3 then
331
332                                            X,Y Visited
333                                            -----------
334           if arms_count()==4                  yes     # whole plane
335           if arm(S) < arms_count()            yes
336           if arm(S)==2 and arms_count()==1    no
337           if arm(T) < arms_count()            yes
338
339       This works because when two arms touch they approach and leave by a
340       right angle, without crossing.  So two opposite segments S and T
341       identify the two possible arms coming to the X,Y point.
342
343                  |
344                  |
345                   \
346             ----   ----
347                 \
348                  |
349                  |
350
351       An arm only touches its immediate neighbour, ie. arm-1 or arm+1 mod 4.
352       This means if arm(S)==2 then arm(T) can only be 1,2,3, not 0.  So if
353       "arms_count()" is 1 then arm(T) cannot be on the curve and no need to
354       run its segment check.
355
356       The only exception to the right-angle touching rule is at the origin
357       X,Y = 0,0.  In that case Xmid,Ymid = 0,0 is on the first arm and X,Y is
358       correctly determined to be on the curve.  If S was not to the East but
359       some other direction away from X,Y then this wouldn't be so.
360
361   Turn
362       At each point the curve always turns either left or right, it never
363       goes straight ahead.  The bit above the lowest 1-bit in N gives the
364       turn direction.
365
366           N = 0b...z10000   (possibly no trailing 0s)
367
368           z bit    Turn
369           -----    ----
370             0      left
371             1      right
372
373       For example N=12 is binary 0b1100, the lowest 1 bit is 0b_1__ and the
374       bit above that is a 1, which means turn to the right.  Or N=18 is
375       binary 0b10010, the lowest 1 is 0b___1_ and the bit above that is 0, so
376       turn left there.
377
378       This z bit can be picked out with some bit twiddling
379
380           $mask = $n & -$n;          # lowest 1 bit, 000100..00
381           $z = $n & ($mask << 1);    # the bit above it
382           $turn = ($z == 0 ? 'left' : 'right');
383
384       This sequence is in Knuth volume 2 "Seminumerical Algorithms" answer to
385       section 4.5.3 question 41 and is called the "dragon sequence".  It's
386       expressed there recursively as
387
388           d(0) = 1       # unused, since first turn at N=1
389           d(2N) = d(N)   # shift down looking for low 1-bit
390           d(4N+1) = 0    # bit above lowest 1-bit is 0
391           d(4N+3) = 1    # bit above lowest 1-bit is 1
392
393   Next Turn
394       The bits also give the turn after next by looking at the bit above the
395       lowest 0-bit.  This works because 011..11 + 1 = 100..00 so the bit
396       above the lowest 0 becomes the bit above the lowest 1.
397
398           N = 0b...w01111    (possibly no trailing 1s)
399
400           w bit    Next Turn
401           ----     ---------
402             0       left
403             1       right
404
405       For example at N=12=0b1100 the lowest 0 is the least significant bit
406       0b___0, and above that is a 0 too, so at N=13 the turn is to the left.
407       Or for N=18=0b10010 the lowest 0 is again the least significant bit,
408       but above it is a 1, so at N=19 the turn is to the right.
409
410       This too can be found with some bit twiddling, as for example
411
412           $mask = $n ^ ($n+1);      # low one and below 000111..11
413           $w = $n & ($mask + 1);    # the bit above there
414           $turn = ($w == 0 ? 'left' : 'right');
415
416   Total Turn
417       The total turn is the count of 0<->1 transitions in the runs of bits of
418       N, which is the same as how many bit pairs of N (including overlaps)
419       are different so "01" or "10".
420
421       This can be seen from the segment replacements resulting from bits of
422       N,
423
424           N bits from high to low, start in "plain" state
425
426           plain state
427            0 bit -> no change
428            1 bit -> count left, and go to reversed state
429
430           reversed state
431            0 bit -> count left, and go to plain state
432            1 bit -> no change
433
434       The 0 or 1 counts are from the different side a segment expands on in
435       plain or reversed state.  Segment A to B expands to an "L" shape bend
436       which is on the right in plain state, but on the left in reversed
437       state.
438
439             plain state             reverse state
440
441             A = = = = B                    +
442              \       ^              0bit  / \
443               \     /               turn /   \ 1bit
444           0bit \   / 1bit           left/     \
445                 \ /  turn              /       v
446                  +   left             A = = = = B
447
448       In both cases a rotate of +45 degrees keeps the very first segment of
449       the whole curve in a fixed direction (along the X axis), which means
450       the south-east slope shown is no-change.  This is the 0 of plain or the
451       1 of reversed.  And the north-east slope which is the other new edge is
452       a turn towards the left.
453
454       It can be seen the "state" above is simply the previous bit, so the
455       effect for the bits of N is to count a left turn at each transition
456       from 0->1 or 1->0.  Initial "plain" state means the infinite zero bits
457       at the high end of N are included.  For example N=9 is 0b1001 so three
458       left turns for curve direction south to N=10 (as can be seen in the
459       diagram above).
460
461            1 00 1   N=9
462           ^ ^  ^
463           +-+--+---three transitions,
464                    so three left turns for direction south
465
466       The transitions can also be viewed as a count of how many runs of
467       contiguous 0s or 1s, up to the highest 1-bit.
468
469           1 00 1   three blocks of 0s and 1s
470
471       This can be calculated by some bit twiddling with a shift and xor to
472       turn transitions into 1-bits which can then be counted, as per Jorg
473       Arndt (fxtbook section 1.31.3.1 "The Dragon Curve").
474
475           total turn = count_1_bits ($n ^ ($n >> 1))
476
477       The reversing structure of the curve shows up in the total turn at each
478       point.  The total turns for a block of 2^N is followed by its own
479       reversal plus 1.  For example,
480
481                           ------->
482           N=0 to N=7    0, 1, 2, 1, 2, 3, 2, 1
483
484           N=15 to N=8   1, 2, 3, 2, 3, 4, 3, 2    each is +1
485                                      <-------
486
487   N to dX,dY
488       "n_to_dxdy()" is the "total turn" per above, or for fractional N then
489       an offset according to the "next turn" above.  If using the bit
490       twiddling operators described then the two can be calculated
491       separately.
492
493       The current "n_to_dxdy()" code tries to support floating point or other
494       number types without bitwise XOR etc by processing bits high to low
495       with a state table which combines the calculations for total turn and
496       next turn.  The state encodes
497
498           total turn       0 to 3
499           next turn        0 or 1
500           previous bit     0 or 1  (the bit above the current bit)
501
502       The "next turn" remembers the bit above lowest 0 seen so far (or 0
503       initially).  The "total turn" counts 0->1 or 1->0 transitions.  The
504       "previous bit" shows when there's a transition, or what bit is above
505       when a 0 is seen.  It also works not to have this previous bit in the
506       state but instead pick out two bits each time.
507
508       At the end of bit processing any "previous bit" in state is no longer
509       needed and can be masked out to lookup the final four dx, dy, next dx,
510       next dy.
511

OEIS

513       The Dragon curve is in Sloane's Online Encyclopedia of Integer
514       Sequences in many forms (and see "DragonMidpoint" for its forms too),
515
516           <http://oeis.org/A014577> (etc)
517
518           A332383   X coordinate
519           A332384   Y coordinate
520
521           A038189   turn, 0=left,1=right, bit above lowest 1, extra 0
522           A089013   turn, 0=left,1=right, bit above lowest 1, extra 1
523           A082410   turn, 1=left,0=right, reversing complement, extra 0
524           A099545   turn, 1=left,3=right, as [odd part n] mod 4
525                       so turn by 90 degrees * 1 or 3
526           A034947   turn, 1=left,-1=right, Jacobi (-1/n)
527           A112347   turn, 1=left,-1=right, Kronecker (-1/n), extra 0
528           A121238   turn, 1=left,-1=right, -1^(n + some partitions) extra 1
529           A119972   turn, n=left,-n=right
530           A014577   next turn, 1=left,0=right
531           A014707   next turn, 0=left,1=right
532           A014709   next turn, 1=left,2=right
533           A014710   next turn, 2=left,1=right
534           A090678   1=same turn as previous, 0=different
535           A143347   paperfolding constant, bits 0=left,1=right in decimal
536
537       These numerous turn sequences differ only in having left or right
538       represented as 0, 1, -1, etc, and possibly "extra" initial 0 or 1 at
539       n=0 arising from the definitions and the first turn being at n=N=1.
540       The "next turn" forms begin at n=0 for turn at N=1 and so are the turn
541       at N=n+1.
542
543           A005811   direction total turn
544           A088748   direction total turn + 1
545           A037834   direction total turn - 1
546           A136004   direction total turn + 4
547           A246960   direction 0,1,2,3 = total turn mod 4
548           A173318   cumulative(total turn)
549           A164910   cumulative(total turn + 1)
550           A166242   2^(total turn), by double/halving
551           A000975   N of new maximum total turn, binary 10101...
552           A268411   direction of horizontals, 0=East, 1=West
553           A043724   N of East
554           A043725   N of North
555           A043726   N of West
556           A043727   N of South
557
558           A088431   turn sequence run lengths
559           A007400     2*runlength
560
561           A091072   N positions of the left turns, being odd part form 4K+1
562           A091067   N positions of the right turns, being odd part form 4K+3
563           A255068   N positions where next turn right
564           A060833   N positions where previous turn right
565           A106837   N positions of consecutive turns R,R
566           A106838   N positions of consecutive turns R,R,R
567           A106840   N positions of consecutive turns L,L
568           A106841   N positions of consecutive turns L,L,L
569
570           A106836   N steps between right turns
571           A088742   N steps between left turns
572           A255070   num right turns 1 to N
573           A236840   2* num right turns 1 to N
574           A003460   turns N=1 to N=2^n-1 packed as bits 1=left,0=right
575                       low to high, then written in octal
576           A126937   coordinates coded by SquareSpiral (start N=0 and flip Y)
577
578           A038503   num segments East  in level k
579           A038504   num segments North in level k
580           A038505   num segments West  in level k
581           A000749   num segments South in level k
582
583           A146559   X at N=2^k, for k>=1, being Re((i+1)^k)
584           A009545   Y at N=2^k, for k>=1, being Im((i+1)^k)
585
586           A227036   boundary length N=0 to N=2^k
587                       also right boundary length to N=2^(k+1)
588           A203175   left boundary length N=0 to N=2^k
589                       = differences of total boundary
590                       = squares on left boundary
591
592           A003476   squares on right boundary
593                       = single points N=0 to N=2^(k-1) inclusive
594           A164395   single points N=0 to N=2^k-1 inclusive, for k=4 up
595
596           A003230   area enclosed N=0 to N=2^k, for k=4 up
597                      same as double points
598           A003478   area enclosed by left side,
599                      also area increment
600           A003477   area of each blob (touching enclosed unit squares)
601
602           A003479   join area between N=2^k replications
603           A003229   join area increment,
604                      also area left side extra over doubling
605           A077949    same
606
607           A289265   growth rate r = 1.695 of boundaries etc
608           A272031   fractal dimension log(r)/log(sqrt(2))
609
610           arms=4
611             A165211   abs(dY), 0,1,0,1,1,0,1,0 repeating
612
613       For reference, "dragon-like" A059125 is similar to the turn sequence
614       A014707, but differs in having the "middle" values for each replication
615       come from successive values of the sequence itself, or some such.
616
617   A088431 and A007400
618       The run lengths A088431 and A007400 are from a continued fraction
619       expansion of an infinite sum
620
621               1   1   1     1      1              1
622           1 + - + - + -- + --- + ----- + ... + ------- + ...
623               2   4   16   256   65536         2^(2^k)
624
625       Jeffrey Shallit and independently M. Kmosek show how continued fraction
626       terms repeated in reverse give rise to this sort of power sum,
627
628           Jeffrey Shallit, "Simple Continued Fractions for Some Irrational
629           Numbers", Journal of Number Theory, volume 11, 1979, pages 209-217.
630           <http://www.cs.uwaterloo.ca/~shallit/papers.html>,
631           <http://www.cs.uwaterloo.ca/~shallit/Papers/scf.ps>
632
633           (And which appears in Knuth "Art of Computer Programming", volume
634           2, section 4.5.3 exercise 41.)
635
636   A126937
637       The A126937 "SquareSpiral" numbering has the dragon curve and square
638       spiralling with their Y axes in opposite directions, as shown in its
639       a126937.pdf.  So the dragon curve turns up towards positive Y but the
640       square spiral is numbered down towards negative Y (or vice versa).
641       "PlanePath" code for this starting at "$i=0" would be
642
643             my $dragon = Math::PlanePath::DragonCurve->new;
644             my $square = Math::PlanePath::SquareSpiral->new (n_start => 0);
645             my ($x, $y) = $dragon->n_to_xy ($i);
646             my $A126937_of_i = $square->xy_to_n ($x, -$y);
647

HOUSE OF GRAPHS

649       House of Graphs entries for the dragon curve as a graph include
650
651           <https://hog.grinvin.org/ViewGraphInfo.action?id=19655> etc
652
653           19655     level=0 (1-segment path)
654           32234     level=1 (2-segment path)
655           286       level=2 (4-segment path)
656           414       level=3 (8-segment path)
657           33739     level=4
658           33741     level=5
659           33743     level=6
660           33745     level=7
661           33747     level=8
662
663       And for just a blob (the biggest 2-connected component in its level)
664
665           674       level=4 (4-cycle single unit square)
666           25223     level=5
667           33749     level=6
668           33751     level=7
669           33753     level=8
670           34163     level=9
671

SEE ALSO

673       Math::PlanePath, Math::PlanePath::DragonRounded,
674       Math::PlanePath::DragonMidpoint, Math::PlanePath::R5DragonCurve,
675       Math::PlanePath::TerdragonCurve
676
677       Math::PlanePath::ComplexMinus, Math::PlanePath::ComplexPlus,
678       Math::PlanePath::CCurve, Math::PlanePath::AlternatePaper
679
680       Graph::Maker::TwindragonAreaTree
681
682       <http://rosettacode.org/wiki/Dragon_curve>
683

HOME PAGE

685       <http://user42.tuxfamily.org/math-planepath/index.html>
686

LICENSE

688       Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019, 2020,
689       2021 Kevin Ryde
690
691       Math-PlanePath is free software; you can redistribute it and/or modify
692       it under the terms of the GNU General Public License as published by
693       the Free Software Foundation; either version 3, or (at your option) any
694       later version.
695
696       Math-PlanePath is distributed in the hope that it will be useful, but
697       WITHOUT ANY WARRANTY; without even the implied warranty of
698       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
699       General Public License for more details.
700
701       You should have received a copy of the GNU General Public License along
702       with Math-PlanePath.  If not, see <http://www.gnu.org/licenses/>.
703
704
705
706perl v5.36.0                      2022-07-22   Math::PlanePath::DragonCurve(3)
Impressum