Building mmSolver is quite easy. The project uses CMake, and provides pre-made build scripts for Windows (Batch Script) and Linux (Bash - Shell Script).
You may edit these scripts for your system, or use them as-is if you have a standard default installation of Maya.
These tools and libraries are required for building the mmSolver
project. For details, please see the section below for each
dependency.
- Autodesk Maya
- Maya Development Kit
- CMake
- C++ Compilier
- GCC (Linux)
- Visual Studio (MSVC) (Windows)
- Rust
- CMinpack
- Eigen
- Ceres Solver
- Lens Distortion Plug-in Kit (LDPK)
- Python
Autodesk Maya 2018+ is supported and must be installed on the host to build mmSolver. mayapy is required to run tests and the main Maya executable is required to test and use mmSolver.
The Maya Development Kit is required for building mmSolver.
Various utilities and libraries and files that are installed with the Maya devkit are used during the build process.
CMake 3.15+ is required to build all parts of mmSolver. Older versions if CMake may work, however the Blender Add-On may fail to generate.
As of mmSolver v0.4.0, the Ninja build system is used in the default Windows Batch scripts - Linux build scripts are not affected. Alternate build systems will likely work (such as NMake or Visual Studio projects) but are not tested.
Depending on the version of Maya you are targeting, you will need the C++ compiler recommended by Autodesk for your platform. Below is a list of the versions currently used and recommended. Please refer to the Autodesk Maya Developer documentation for details on setting up your build environment.
Each Maya version also specifies a different C++ standard. As of mmSolver v0.4.0 a C++ compiler with at least C++11 is required.
- Linux
- GCC 4.4.7 (Maya 2016 and 2017)
- GCC 4.8.2 (Maya 2018)
- GCC 6.3.1 (Maya 2019 and 2020)
- Red Hat DST 6.1
yum install devtoolset-6
on RHEL 7 / CentOS 7
- GCC 9.3.1 (Maya 2022 and 2023)
- Red Hat DST 9.1
yum install devtoolset-9
on RHEL 7 / CentOS 7
- GCC 11.2.1 (Maya 2024)
- Red Hat DST 11
dnf install devtoolset-11
on RHEL 8 / Rocky Linux 8
- Windows
- Visual Studio 2012 update 5 (MSVC 11.0) (Maya 2016 and 2017)
- Visual Studio 2015 update 3 (MSVC 14.0) (Maya 2018 and 2019)
- Visual Studio 2017 (MSVC 15.0) (Maya 2020)
- Visual Studio 2019 (MSVC 16.0) (Maya 2022 and 2023)
- Visual Studio 2019 (MSVC 19.0) (Maya 2024)
Rust 1.43+ is required for MM Scene Graph
features inside mmSolver.
Rust is a modern programming language comparable to C or C++ in terms of speed, is highly performant and provides safety and stability guarantees for software written in Rust.
Both the Rust compiler (rustc
) and the Rust package manager
(cargo
) are required to be installed to build mmSolver. No part of
Rust is required to be installed at run-time.
See the 'Cargo.toml' files for a full list of (automatically) installed dependencies via the package managers.
cxx-bridge is an executable required for generating
C++ bindings for Rust code. This utility allows C++ code to interact
with Rust code in simple and a safe way. This is used for the MM Scene Graph
features.
Eigen is a requirement of mmSolver and
is used to store 3D vectors, matrices, perform linear algebra, and is
also required for OpenMVG
(see below).
CMinpack 1.3.8 is required for non-linear least-squares minimization.
This solver is not as sophisticated as Ceres and may be deprecated in a future release (in favor of Ceres Solver)
Ceres Solver is a state-of-the-art non-linear least-squares minimization library.
Ceres Solver allows solving large minimization problems efficiently using sparse matrices. Ceres Solver itself has many dependencies, and the speed of the library depends on the underlying sparse matrix libraries and functions. Feel free to compile and use whatever underlying dependencies provides the best performance for you - however make sure that sparse matrix solving is available.
Ceres Solver is not optional, and is required for OpenMVG
features.
In a future version of mmSolver Ceres may replace CMinpack as the default and recommended solving engine.
OpenMVG 2.0 is used for traditional Multiple-View Geometry calculations inside mmSolver, such as Structure from Motion, triangulation and other features. Only a sub-set of OpenMVG is included with mmSolver.
OpenMVG is not a third-party dependency, because it's included inside mmSolver. OpenMVG requires Eigen and Ceres Solver internally.
Lens Distortion Plug-in Kit (LDPK) is an open source project provided freely by Science-D-Visions, the creators of 3DEqualizer.
The LDPK provides a standard set of lens distortion features and the ability to provide custom lens distortion plug-ins.
Python 3.x is used for development, testing and formatting Python code.
The mmSolver build will use the provided Maya Python executable
(mayapy
) for some processes, such as generating Python files from
Qt .ui files. Use of mayapy
will use Python 2.x or 3.x depending
on the Maya version.
See 'requirements-dev.txt' for more details of all dependencies.
Sphinx is used to build documentation for mmSolver including the mmSolver documentation page, and the documentation bundled with mmSolver.
Black is used for for Python code formatting, and is only used by developers.
PyLint for Python code 'linting'. It is not critical for building mmSolver.
Both Black and PyLint are used for during development and is not required for building mmSolver.
An overview of compiling is:
- Download mayaMatchMoveSolver project from GitHub.
- Unzip the source code into a directory.
- Open a command line or terminal and navigate to the unzipped files.
- Run the provided build script to compile mmSolver.
Below lists all the commands run in an example session, following the above sections.
On Linux:
# Go to root of project directory.
$ cd <project root>
# Build mmSolver, compile UI files, compile Maya plug-in, build
# documentation, create module and install to home directory.
$ bash scripts/build_mmSolver_linux_mayaXXXX.bash
On Windows:
:: Go to root of project directory.
> CD <project root>
:: Build mmSolver, compile UI files, compile Maya plug-in, build
:: documentation, create module and install to home directory.
> scripts/build_mmSolver_windows64_mayaXXXX.bat
To build the project you can use the build scripts provided.
Build Script Name | Operating System |
---|---|
build_mmSolver_linux_mayaXXXX.bash | Linux |
build_mmSolver_windows64_mayaXXXX.bat | Windows |
For details of building the project, please see BUILD_LINUX.md or BUILD_WINDOWS.md.