haskell-notes

кода. Для выделения одной строки мы можем воспользоваться знаком > .

Примеры вычисления в интерпретаторе

В Haddock мы можем привести пример вычисления выражения в интерпретаторе. Это делается с помощью

тройного символа > :

— | Two examples are given bellow:

— >>> 2+3

— 5

— >>> print 1 >> print 2

— 1

— 2

Строки, которые идут сразу за строкой с символом >>> помечаются как результат выполнения выражения

в интерпретаторе.

Имена определений

Для того чтобы выделить имя любого определения, будь то функция, тип или класс, необходимо заклю-

чить его в ординарные кавычки, как в ’T’. При этом Haddock установит ссылку к определению и подсветит

имя в тексте. Для того чтобы сослаться на определение из другого модуля необходимо написать его полное

имя, то есть с приставкой имени модуля, например функция fun, определённая в модуле M, имеет полное

имя M. fun, тогда в комментариях мы обозначаем её ’M.fun’.

Ординарные кавычки часто используются в английском языке как апострофы, в таких сочетаниях как

don’t, isn’t. Перед такими вхождениями ординарных кавычек можно не писать обратный слэш. Haddock сумеет

отличить их от идентификатора.

Курсив и моноширинный шрифт

Для выделения текста курсивом, он заключается в окружение . Для написания текста моноширинным

шрифтом, он заключается в окружение …@@.

Модули

Для обозначения модулей используются двойные кавычки, как в

— | This is a reference to the ”Foo” module.

Создание документации с помощью Haddock | 273

Списки

Список без нумерации обозначается с помощью звёздочек:

— | This is a bulleted list:

* first item

* second item

Пронумерованный список, обозначается символами (n) или n. (n с точкой), где n – некоторое целое

число:

— | This is an enumerated list:

(1) first item

2. second item

Список определений

Определения обозначаются квадратными скобками, например комментарий:

— | This is a definition list:

[@foo@] The description of @foo@.

[@bar@] The description of @bar@.

в документации будет выглядеть так:

foo The description of foo.

bar The description of bar.

Для выделения текста моноширинным шрифтом мы воспользовались окружением …@@.

URL

Ссылки на сайты включаются с помощью окружения .

Ссылки внутри модуля

Для того чтобы сослаться на какой-нибудь текст внутри модуля, его необходимо отметить ссылкой. Для

этого мы помещаем в том месте, на которое мы хотим сослаться, запись #label#, где label – это идентифика-

тор ссылки. Теперь мы можем сослаться на это место из другого модуля с помощью записи ” module#label”,

где module – имя модуля, в котором находится ссылка label.

18.3 Краткое содержание

В этой главе мы познакомились с основными элементами арсенала разработчика программ. Мы научи-

лись создавать библиотеки и документировать их.

18.4 Упражнения

Вспомните один из примеров и превратите его в библиотеку. Например, напишите библиотеку для нату-

ральных чисел Пеано.

274 | Глава 18: Средства разработки

Глава 19

Ориентируемся по карте

Рассмотрим задачу поиска маршрута на карте. У нас есть карта метро и нам нужно проложить маршрут

от одной станции к другой. Карта метро~– это граф, узлы обозначают станции, а рёбра соединяют соседние

станции. Предположим, что мы знаем расстояния между всеми станциями и нам надо найти кратчайший

путь от станции площадь Баха до станции Таинственный лес (рис. 19.1).

Космодром

Запад

Таинственный

лес

Призрак

Инева

ул.Булычёва

Троллев мост

Тилль

Сириус

Звезда

Север

Лао

Юг

Де

пл.Баха

Крест

пл.Шекспира

Дно болота

Родник

Восток

Рис. 19.1: Схема метрополитена

Давайте переведём этот рисунок на Haskell. Сначала опишем имена линий и станций:

module Metro where

data Station = St Way Name

deriving (Show, Eq)

data Way = Blue | Black | Green | Red | Orange

deriving (Show, Eq)

data Name = Kosmodrom | UlBylichova | Zvezda

| Zapad | Ineva | De | Krest | Rodnik | Vostok

| Yug | Sirius | Til | TrollevMost | Prizrak | TainstvenniyLes

| DnoBolota | PlBakha | Lao | Sever

| PlShekspira

deriving (Show, Eq)

Предположим, что нам известны координаты каждой из станций. По ним мы можем вычислять расстояние

между станциями по прямой:

| 275

data Point = Point

{ px :: Double

, py :: Double

} deriving (Show, Eq)

place :: Name -> Point

place x = uncurry Point $ case x of

Kosmodrom

-> (3,7)

UlBylichova

-> (2,4)

Zvezda

-> (0,1)

Zapad

-> (1,7)

Ineva

-> (0.5, 4)

De

-> (0, 1)

Krest

-> (0, 3)

Rodnik

-> (0, 5)

Vostok

-> (1, 7)

Yug

-> (7, 1)

Sirius

-> (3,0)

Til

-> (3,2)

TrollevMost

-> (5,4)

Prizrak

-> (8,6)

TainstvenniyLes

-> (11,7)

DnoBolota

-> (7, 4)

PlBakha

-> (3, 3)

Lao

-> (3.5,0)

Sever

-> (6,1)

PlShekspira

-> (3, 3)

dist :: Point -> Point -> Double

dist a b = sqrt $ (px a px b)^2 + (py a py b)^2

stationDist :: Station -> Station -> Double

stationDist (St n a) (St m b)

| n /= m && a == b

= penalty

| otherwise

= dist (place a) (place b)

where penalty = 1

Расстояние между точками вычисляется по формуле Евклида (dist). Если у станций одинаковые имена,

но они расположены на разных линиях мы будем считать, что расстояние между ними равно единице. Теперь

нам необходимо описать связность станций. Мы опишем связность в виде функции, которая для данной

Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162