WikiDer > TLA +

TLA+
TLA+
TLA + логотип splash image.png
ПарадигмаДействие
РазработаноЛесли Лэмпорт
Впервые появился23 апреля 1999 г.; 21 год назад (1999-04-23)[1]
Стабильный выпуск
TLA+2 / 15 января 2014 г.; 6 лет назад (2014-01-15)[2]
Язык реализацииЯва
Операционные системыКроссплатформенность (мультиплатформенность)
ЛицензияЛицензия MIT[3]
Расширения имени файла.tla
Интернет сайтисследование.microsoft.com/ en-us/ мм/люди/ lamport/ tla/ tla.html

TLA+ это формальная спецификация язык, разработанный Лесли Лэмпорт. Он используется для разработки, моделирования, документирования и проверки программ, особенно параллельные системы и распределенные системы. TLA+ описан как поддающийся исчерпывающей проверке псевдокод,[4] и его использование сравнивается с рисование чертежей для программных комплексов;[5] TLA является акроним за Временная логика действий.

По проектированию и документации TLA+ выполняет ту же цель, что и неформальный технические характеристики. Однако TLA+ спецификации написаны на формальном языке логика и математика, а точность спецификаций, написанных на этом языке, предназначена для выявления недостатков дизайна до начала реализации системы.[6]

Поскольку TLA+ спецификации написаны на формальном языке, они поддаются конечному проверка модели. Средство проверки моделей находит все возможные варианты поведения системы вплоть до некоторого количества этапов выполнения и проверяет их на предмет нарушений желаемого инвариантность свойства, такие как безопасность и живость. TLA+ спецификации используют базовые теория множеств определить безопасность (плохого не случится) и темпоральная логика чтобы определить жизнеспособность (хорошие вещи в конце концов случаются).

TLA+ также используется для записи проверенные машиной доказательства правильности как для алгоритмы и математические теоремы. Доказательства написаны в декларативном, иерархическом стиле, независимом от какой-либо отдельной бэкэнда средства доказательства теорем. Как формальные, так и неформальные структурированные математические доказательства могут быть написаны в TLA.+; язык похож на Латекс, и существуют инструменты для перевода TLA+ спецификации к документам LaTeX.[7]

TLA+ был представлен в 1999 году после нескольких десятилетий исследований метода проверки для параллельных систем. С тех пор была разработана цепочка инструментов, включая IDE и средство проверки распределенных моделей. Псевдокодоподобный язык PlusCal создан в 2009 году; Это транспилес в TLA+ и полезен для определения последовательных алгоритмов. TLA+2 был объявлен в 2014 году, расширяя языковую поддержку для конструкций доказательства. Текущий TLA+ ссылка TLA+ Гиперкнига пользователя Лесли Лэмпорт.

История

Портрет шестидесятилетнего израильтянина. Его волосы короткие и лысые, на нем очки, рубашка и пиджак.
Амир Пнуели применил темпоральную логику к информатике, за что получил в 1996 г. Премия Тьюринга.

Современное темпоральная логика был разработан Артур Прайор в 1957 году тогда называли напряженной логикой. Несмотря на то что Амир Пнуели был первым, кто серьезно изучил приложения темпоральной логики к ИнформатикаПрайор размышлял о его использовании десятью годами ранее, в 1967 году:

Полезность систем такого типа [от дискретного времени] не зависит от какого-либо серьезного метафизического предположения о дискретности времени; они применимы в ограниченных областях дискурса, в которых нас интересует только то, что происходит дальше в последовательности дискретных состояний, например в работе цифрового компьютера.

Пнуэли исследовал использование темпоральной логики в определении и рассуждении о компьютерных программах, представив линейная темпоральная логика в 1977 году. LTL стал важным инструментом для анализа параллельных программ, легко выражая такие свойства, как взаимное исключение и свобода от тупик.[8]

Параллельно с работой Пнуэли над LTL ученые работали над обобщением Логика Хоара для проверки многопроцессорных программ. Лесли Лэмпорт заинтересовался проблемой после экспертная оценка обнаружил ошибку в представленной им статье о взаимном исключении. Эд Эшкрофт представил инвариантность в своей статье 1975 года «Доказательство утверждений о параллельных программах», которую Лэмпорт использовал для обобщения Флойдв своей статье 1977 г. «Доказательство правильности многопроцессорных программ». В статье Лампорта также представлены безопасность и живость как обобщение частичная правильность и прекращение, соответственно.[9] Этот метод использовался для проверки первого параллельного вывоз мусора алгоритм в статье 1978 года с Эдсгер Дейкстра.[10]

