blob: f410ea5257552330c84af4803f3297a7511145f3 [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
Markus Mollc497bd62012-08-17 14:40:13 +0200191# If SuiteSparse version is >= 4 then SuiteSparse_config is required.
192# For SuiteSparse 3, UFconfig.h is required.
193MESSAGE("-- Check for SuiteSparse_config (SuiteSparse v4)")
194SET(SUITESPARSE_CONFIG_FOUND TRUE)
195
196FIND_LIBRARY(SUITESPARSE_CONFIG_LIB
197 NAMES suitesparseconfig
198 PATHS ${SUITESPARSE_SEARCH_LIBS})
199IF (EXISTS ${SUITESPARSE_CONFIG_LIB})
200 MESSAGE("-- Found SuiteSparse_config library: ${SUITESPARSE_CONFIG_LIB}")
201ELSE (EXISTS ${SUITESPARSE_CONFIG_LIB})
202 MESSAGE("-- Did not find SuiteSparse_config library")
203ENDIF (EXISTS ${SUITESPARSE_CONFIG_LIB})
204
205FIND_PATH(SUITESPARSE_CONFIG_INCLUDE
206 NAMES SuiteSparse_config.h
Sameer Agarwal96f25dc2012-08-17 15:34:42 -0700207 PATHS ${SUITESPARSE_SEARCH_HEADERS})
Markus Mollc497bd62012-08-17 14:40:13 +0200208IF (EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
209 MESSAGE("-- Found SuiteSparse_config header in: ${SUITESPARSE_CONFIG_INCLUDE}")
210ELSE (EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
211 MESSAGE("-- Did not find SuiteSparse_config header")
212ENDIF (EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
213
214IF (NOT EXISTS ${SUITESPARSE_CONFIG_LIB} OR NOT EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
215 SET(SUITESPARSE_CONFIG_FOUND FALSE)
216ENDIF (NOT EXISTS ${SUITESPARSE_CONFIG_LIB} OR NOT EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
217
218MESSAGE("-- Check for UFconfig (SuiteSparse v3)")
219SET(UFCONFIG_FOUND TRUE)
220
221FIND_PATH(UFCONFIG_INCLUDE
222 NAMES UFconfig.h
Sameer Agarwal96f25dc2012-08-17 15:34:42 -0700223 PATHS ${SUITESPARSE_SEARCH_INCLUDE})
Markus Mollc497bd62012-08-17 14:40:13 +0200224IF (EXISTS ${UFCONFIG_INCLUDE})
225 MESSAGE("-- Found UFconfig header in: ${UFCONFIG_INCLUDE}")
226ELSE (EXISTS ${UFCONFIG_INCLUDE})
227 MESSAGE("-- Did not find UFconfig header")
228 SET(UFCONFIG_FOUND FALSE)
229ENDIF (EXISTS ${UFCONFIG_INCLUDE})
230
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700231MESSAGE("-- Check for METIS (optional)")
232FIND_LIBRARY(METIS_LIB NAMES metis PATHS ${SUITESPARSE_SEARCH_LIBS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700233
Sameer Agarwalb0518732012-05-29 00:27:57 -0700234IF (EXISTS ${METIS_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700235 MESSAGE("-- Found METIS library: ${METIS_LIB}")
236ELSE (EXISTS ${METIS_LIB})
237 MESSAGE("-- Did not find METIS library")
238ENDIF (EXISTS ${METIS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700239
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700240SET(BLAS_AND_LAPACK_FOUND TRUE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700241IF (${APPLE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700242 # Mac OS X has LAPACK/BLAS bundled in a framework called
243 # "vecLib". Search for that instead of for the normal "lapack"
244 # library.
245 FIND_LIBRARY(LAPACK_LIB NAMES vecLib)
Sameer Agarwald1146902012-05-30 01:40:22 -0700246ELSE (${APPLE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700247 FIND_LIBRARY(BLAS_LIB NAMES blas)
Sameer Agarwalb0518732012-05-29 00:27:57 -0700248 IF (EXISTS ${BLAS_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700249 MESSAGE("-- Found BLAS library: ${BLAS_LIB}")
250 ELSE (EXISTS ${BLAS_LIB})
251 MESSAGE("-- Did not find BLAS library")
252 SET(BLAS_AND_LAPACK_FOUND FALSE)
253 ENDIF (EXISTS ${BLAS_LIB})
254 FIND_LIBRARY(LAPACK_LIB NAMES lapack)
Sameer Agarwald1146902012-05-30 01:40:22 -0700255ENDIF (${APPLE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700256
Sameer Agarwalb0518732012-05-29 00:27:57 -0700257IF (EXISTS ${LAPACK_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700258 MESSAGE("-- Found LAPACK library: ${LAPACK_LIB}")
259ELSE (EXISTS ${LAPACK_LIB})
260 SET(BLAS_AND_LAPACK_FOUND FALSE)
261 MESSAGE("-- Did not find LAPACK library")
262ENDIF (EXISTS ${LAPACK_LIB})
Keir Mierle92d5ab52012-05-01 18:33:08 -0700263
Sameer Agarwalb0518732012-05-29 00:27:57 -0700264SET(SUITESPARSE_FOUND
Keir Mierleefe7ac62012-06-24 22:25:28 -0700265 ${AMD_FOUND} AND
266 ${CAMD_FOUND} AND
267 ${COLAMD_FOUND} AND
268 ${CCOLAMD_FOUND} AND
269 ${CHOLMOD_FOUND} AND
Markus Mollc497bd62012-08-17 14:40:13 +0200270 (${SUITESPARSE_CONFIG_FOUND} OR ${UFCONFIG_FOUND}) AND
Keir Mierleefe7ac62012-06-24 22:25:28 -0700271 ${BLAS_AND_LAPACK_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700272
273# By default, if all of SuiteSparse's dependencies are found, Ceres is
274# built with SuiteSparse support. -DSUITESPARSE=ON/OFF can be used to
275# enable/disable SuiteSparse explicitly.
276IF (DEFINED SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700277 IF (${SUITESPARSE})
278 IF (NOT ${SUITESPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700279 MESSAGE(FATAL_ERROR "One or more of SuiteSparse's dependencies was not found")
Sameer Agarwald1146902012-05-30 01:40:22 -0700280 ENDIF (NOT ${SUITESPARSE_FOUND})
281 ELSE (${SUITESPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700282 ADD_DEFINITIONS(-DCERES_NO_SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700283 ENDIF (${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700284ELSE (DEFINED SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700285 IF (${SUITESPARSE_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700286 MESSAGE("-- Found all SuiteSparse dependencies. Building with SuiteSparse")
287 SET(SUITESPARSE ON)
Sameer Agarwald1146902012-05-30 01:40:22 -0700288 ELSE (${SUITESPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700289 MESSAGE("-- Did not find all SuiteSparse dependencies. Building without SuiteSparse")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700290 SET(SUITESPARSE OFF)
291 ADD_DEFINITIONS(-DCERES_NO_SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700292 ENDIF (${SUITESPARSE_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700293ENDIF (DEFINED SUITESPARSE)
Keir Mierle8ebb0732012-04-30 23:09:08 -0700294
Sameer Agarwalb0518732012-05-29 00:27:57 -0700295# By default, if all of CXSparse's dependencies are found, Ceres is
296# built with CXSparse support. -DCXSPARSE=ON/OFF can be used to
297# enable/disable CXSparse explicitly.
298MESSAGE("-- Check for CXSparse")
299SET(CXSPARSE_FOUND ON)
300
301FIND_LIBRARY(CXSPARSE_LIB NAMES cxsparse PATHS ${CXSPARSE_SEARCH_LIBS})
302IF (EXISTS ${CXSPARSE_LIB})
303 MESSAGE("-- Found CXSparse library in: ${CXSPARSE_LIB}")
304ELSE (EXISTS ${CXSPARSE_LIB})
305 MESSAGE("-- Did not find CXSparse header")
306 SET(CXSPARSE_FOUND FALSE)
307ENDIF (EXISTS ${CXSPARSE_LIB})
308
309FIND_PATH(CXSPARSE_INCLUDE NAMES cs.h PATHS ${CXSPARSE_SEARCH_HEADERS})
310IF (EXISTS ${CXSPARSE_INCLUDE})
311 MESSAGE("-- Found CXSparse header in: ${CXSPARSE_INCLUDE}")
312ELSE (EXISTS ${CXSPARSE_INCLUDE})
313 MESSAGE("-- Did not find CXSparse header")
314 SET(CXSPARSE_FOUND FALSE)
315ENDIF (EXISTS ${CXSPARSE_INCLUDE})
316
317IF (DEFINED CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700318 IF (${CXSPARSE})
319 IF (NOT ${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700320 MESSAGE(FATAL_ERROR "-- CXSparse not found.")
Sameer Agarwald1146902012-05-30 01:40:22 -0700321 ENDIF (NOT ${CXSPARSE_FOUND})
322 ELSE (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700323 ADD_DEFINITIONS(-DCERES_NO_CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700324 ENDIF (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700325ELSE (DEFINED CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700326 IF (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700327 MESSAGE("-- Building with CXSparse support.")
328 SET(CXSPARSE ON)
Sameer Agarwald1146902012-05-30 01:40:22 -0700329 ELSE (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700330 MESSAGE("-- Building without CXSparse.")
331 SET(CXSPARSE OFF)
332 ADD_DEFINITIONS(-DCERES_NO_CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700333 ENDIF (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700334ENDIF (DEFINED CXSPARSE)
335
Keir Mierle8ebb0732012-04-30 23:09:08 -0700336# Google Flags
337OPTION(GFLAGS
338 "Enable Google Flags."
339 ON)
340
Sameer Agarwald1146902012-05-30 01:40:22 -0700341IF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700342 MESSAGE("-- Check for Google Flags")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700343 FIND_LIBRARY(GFLAGS_LIB NAMES gflags PATHS ${SEARCH_LIBS})
344 IF (NOT EXISTS ${GFLAGS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700345 MESSAGE(FATAL_ERROR
346 "Can't find Google Flags. Please specify: "
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700347 "-DGFLAGS_LIB=...")
348 ENDIF (NOT EXISTS ${GFLAGS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700349 MESSAGE("-- Found Google Flags library: ${GFLAGS_LIB}")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700350 FIND_PATH(GFLAGS_INCLUDE NAMES gflags/gflags.h PATHS ${SEARCH_HEADERS})
351 IF (NOT EXISTS ${GFLAGS_INCLUDE})
352 MESSAGE(FATAL_ERROR
353 "Can't find Google Flags. Please specify: "
354 "-DGFLAGS_INCLUDE=...")
355 ENDIF (NOT EXISTS ${GFLAGS_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700356 MESSAGE("-- Found Google Flags header in: ${GFLAGS_INCLUDE}")
Sameer Agarwald1146902012-05-30 01:40:22 -0700357ELSE (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700358 MESSAGE("-- Google Flags disabled; no tests or tools will be built!")
359 ADD_DEFINITIONS(-DCERES_NO_GFLAGS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700360ENDIF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700361
362# Google Logging
Keir Mierleaefb8a82012-07-28 13:23:55 -0700363IF (NOT ${BUILD_ANDROID})
364 MESSAGE("-- Check for Google Log")
365 FIND_LIBRARY(GLOG_LIB NAMES glog PATHS ${SEARCH_LIBS})
366 IF (NOT EXISTS ${GLOG_LIB})
367 MESSAGE(FATAL_ERROR
368 "Can't find Google Log. Please specify: "
369 "-DGLOG_LIB=...")
370 ENDIF (NOT EXISTS ${GLOG_LIB})
371 MESSAGE("-- Found Google Log library: ${GLOG_LIB}")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700372
Keir Mierleaefb8a82012-07-28 13:23:55 -0700373 FIND_PATH(GLOG_INCLUDE NAMES glog/logging.h PATHS ${SEARCH_HEADERS})
374 IF (NOT EXISTS ${GLOG_INCLUDE})
375 MESSAGE(FATAL_ERROR
376 "Can't find Google Log. Please specify: "
377 "-DGLOG_INCLUDE=...")
378 ENDIF (NOT EXISTS ${GLOG_INCLUDE})
379 MESSAGE("-- Found Google Log header in: ${GLOG_INCLUDE}")
380ELSE (NOT ${BUILD_ANDROID})
381 SET(GLOG_LIB miniglog)
382 MESSAGE("-- Using minimal Glog substitute for Android (library): ${GLOG_LIB}")
383 SET(GLOG_INCLUDE internal/ceres/miniglog)
384 MESSAGE("-- Using minimal Glog substitute for Android (include): ${GLOG_INCLUDE}")
385ENDIF (NOT ${BUILD_ANDROID})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700386
387# Eigen
388MESSAGE("-- Check for Eigen 3.0")
Keir Mierlef477a382012-05-01 18:10:48 -0700389FIND_PATH(EIGEN_INCLUDE NAMES Eigen/Core PATHS ${EIGEN_SEARCH_HEADERS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700390IF (NOT EXISTS ${EIGEN_INCLUDE})
Keir Mierlef477a382012-05-01 18:10:48 -0700391 MESSAGE(FATAL_ERROR "Can't find Eigen. Try passing -DEIGEN_INCLUDE=...")
Keir Mierle8ebb0732012-04-30 23:09:08 -0700392ENDIF (NOT EXISTS ${EIGEN_INCLUDE})
393MESSAGE("-- Found Eigen 3.0: ${EIGEN_INCLUDE}")
394
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700395# Template specializations for the Schur complement based solvers. If
396# compile time, binary size or compiler performance is an issue, you
397# may consider disabling this.
Keir Mierle8ebb0732012-04-30 23:09:08 -0700398OPTION(SCHUR_SPECIALIZATIONS
399 "Enable fixed-size schur specializations."
400 ON)
401
Sameer Agarwald1146902012-05-30 01:40:22 -0700402IF (NOT ${SCHUR_SPECIALIZATIONS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700403 ADD_DEFINITIONS(-DCERES_RESTRICT_SCHUR_SPECIALIZATION)
Keir Mierlef10163a2012-05-04 21:33:53 -0700404 MESSAGE("-- Disabling Schur specializations (faster compiles)")
Sameer Agarwald1146902012-05-30 01:40:22 -0700405ENDIF (NOT ${SCHUR_SPECIALIZATIONS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700406
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700407# Multithreading using OpenMP
Keir Mierle8ebb0732012-04-30 23:09:08 -0700408OPTION(OPENMP
409 "Enable threaded solving in Ceres (requires OpenMP)"
410 ON)
411
Sameer Agarwald1146902012-05-30 01:40:22 -0700412IF (${OPENMP})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700413 FIND_PACKAGE(OpenMP)
Sameer Agarwald1146902012-05-30 01:40:22 -0700414 IF(${OPENMP_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700415 MESSAGE("-- Found OpenMP.")
416 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OpenMP_CXX_FLAGS}")
417 ADD_DEFINITIONS(-DCERES_USE_OPENMP)
Sameer Agarwald1146902012-05-30 01:40:22 -0700418 ELSE(${OPENMP_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700419 MESSAGE("-- Can't find OpenMP. Continuing without it.")
Sameer Agarwald1146902012-05-30 01:40:22 -0700420 ENDIF(${OPENMP_FOUND})
421ENDIF (${OPENMP})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700422
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700423# Protocol buffers
Keir Mierle8ebb0732012-04-30 23:09:08 -0700424OPTION(PROTOBUF
425 "Enable protocol buffers support."
426 ON)
427
Sameer Agarwald1146902012-05-30 01:40:22 -0700428IF (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700429 FIND_PACKAGE(Protobuf)
Sameer Agarwald1146902012-05-30 01:40:22 -0700430 IF (${PROTOBUF_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700431 INCLUDE_DIRECTORIES(${PROTOBUF_INCLUDE_DIRS})
432 INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/internal)
Sameer Agarwald1146902012-05-30 01:40:22 -0700433 ELSE (${PROTOBUF_FOUND})
Sameer Agarwaldd2b17d2012-08-16 19:34:57 -0700434 ADD_DEFINITIONS(-DCERES_NO_PROTOCOL_BUFFERS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700435 ENDIF (${PROTOBUF_FOUND})
436ELSE (${PROTOBUF})
Sameer Agarwaldd2b17d2012-08-16 19:34:57 -0700437 ADD_DEFINITIONS(-DCERES_NO_PROTOCOL_BUFFERS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700438ENDIF (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700439
Keir Mierleaefb8a82012-07-28 13:23:55 -0700440
441# Use threads but not on Android, where there is no support for OpenMP yet.
Keir Mierle254f9d32012-08-02 21:18:49 -0700442IF ("${UNIX}" AND NOT ${BUILD_ANDROID})
Keir Mierleaefb8a82012-07-28 13:23:55 -0700443 # At least on Linux, we need pthreads to be enabled for mutex to compile.
444 # This may not work on windows or android.
Keir Mierle8ebb0732012-04-30 23:09:08 -0700445 FIND_PACKAGE(Threads REQUIRED)
446 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_THREAD_LIBS_INIT}")
447 ADD_DEFINITIONS(-DCERES_HAVE_PTHREAD)
448 ADD_DEFINITIONS(-DCERES_HAVE_RWLOCK)
Keir Mierle254f9d32012-08-02 21:18:49 -0700449ENDIF ("${UNIX}" AND NOT ${BUILD_ANDROID})
Keir Mierleaefb8a82012-07-28 13:23:55 -0700450
451# Disable threads in mutex.h. Someday, after there is OpenMP support in
452# Android, this can get removed.
453IF (${BUILD_ANDROID})
Keir Mierleff71d742012-08-10 17:05:15 -0700454 ADD_DEFINITIONS(-DCERES_NO_THREADS)
Keir Mierleaefb8a82012-07-28 13:23:55 -0700455ENDIF (${BUILD_ANDROID})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700456
Keir Mierled2164902012-08-15 19:04:50 -0700457OPTION(DISABLE_TR1
458 "Don't use TR1. This replaces some hash tables with sets. Slower."
459 OFF)
460
461IF (${DISABLE_TR1})
462 MESSAGE("-- Replacing unordered_map/set with map/set (warning: slower!)")
463 ADD_DEFINITIONS(-DCERES_NO_TR1)
464ELSE (${DISABLE_TR1})
465 MESSAGE("-- Using normal TR1 unordered_map/set")
466 # Use the std namespace for the hash<> and related templates. This may vary by
467 # system.
468 IF (MSVC)
469 # This is known to work with Visual Studio 2010 Express.
470 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_START=namespace std {\"")
471 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_END=}\"")
472 ELSE (MSVC)
473 # This is known to work with recent versions of Linux and Mac OS X.
474 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_START=namespace std { namespace tr1 {\"")
475 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_END=}}\"")
476 ENDIF (MSVC)
477ENDIF (${DISABLE_TR1})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700478
479INCLUDE_DIRECTORIES(
480 include
481 internal
482 internal/ceres
Keir Mierle8ebb0732012-04-30 23:09:08 -0700483 ${GLOG_INCLUDE}
Keir Mierle8ebb0732012-04-30 23:09:08 -0700484 ${EIGEN_INCLUDE}
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700485 )
486
Sameer Agarwald1146902012-05-30 01:40:22 -0700487IF (${SUITESPARSE})
Markus Mollc497bd62012-08-17 14:40:13 +0200488 INCLUDE_DIRECTORIES(${AMD_INCLUDE})
489 INCLUDE_DIRECTORIES(${CAMD_INCLUDE})
490 INCLUDE_DIRECTORIES(${COLAMD_INCLUDE})
491 INCLUDE_DIRECTORIES(${CCOLAMD_INCLUDE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700492 INCLUDE_DIRECTORIES(${CHOLMOD_INCLUDE})
Markus Mollc497bd62012-08-17 14:40:13 +0200493 IF (${SUITESPARSE_CONFIG_FOUND})
494 INCLUDE_DIRECTORIES(${SUITESPARSE_CONFIG_INCLUDE})
495 ENDIF (${SUITESPARSE_CONFIG_FOUND})
496 IF (${UFCONFIG_FOUND})
497 INCLUDE_DIRECTORIES(${UFCONFIG_INCLUDE})
498 ENDIF (${UFCONFIG_FOUND})
Sameer Agarwald1146902012-05-30 01:40:22 -0700499ENDIF(${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700500
Sameer Agarwald1146902012-05-30 01:40:22 -0700501IF (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700502 INCLUDE_DIRECTORIES(${CXSPARSE_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700503ENDIF(${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700504
Sameer Agarwald1146902012-05-30 01:40:22 -0700505IF (${GFLAGS})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700506 INCLUDE_DIRECTORIES(${GFLAGS_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700507ENDIF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700508
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700509# Change the default build type from Debug to Release, while still
510# supporting overriding the build type.
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700511#
512# The CACHE STRING logic here and elsewhere is needed to force CMake
513# to pay attention to the value of these variables.
514IF (NOT CMAKE_BUILD_TYPE)
515 MESSAGE("-- No build type specified; defaulting to CMAKE_BUILD_TYPE=Release.")
516 SET(CMAKE_BUILD_TYPE Release CACHE STRING
517 "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel."
518 FORCE)
519ELSE (NOT CMAKE_BUILD_TYPE)
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700520 IF (CMAKE_BUILD_TYPE STREQUAL "Debug")
521 MESSAGE("\n=================================================================================")
522 MESSAGE("\n-- Build type: Debug. Performance will be terrible!")
523 MESSAGE("-- Add -DCMAKE_BUILD_TYPE=Release to the CMake command line to get an optimized build.")
524 MESSAGE("\n=================================================================================")
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700525 ENDIF (CMAKE_BUILD_TYPE STREQUAL "Debug")
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700526ENDIF (NOT CMAKE_BUILD_TYPE)
527
528# Set the default Ceres flags to an empty string.
529SET (CERES_CXX_FLAGS)
530
531IF (CMAKE_BUILD_TYPE STREQUAL "Release")
532 IF (CMAKE_COMPILER_IS_GNUCXX)
Keir Mierleaefb8a82012-07-28 13:23:55 -0700533 IF (${BUILD_ANDROID})
534 # TODO(keir): Figure out what flags should go here to make an optimized
535 # native ARM binary for Android.
536 ELSE (${BUILD_ANDROID})
537 # Linux
538 IF (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
539 SET (CERES_CXX_FLAGS "${CERES_CXX_FLAGS} -march=native -mtune=native")
540 ENDIF (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
541 # Mac OS X
542 IF (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
543 SET (CERES_CXX_FLAGS "${CERES_CXX_FLAGS} -fast -msse3")
544 ENDIF (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
545 ENDIF (${BUILD_ANDROID})
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700546 ENDIF (CMAKE_COMPILER_IS_GNUCXX)
547 SET (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} ${CERES_CXX_FLAGS}"
548 CACHE STRING "Release mode flags to the C++ Compiler" FORCE)
549ENDIF (CMAKE_BUILD_TYPE STREQUAL "Release")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700550
551# After the tweaks for the compile settings, disable some warnings on MSVC.
552IF (MSVC)
553 # Disable signed/unsigned int conversion warnings.
Keir Mierleaefb8a82012-07-28 13:23:55 -0700554 ADD_DEFINITIONS("/wd4018")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700555 # Disable warning about using struct/class for the same symobl.
Keir Mierleaefb8a82012-07-28 13:23:55 -0700556 ADD_DEFINITIONS("/wd4099")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700557 # Disable warning about the insecurity of using "std::copy".
558 ADD_DEFINITIONS("/wd4996")
559 # Disable performance warning about int-to-bool conversion.
560 ADD_DEFINITIONS("/wd4800")
561 # Disable performance warning about fopen insecurity.
562 ADD_DEFINITIONS("/wd4996")
563 # Disable warning about int64 to int32 conversion. Disabling
564 # this warning may not be correct; needs investigation.
565 # TODO(keir): Investigate these warnings in more detail.
566 ADD_DEFINITIONS("/wd4244")
567 # It's not possible to use STL types in DLL interfaces in a portable and
568 # reliable way. However, that's what happens with Google Log and Google Flags
569 # on Windows. MSVC gets upset about this and throws warnings that we can't do
570 # much about. The real solution is to link static versions of Google Log and
571 # Google Test, but that seems tricky on Windows. So, disable the warning.
572 ADD_DEFINITIONS("/wd4251")
573
574 # Google Flags doesn't have their DLL import/export stuff set up correctly,
575 # which results in linker warnings. This is irrelevant for Ceres, so ignore
576 # the warnings.
577 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /ignore:4049")
578ENDIF (MSVC)
579
580ADD_SUBDIRECTORY(internal/ceres)
581ADD_SUBDIRECTORY(examples)