Эйнштейна
Не особо страшно. Между тем времени жизни Вселенной не хватит, чтобы исследовать все расширения этого уравнения.
Буквы
Приведу простейшую аналогию. Все видели детские книжки со страницами, усыпанными цифрами. Если соединять цифры линией в правильном порядке, обнаруживаются скрытые, порой удивительные, картинки. Изображение на телевизионном экране получается путем применения того же принципа в значительно усложненном виде.
Теоретически каждый, умеющий складывать и умножать, способен построить множество Мандельброта с помощью ручки или карандаша на листке бумаги в клеточку. Однако, как мы увидим позже, существуют практические сложности. Главная из них в том, что жизнь человека редко длится больше ста лет. Поэтому множество Мандельброта создают не вручную, а с помощью компьютера и демонстрируют на дисплеях.
Есть два способа определить координаты точки в пространстве. Один используется чаще, другой реже. В первом требуется некая вспомогательная решетка — восток-запад, север-юг — либо вертикальная ось
Представьте, что дисплей компьютера — это экран радара. На нем — одна точка, за движением которой будет следить множество Мандельброта. Прежде чем мы включим наш радар, хотелось бы упростить уравнение еще больше, вот так:
Я отбросил
Маленькая буква
Пока ничего особо волнующего. Но теперь наступает черед модификации, приводящей к серьезным отличиям:
Знак равенства заменен двойной стрелочкой. Напоминает знак двустороннего движения, показывающий, что числа плывут в обоих направлениях. На этот раз мы не остановимся на
256, 65536, 4294967296…
Точка, стартовавшая всего в 2 единицах от центра, гигантскими, непрестанно увеличивающимися шагами направится к бесконечности.
Виток при постоянном движении по петле называется итерацией. Процесс похож на то, как собака гоняется за собственным хвостом. Но собака при этом никуда не денется, а вот математические итерации способны увести нас в очень странные места. Скоро мы на них посмотрим.
Наконец мы готовы включить радар. На большинстве дисплеев рисуют круги радиусами 10, 20… 100 километров от центра. Нам потребуется единственный круг радиусом 1. Незачем вводить единицы измерения, поскольку мы оперируем чистыми числами. Хотите — назовите их сантиметрами или световыми годами, как больше нравится.
Предположим, что первоначальная позиция точки находится где угодно в пределах этого круга. Точное место не имеет значения. Итак,
Поскольку 1 в квадрате дает 1, то
Теперь рассмотрим случай, когда первоначальное
При первом возведении в квадрат
1,000000000000000000002
затем
1,000000000000000000004
1,000000000000000000008
1,000000000000000000016
1,000000000000000000032
И так далее — насколько хватит бумаги для распечатки. Для любых практических целей подобные величины округляют до 1. Наша точка не двинулась заметно ни вперед, ни назад. Она все равно остается в кружке с радиусом 1.
Но нули медленно исчезают, и цифры после запятой неуклонно маршируют влево. Неожиданно что-то появляется на месте третьей, второй, первой цифры после запятой. После небольшого числа операций числа начинают взрываться, как показывает этот пример:
1,001 1,002 1,004 1,008 1,016 1,032
1,066 1,136 1,292 1,668 2,783 7,745
59,987 3598,467 12948970
167675700000000
28115140000000000000000000000
И до бесконечности.
Справа может быть миллион, миллиард нулей, но результат не изменится. Постепенно цифры доберутся до запятой, и тогда
Теперь рассмотрим другой случай. Допустим,
0,99999999999999999999.
Как и раньше, долгое время, пока мы будем крутиться по спирали, все останется на своих местах. Но числа в дальнем правом конце будут постепенно уменьшаться. После нескольких тысяч или миллионов итераций — катастрофа! —
Проверьте это на компьютере. Он управляется только с двенадцатизначными цифрами? Не имеет значения. Вы получите тот же ответ. Честное слово.
Результаты наших действий, выработанного алгоритма, можно суммировать тремя законами. Некоторым они покажутся слишком тривиальными. Но не бывает тривиальных математических истин. Через пару шагов эти законы уведут нас во вселенную, поражающую удивительной красотой. Вот три закона «квадратичной» программы:
1. Если исходное