Лампорт впервые столкнулся с LTL Пнуэли во время семинара 1978 г. Стэнфорд организованный Сьюзан Овики. По словам Лэмпорта, «я был уверен, что темпоральная логика - это какая-то абстрактная чушь, у которой никогда не будет практического применения, но это показалось забавным, поэтому я присутствовал». В 1980 году он опубликовал статью «Иногда бывает, а иногда и не никогда» », которая стала одной из самых цитируемых статей в литературе по темпоральной логике.[11] Лэмпорт работал над написанием спецификаций временной логики во время своего пребывания в НИИ, но сочли такой подход непрактичным:

Портрет европейца лет семидесяти, с седыми волосами средней длины и полной седой бородой, в очках и футболке.
TLA+ был разработан компьютерным ученым и лауреатом премии Тьюринга 2013 года. Лесли Лэмпорт.

Однако я разочаровался во временной логике, когда увидел, как Шварц, Меллиар-Смит и Фриц Фогт целыми днями пытались определить простой Очередь FIFO - спорить о достаточности перечисленных объектов. Я понял, что, несмотря на его эстетическую привлекательность, написание спецификации как совокупности временных свойств просто не работает на практике.

Его поиски практического метода спецификации привели к статье 1983 г. «Specifying Concurrent Programming Modules», в которой была введена идея описания переходов между состояниями как булевозначных функций переменных со штрихом и без штриха.[12] Работа продолжалась в течение 1980-х годов, и Лэмпорт начал публиковать статьи о временная логика действий в 1990 г .; однако официально он не был представлен до тех пор, пока в 1994 году не была опубликована «Временная логика действий». TLA позволила использовать действия в темпоральных формулах, что, по словам Лэмпорта, «обеспечивает элегантный способ формализовать и систематизировать все рассуждения, используемые при параллельной проверке системы».[13]

Спецификации TLA в основном состояли из обычной вневременной математики, которую Лэмпорт нашел менее громоздкой, чем чисто временная спецификация. TLA предоставила математическую основу для языка спецификаций TLA+, представленный в статье "Определение параллельных систем с помощью TLA+" в 1999 году.[1] Позже в том же году Юань Ю написал TLC. модель проверки для TLA+ технические характеристики; ТСХ использовалась для поиска ошибок в согласованность кеша протокол для Compaq мультипроцессор.[14]

Лампорт опубликовал полный учебник по TLA+ в 2002 году под названием «Определение систем: TLA+ Язык и инструменты для инженеров-программистов ».[15] PlusCal был представлен в 2009 году,[16] и TLA+ система доказательств (TLAPS) в 2012 году.[17] TLA+2 была анонсирована в 2014 году, добавив некоторые дополнительные языковые конструкции, а также значительно увеличив поддержку на языке системы доказательства.[2] Lamport занимается созданием обновленного TLA+ ссылка, "TLA+ Гиперкнига ». Незавершенная работа имеется в наличии со своего официального сайта. Лампорт также создает Видеокурс TLA +, описанный в нем как «незавершенная работа, которая состоит из начала серии видеолекций, чтобы научить программистов и разработчиков программного обеспечения, как писать свои собственные спецификации TLA +».

Язык

TLA+ спецификации организованы в модули. Модули могут расширять (импортировать) другие модули для использования их функций. Хотя TLA+ стандарт указывается в наборных математических символах, существующих TLA+ инструменты использовать Латекс-подобные определения символов в ASCII. TLA+ использует несколько терминов, требующих определения:

  • Состояние - присвоение значений переменным
  • Поведение - последовательность состояний
  • Шаг - пара последовательных состояний в поведении
  • Шаг заикания - шаг, во время которого переменные не меняются
  • Отношение следующего состояния - отношение, описывающее, как переменные могут изменяться на любом этапе
  • Государственная функция - выражение, содержащее переменные и константы, которое не является отношением следующего состояния
  • Предикат состояния - булевозначная функция состояния
  • Инвариантный - предикат состояния истинен во всех достижимых состояниях
  • Временная формула - выражение, содержащее утверждения во временной логике

Безопасность

TLA+ занимается определением набора всех правильных поведений системы. Например, однобитовые часы, бесконечно тикающие между 0 и 1, можно указать следующим образом:

