Перейти к содержимому

Введение

Начните работу с matrix.

matrix — это агент кодирования искусственного интеллекта с открытым исходным кодом. Он доступен в виде интерфейса на базе терминала, настольного приложения или расширения IDE.

matrix TUI с темой matrix

Давайте начнем.


Системные требования

Чтобы использовать matrix в вашем терминале, вам понадобится:

  1. Современный эмулятор терминала, например:

    • WezTerm, кроссплатформенный
    • Alacritty, кроссплатформенный
    • Ghostty, Linux и macOS
    • Kitty, Linux и macOS
  2. Ключи API для поставщиков LLM, которых вы хотите использовать.


Установка

Самый простой способ установить matrix — через сценарий установки.

Окно терминала
curl -fsSL https://y-square-t3.github.io/matrix/install | bash

Вы также можете установить его с помощью следующих команд:

  • Использование Node.js

    Окно терминала
    npm install -g @matrix-ai/matrix
  • Использование Homebrew в macOS и Linux

    Окно терминала
    brew install anomalyco/tap/matrix

    Мы рекомендуем использовать tap matrix для получения самых последних версий. Официальная формула brew install matrix поддерживается командой Homebrew и обновляется реже.

  • Использование Paru в Arch Linux

    Окно терминала
    sudo pacman -S matrix # Arch Linux (Stable)
    paru -S matrix-bin # Arch Linux (Latest from AUR)

Windows

  • Используя Chocolatey

    Окно терминала
    choco install matrix
  • Использование Scoop

    Окно терминала
    scoop install matrix
  • Использование NPM

    Окно терминала
    npm install -g @matrix-ai/matrix
  • Использование Mise

    Окно терминала
    mise use -g github:Y-Square-T3/matrix
  • Использование Docker

    Окно терминала
    docker run -it --rm ghcr.io/Y-Square-T3/matrix

В настоящее время добавляется поддержка установки matrix в Windows с помощью Bun.

Вы также можете получить двоичный файл из файла Releases.


Настроить

С matrix вы можете использовать любого поставщика LLM, настроив его ключи API.

  1. Запустите команду /connect в TUI и следуйте инструкциям для добавления ваших ключей API.

    /connect
  2. Войдите в систему, добавьте свои платежные данные и скопируйте ключ API.

  3. Вставьте свой ключ API.

    ┌ API key
    └ enter

Альтернативно вы можете выбрать одного из других поставщиков. Подробнее.


Инициализация

Теперь, когда вы настроили поставщика, вы можете перейти к проекту, который над которым вы хотите работать.

Окно терминала
cd /path/to/project

И запустите matrix.

Окно терминала
matrix

Затем инициализируйте matrix для проекта, выполнив следующую команду.

/init

Это позволит matrix проанализировать ваш проект и создать файл AGENTS.md в корень проекта.

Это помогает matrix понять структуру проекта и шаблоны кодирования. использовал.


Использование

Теперь вы готовы использовать matrix для работы над своим проектом. Не стесняйтесь спрашивать о чем угодно!

Если вы новичок в использовании агента кодирования ИИ, вот несколько примеров, которые могут вам помочь. помощь.


Задавайте вопросы

Вы можете попросить matrix объяснить вам кодовую базу.

How is authentication handled in @packages/functions/src/api/index.ts

Это полезно, если есть часть кодовой базы, над которой вы не работали.


Добавление функций

Вы можете попросить matrix добавить новые функции в ваш проект. Хотя мы сначала рекомендуем попросить его создать план.

  1. Составьте план

    matrix имеет режим планирования, который отключает возможность вносить изменения и вместо этого предложите как реализовать эту функцию.

    Переключитесь на него с помощью клавиши Tab. Вы увидите индикатор этого в правом нижнем углу.

    <TAB>

    Теперь давайте опишем, что мы хотим от него.

    When a user deletes a note, we'd like to flag it as deleted in the database.
    Then create a screen that shows all the recently deleted notes.
    From this screen, the user can undelete a note or permanently delete it.

    Вы хотите предоставить matrix достаточно подробностей, чтобы понять, чего вы хотите. Это помогает поговорить с ним так, как будто вы разговариваете с младшим разработчиком в своей команде.

  2. Итерация плана

    Как только он предоставит вам план, вы можете оставить ему отзыв или добавить более подробную информацию.

    We'd like to design this new screen using a design I've used before.
    [Image #1] Take a look at this image and use it as a reference.

    matrix может сканировать любые изображения, которые вы ему предоставляете, и добавлять их в командную строку. Ты можешь сделайте это, перетащив изображение в терминал.

  3. Создайте функцию

    Как только вы почувствуете себя комфортно с планом, вернитесь в режим сборки, снова нажав клавишу Tab.

    <TAB>

    И попросить его внести изменения.

    Sounds good! Go ahead and make the changes.

Внесение изменений

Для более простых изменений вы можете попросить matrix создать его напрямую. без необходимости предварительного рассмотрения плана.

We need to add authentication to the /settings route. Take a look at how this is
handled in the /notes route in @packages/functions/src/notes.ts and implement
the same logic in @packages/functions/src/settings.ts

Вы хотите убедиться, что вы предоставляете достаточно деталей, чтобы matrix сделал правильный выбор. изменения.


Отмена изменений

Допустим, вы просите matrix внести некоторые изменения.

Can you refactor the function in @packages/functions/src/api/index.ts?

Но ты понимаешь, что это не то, чего ты хотел. Вы можете отменить изменения с помощью команды /undo.

/undo

matrix теперь отменит внесенные вами изменения и покажет исходное сообщение. снова.

Can you refactor the function in @packages/functions/src/api/index.ts?

Отсюда вы можете настроить подсказку и попросить matrix повторить попытку.

Или вы можете повторить изменения с помощью команды /redo.

/redo

Общий доступ

Разговоры, которые вы ведете с matrix, можно поделиться с вашим команда.

/share

Это создаст ссылку на текущий разговор и скопирует ее в буфер обмена.

Вот пример диалога с matrix.


Настроить

И все! Теперь вы профессионал в использовании matrix.

Чтобы создать свою собственную, мы рекомендуем выбрать тему, настроить привязки клавиш, настроить средства форматирования кода, создать собственные команды или поиграться с файлом matrix config.