Ssylka

Шахматы на регулярных выражениях

Создан шахматный движок, использующий 84688 регулярных выражений. Программа представляет собой интерпретатор набора команд, которые манипулируют данными о шахматной доске, представленными в виде единой текстовой строки. Это достигается за счет стековой архитектуры и переменных, позволяющих имитировать работу процессора.
Шахматы на регулярных выражениях
Изображение носит иллюстративный характер

Реализованы основные операции стека, такие как push и pop, а также операции чтения и записи переменных. Присвоение значения переменной учитывает как случай изменения уже существующей переменной, так и создание новой. Условные операции реализованы без ветвления, с использованием меток активации и деактивации потоков.

Особое внимание уделяется параллельной обработке с использованием SIMD-архитектуры, которая позволяет выполнять операции одновременно для нескольких потоков. Команда fork создает несколько параллельных состояний, что позволяет обрабатывать сразу несколько возможных ситуаций на доске.

Шахматный движок использует эту архитектуру для оценки возможных ходов, с применением упрощенной версии минимаксного алгоритма на глубину 2. При этом используется параллельная обработка для одновременной оценки множества вариантов. Исходный код движка доступен на GitHub, он включает в себя также реализацию рокировки, взятие на проходе и многое другое. Для ускорения работы применяются такие методы, как удаление промежуточных переменных, использование узкоспециализированных команд и оптимизация сопоставлений регулярных выражений.


Новое на сайте

18594Записная книжка против нейросети: ценность медленного мышления 18593Растущая брешь в магнитном щите земли 18592Каким образом блокчейн-транзакции стали новым инструментом для кражи криптовалюты? 18591Что скрывается за ростом прибыли The Walt Disney Company? 18590Является ли ИИ-архитектура, имитирующая мозг, недостающим звеном на пути к AGI? 18589Как Operation Endgame нанесла сокрушительный удар по глобальной киберпреступности? 18588Кибервойна на скорости машин: почему защита должна стать автоматической к 2026 году 18587Как одна ошибка в коде открыла для хакеров 54 000 файрволов WatchGuard? 18586Криптовалютный червь: как десятки тысяч фейковых пакетов наводнили npm 18585Портативный звук JBL по рекордно низкой цене 18584Воин-крокодил триаса: находка в Бразилии связала континенты 18583Опиум как повседневность древнего Египта 18582Двойной удар по лекарственно-устойчивой малярии 18581Почему взрыв массивной звезды асимметричен в первые мгновения? 18580Почему самые удобные для поиска жизни звезды оказались наиболее враждебными?