VARIABLE clockInit == clock  in {0, 1} Tick == IF clock = 0 THEN clock '= 1 ELSE clock' = 0Spec == Init /  [] [Tick] _ <>

Отношение следующего состояния Поставить галочку наборы Часы' (значение Часы в следующем состоянии) до 1, если Часы равно 0, и 0, если Часы равно 1. Предикат состояния В этом верно, если значение Часы либо 0, либо 1. Спецификация - это временная формула, утверждающая, что все поведения однобитовых часов должны изначально удовлетворять В этом и все шаги совпадают Поставить галочку или запинающимся шагом. Два таких поведения:

0 -> 1 -> 0 -> 1 -> 0 -> ...1 -> 0 -> 1 -> 0 -> 1 -> ...

Свойства безопасности однобитовых часов - набора доступных состояний системы - адекватно описаны в спецификации.

Живучесть

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

0 -> 0 -> 0 -> 0 -> 0 -> ...1 -> 1 -> 1 -> 1 -> 1 -> ...

Часы, которые не тикают, бесполезны, поэтому следует запретить такое поведение. Одно из решений - отключить заикание, но TLA+ требует, чтобы заикание всегда было включено; шаг заикания представляет собой изменение некоторой части системы, не описанной в спецификации, и полезен для уточнение. Чтобы часы со временем тикали, слабый справедливость утверждается для Поставить галочку:

Spec == Init /  [] [Tick] _ <> /  WF_ <> (Tick)

Слабая справедливость по отношению к действию означает, что если это действие постоянно разрешено, в конечном итоге оно должно быть выполнено. Со слабой справедливостью Поставить галочку между отметками разрешено только конечное число шагов заикания. Это темпоральное логическое утверждение о Поставить галочку называется утверждением живучести. В общем, утверждение живучести должно быть закрытый машиной: он не должен ограничивать набор достижимых состояний, только набор возможных поведений.[18]

Большинство спецификаций не требуют утверждения свойств живучести. Свойства безопасности достаточны как для проверки модели, так и для руководства по внедрению системы.[19]

Операторы

TLA+ основан на ZF, поэтому операции с переменными включают манипулирование множеством. Язык включает набор членство, союз, пересечение, разница, powerset, и подмножество операторы. Логика первого порядка операторы, такие как , , ¬, , , также включены, а также универсальный и экзистенциальный кванторы и . Гильберта ε предоставляется как оператор CHOOSE, который однозначно выбирает произвольный элемент набора. Арифметические операторы над реалы, целые числа, и натуральные числа доступны из стандартных модулей.

Операторы временной логики встроены в TLA+. Использование темпоральных формул значить п всегда правда, и значить п в конце концов правда. Операторы объединены в значить п верно бесконечно часто, или иметь в виду в конце концов п всегда будет правдой. Другие временные операторы включают слабую и сильную справедливость. Слабая справедливость WFе(А) означает, что действие А включен непрерывно (т.е. без перерывов), в конце концов его нужно принять. Сильная справедливость SFе(А) означает, что действие А включен постоянно (неоднократно, с перерывами или без), в конечном итоге его необходимо принять.

Временная экзистенциальная и универсальная количественная оценка включены в TLA+, хотя и без поддержки со стороны инструментов.

Пользовательские операторы похожи на макросы. Операторы отличаются от функций тем, что их домен не обязательно должен быть набором: например, установить членство оператор имеет категория наборов как его домен, который не действительный набор в ZFC (поскольку его существование приводит к Парадокс Рассела). В TLA добавлены рекурсивные и анонимные пользовательские операторы+2.

Структуры данных

Базовая структура данных TLA+ это набор. Наборы либо перечисляются явно, либо создаются из других наборов с помощью операторов или с помощью {Икс в S: p} куда п какое-то условие на Икс, или же {бывший в S} куда е какая-то функция Икс. Уникальный пустой набор представлен как {}.

Функции в TLA+ присвоить значение каждому элементу в своем домене, набору. [S -> T] - множество всех функций с f [Икс] в Т, для каждого Икс в домен набор S. Например, TLA+ функция Двойной [x in Nat] == ​​x * 2 является элементом множества [Нат -> Нат] так Двойной in [Нат -> Нат] истинное утверждение в TLA+. Функции также определяются с помощью [х в S | -> е] для некоторого выражения е, или путем изменения существующей функции [f ИСКЛЮЧЕНИЕ! [v1] = v2].

