blob: 628cab7479fcdb592f4b135c412c2e9dc33cac4a [file] [log] [blame]
Keir Mierle8ebb0732012-04-30 23:09:08 -07001# Ceres Solver - A fast non-linear least squares minimizer
2# Copyright 2010, 2011, 2012 Google Inc. All rights reserved.
3# http://code.google.com/p/ceres-solver/
4#
5# Redistribution and use in source and binary forms, with or without
6# modification, are permitted provided that the following conditions are met:
7#
8# * Redistributions of source code must retain the above copyright notice,
9# this list of conditions and the following disclaimer.
10# * Redistributions in binary form must reproduce the above copyright notice,
11# this list of conditions and the following disclaimer in the documentation
12# and/or other materials provided with the distribution.
13# * Neither the name of Google Inc. nor the names of its contributors may be
14# used to endorse or promote products derived from this software without
15# specific prior written permission.
16#
17# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27# POSSIBILITY OF SUCH DAMAGE.
28#
29# Author: keir@google.com (Keir Mierle)
30
Sameer Agarwald1146902012-05-30 01:40:22 -070031CMAKE_MINIMUM_REQUIRED(VERSION 2.8.0)
Keir Mierle8ebb0732012-04-30 23:09:08 -070032
33IF (COMMAND cmake_policy)
34 CMAKE_POLICY(SET CMP0003 NEW)
35ENDIF (COMMAND cmake_policy)
36
37PROJECT(CERES C CXX)
38
Keir Mierle05107ba2012-07-18 13:50:12 -070039# Important: Always bump the second number (e.g. 1.3.x to 1.4.0) for any
40# release that changes the ABI. The ABI changes for almost any modification to
41# include/ceres (e.g. the public API). If you are unsure about whether
42# something is an ABI change, please ask on the list.
43#
44# For versions without ABI changes, bump the smallest number in CERES_VERSION,
45# but leave the CERES_ABI_VERSION unchanged.
46SET(CERES_VERSION 1.3.0)
47SET(CERES_ABI_VERSION 1.3.0)
48
Sameer Agarwal30c5f932012-05-03 10:44:43 -070049ENABLE_TESTING()
Keir Mierle8ebb0732012-04-30 23:09:08 -070050
Sameer Agarwalaa9526d2012-05-08 21:22:09 -070051OPTION(BUILD_TESTING
52 "Enable tests"
53 ON)
54
Keir Mierleaefb8a82012-07-28 13:23:55 -070055OPTION(BUILD_ANDROID
56 "Build for Android. Use build_android.sh instead of setting this."
57 OFF)
58
Sameer Agarwalaa9526d2012-05-08 21:22:09 -070059# To get a more static build, try the following line on Mac and Linux:
60# SET(CMAKE_FIND_LIBRARY_SUFFIXES .a ${CMAKE_FIND_LIBRARY_SUFFIXES})
61
Sameer Agarwaldaa98242012-05-11 11:26:38 -070062# Default locations to search for on various platforms.
63LIST(APPEND SEARCH_LIBS /usr/lib)
64LIST(APPEND SEARCH_LIBS /usr/local/lib)
65LIST(APPEND SEARCH_LIBS /usr/local/homebrew/lib) # Mac OS X
66LIST(APPEND SEARCH_LIBS /opt/local/lib)
Keir Mierle8ebb0732012-04-30 23:09:08 -070067
Sameer Agarwaldaa98242012-05-11 11:26:38 -070068LIST(APPEND SEARCH_HEADERS /usr/include)
69LIST(APPEND SEARCH_HEADERS /usr/local/include)
70LIST(APPEND SEARCH_HEADERS /usr/local/homebrew/include) # Mac OS X
71LIST(APPEND SEARCH_HEADERS /opt/local/include)
Keir Mierle8ebb0732012-04-30 23:09:08 -070072
Sameer Agarwaldaa98242012-05-11 11:26:38 -070073# Locations to search for Eigen
74SET(EIGEN_SEARCH_HEADERS ${SEARCH_HEADERS})
75LIST(APPEND EIGEN_SEARCH_HEADERS /usr/include/eigen3) # Ubuntu 10.04's default location.
Sameer Agarwalb0518732012-05-29 00:27:57 -070076LIST(APPEND EIGEN_SEARCH_HEADERS /usr/local/include/eigen3)
Sameer Agarwaldaa98242012-05-11 11:26:38 -070077LIST(APPEND EIGEN_SEARCH_HEADERS /usr/local/homebrew/include/eigen3) # Mac OS X
78LIST(APPEND EIGEN_SEARCH_HEADERS /opt/local/var/macports/software/eigen3/opt/local/include/eigen3) # Mac OS X
79
80# Locations to search for SuiteSparse
81SET(SUITESPARSE_SEARCH_LIBS ${SEARCH_LIBS})
82LIST(APPEND SUITESPARSE_SEARCH_LIBS /usr/lib/suitesparse) # Ubuntu
Sameer Agarwalb0518732012-05-29 00:27:57 -070083LIST(APPEND SUITESPARSE_SEARCH_LIBS /usr/local/lib/suitesparse)
Sameer Agarwaldaa98242012-05-11 11:26:38 -070084LIST(APPEND SUITESPARSE_SEARCH_LIBS /opt/local/lib/ufsparse) # Mac OS X
85
86SET(SUITESPARSE_SEARCH_HEADERS ${SEARCH_HEADERS})
87LIST(APPEND SUITESPARSE_SEARCH_HEADERS /usr/include/suitesparse) # Ubuntu
Sameer Agarwalb0518732012-05-29 00:27:57 -070088LIST(APPEND SUITESPARSE_SEARCH_HEADERS /usr/local/include/suitesparse)
Sameer Agarwaldaa98242012-05-11 11:26:38 -070089LIST(APPEND SUITESPARSE_SEARCH_HEADERS /opt/local/include/ufsparse) # Mac OS X
90
Sameer Agarwalb0518732012-05-29 00:27:57 -070091SET(CXSPARSE_SEARCH_LIBS ${SEARCH_LIBS})
92SET(CXSPARSE_SEARCH_HEADERS ${SEARCH_HEADERS})
93LIST(APPEND CXSPARSE_SEARCH_HEADERS /usr/include/suitesparse) # Ubuntu
94
Sameer Agarwaldaa98242012-05-11 11:26:38 -070095# Check for SuiteSparse dependencies
96MESSAGE("-- Check for AMD")
97SET(AMD_FOUND TRUE)
98
99FIND_LIBRARY(AMD_LIB NAMES amd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700100IF (EXISTS ${AMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700101 MESSAGE("-- Found AMD library: ${AMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700102ELSE (EXISTS ${AMD_LIB})
103 MESSAGE("-- Did not find AMD library")
104 SET(AMD_FOUND FALSE)
105ENDIF (EXISTS ${AMD_LIB})
106
107FIND_PATH(AMD_INCLUDE NAMES amd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700108IF (EXISTS ${AMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700109 MESSAGE("-- Found AMD header in: ${AMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700110ELSE (EXISTS ${AMD_INCLUDE})
111 MESSAGE("-- Did not find AMD header")
112 SET(AMD_FOUND FALSE)
113ENDIF (EXISTS ${AMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700114
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700115MESSAGE("-- Check for CAMD")
116SET(CAMD_FOUND TRUE)
117
118FIND_LIBRARY(CAMD_LIB NAMES camd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700119IF (EXISTS ${CAMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700120 MESSAGE("-- Found CAMD library: ${CAMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700121ELSE (EXISTS ${CAMD_LIB})
122 MESSAGE("-- Did not find CAMD library")
123 SET(CAMD_FOUND FALSE)
124ENDIF (EXISTS ${CAMD_LIB})
125
126FIND_PATH(CAMD_INCLUDE NAMES camd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700127IF (EXISTS ${CAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700128 MESSAGE("-- Found CAMD header in: ${CAMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700129ELSE (EXISTS ${CAMD_INCLUDE})
130 MESSAGE("-- Did not find CAMD header")
131 SET(CAMD_FOUND FALSE)
132ENDIF (EXISTS ${CAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700133
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700134MESSAGE("-- Check for COLAMD")
135SET(COLAMD_FOUND TRUE)
136
137FIND_LIBRARY(COLAMD_LIB NAMES colamd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700138IF (EXISTS ${COLAMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700139 MESSAGE("-- Found COLAMD library: ${COLAMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700140ELSE (EXISTS ${COLAMD_LIB})
141 MESSAGE("-- Did not find COLAMD library")
142 SET(COLAMD_FOUND FALSE)
143ENDIF (EXISTS ${COLAMD_LIB})
144
145FIND_PATH(COLAMD_INCLUDE NAMES colamd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700146IF (EXISTS ${COLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700147 MESSAGE("-- Found COLAMD header in: ${COLAMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700148ELSE (EXISTS ${COLAMD_INCLUDE})
149 MESSAGE("-- Did not find COLAMD header")
150 SET(COLAMD_FOUND FALSE)
151ENDIF (EXISTS ${COLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700152
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700153MESSAGE("-- Check for CCOLAMD")
154SET(CCOLAMD_FOUND TRUE)
155
156FIND_LIBRARY(CCOLAMD_LIB NAMES ccolamd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700157IF (EXISTS ${CCOLAMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700158 MESSAGE("-- Found CCOLAMD library: ${CCOLAMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700159ELSE (EXISTS ${CCOLAMD_LIB})
160 MESSAGE("-- Did not find CCOLAMD library")
161 SET(CCOLAMD_FOUND FALSE)
162ENDIF (EXISTS ${CCOLAMD_LIB})
163
164FIND_PATH(CCOLAMD_INCLUDE NAMES ccolamd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700165IF (EXISTS ${CCOLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700166 MESSAGE("-- Found CCOLAMD header in: ${CCOLAMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700167ELSE (EXISTS ${CCOLAMD_INCLUDE})
168 MESSAGE("-- Did not find CCOLAMD header")
169 SET(CCOLAMD_FOUND FALSE)
170ENDIF (EXISTS ${CCOLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700171
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700172MESSAGE("-- Check for CHOLMOD")
173SET(CHOLMOD_FOUND TRUE)
174
175FIND_LIBRARY(CHOLMOD_LIB NAMES cholmod PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700176IF (EXISTS ${CHOLMOD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700177 MESSAGE("-- Found CHOLMOD library: ${CHOLMOD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700178ELSE (EXISTS ${CHOLMOD_LIB})
179 MESSAGE("-- Did not find CHOLMOD library")
180 SET(CHOLMOD_FOUND FALSE)
181ENDIF (EXISTS ${CHOLMOD_LIB})
182
183FIND_PATH(CHOLMOD_INCLUDE NAMES cholmod.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700184IF (EXISTS ${CHOLMOD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700185 MESSAGE("-- Found CHOLMOD header in: ${CHOLMOD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700186ELSE (EXISTS ${CHOLMOD_INCLUDE})
187 MESSAGE("-- Did not find CHOLMOD header")
188 SET(CHOLMOD_FOUND FALSE)
189ENDIF (EXISTS ${CHOLMOD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700190
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700191MESSAGE("-- Check for METIS (optional)")
192FIND_LIBRARY(METIS_LIB NAMES metis PATHS ${SUITESPARSE_SEARCH_LIBS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700193
Sameer Agarwalb0518732012-05-29 00:27:57 -0700194IF (EXISTS ${METIS_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700195 MESSAGE("-- Found METIS library: ${METIS_LIB}")
196ELSE (EXISTS ${METIS_LIB})
197 MESSAGE("-- Did not find METIS library")
198ENDIF (EXISTS ${METIS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700199
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700200SET(BLAS_AND_LAPACK_FOUND TRUE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700201IF (${APPLE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700202 # Mac OS X has LAPACK/BLAS bundled in a framework called
203 # "vecLib". Search for that instead of for the normal "lapack"
204 # library.
205 FIND_LIBRARY(LAPACK_LIB NAMES vecLib)
Sameer Agarwald1146902012-05-30 01:40:22 -0700206ELSE (${APPLE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700207 FIND_LIBRARY(BLAS_LIB NAMES blas)
Sameer Agarwalb0518732012-05-29 00:27:57 -0700208 IF (EXISTS ${BLAS_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700209 MESSAGE("-- Found BLAS library: ${BLAS_LIB}")
210 ELSE (EXISTS ${BLAS_LIB})
211 MESSAGE("-- Did not find BLAS library")
212 SET(BLAS_AND_LAPACK_FOUND FALSE)
213 ENDIF (EXISTS ${BLAS_LIB})
214 FIND_LIBRARY(LAPACK_LIB NAMES lapack)
Sameer Agarwald1146902012-05-30 01:40:22 -0700215ENDIF (${APPLE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700216
Sameer Agarwalb0518732012-05-29 00:27:57 -0700217IF (EXISTS ${LAPACK_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700218 MESSAGE("-- Found LAPACK library: ${LAPACK_LIB}")
219ELSE (EXISTS ${LAPACK_LIB})
220 SET(BLAS_AND_LAPACK_FOUND FALSE)
221 MESSAGE("-- Did not find LAPACK library")
222ENDIF (EXISTS ${LAPACK_LIB})
Keir Mierle92d5ab52012-05-01 18:33:08 -0700223
Sameer Agarwalb0518732012-05-29 00:27:57 -0700224SET(SUITESPARSE_FOUND
Keir Mierleefe7ac62012-06-24 22:25:28 -0700225 ${AMD_FOUND} AND
226 ${CAMD_FOUND} AND
227 ${COLAMD_FOUND} AND
228 ${CCOLAMD_FOUND} AND
229 ${CHOLMOD_FOUND} AND
230 ${BLAS_AND_LAPACK_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700231
232# By default, if all of SuiteSparse's dependencies are found, Ceres is
233# built with SuiteSparse support. -DSUITESPARSE=ON/OFF can be used to
234# enable/disable SuiteSparse explicitly.
235IF (DEFINED SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700236 IF (${SUITESPARSE})
237 IF (NOT ${SUITESPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700238 MESSAGE(FATAL_ERROR "One or more of SuiteSparse's dependencies was not found")
Sameer Agarwald1146902012-05-30 01:40:22 -0700239 ENDIF (NOT ${SUITESPARSE_FOUND})
240 ELSE (${SUITESPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700241 ADD_DEFINITIONS(-DCERES_NO_SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700242 ENDIF (${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700243ELSE (DEFINED SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700244 IF (${SUITESPARSE_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700245 MESSAGE("-- Found all SuiteSparse dependencies. Building with SuiteSparse")
246 SET(SUITESPARSE ON)
Sameer Agarwald1146902012-05-30 01:40:22 -0700247 ELSE (${SUITESPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700248 MESSAGE("-- Did not find all SuiteSparse dependencies. Building without SuiteSparse")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700249 SET(SUITESPARSE OFF)
250 ADD_DEFINITIONS(-DCERES_NO_SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700251 ENDIF (${SUITESPARSE_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700252ENDIF (DEFINED SUITESPARSE)
Keir Mierle8ebb0732012-04-30 23:09:08 -0700253
Sameer Agarwalb0518732012-05-29 00:27:57 -0700254# By default, if all of CXSparse's dependencies are found, Ceres is
255# built with CXSparse support. -DCXSPARSE=ON/OFF can be used to
256# enable/disable CXSparse explicitly.
257MESSAGE("-- Check for CXSparse")
258SET(CXSPARSE_FOUND ON)
259
260FIND_LIBRARY(CXSPARSE_LIB NAMES cxsparse PATHS ${CXSPARSE_SEARCH_LIBS})
261IF (EXISTS ${CXSPARSE_LIB})
262 MESSAGE("-- Found CXSparse library in: ${CXSPARSE_LIB}")
263ELSE (EXISTS ${CXSPARSE_LIB})
264 MESSAGE("-- Did not find CXSparse header")
265 SET(CXSPARSE_FOUND FALSE)
266ENDIF (EXISTS ${CXSPARSE_LIB})
267
268FIND_PATH(CXSPARSE_INCLUDE NAMES cs.h PATHS ${CXSPARSE_SEARCH_HEADERS})
269IF (EXISTS ${CXSPARSE_INCLUDE})
270 MESSAGE("-- Found CXSparse header in: ${CXSPARSE_INCLUDE}")
271ELSE (EXISTS ${CXSPARSE_INCLUDE})
272 MESSAGE("-- Did not find CXSparse header")
273 SET(CXSPARSE_FOUND FALSE)
274ENDIF (EXISTS ${CXSPARSE_INCLUDE})
275
276IF (DEFINED CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700277 IF (${CXSPARSE})
278 IF (NOT ${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700279 MESSAGE(FATAL_ERROR "-- CXSparse not found.")
Sameer Agarwald1146902012-05-30 01:40:22 -0700280 ENDIF (NOT ${CXSPARSE_FOUND})
281 ELSE (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700282 ADD_DEFINITIONS(-DCERES_NO_CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700283 ENDIF (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700284ELSE (DEFINED CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700285 IF (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700286 MESSAGE("-- Building with CXSparse support.")
287 SET(CXSPARSE ON)
Sameer Agarwald1146902012-05-30 01:40:22 -0700288 ELSE (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700289 MESSAGE("-- Building without CXSparse.")
290 SET(CXSPARSE OFF)
291 ADD_DEFINITIONS(-DCERES_NO_CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700292 ENDIF (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700293ENDIF (DEFINED CXSPARSE)
294
Keir Mierle8ebb0732012-04-30 23:09:08 -0700295# Google Flags
296OPTION(GFLAGS
297 "Enable Google Flags."
298 ON)
299
Sameer Agarwald1146902012-05-30 01:40:22 -0700300IF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700301 MESSAGE("-- Check for Google Flags")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700302 FIND_LIBRARY(GFLAGS_LIB NAMES gflags PATHS ${SEARCH_LIBS})
303 IF (NOT EXISTS ${GFLAGS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700304 MESSAGE(FATAL_ERROR
305 "Can't find Google Flags. Please specify: "
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700306 "-DGFLAGS_LIB=...")
307 ENDIF (NOT EXISTS ${GFLAGS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700308 MESSAGE("-- Found Google Flags library: ${GFLAGS_LIB}")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700309 FIND_PATH(GFLAGS_INCLUDE NAMES gflags/gflags.h PATHS ${SEARCH_HEADERS})
310 IF (NOT EXISTS ${GFLAGS_INCLUDE})
311 MESSAGE(FATAL_ERROR
312 "Can't find Google Flags. Please specify: "
313 "-DGFLAGS_INCLUDE=...")
314 ENDIF (NOT EXISTS ${GFLAGS_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700315 MESSAGE("-- Found Google Flags header in: ${GFLAGS_INCLUDE}")
Sameer Agarwald1146902012-05-30 01:40:22 -0700316ELSE (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700317 MESSAGE("-- Google Flags disabled; no tests or tools will be built!")
318 ADD_DEFINITIONS(-DCERES_NO_GFLAGS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700319ENDIF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700320
321# Google Logging
Keir Mierleaefb8a82012-07-28 13:23:55 -0700322IF (NOT ${BUILD_ANDROID})
323 MESSAGE("-- Check for Google Log")
324 FIND_LIBRARY(GLOG_LIB NAMES glog PATHS ${SEARCH_LIBS})
325 IF (NOT EXISTS ${GLOG_LIB})
326 MESSAGE(FATAL_ERROR
327 "Can't find Google Log. Please specify: "
328 "-DGLOG_LIB=...")
329 ENDIF (NOT EXISTS ${GLOG_LIB})
330 MESSAGE("-- Found Google Log library: ${GLOG_LIB}")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700331
Keir Mierleaefb8a82012-07-28 13:23:55 -0700332 FIND_PATH(GLOG_INCLUDE NAMES glog/logging.h PATHS ${SEARCH_HEADERS})
333 IF (NOT EXISTS ${GLOG_INCLUDE})
334 MESSAGE(FATAL_ERROR
335 "Can't find Google Log. Please specify: "
336 "-DGLOG_INCLUDE=...")
337 ENDIF (NOT EXISTS ${GLOG_INCLUDE})
338 MESSAGE("-- Found Google Log header in: ${GLOG_INCLUDE}")
339ELSE (NOT ${BUILD_ANDROID})
340 SET(GLOG_LIB miniglog)
341 MESSAGE("-- Using minimal Glog substitute for Android (library): ${GLOG_LIB}")
342 SET(GLOG_INCLUDE internal/ceres/miniglog)
343 MESSAGE("-- Using minimal Glog substitute for Android (include): ${GLOG_INCLUDE}")
344ENDIF (NOT ${BUILD_ANDROID})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700345
346# Eigen
347MESSAGE("-- Check for Eigen 3.0")
Keir Mierlef477a382012-05-01 18:10:48 -0700348FIND_PATH(EIGEN_INCLUDE NAMES Eigen/Core PATHS ${EIGEN_SEARCH_HEADERS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700349IF (NOT EXISTS ${EIGEN_INCLUDE})
Keir Mierlef477a382012-05-01 18:10:48 -0700350 MESSAGE(FATAL_ERROR "Can't find Eigen. Try passing -DEIGEN_INCLUDE=...")
Keir Mierle8ebb0732012-04-30 23:09:08 -0700351ENDIF (NOT EXISTS ${EIGEN_INCLUDE})
352MESSAGE("-- Found Eigen 3.0: ${EIGEN_INCLUDE}")
353
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700354# Template specializations for the Schur complement based solvers. If
355# compile time, binary size or compiler performance is an issue, you
356# may consider disabling this.
Keir Mierle8ebb0732012-04-30 23:09:08 -0700357OPTION(SCHUR_SPECIALIZATIONS
358 "Enable fixed-size schur specializations."
359 ON)
360
Sameer Agarwald1146902012-05-30 01:40:22 -0700361IF (NOT ${SCHUR_SPECIALIZATIONS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700362 ADD_DEFINITIONS(-DCERES_RESTRICT_SCHUR_SPECIALIZATION)
Keir Mierlef10163a2012-05-04 21:33:53 -0700363 MESSAGE("-- Disabling Schur specializations (faster compiles)")
Sameer Agarwald1146902012-05-30 01:40:22 -0700364ENDIF (NOT ${SCHUR_SPECIALIZATIONS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700365
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700366# Multithreading using OpenMP
Keir Mierle8ebb0732012-04-30 23:09:08 -0700367OPTION(OPENMP
368 "Enable threaded solving in Ceres (requires OpenMP)"
369 ON)
370
Sameer Agarwald1146902012-05-30 01:40:22 -0700371IF (${OPENMP})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700372 FIND_PACKAGE(OpenMP)
Sameer Agarwald1146902012-05-30 01:40:22 -0700373 IF(${OPENMP_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700374 MESSAGE("-- Found OpenMP.")
375 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OpenMP_CXX_FLAGS}")
376 ADD_DEFINITIONS(-DCERES_USE_OPENMP)
Sameer Agarwald1146902012-05-30 01:40:22 -0700377 ELSE(${OPENMP_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700378 MESSAGE("-- Can't find OpenMP. Continuing without it.")
Sameer Agarwald1146902012-05-30 01:40:22 -0700379 ENDIF(${OPENMP_FOUND})
380ENDIF (${OPENMP})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700381
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700382# Protocol buffers
Keir Mierle8ebb0732012-04-30 23:09:08 -0700383OPTION(PROTOBUF
384 "Enable protocol buffers support."
385 ON)
386
Sameer Agarwald1146902012-05-30 01:40:22 -0700387IF (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700388 FIND_PACKAGE(Protobuf)
Sameer Agarwald1146902012-05-30 01:40:22 -0700389 IF (${PROTOBUF_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700390 INCLUDE_DIRECTORIES(${PROTOBUF_INCLUDE_DIRS})
391 INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/internal)
Sameer Agarwald1146902012-05-30 01:40:22 -0700392 ELSE (${PROTOBUF_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700393 ADD_DEFINITIONS(-DCERES_DONT_HAVE_PROTOCOL_BUFFERS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700394 ENDIF (${PROTOBUF_FOUND})
395ELSE (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700396 ADD_DEFINITIONS(-DCERES_DONT_HAVE_PROTOCOL_BUFFERS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700397ENDIF (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700398
Keir Mierleaefb8a82012-07-28 13:23:55 -0700399
400# Use threads but not on Android, where there is no support for OpenMP yet.
Keir Mierle254f9d32012-08-02 21:18:49 -0700401IF ("${UNIX}" AND NOT ${BUILD_ANDROID})
Keir Mierleaefb8a82012-07-28 13:23:55 -0700402 # At least on Linux, we need pthreads to be enabled for mutex to compile.
403 # This may not work on windows or android.
Keir Mierle8ebb0732012-04-30 23:09:08 -0700404 FIND_PACKAGE(Threads REQUIRED)
405 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_THREAD_LIBS_INIT}")
406 ADD_DEFINITIONS(-DCERES_HAVE_PTHREAD)
407 ADD_DEFINITIONS(-DCERES_HAVE_RWLOCK)
Keir Mierle254f9d32012-08-02 21:18:49 -0700408ENDIF ("${UNIX}" AND NOT ${BUILD_ANDROID})
Keir Mierleaefb8a82012-07-28 13:23:55 -0700409
410# Disable threads in mutex.h. Someday, after there is OpenMP support in
411# Android, this can get removed.
412IF (${BUILD_ANDROID})
Keir Mierleff71d742012-08-10 17:05:15 -0700413 ADD_DEFINITIONS(-DCERES_NO_THREADS)
Keir Mierleaefb8a82012-07-28 13:23:55 -0700414ENDIF (${BUILD_ANDROID})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700415
Keir Mierle8ebb0732012-04-30 23:09:08 -0700416# Use the std namespace for the hash<> and related templates. This may vary by
417# system.
Keir Mierleefe7ac62012-06-24 22:25:28 -0700418IF (MSVC)
419 # This is known to work with Visual Studio 2010 Express.
420 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_START=namespace std {\"")
421 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_END=}\"")
422ELSE (MSVC)
423 # This is known to work with recent versions of Linux and Mac OS X.
424 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_START=namespace std { namespace tr1 {\"")
425 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_END=}}\"")
426ENDIF (MSVC)
Keir Mierle8ebb0732012-04-30 23:09:08 -0700427
428INCLUDE_DIRECTORIES(
429 include
430 internal
431 internal/ceres
Keir Mierle8ebb0732012-04-30 23:09:08 -0700432 ${GLOG_INCLUDE}
Keir Mierle8ebb0732012-04-30 23:09:08 -0700433 ${EIGEN_INCLUDE}
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700434 )
435
Sameer Agarwald1146902012-05-30 01:40:22 -0700436IF (${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700437 INCLUDE_DIRECTORIES(${CHOLMOD_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700438ENDIF(${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700439
Sameer Agarwald1146902012-05-30 01:40:22 -0700440IF (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700441 INCLUDE_DIRECTORIES(${CXSPARSE_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700442ENDIF(${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700443
Sameer Agarwald1146902012-05-30 01:40:22 -0700444IF (${GFLAGS})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700445 INCLUDE_DIRECTORIES(${GFLAGS_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700446ENDIF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700447
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700448# Change the default build type from Debug to Release, while still
449# supporting overriding the build type.
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700450#
451# The CACHE STRING logic here and elsewhere is needed to force CMake
452# to pay attention to the value of these variables.
453IF (NOT CMAKE_BUILD_TYPE)
454 MESSAGE("-- No build type specified; defaulting to CMAKE_BUILD_TYPE=Release.")
455 SET(CMAKE_BUILD_TYPE Release CACHE STRING
456 "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel."
457 FORCE)
458ELSE (NOT CMAKE_BUILD_TYPE)
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700459 IF (CMAKE_BUILD_TYPE STREQUAL "Debug")
460 MESSAGE("\n=================================================================================")
461 MESSAGE("\n-- Build type: Debug. Performance will be terrible!")
462 MESSAGE("-- Add -DCMAKE_BUILD_TYPE=Release to the CMake command line to get an optimized build.")
463 MESSAGE("\n=================================================================================")
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700464 ENDIF (CMAKE_BUILD_TYPE STREQUAL "Debug")
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700465ENDIF (NOT CMAKE_BUILD_TYPE)
466
467# Set the default Ceres flags to an empty string.
468SET (CERES_CXX_FLAGS)
469
470IF (CMAKE_BUILD_TYPE STREQUAL "Release")
471 IF (CMAKE_COMPILER_IS_GNUCXX)
Keir Mierleaefb8a82012-07-28 13:23:55 -0700472 IF (${BUILD_ANDROID})
473 # TODO(keir): Figure out what flags should go here to make an optimized
474 # native ARM binary for Android.
475 ELSE (${BUILD_ANDROID})
476 # Linux
477 IF (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
478 SET (CERES_CXX_FLAGS "${CERES_CXX_FLAGS} -march=native -mtune=native")
479 ENDIF (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
480 # Mac OS X
481 IF (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
482 SET (CERES_CXX_FLAGS "${CERES_CXX_FLAGS} -fast -msse3")
483 ENDIF (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
484 ENDIF (${BUILD_ANDROID})
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700485 ENDIF (CMAKE_COMPILER_IS_GNUCXX)
486 SET (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} ${CERES_CXX_FLAGS}"
487 CACHE STRING "Release mode flags to the C++ Compiler" FORCE)
488ENDIF (CMAKE_BUILD_TYPE STREQUAL "Release")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700489
490# After the tweaks for the compile settings, disable some warnings on MSVC.
491IF (MSVC)
492 # Disable signed/unsigned int conversion warnings.
Keir Mierleaefb8a82012-07-28 13:23:55 -0700493 ADD_DEFINITIONS("/wd4018")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700494 # Disable warning about using struct/class for the same symobl.
Keir Mierleaefb8a82012-07-28 13:23:55 -0700495 ADD_DEFINITIONS("/wd4099")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700496 # Disable warning about the insecurity of using "std::copy".
497 ADD_DEFINITIONS("/wd4996")
498 # Disable performance warning about int-to-bool conversion.
499 ADD_DEFINITIONS("/wd4800")
500 # Disable performance warning about fopen insecurity.
501 ADD_DEFINITIONS("/wd4996")
502 # Disable warning about int64 to int32 conversion. Disabling
503 # this warning may not be correct; needs investigation.
504 # TODO(keir): Investigate these warnings in more detail.
505 ADD_DEFINITIONS("/wd4244")
506 # It's not possible to use STL types in DLL interfaces in a portable and
507 # reliable way. However, that's what happens with Google Log and Google Flags
508 # on Windows. MSVC gets upset about this and throws warnings that we can't do
509 # much about. The real solution is to link static versions of Google Log and
510 # Google Test, but that seems tricky on Windows. So, disable the warning.
511 ADD_DEFINITIONS("/wd4251")
512
513 # Google Flags doesn't have their DLL import/export stuff set up correctly,
514 # which results in linker warnings. This is irrelevant for Ceres, so ignore
515 # the warnings.
516 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /ignore:4049")
517ENDIF (MSVC)
518
519ADD_SUBDIRECTORY(internal/ceres)
520ADD_SUBDIRECTORY(examples)
521