Кривая Серпинского - Sierpiński curve

Кривые Серпинского площадь рекурсивно определены последовательность из непрерывный закрытый самолет фрактальные кривые обнаружен Вацлав Серпинский, который в пределе полностью заполняют единичный квадрат: таким образом, их предельная кривая, также называемая кривая Серпинского, является примером кривая заполнения пространства.

Поскольку кривая Серпинского заполняет пространство, ее Хаусдорфово измерение (в пределе ) является .
В Евклидова длина из th итерационная кривая является

т.е. он растет экспоненциально с участием вне всяких пределов, тогда как предел для территории, окруженной является квадрат (в евклидовой метрике).

Кривая Серпинского («Квадратная снежинка Серпинского»[1]) первого порядка
Кривые Серпинского 1-го и 2-го порядков
Кривые Серпинского порядков 1-3
Серпинского "квадратная кривая"[2] заказов 2-4

Использование кривой

Кривая Серпинского полезна в нескольких практических приложениях, потому что она более симметрична, чем другие обычно изучаемые кривые заполнения пространства. Например, он был использован в качестве основы для быстрого построения приближенного решения задачи Проблема коммивояжера (который запрашивает кратчайшую последовательность из заданного набора точек): эвристика заключается в простом посещении точек в той же последовательности, в которой они появляются на кривой Серпинского.[3] Для этого требуется два шага: сначала вычислить инверсию каждой точки, которую нужно посетить; затем отсортируйте значения. Эта идея была использована для создания систем маршрутизации для коммерческих автомобилей, основанных только на картах Rolodex.[4]

Кривая заполнения пространства - это непрерывное отображение единичного интервала на единичный квадрат, и поэтому (псевдо) инверсия отображает единичный квадрат на единичный интервал. Один из способов построения псевдообращения следующий. Пусть нижний левый угол (0, 0) единичного квадрата соответствует 0,0 (и 1,0). Тогда верхний левый угол (0, 1) должен соответствовать 0,25, верхний правый угол (1, 1) - 0,50, а правый нижний угол (1, 0) - 0,75. Обратное отображение внутренних точек вычисляется с использованием рекурсивной структуры кривой. Вот функция, закодированная на Java, которая вычисляет относительное положение любой точки на кривой Серпинского (то есть псевдообратное значение). Он принимает в качестве входных данных координаты точки (x, y), которую нужно инвертировать, и углы охватывающего прямоугольного равнобедренного треугольника (ax, ay), (bx, by) и (cx, cy). (Обратите внимание, что единичный квадрат представляет собой объединение двух таких треугольников.) Остальные параметры определяют уровень точности, с которой должно быть вычислено обратное.

    статический длинная sierp_pt2code( двойной топор, двойной ай, двойной bx, двойной от, двойной сх, двойной Сай,        int текущий уровень, int maxLevel, длинная код, двойной Икс, двойной y )     {        если (текущий уровень <= maxLevel) {            текущий уровень++;            если ((sqr(Икс-топор) + sqr(y-ай)) < (sqr(Икс-сх) + sqr(y-Сай))) {                код = sierp_pt2code( топор, ай, (топор+сх)/2.0, (ай+Сай)/2.0, bx, от,                    текущий уровень, maxLevel, 2 * код + 0, Икс, y );            }            еще {                код = sierp_pt2code( bx, от, (топор+сх)/2.0, (ай+Сай)/2.0, сх, Сай,                    текущий уровень, maxLevel, 2 * код + 1, Икс, y );            }        }        вернуть код;        }

Представление как система Линденмайера

Кривая Серпинского может быть выражена переписать систему (L-система ).

Алфавит: F, G, X
Константы: F, G, +, -
Аксиома: F - XF - F - XF
Правила производства:
Х → XF + G + XF - F - XF + G + X
Угол: 45

Здесь оба F и г означает «протянуть вперед», + означает «повернуть налево на 45 °», и означает «повернуть направо на 45 °» (см. черепаха графика ). Кривая обычно строится с разной длиной для F и G.

Квадратная кривая Серпинского может быть выражена аналогичным образом:

Алфавит: F, X
Константы: F, +, -
Аксиома: F + XF + F + XF
Правила производства:
X → XF-F + F-XF + F + XF-F + F-X
Угол: 90

Кривая стрелки

В Кривая наконечника стрелы Серпинского представляет собой фрактальную кривую, похожую по внешнему виду и идентичную в пределе Серпинский треугольник.

Эволюция кривой наконечника стрелы Серпинского

Кривая стрелки Серпинского представляет собой равносторонний треугольник с треугольными отверстиями через равные промежутки. Его можно описать двумя производственными правилами подстановки: (A → B-A-B) и (B → A + B + A). A и B повторяются и внизу делают то же самое - проводят линию. Плюс и минус (+ и -) означают поворот на 60 градусов влево или вправо. Конечная точка кривой стрелки Серпинского всегда одна и та же, при условии, что вы повторяете четное количество раз и при каждой рекурсии вы уменьшаете длину линии вдвое. Если вы вернетесь на нечетную глубину (порядок нечетный), то вы окажетесь повернутым на 60 градусов в другой точке треугольника.

Альтернативная перетяжка дана в статье о кривая де Рама: используется тот же метод, что и для кривых де Рама, но вместо использования двоичного (основание-2) расширения используется троичное (основание-3) расширение.

Код

Учитывая функции рисования void draw_line (двойное расстояние); и пустой поворот (int angle_in_degrees);код для рисования (приблизительной) кривой наконечника стрелки Серпинского выглядит следующим образом:

пустота sierpinski_arrowhead_curve(беззнаковый порядок, двойной длина){    // Если порядок четный, мы можем просто нарисовать кривую.    если ( 0 == (порядок & 1) ) {        кривая(порядок, длина, +60);    }    еще / * порядок нечетный * / {        очередь( +60);        кривая(порядок, длина, -60);    }}
пустота кривая(беззнаковый порядок, двойной длина, int угол){    если ( 0 == порядок ) {        draw_line(длина);    } еще {        кривая(порядок - 1, длина / 2, -угол);        очередь(угол);        кривая(порядок - 1, длина / 2, угол);        очередь(угол);        кривая(порядок - 1, длина / 2, -угол);    }}

Представление как система Линденмайера

Как и многие двумерные фрактальные кривые, кривую стрелки Серпинского можно расширить до трех измерений.

Кривая наконечника стрелки Серпинского может быть выражена переписать систему (L-система ).

Алфавит: X, Y
Константы: F, +, -
Аксиома: XF
Правила производства:
X → YF + XF + Y
Y → XF - YF - X

Вот, F означает «протянуть вперед», + означает «повернуть налево на 60 °», и означает «повернуть направо на 60 °» (см. черепаха графика ).

Смотрите также

использованная литература

  1. ^ Вайсштейн, Эрик В. «Кривая Серпинского». MathWorld. Получено 21 января 2019.
  2. ^ Дикау, Роберт М. (1996/7) "Двумерные L-системы ", Математические фигуры Роберта. MathForum.org. Проверено 21 января 2019.
  3. ^ Platzman, Loren K .; Бартольди, Джон Дж., III (1989). «Кривые заполнения пространства и плоская задача коммивояжера». Журнал Ассоциации вычислительной техники. 36 (4): 719–737. Дои:10.1145/76359.76361.
  4. ^ Бартольди, Джон Дж., III. «Некоторые комбинаторные приложения кривых заполнения пространства». Технологический институт Джорджии. Архивировано из оригинал на 2012-08-03.

дальнейшее чтение