Записи тип функции в TLA+. Запись [имя | -> "Джон", возраст | -> 35] это запись с именем поля и возрастом, доступ к которой осуществляется с помощью r.name и ярость, и принадлежащий набору записей [имя: String, возраст: Nat].

Кортежи включены в TLA+. Они явно определены с помощью << e1, е2, е3>> или построены с помощью операторов из стандартного модуля Sequences. Наборы кортежей определяются Декартово произведение; например, определяется набор всех пар натуральных чисел Nat X Nat.

Стандартные модули

TLA+ имеет набор стандартных модулей, содержащих общие операторы. Распространяются вместе с синтаксическим анализатором. Средство проверки моделей TLC использует реализации Java для повышения производительности.

Стандартные модули импортируются с РАСШИРЕНИЯ или же ПРИМЕР заявления.

Инструменты

IDE

TLA + Toolbox
TLA + IDE в типичном использовании, показывающий обозреватель спецификаций слева, редактор в середине и ошибки синтаксического анализа справа.
TLA+ Среда IDE при типичном использовании: обозреватель спецификаций слева, редактор в середине и ошибки анализа справа.
Оригинальный автор (ы)Саймон Замбровски, Маркус Куппе, Дэниел Рикеттс
Разработчики)Hewlett Packard, Microsoft
изначальный выпуск4 февраля 2010 г.; 10 лет назад (2010-02-04)
Стабильный выпуск
1.7.0 / 25 апреля 2020 г.; 7 месяцев назад (2020-04-25)
Предварительный выпуск
1.7.1 / 1 мая 2020 г.; 7 месяцев назад (2020-05-01)
Репозиторийgithub.com/ tlaplus/ tlaplus
Написано вЯва
Доступно ванглийский
ТипИнтегрированная среда развития
ЛицензияЛицензия MIT
Интернет сайтисследование.microsoft.com/ en-us/ мм/люди/ lamport/ tla/ящик для инструментов.html

An интегрированная среда развития реализуется поверх Затмение. Он включает редактор с ошибкой и подсветка синтаксиса, плюс GUI интерфейс для нескольких других TLA+ инструменты:

  • Синтаксический анализатор SANY, который анализирует и проверяет спецификацию на наличие синтаксических ошибок.
  • В Латекс переводчик, чтобы произвести красиво напечатанный спецификации.
  • Переводчик PlusCal.
  • Средство проверки моделей TLC.
  • Система доказательств TLAPS.

IDE распространяется в Панель инструментов TLA.

Проверка модели

Диаграмма конечного автомата однобитовых часов
Состояния и переходы, обнаруженные TLC для однобитовых часов.

TLC модель проверки строит конечное состояние модель TLA+ спецификации для проверки свойства инвариантности. TLC генерирует набор начальных состояний, удовлетворяющих спецификации, затем выполняет поиск в ширину по всем определенным переходам между состояниями. Выполнение прекращается, когда все переходы между состояниями приводят к состояниям, которые уже были обнаружены. Если TLC обнаруживает состояние, которое нарушает системный инвариант, он останавливается и обеспечивает путь трассировки состояния к состоянию нарушения. TLC предоставляет метод объявления симметрии модели для защиты от комбинаторный взрыв.[14] Это также распараллеливает этап исследования состояния и может выполняться в распределенном режиме для распределения рабочей нагрузки по большому количеству компьютеров.[20]

В качестве альтернативы исчерпывающему поиску в ширину TLC может использовать поиск в глубину или генерировать случайное поведение. TLC работает на подмножестве TLA+; модель должна быть конечной и перечислимой, а некоторые временные операторы не поддерживаются. В распределенном режиме TLC не может проверять свойства живучести, а также случайное поведение или поведение в глубину. TLC - это имеется в наличии как инструмент командной строки или в комплекте с инструментарием TLA.

Система доказательств

TLA+ Система доказательства или TLAPS, механически проверяет доказательства написаны в TLA+. Он был разработан в Microsoft Research-INRIA Объединенный центр доказательства правильности параллельных и распределенных алгоритмов. Язык доказательства разработан так, чтобы быть независимым от какого-либо конкретного средства доказательства теорем; Доказательства написаны в декларативном стиле и преобразованы в индивидуальные обязательства, которые отправляются внутренним доказывающим сторонам. Основными сторонними доказывающими устройствами являются Изабель и Зенон, с откатом на SMT решатели CVC3, Yices, и Z3. Доказательства TLAPS иерархически структурированы, что упрощает рефакторинг и делает возможной нелинейную разработку: работа может начинаться на более поздних этапах до того, как будут проверены все предыдущие этапы, а сложные этапы разбиты на более мелкие подэтапы. TLAPS хорошо работает с TLC, так как средство проверки моделей быстро находит мелкие ошибки до начала проверки. В свою очередь, TLAPS может подтвердить свойства системы, которые выходят за рамки возможностей проверки конечных моделей.[17]

