1 引言
Ceres Solver 是一个由 Google 开发的开源 C++ 库,用于求解大规模非线性最小二乘问题,广泛应用于计算机视觉、机器人和三维重建等领域。
2 构建
记得以前构建Ceres Solver经常失败,其中一个原因是因为 Google 系的 C/C++ 程序库很喜欢使用静态库,Google 的程序员认为静态库可以避免二进制兼容的问题。至于构建的性能问题,他们通过在专门的高性能机器上构建来解决。不过,像 Ceres Solver 这样的大型库需要的依赖库太多,它们不一定是静态库,动态库和静态库混合使用,构建时很容易出现找不到符号的问题。
笔者这里构建 Ceres Solver 使用的有依赖库有 eigen、gflags、glog、OpenBLAS 和 SuiteSparse。这里面大部分库的构建前面的文章《CMake构建学习笔记-目录》都介绍过,gflags、glog 构建也比较简单,使用本系列文章实现的自动化工具 BuildCppDependency 安装 Ceres Solver 的时候会自动进行安装。
在 Windows 平台下输入指令:
./BuildCppDependency.ps1 `-Generator "Visual Studio 16 2019" `-InstallDir "$env:GISBasic" `-SymbolDir "$env:GISBasic/symbols" `-Install ceres-solver
在 Linux (Ubuntu) 平台下输入指令:
./build.sh -install ceres-solver -installdir "$GISBasic"
还是展开看一下 Windows 下的构建脚本中的 CMake 构建参数:
# ceres-solver.ps1
param( [string]$Name = "ceres-solver-2.2.0",[string]$SourceDir = "../Source",[string]$Generator,[string]$InstallDir, [string]$SymbolDir, [bool]$Force = $false, # 是否强制重新构建[bool]$Cleanup = $true # 是否在构建完成后删除源码和构建目录
)# 目标文件
$DllPath = "$InstallDir/lib/ceres.lib"# 依赖库数组
$Librarys = @("eigen", "gflags", "glog", "OpenBLAS", "SuiteSparse") # 符号库文件
$PdbFiles = @("lib/RelWithDebInfo/ceres.pdb""lib/RelWithDebInfo/ceres_cuda_kernels.pdb"
) # 额外构建参数
$CMakeCacheVariables = @{BUILD_TESTING = "OFF"BUILD_EXAMPLES = "OFF"BUILD_SHARED_LIBS = "OFF" USE_CUDA = "ON"
}. ./build-common.ps1 -Name $Name `-SourceDir $SourceDir `-InstallDir $InstallDir `-SymbolDir $SymbolDir `-Generator $Generator `-TargetDll $DllPath `-PdbFiles $PdbFiles `-CMakeCacheVariables $CMakeCacheVariables `-MultiConfig $false `-Force $Force `-Cleanup $Cleanup `-Librarys $Librarys
解释一下这几个 CMake 构建参数:
BUILD_TESTING = "OFF"&&BUILD_EXAMPLES = "OFF":一般含有TEST或者EXAMPLE的构建项都不是必须的,一般都可以去掉,减少构建时间和构建体积。BUILD_SHARED_LIBS = "OFF":尝试过构建动态库,但是失败了,原因待查。这里关掉表示构建静态库。USE_CUDA = "ON":如果没有安装 CUDA SDK 就可以关掉。
3 其他
系列文章:《CMake构建学习笔记-目录》
构建工具: Github地址,GitCode地址
二进制构建结果:Github地址,GitCode地址