2 мая 2023 года Modular (одна из компаний-лидеров в сфере AI-инфраструктуры) анонсировала язык программирования Mojo, обещающий полную совместимость с Python в сочетании со сверх-высокой производительностью.
В компании утверждают, что автоматическое низкоуровневое распараллеливание, возможности строгой типизации и статической компиляции уже на самых ранних этапах развития языка позволяют достичь скорости, превосходящей Python в 35 000 раз!
Прежде всего возникает подозрение: а не проходной ли это проект на волне популярности вокруг ИИ?
Здесь, конечно, время всё расставит на свои места, однако создатели у языка ещё какие:
Крис Лэттнер (со основатель и директор Modular)
В прошлом — один из ключевых разработчиков языка Swift, компилятора Clang, а также технологий LLVM и MLIR. До основания Modular AI работал в Google, Tesla, Apple.
Тим Дэвис (со основатель и руководитель продукта)
Привнёс значительный вклад в разработку и масштабирование Google Brain проектов, а также TensorFlow.
... и множество других опытных разработчиков.
Синтаксис Питона с минимальными изменениями Даже нововведения в Mojo разработчики постарались сделать максимально схожими с Python:
Честно, доступ есть ещё далеко не ко всем, но к нескольким самым известным (Numpy, Matplotlob) разработчики его всё-таки наладили.
В целом, это работает следующим образом: сначала импортируется любой модуль Python, затем его можно использовать как угодно.
К сожалению, сейчас имеется возможность импорта только модуля целиком (выхватить только парочку функций не выйдет).
Можно даже импортировать собственные модули:
Благодаря такой гибкости по отношению к Питону, Mojo будет возможно точечно встраивать в уже готовые модели, переопределять операции с его помощью, пользоваться супер-быстрыми реализациями многих алгоритмов, и т.п.
Обо всех подробностях низкоуровневых усовершенствований, распараллеливания, статической компиляции и прочих фишках, влияющих на производительность, подробно рассказано в документации.
Утверждается, например, что на алгоритме вычисления и построения множества Мандельброта Mojo справляется быстрее Питона в 35 000 (!) раз:
Довольно об особенностях, давайте перейдём к конкретике и рассмотрим несколько основных особенностей кода языка Mojo.
Здесь будет приведено лишь краткое описание нескольких основных программных нововведений в синтаксис Питона — всё это, и ещё больше, в подробнейшем виде расписано в документации.
Mojo позволяет объявлять переменные среды с ограниченной областью.
let — неизменяемая переменная,
var — изменяемая.
Такой синтаксис также поддерживает спецификаторы типа и отложенную инициализацию:
struct в Mojo, как и class в Питоне, может содержать методы, поля, декораторы, перегрузку операторов — но есть существенное различие.
Классы в Питоне динамические — они допускают добавление и подмену методов и значений в рантайме, жертвуя при этом производительностью.
Структуры в Mojo статические — они формируются во время компиляции, не позволяя вносить изменения в рантайме. Помимо лучшей безопасности, такой подход позволяет выигрывать в производительности.
Важно также заметить, что структура обязывает объявлять поля в ней через let или var.
Mojo позволяет пользоваться гибкой системой типов Питона, но также предоставляет систему типов и механизм для контроля операций с ними.
Простейший способ использовать эту систему контроля — просто писать код в структурах (как уже говорилось, это связывает переменные с их типами во время компиляции), что не позволит случиться подобным ситуациям:
Кстати, почему Int, а не int?
Дело в том, что питоновский int "отягощён" множеством дополнительных возможностей, как работа с большими числами или сравнение значений. Тип Int в Mojo наоборот очень простой и лёгкий, что позволяет значительно повысить скорость работы с ним.
В Mojo есть свой вариант синтаксиса функции — fn. Он полностью взаимозаменяем с def, однако накладывает ряд ограничений:
Значения аргументов по умолчанию неизменяемы в теле функции, что исключает случайные изменения и позволяет использовать неизменяемые типы в качестве аргументов.
Для всех аргументов (кроме self) и для возвращаемого значения требуется указать тип.
Все локальные переменные должны быть объявлены явно (ой, тавтология).
Хоть этот, безусловно, интересный язык сейчас находится в версии 0.1, не поддерживает многие концепции Питона и был анонсирован несколько дней назад, он уже показывает себя достаточно серьёзным.