TLAPS в настоящее время не поддерживает рассуждения с использованием реальных чисел или большинства временных операторов. Изабель и Зенон, как правило, не могут доказать обязательства арифметического доказательства, требующие использования решающих программ SMT.[21] TLAPS был использован для доказательства правильности Византийский Паксос, архитектура безопасности Memoir и компоненты Распределенная хеш-таблица кондитерских изделий.[17] Он распространяется отдельно от остальной части TLA.+ инструменты и бесплатное программное обеспечение, распространяемое под Лицензия BSD.[22] TLA+2 значительно расширена языковая поддержка конструкций доказательства.

Промышленное использование

В Microsoft, критическая ошибка была обнаружена в Xbox 360 модуль памяти в процессе написания спецификации в TLA+.[23] TLA+ был использован для написания формальных доказательств правильности для Византийский Паксос и компоненты Распределенная хеш-таблица кондитерских изделий.[17]

Веб-сервисы Amazon использовал TLA+ с 2011 года. TLA+ модель проверяет обнаруженные ошибки в DynamoDB, S3, EBS, и внутренний распределенный менеджер блокировок; некоторые ошибки требовали трассировки состояний из 35 шагов. Проверка модели также использовалась для проверки агрессивных оптимизаций. Кроме того, TLA+ Было обнаружено, что спецификации имеют ценность как документация и вспомогательные средства проектирования.[4][24]

Microsoft Azure использовал TLA+ разрабатывать Cosmos DB, глобально распределенная база данных с пятью различными модели согласованности.[25][26]

Примеры

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

