Введение
В этом руководстве объясняется, как выполнить сборку из исходного кода OR-Tools с поддержкой Python в Linux.
Если вы не планируете изменять исходный код или использовать сторонний решатель с OR-Tools, мы рекомендуем установку пакета .
Хотя эти инструкции могут работать и на других вариантах Linux, мы тестировали их только на машинах, отвечающих следующим требованиям:
- Alpine Edge 64-разрядная версия (x86_64)
- Centos 7 LTS 64-бит (x86_64)
- Debian SID 64-бит (x86_64)
- Debian 11 (яблочко) 64-разрядная версия (x86_64)
- Федора 38, 64-разрядная версия (x86_64)
- Федора 37, 64-разрядная версия (x86_64)
- OpenSuse Leap 64-бит (x86_64)
- Ubuntu 24.04 64-разрядная версия (x86_64)
- Ubuntu 22.04 LTS 64-бит (x86_64)
- Ubuntu 20.04 LTS 64-бит (x86_64)
Предварительные условия
В следующих разделах описаны необходимые условия для установки OR-Tools.
Инструменты С++
Чтобы установить инструменты C++, откройте окно терминала и введите:
Альпийский
apk add alpine-sdk linux-headers cmake lsb-release-minimal
Центос
sudo yum groupinstall -y 'Development Tools'
sudo yum install -y pkgconfig redhat-lsb-core
Дебиан
sudo apt update
sudo apt install -y build-essential cmake lsb-release
Федора
sudo dnf groupinstall -y 'Development Tools'
sudo dnf install -y gcc-c++ cmake redhat-lsb-core
Федора
sudo dnf groupinstall -y 'Development Tools'
sudo dnf install -y gcc-c++ cmake redhat-lsb-core
OpenSUSE
sudo zypper refresh
sudo zypper install -y git gcc11 gcc11-c++ lsb-release
Убунту
sudo apt update
sudo apt install -y build-essential cmake lsb-release
Убунту
sudo apt update
sudo apt install -y build-essential cmake lsb-release
Убунту
sudo apt update
sudo apt install -y build-essential cmake lsb-release
СВИГ
Чтобы установить SWIG, откройте окно терминала и введите:
Альпийский
apk add swig
Центос
sudo yum install -y swig
Дебиан
sudo apt install -y swig
Федора
sudo dnf install -y swig
Федора
sudo dnf install -y swig
OpenSUSE
sudo zypper install -y swig
Убунту
sudo apt install -y swig
Убунту
sudo apt install -y swig
Убунту
sudo apt install -y swig
Питон
У вас должен быть установлен Python 3.8+.
Чтобы установить Python 3.8+, откройте окно терминала и введите:
Альпийский
apk add python3-dev py3-pip py3-wheel
Центос
sudo yum install -y python3 python3-devel python3-pip numpy
Дебиан
sudo apt install -y python3-dev python3-pip python3-venv
Федора
sudo dnf install -y python3-devel python3-pip python3-venv
Федора
sudo dnf install -y python3-devel python3-pip python3-venv
OpenSUSE
sudo zypper install -y python3-devel python3-pip python3-wheel
Убунту
sudo apt install -y python3-dev python3-pip python3-venv
Убунту
sudo apt install -y python3-dev python3-pip python3-venv
Убунту
sudo apt install -y python3-dev python3-pip python3-venv
Вы можете проверить установку Python 3, используя:
python3 --version
python3 -c "import platform; print(platform.architecture()[0])"
python3 -m pip --version
Загрузите исходный код
На GitHub есть две отдельные ветки исходного кода OR-Tools: stable
и main
.
stable
ветка была тщательно протестирована и должна безупречно работать на всех поддерживаемых платформах.
В main
ветке применены последние обновления и улучшения; он более актуален, но менее стабилен.
Загрузите стабильный исходный код
Вы можете получить стабильный исходный код OR-Tools одним из следующих способов:
Клонируйте
stable
ветку, введя:git clone https://github.com/google/or-tools
Загрузите последнюю версию в сжатом файле, нажав кнопку
Clone or download
на GitHub .
Загрузите основной исходный код
Чтобы получить исходный код из main
ветки, введите:
git clone -b main https://github.com/google/or-tools
Загрузить предыдущие выпуски
Вы можете получить исходный код предыдущих выпусков одним из следующих способов:
- Загрузите предыдущий выпуск со страницы выпуска GitHub .
Предполагая, что вы уже создали локальный репозиторий (с помощью
git clone
), вы можете проверить конкретный выпуск, используя тег Git. Например, чтобы работать с выпуском v9.10 вместоmain
ветки, введите в локальном репозитории следующие команды:git fetch --all --tags --prune
git checkout tags/v9.10 -b v9.10
Настройка сборки
Перед сборкой OR-Tools вам необходимо настроить генератор системы сборки CMake.
Откройте терминал и перейдите в каталог, в который вы извлекли файлы. Затем введите:
cmake -S . -B build -DBUILD_DEPS=ON -DBUILD_PYTHON=ON
Подробности смотрите в документации CMake .
Использование SCIP
Начиная с версии 7.8, SCIP теперь интегрирован, поэтому вам не придется устанавливать его вручную.
Использование Гуроби
Гуроби теперь предварительно интегрирован. При необходимости во время выполнения OR-Tools будет искать общую библиотеку Gurobi в пути установки по умолчанию установщиков Gurobi в MAC OS X и Windows или с помощью переменной среды GUROBI_HOME
.
Использование дополнительного стороннего решателя MIP
Вы также можете использовать OR-Tools с любым из следующих дополнительных сторонних решателей MIP, поддержка которых отключена по умолчанию:
- Комплексный комплекс
- GLPK (только Linux и MacOS)
- XPRESS-решатель
Пожалуйста, ознакомьтесь с этой документацией для получения подробной информации.
Сборка исходного кода
Чтобы создать исходный код, откройте терминал и перейдите в каталог, в который вы извлекли файлы. Затем введите следующую команду для компиляции OR-Tools:
cmake --build build --config Release --target all -j -v
Подробности смотрите в документации CMake .
Проверьте исходный код
Вы можете проверить, что все работает правильно, введя:
cmake --build build --config Release --target test -v
Это запускает примеры для OR-Tools. Если все примеры выполняются успешно, вы готовы приступить к работе с OR-Tools .
Очистка файлов сборки
Если вам нужно переустановить OR-Tools, команда:
rm -r build
удалит все скомпилированные зависимости. Это может быть полезно для сброса в чистое состояние.
Затем повторно введите команды:
cmake -S . -B build -DBUILD_DEPS=ON -DBUILD_PYTHON=ON
cmake --build build --config Release --target all -j -v
Установка OR-Tools в вашу операционную систему
Вы можете установить OR-Tools for Python в свою операционную систему, введя:
cmake --build build --config Release --target install -v