Основная цель этой работы — позволить разработчикам максимально просто использовать zero knowledge proof в своих приложениях — это достигается за счет минимизации требований к знаниям криптографии.
Что такое zero knowledge proof (ZKP)?
Прежде всего, давайте кратко напомним себе, что такое ZKP. Это некоторая часть данных, которая доказывает, что мы выполнили вычисления правильно; например, что мы использовали закрытый ключ, чтобы отправить кому-то NFT, или что у нас есть какой-то атрибут, который позволяет нам обновлять состояние приложения. Кроме того, это позволяет нам сохранять некоторые данные в секрете, если мы того пожелаем; например, нам не нужно раскрывать тот закрытый ключ, который мы использовали для отправки NFT. И данные доказательства также намного меньше, чем все вычисления, поэтому для них потребуется намного меньше места для хранения (в цепочке) и будет быстрее передаваться.
Обзор Leo
Leo — это основанный на Rust язык программирования со статической типизацией, созданный для написания частных приложений. Он предназначен для разработчиков, которые могут интуитивно строить блокчейн Aleo, обеспечивая основу для частной децентрализованной экосистемы. Это первый известный язык программирования, который представляет среду тестирования, реестр пакетов, преобразователь импорта, удаленный компилятор и генератор теорем для приложений с ZKP.
Синтаксис Leo сделан на подобии Javascript и Typescript, так что разработчики JS/TS будет иметь очень простую кривую обучения.
Что происходит под капотом?
Давайте углубимся дальше и скажем, что вы написали сортировку пузырьком — что на самом деле делает Leo, когда вы запускаете программу?
Он берет ваш код, создает схему проверки, которая представляет вычисление, которое вы хотите запустить, заполняет входные данные нужными значениями, запускает схему, генерирует ключи проверки, а затем объединяет все соответствующие данные в ZKP. Например, вы можете запустить его на входных данных на изображении ниже.
Но мы знаем, что для использования Leo совсем не нужно особых знаний в криптографии, так что же это за штука с созданием “доказательств”? Подводя итог, можно сказать, что Leo выводит доказательство того, что вы выполнили свои вычисления правильно, а это означает, что если вы запустите описанную выше схему на некотором массиве и представите выходной массив вместе с доказательством, любой наблюдатель сможет подтвердить, что массив действительно был отсортирован по проверкe доказательства, а не массива.
Это может показаться не таким уж быстрым, если массив содержит только 10 элементов, но когда мы начинаем работать со структурами данных, которые имеют миллионы элементов и более сложные вычисления, проверка доказательства (которое всегда одного размера!) начинает приносить намного больше ценности.
Leo также делает больше, чем просто создает для вас схему и генерирует на ее основе доказательство. Он наполнен функциональностью, которая помогает максимально сократить время разработки. Платформа тестирования, реестр пакетов и преобразователь импорта работают вместе, чтобы сэкономить разработчикам много времени, гарантируя, что внешние функции легко импортируются, и что код действительно делает то, что от него ожидалось.
Когда вы строите экосистему, основной целью которой является разработка масштабируемых и безопасных приложений, один из лучших способов улучшить масштабирование— устранить как можно больше препятствий при разработке приложений. Это то, что Leo помогает достичь. Если вы хотите узнать больше, загляните в документацию.
Дискорд: Nikitos#5053
Твиттер: https://twitter.com/X2Stri
Телеграм: @nek1tk
Комментарии (5)
vba
17.02.2022 12:21+4Введение в язык программирования Leo
Сразу вспоминается мем с Траволтой. А где введение то?
sargon5000
18.02.2022 21:07Немного безумный текст. Все слова по отдельности понятны, но о чем всё это?
“Он предназначен для разработчиков, которые могут интуитивно строить блокчейн Aleo".
Хотелось бы посмотреть на таких. Я вот интуитивно даже пятизначное натуральное число не смогу факторизовать, придется повозиться.
thatsme
Не совсем понятно где статическая типизация, если в примере кода декларирования типизации вообще нет...
А вообще, на статью это не тянет.
Эту заметку писала GPT-3?
amarao
Нет. Модель GPT-3 создаёт связный текст. Этот текст явно переведён кожанным мешком.
amarao
В коде, кстати, типизация есть. В сигнатуре функции указана, дальше там автовыведение типов (Rust так тоже делает). Не смотря на "авто" она очень строгая.