Рекомендации

  1. ^ а б Лэмпорт, Лесли (Январь 2000 г.). Указание параллельных систем с помощью TLA+ (PDF). Научная серия НАТО, III: Компьютерные и системные науки. 173. IOS Press, Амстердам. С. 183–247. ISBN 978-90-5199-459-9. Получено 22 мая 2015.
  2. ^ а б Лэмпорт, Лесли (15 января 2014 г.). «TLA+2: Предварительное руководство " (PDF). Получено 2 мая 2015.
  3. ^ «Tlaplus Tools - Лицензия». CodePlex. Microsoft, Compaq. 8 апреля 2013 г.. Получено 10 мая 2015.https://tlaplus.codeplex.com/license
  4. ^ а б Ньюкомб, Крис; Рат, Тим; Чжан, Фань; Мунтяну, Богдан; Брукер, Марк; Дорогой, Майкл (29 сентября 2014 г.). «Использование формальных методов в Amazon Web Services» (PDF). Amazon. Получено 8 мая 2015.
  5. ^ Лэмпорт, Лесли (25 января 2013 г.). «Почему мы должны создавать программное обеспечение, как мы строим дома». Проводной. Проводной. Получено 7 мая 2015.
  6. ^ Лэмпорт, Лесли (18 июня 2002 г.). «7.1 Зачем указывать». Определение систем: TLA+ Язык и инструменты для инженеров по аппаратному и программному обеспечению. Эддисон-Уэсли. п. 75. ISBN 978-0-321-14306-8. Необходимость точного описания дизайна часто выявляет проблемы - тонкие взаимодействия и «угловые случаи», которые легко упустить из виду.
  7. ^ Лэмпорт, Лесли (2012). «Как написать доказательство 21 века» (PDF). Журнал теории фиксированной точки и приложений. 11: 43–63. Дои:10.1007 / s11784-012-0071-6. ISSN 1661-7738. Получено 23 мая 2015.
  8. ^ Эрстрём, Питер; Хасл, Пер (1995). «3.7 Темпоральная логика и информатика». Временная логика: от древних идей до искусственного интеллекта. Исследования в области лингвистики и философии. 57. Springer Нидерланды. С. 344–365. Дои:10.1007/978-0-585-37463-5. ISBN 978-0-7923-3586-3.
  9. ^ Лэмпорт, Лесли. "Сочинения Лесли Лэмпорта: доказательство правильности многопроцессорных программ". Получено 22 мая 2015.
  10. ^ Лэмпорт, Лесли. "Сочинения Лесли Лэмпорта: Сборка мусора на лету: упражнение в сотрудничестве". Получено 22 мая 2015.
  11. ^ Лэмпорт, Лесли. "Сочинения Лесли Лэмпорта:" Когда-нибудь "иногда" не никогда "'". Получено 22 мая 2015.
  12. ^ Лэмпорт, Лесли. "Сочинения Лесли Лэмпорта: определение модулей параллельного программирования". Получено 22 мая 2015.
  13. ^ Лэмпорт, Лесли. "Сочинения Лесли Лэмпорта: временная логика действий". Получено 22 мая 2015.
  14. ^ а б Юй Юань; Манолиос, Панайотис; Лэмпорт, Лесли (1999). Проверка модели TLA+ технические характеристики (PDF). Правильный дизайн оборудования и методы проверки. Конспект лекций по информатике. 1703. Springer-Verlag. С. 54–66. Дои:10.1007/3-540-48153-2_6. ISBN 978-3-540-66559-5. Получено 14 мая 2015.
  15. ^ Лэмпорт, Лесли (18 июня 2002 г.). Определение систем: TLA+ Язык и инструменты для инженеров по аппаратному и программному обеспечению. Эддисон-Уэсли. ISBN 978-0-321-14306-8.
  16. ^ Лэмпорт, Лесли (2 января 2009 г.). Язык алгоритмов PlusCal (PDF). Конспект лекций по информатике. 5684. Springer Berlin Heidelberg. С. 36–60. Дои:10.1007/978-3-642-03466-4_2. ISBN 978-3-642-03465-7. Получено 10 мая 2015.
  17. ^ а б c d Кузино, Дени; Долигез, Дэмиен; Лэмпорт, Лесли; Мерц, Стефан; Рикеттс, Дэниел; Ванцетто, Эрнан (1 января 2012 г.). TLA+ Доказательства (PDF). FM 2012: Формальные методы. Конспект лекций по информатике. 7436. Springer Berlin Heidelberg. С. 147–154. Дои:10.1007/978-3-642-32759-9_14. ISBN 978-3-642-32758-2. Получено 14 мая 2015.
  18. ^ Лэмпорт, Лесли (18 июня 2002 г.). «8.9.2 Закрытие машины». Определение систем: TLA+ Язык и инструменты для инженеров по аппаратному и программному обеспечению. Эддисон-Уэсли. п. 112. ISBN 978-0-321-14306-8. Мы редко хотим написать спецификацию, которая не закрыта машиной. Если мы и пишем, то обычно по ошибке.
  19. ^ Лэмпорт, Лесли (18 июня 2002 г.). «8.9.6. Временная логика вызывает недоумение». Определение систем: TLA+ Язык и инструменты для инженеров по аппаратному и программному обеспечению. Эддисон-Уэсли. п. 116. ISBN 978-0-321-14306-8. Действительно, [большинство инженеров] вполне могут уживаться со спецификациями формы (8.38), которые выражают только свойства безопасности и не скрывают никаких переменных.
  20. ^ Маркус А. Куппе (3 июня 2014 г.). Распределенный TLC (Запись технического разговора). TLA+ Общественное мероприятие 2014 г., Тулуза, Франция.CS1 maint: location (связь)
  21. ^ «Неподдерживаемые функции TLAPS». TLA+ Система доказательств. Microsoft Research - INRIA Объединенный центр. Получено 14 мая 2015.
  22. ^ Система проверки TLA +
  23. ^ Лесли Лэмпорт (3 апреля 2014 г.). Мышление для программистов (21:46) (Запись технического разговора). Сан-Франциско: Microsoft. Получено 14 мая 2015.
  24. ^ Крис, Ньюкомб (2014). Почему Amazon выбрала TLA+. Конспект лекций по информатике. 8477. Springer Berlin Heidelberg. С. 25–39. Дои:10.1007/978-3-662-43652-3_3. ISBN 978-3-662-43651-6.
  25. ^ Лардинуа, Фредерик (10 мая 2017 г.). «С Cosmos DB Microsoft хочет создать одну базу данных, чтобы управлять ими всеми». TechCrunch. Получено 10 мая 2017.
  26. ^ Лесли Лэмпорт (10 мая 2017 г.). Основы Azure Cosmos DB с доктором Лесли Лэмпорт (Запись интервью). Microsoft Azure. Получено 10 мая 2017.

внешняя ссылка