blob: 117e86b796498768c75ccbcc548138fc84177069 [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
Arnaud Gelasb3fa0092012-08-17 10:31:41 +020039SET(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
40SET(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
41SET(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
42
Keir Mierle05107ba2012-07-18 13:50:12 -070043# Important: Always bump the second number (e.g. 1.3.x to 1.4.0) for any
44# release that changes the ABI. The ABI changes for almost any modification to
45# include/ceres (e.g. the public API). If you are unsure about whether
46# something is an ABI change, please ask on the list.
47#
48# For versions without ABI changes, bump the smallest number in CERES_VERSION,
49# but leave the CERES_ABI_VERSION unchanged.
50SET(CERES_VERSION 1.3.0)
51SET(CERES_ABI_VERSION 1.3.0)
52
Sameer Agarwal30c5f932012-05-03 10:44:43 -070053ENABLE_TESTING()
Keir Mierle8ebb0732012-04-30 23:09:08 -070054
Sameer Agarwalaa9526d2012-05-08 21:22:09 -070055OPTION(BUILD_TESTING
56 "Enable tests"
57 ON)
58
Keir Mierleaefb8a82012-07-28 13:23:55 -070059OPTION(BUILD_ANDROID
60 "Build for Android. Use build_android.sh instead of setting this."
61 OFF)
62
Sameer Agarwalaa9526d2012-05-08 21:22:09 -070063# To get a more static build, try the following line on Mac and Linux:
64# SET(CMAKE_FIND_LIBRARY_SUFFIXES .a ${CMAKE_FIND_LIBRARY_SUFFIXES})
65
Sameer Agarwaldaa98242012-05-11 11:26:38 -070066# Default locations to search for on various platforms.
67LIST(APPEND SEARCH_LIBS /usr/lib)
68LIST(APPEND SEARCH_LIBS /usr/local/lib)
69LIST(APPEND SEARCH_LIBS /usr/local/homebrew/lib) # Mac OS X
70LIST(APPEND SEARCH_LIBS /opt/local/lib)
Keir Mierle8ebb0732012-04-30 23:09:08 -070071
Sameer Agarwaldaa98242012-05-11 11:26:38 -070072LIST(APPEND SEARCH_HEADERS /usr/include)
73LIST(APPEND SEARCH_HEADERS /usr/local/include)
74LIST(APPEND SEARCH_HEADERS /usr/local/homebrew/include) # Mac OS X
75LIST(APPEND SEARCH_HEADERS /opt/local/include)
Keir Mierle8ebb0732012-04-30 23:09:08 -070076
Sameer Agarwaldaa98242012-05-11 11:26:38 -070077# Locations to search for Eigen
78SET(EIGEN_SEARCH_HEADERS ${SEARCH_HEADERS})
79LIST(APPEND EIGEN_SEARCH_HEADERS /usr/include/eigen3) # Ubuntu 10.04's default location.
Sameer Agarwalb0518732012-05-29 00:27:57 -070080LIST(APPEND EIGEN_SEARCH_HEADERS /usr/local/include/eigen3)
Sameer Agarwaldaa98242012-05-11 11:26:38 -070081LIST(APPEND EIGEN_SEARCH_HEADERS /usr/local/homebrew/include/eigen3) # Mac OS X
82LIST(APPEND EIGEN_SEARCH_HEADERS /opt/local/var/macports/software/eigen3/opt/local/include/eigen3) # Mac OS X
83
84# Locations to search for SuiteSparse
85SET(SUITESPARSE_SEARCH_LIBS ${SEARCH_LIBS})
86LIST(APPEND SUITESPARSE_SEARCH_LIBS /usr/lib/suitesparse) # Ubuntu
Sameer Agarwalb0518732012-05-29 00:27:57 -070087LIST(APPEND SUITESPARSE_SEARCH_LIBS /usr/local/lib/suitesparse)
Sameer Agarwaldaa98242012-05-11 11:26:38 -070088LIST(APPEND SUITESPARSE_SEARCH_LIBS /opt/local/lib/ufsparse) # Mac OS X
89
90SET(SUITESPARSE_SEARCH_HEADERS ${SEARCH_HEADERS})
91LIST(APPEND SUITESPARSE_SEARCH_HEADERS /usr/include/suitesparse) # Ubuntu
Sameer Agarwalb0518732012-05-29 00:27:57 -070092LIST(APPEND SUITESPARSE_SEARCH_HEADERS /usr/local/include/suitesparse)
Sameer Agarwaldaa98242012-05-11 11:26:38 -070093LIST(APPEND SUITESPARSE_SEARCH_HEADERS /opt/local/include/ufsparse) # Mac OS X
94
Sameer Agarwalb0518732012-05-29 00:27:57 -070095SET(CXSPARSE_SEARCH_LIBS ${SEARCH_LIBS})
96SET(CXSPARSE_SEARCH_HEADERS ${SEARCH_HEADERS})
97LIST(APPEND CXSPARSE_SEARCH_HEADERS /usr/include/suitesparse) # Ubuntu
98
Sameer Agarwaldaa98242012-05-11 11:26:38 -070099# Check for SuiteSparse dependencies
100MESSAGE("-- Check for AMD")
101SET(AMD_FOUND TRUE)
102
103FIND_LIBRARY(AMD_LIB NAMES amd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700104IF (EXISTS ${AMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700105 MESSAGE("-- Found AMD library: ${AMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700106ELSE (EXISTS ${AMD_LIB})
107 MESSAGE("-- Did not find AMD library")
108 SET(AMD_FOUND FALSE)
109ENDIF (EXISTS ${AMD_LIB})
110
111FIND_PATH(AMD_INCLUDE NAMES amd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700112IF (EXISTS ${AMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700113 MESSAGE("-- Found AMD header in: ${AMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700114ELSE (EXISTS ${AMD_INCLUDE})
115 MESSAGE("-- Did not find AMD header")
116 SET(AMD_FOUND FALSE)
117ENDIF (EXISTS ${AMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700118
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700119MESSAGE("-- Check for CAMD")
120SET(CAMD_FOUND TRUE)
121
122FIND_LIBRARY(CAMD_LIB NAMES camd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700123IF (EXISTS ${CAMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700124 MESSAGE("-- Found CAMD library: ${CAMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700125ELSE (EXISTS ${CAMD_LIB})
126 MESSAGE("-- Did not find CAMD library")
127 SET(CAMD_FOUND FALSE)
128ENDIF (EXISTS ${CAMD_LIB})
129
130FIND_PATH(CAMD_INCLUDE NAMES camd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700131IF (EXISTS ${CAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700132 MESSAGE("-- Found CAMD header in: ${CAMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700133ELSE (EXISTS ${CAMD_INCLUDE})
134 MESSAGE("-- Did not find CAMD header")
135 SET(CAMD_FOUND FALSE)
136ENDIF (EXISTS ${CAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700137
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700138MESSAGE("-- Check for COLAMD")
139SET(COLAMD_FOUND TRUE)
140
141FIND_LIBRARY(COLAMD_LIB NAMES colamd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700142IF (EXISTS ${COLAMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700143 MESSAGE("-- Found COLAMD library: ${COLAMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700144ELSE (EXISTS ${COLAMD_LIB})
145 MESSAGE("-- Did not find COLAMD library")
146 SET(COLAMD_FOUND FALSE)
147ENDIF (EXISTS ${COLAMD_LIB})
148
149FIND_PATH(COLAMD_INCLUDE NAMES colamd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700150IF (EXISTS ${COLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700151 MESSAGE("-- Found COLAMD header in: ${COLAMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700152ELSE (EXISTS ${COLAMD_INCLUDE})
153 MESSAGE("-- Did not find COLAMD header")
154 SET(COLAMD_FOUND FALSE)
155ENDIF (EXISTS ${COLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700156
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700157MESSAGE("-- Check for CCOLAMD")
158SET(CCOLAMD_FOUND TRUE)
159
160FIND_LIBRARY(CCOLAMD_LIB NAMES ccolamd PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700161IF (EXISTS ${CCOLAMD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700162 MESSAGE("-- Found CCOLAMD library: ${CCOLAMD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700163ELSE (EXISTS ${CCOLAMD_LIB})
164 MESSAGE("-- Did not find CCOLAMD library")
165 SET(CCOLAMD_FOUND FALSE)
166ENDIF (EXISTS ${CCOLAMD_LIB})
167
168FIND_PATH(CCOLAMD_INCLUDE NAMES ccolamd.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700169IF (EXISTS ${CCOLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700170 MESSAGE("-- Found CCOLAMD header in: ${CCOLAMD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700171ELSE (EXISTS ${CCOLAMD_INCLUDE})
172 MESSAGE("-- Did not find CCOLAMD header")
173 SET(CCOLAMD_FOUND FALSE)
174ENDIF (EXISTS ${CCOLAMD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700175
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700176MESSAGE("-- Check for CHOLMOD")
177SET(CHOLMOD_FOUND TRUE)
178
179FIND_LIBRARY(CHOLMOD_LIB NAMES cholmod PATHS ${SUITESPARSE_SEARCH_LIBS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700180IF (EXISTS ${CHOLMOD_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700181 MESSAGE("-- Found CHOLMOD library: ${CHOLMOD_LIB}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700182ELSE (EXISTS ${CHOLMOD_LIB})
183 MESSAGE("-- Did not find CHOLMOD library")
184 SET(CHOLMOD_FOUND FALSE)
185ENDIF (EXISTS ${CHOLMOD_LIB})
186
187FIND_PATH(CHOLMOD_INCLUDE NAMES cholmod.h PATHS ${SUITESPARSE_SEARCH_HEADERS})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700188IF (EXISTS ${CHOLMOD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700189 MESSAGE("-- Found CHOLMOD header in: ${CHOLMOD_INCLUDE}")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700190ELSE (EXISTS ${CHOLMOD_INCLUDE})
191 MESSAGE("-- Did not find CHOLMOD header")
192 SET(CHOLMOD_FOUND FALSE)
193ENDIF (EXISTS ${CHOLMOD_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700194
Markus Mollc497bd62012-08-17 14:40:13 +0200195# If SuiteSparse version is >= 4 then SuiteSparse_config is required.
196# For SuiteSparse 3, UFconfig.h is required.
197MESSAGE("-- Check for SuiteSparse_config (SuiteSparse v4)")
198SET(SUITESPARSE_CONFIG_FOUND TRUE)
199
200FIND_LIBRARY(SUITESPARSE_CONFIG_LIB
201 NAMES suitesparseconfig
202 PATHS ${SUITESPARSE_SEARCH_LIBS})
203IF (EXISTS ${SUITESPARSE_CONFIG_LIB})
204 MESSAGE("-- Found SuiteSparse_config library: ${SUITESPARSE_CONFIG_LIB}")
205ELSE (EXISTS ${SUITESPARSE_CONFIG_LIB})
206 MESSAGE("-- Did not find SuiteSparse_config library")
207ENDIF (EXISTS ${SUITESPARSE_CONFIG_LIB})
208
209FIND_PATH(SUITESPARSE_CONFIG_INCLUDE
210 NAMES SuiteSparse_config.h
Sameer Agarwal96f25dc2012-08-17 15:34:42 -0700211 PATHS ${SUITESPARSE_SEARCH_HEADERS})
Markus Mollc497bd62012-08-17 14:40:13 +0200212IF (EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
213 MESSAGE("-- Found SuiteSparse_config header in: ${SUITESPARSE_CONFIG_INCLUDE}")
214ELSE (EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
215 MESSAGE("-- Did not find SuiteSparse_config header")
216ENDIF (EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
217
218IF (NOT EXISTS ${SUITESPARSE_CONFIG_LIB} OR NOT EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
219 SET(SUITESPARSE_CONFIG_FOUND FALSE)
220ENDIF (NOT EXISTS ${SUITESPARSE_CONFIG_LIB} OR NOT EXISTS ${SUITESPARSE_CONFIG_INCLUDE})
221
222MESSAGE("-- Check for UFconfig (SuiteSparse v3)")
223SET(UFCONFIG_FOUND TRUE)
224
225FIND_PATH(UFCONFIG_INCLUDE
226 NAMES UFconfig.h
Sameer Agarwale83f7872012-08-17 15:34:42 -0700227 PATHS ${SUITESPARSE_SEARCH_HEADERS})
Markus Mollc497bd62012-08-17 14:40:13 +0200228IF (EXISTS ${UFCONFIG_INCLUDE})
229 MESSAGE("-- Found UFconfig header in: ${UFCONFIG_INCLUDE}")
230ELSE (EXISTS ${UFCONFIG_INCLUDE})
231 MESSAGE("-- Did not find UFconfig header")
232 SET(UFCONFIG_FOUND FALSE)
233ENDIF (EXISTS ${UFCONFIG_INCLUDE})
234
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700235MESSAGE("-- Check for METIS (optional)")
236FIND_LIBRARY(METIS_LIB NAMES metis PATHS ${SUITESPARSE_SEARCH_LIBS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700237
Sameer Agarwalb0518732012-05-29 00:27:57 -0700238IF (EXISTS ${METIS_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700239 MESSAGE("-- Found METIS library: ${METIS_LIB}")
240ELSE (EXISTS ${METIS_LIB})
241 MESSAGE("-- Did not find METIS library")
242ENDIF (EXISTS ${METIS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700243
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700244SET(BLAS_AND_LAPACK_FOUND TRUE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700245IF (${APPLE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700246 # Mac OS X has LAPACK/BLAS bundled in a framework called
247 # "vecLib". Search for that instead of for the normal "lapack"
248 # library.
249 FIND_LIBRARY(LAPACK_LIB NAMES vecLib)
Sameer Agarwald1146902012-05-30 01:40:22 -0700250ELSE (${APPLE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700251 FIND_LIBRARY(BLAS_LIB NAMES blas)
Sameer Agarwalb0518732012-05-29 00:27:57 -0700252 IF (EXISTS ${BLAS_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700253 MESSAGE("-- Found BLAS library: ${BLAS_LIB}")
254 ELSE (EXISTS ${BLAS_LIB})
255 MESSAGE("-- Did not find BLAS library")
256 SET(BLAS_AND_LAPACK_FOUND FALSE)
257 ENDIF (EXISTS ${BLAS_LIB})
258 FIND_LIBRARY(LAPACK_LIB NAMES lapack)
Sameer Agarwald1146902012-05-30 01:40:22 -0700259ENDIF (${APPLE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700260
Sameer Agarwalb0518732012-05-29 00:27:57 -0700261IF (EXISTS ${LAPACK_LIB})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700262 MESSAGE("-- Found LAPACK library: ${LAPACK_LIB}")
263ELSE (EXISTS ${LAPACK_LIB})
264 SET(BLAS_AND_LAPACK_FOUND FALSE)
265 MESSAGE("-- Did not find LAPACK library")
266ENDIF (EXISTS ${LAPACK_LIB})
Keir Mierle92d5ab52012-05-01 18:33:08 -0700267
Sameer Agarwalb0518732012-05-29 00:27:57 -0700268SET(SUITESPARSE_FOUND
Keir Mierleefe7ac62012-06-24 22:25:28 -0700269 ${AMD_FOUND} AND
270 ${CAMD_FOUND} AND
271 ${COLAMD_FOUND} AND
272 ${CCOLAMD_FOUND} AND
273 ${CHOLMOD_FOUND} AND
Markus Mollc497bd62012-08-17 14:40:13 +0200274 (${SUITESPARSE_CONFIG_FOUND} OR ${UFCONFIG_FOUND}) AND
Keir Mierleefe7ac62012-06-24 22:25:28 -0700275 ${BLAS_AND_LAPACK_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700276
277# By default, if all of SuiteSparse's dependencies are found, Ceres is
278# built with SuiteSparse support. -DSUITESPARSE=ON/OFF can be used to
279# enable/disable SuiteSparse explicitly.
280IF (DEFINED SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700281 IF (${SUITESPARSE})
282 IF (NOT ${SUITESPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700283 MESSAGE(FATAL_ERROR "One or more of SuiteSparse's dependencies was not found")
Sameer Agarwald1146902012-05-30 01:40:22 -0700284 ENDIF (NOT ${SUITESPARSE_FOUND})
285 ELSE (${SUITESPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700286 ADD_DEFINITIONS(-DCERES_NO_SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700287 ENDIF (${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700288ELSE (DEFINED SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700289 IF (${SUITESPARSE_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700290 MESSAGE("-- Found all SuiteSparse dependencies. Building with SuiteSparse")
291 SET(SUITESPARSE ON)
Sameer Agarwald1146902012-05-30 01:40:22 -0700292 ELSE (${SUITESPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700293 MESSAGE("-- Did not find all SuiteSparse dependencies. Building without SuiteSparse")
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700294 SET(SUITESPARSE OFF)
295 ADD_DEFINITIONS(-DCERES_NO_SUITESPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700296 ENDIF (${SUITESPARSE_FOUND})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700297ENDIF (DEFINED SUITESPARSE)
Keir Mierle8ebb0732012-04-30 23:09:08 -0700298
Sameer Agarwalb0518732012-05-29 00:27:57 -0700299# By default, if all of CXSparse's dependencies are found, Ceres is
300# built with CXSparse support. -DCXSPARSE=ON/OFF can be used to
301# enable/disable CXSparse explicitly.
302MESSAGE("-- Check for CXSparse")
303SET(CXSPARSE_FOUND ON)
304
305FIND_LIBRARY(CXSPARSE_LIB NAMES cxsparse PATHS ${CXSPARSE_SEARCH_LIBS})
306IF (EXISTS ${CXSPARSE_LIB})
307 MESSAGE("-- Found CXSparse library in: ${CXSPARSE_LIB}")
308ELSE (EXISTS ${CXSPARSE_LIB})
309 MESSAGE("-- Did not find CXSparse header")
310 SET(CXSPARSE_FOUND FALSE)
311ENDIF (EXISTS ${CXSPARSE_LIB})
312
313FIND_PATH(CXSPARSE_INCLUDE NAMES cs.h PATHS ${CXSPARSE_SEARCH_HEADERS})
314IF (EXISTS ${CXSPARSE_INCLUDE})
315 MESSAGE("-- Found CXSparse header in: ${CXSPARSE_INCLUDE}")
316ELSE (EXISTS ${CXSPARSE_INCLUDE})
317 MESSAGE("-- Did not find CXSparse header")
318 SET(CXSPARSE_FOUND FALSE)
319ENDIF (EXISTS ${CXSPARSE_INCLUDE})
320
321IF (DEFINED CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700322 IF (${CXSPARSE})
323 IF (NOT ${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700324 MESSAGE(FATAL_ERROR "-- CXSparse not found.")
Sameer Agarwald1146902012-05-30 01:40:22 -0700325 ENDIF (NOT ${CXSPARSE_FOUND})
326 ELSE (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700327 ADD_DEFINITIONS(-DCERES_NO_CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700328 ENDIF (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700329ELSE (DEFINED CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700330 IF (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700331 MESSAGE("-- Building with CXSparse support.")
332 SET(CXSPARSE ON)
Sameer Agarwald1146902012-05-30 01:40:22 -0700333 ELSE (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700334 MESSAGE("-- Building without CXSparse.")
335 SET(CXSPARSE OFF)
336 ADD_DEFINITIONS(-DCERES_NO_CXSPARSE)
Sameer Agarwald1146902012-05-30 01:40:22 -0700337 ENDIF (${CXSPARSE_FOUND})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700338ENDIF (DEFINED CXSPARSE)
339
Keir Mierle8ebb0732012-04-30 23:09:08 -0700340# Google Flags
341OPTION(GFLAGS
342 "Enable Google Flags."
343 ON)
344
Sameer Agarwald1146902012-05-30 01:40:22 -0700345IF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700346 MESSAGE("-- Check for Google Flags")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700347 FIND_LIBRARY(GFLAGS_LIB NAMES gflags PATHS ${SEARCH_LIBS})
348 IF (NOT EXISTS ${GFLAGS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700349 MESSAGE(FATAL_ERROR
350 "Can't find Google Flags. Please specify: "
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700351 "-DGFLAGS_LIB=...")
352 ENDIF (NOT EXISTS ${GFLAGS_LIB})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700353 MESSAGE("-- Found Google Flags library: ${GFLAGS_LIB}")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700354 FIND_PATH(GFLAGS_INCLUDE NAMES gflags/gflags.h PATHS ${SEARCH_HEADERS})
355 IF (NOT EXISTS ${GFLAGS_INCLUDE})
356 MESSAGE(FATAL_ERROR
357 "Can't find Google Flags. Please specify: "
358 "-DGFLAGS_INCLUDE=...")
359 ENDIF (NOT EXISTS ${GFLAGS_INCLUDE})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700360 MESSAGE("-- Found Google Flags header in: ${GFLAGS_INCLUDE}")
Sameer Agarwald1146902012-05-30 01:40:22 -0700361ELSE (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700362 MESSAGE("-- Google Flags disabled; no tests or tools will be built!")
363 ADD_DEFINITIONS(-DCERES_NO_GFLAGS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700364ENDIF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700365
366# Google Logging
Keir Mierleaefb8a82012-07-28 13:23:55 -0700367IF (NOT ${BUILD_ANDROID})
368 MESSAGE("-- Check for Google Log")
369 FIND_LIBRARY(GLOG_LIB NAMES glog PATHS ${SEARCH_LIBS})
370 IF (NOT EXISTS ${GLOG_LIB})
371 MESSAGE(FATAL_ERROR
372 "Can't find Google Log. Please specify: "
373 "-DGLOG_LIB=...")
374 ENDIF (NOT EXISTS ${GLOG_LIB})
375 MESSAGE("-- Found Google Log library: ${GLOG_LIB}")
Sameer Agarwalaa9526d2012-05-08 21:22:09 -0700376
Keir Mierleaefb8a82012-07-28 13:23:55 -0700377 FIND_PATH(GLOG_INCLUDE NAMES glog/logging.h PATHS ${SEARCH_HEADERS})
378 IF (NOT EXISTS ${GLOG_INCLUDE})
379 MESSAGE(FATAL_ERROR
380 "Can't find Google Log. Please specify: "
381 "-DGLOG_INCLUDE=...")
382 ENDIF (NOT EXISTS ${GLOG_INCLUDE})
383 MESSAGE("-- Found Google Log header in: ${GLOG_INCLUDE}")
384ELSE (NOT ${BUILD_ANDROID})
385 SET(GLOG_LIB miniglog)
386 MESSAGE("-- Using minimal Glog substitute for Android (library): ${GLOG_LIB}")
387 SET(GLOG_INCLUDE internal/ceres/miniglog)
388 MESSAGE("-- Using minimal Glog substitute for Android (include): ${GLOG_INCLUDE}")
389ENDIF (NOT ${BUILD_ANDROID})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700390
391# Eigen
392MESSAGE("-- Check for Eigen 3.0")
Keir Mierlef477a382012-05-01 18:10:48 -0700393FIND_PATH(EIGEN_INCLUDE NAMES Eigen/Core PATHS ${EIGEN_SEARCH_HEADERS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700394IF (NOT EXISTS ${EIGEN_INCLUDE})
Keir Mierlef477a382012-05-01 18:10:48 -0700395 MESSAGE(FATAL_ERROR "Can't find Eigen. Try passing -DEIGEN_INCLUDE=...")
Keir Mierle8ebb0732012-04-30 23:09:08 -0700396ENDIF (NOT EXISTS ${EIGEN_INCLUDE})
397MESSAGE("-- Found Eigen 3.0: ${EIGEN_INCLUDE}")
398
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700399# Template specializations for the Schur complement based solvers. If
400# compile time, binary size or compiler performance is an issue, you
401# may consider disabling this.
Keir Mierle8ebb0732012-04-30 23:09:08 -0700402OPTION(SCHUR_SPECIALIZATIONS
403 "Enable fixed-size schur specializations."
404 ON)
405
Sameer Agarwald1146902012-05-30 01:40:22 -0700406IF (NOT ${SCHUR_SPECIALIZATIONS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700407 ADD_DEFINITIONS(-DCERES_RESTRICT_SCHUR_SPECIALIZATION)
Keir Mierlef10163a2012-05-04 21:33:53 -0700408 MESSAGE("-- Disabling Schur specializations (faster compiles)")
Sameer Agarwald1146902012-05-30 01:40:22 -0700409ENDIF (NOT ${SCHUR_SPECIALIZATIONS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700410
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700411# Multithreading using OpenMP
Keir Mierle8ebb0732012-04-30 23:09:08 -0700412OPTION(OPENMP
413 "Enable threaded solving in Ceres (requires OpenMP)"
414 ON)
415
Sameer Agarwald1146902012-05-30 01:40:22 -0700416IF (${OPENMP})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700417 FIND_PACKAGE(OpenMP)
Sameer Agarwald1146902012-05-30 01:40:22 -0700418 IF(${OPENMP_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700419 MESSAGE("-- Found OpenMP.")
420 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OpenMP_CXX_FLAGS}")
421 ADD_DEFINITIONS(-DCERES_USE_OPENMP)
Sameer Agarwald1146902012-05-30 01:40:22 -0700422 ELSE(${OPENMP_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700423 MESSAGE("-- Can't find OpenMP. Continuing without it.")
Sameer Agarwald1146902012-05-30 01:40:22 -0700424 ENDIF(${OPENMP_FOUND})
425ENDIF (${OPENMP})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700426
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700427# Protocol buffers
Keir Mierle8ebb0732012-04-30 23:09:08 -0700428OPTION(PROTOBUF
429 "Enable protocol buffers support."
430 ON)
431
Sameer Agarwald1146902012-05-30 01:40:22 -0700432IF (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700433 FIND_PACKAGE(Protobuf)
Sameer Agarwald1146902012-05-30 01:40:22 -0700434 IF (${PROTOBUF_FOUND})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700435 INCLUDE_DIRECTORIES(${PROTOBUF_INCLUDE_DIRS})
436 INCLUDE_DIRECTORIES(${CMAKE_CURRENT_BINARY_DIR}/internal)
Sameer Agarwald1146902012-05-30 01:40:22 -0700437 ELSE (${PROTOBUF_FOUND})
Sameer Agarwaldd2b17d2012-08-16 19:34:57 -0700438 ADD_DEFINITIONS(-DCERES_NO_PROTOCOL_BUFFERS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700439 ENDIF (${PROTOBUF_FOUND})
440ELSE (${PROTOBUF})
Sameer Agarwaldd2b17d2012-08-16 19:34:57 -0700441 ADD_DEFINITIONS(-DCERES_NO_PROTOCOL_BUFFERS)
Sameer Agarwald1146902012-05-30 01:40:22 -0700442ENDIF (${PROTOBUF})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700443
Keir Mierleaefb8a82012-07-28 13:23:55 -0700444
445# Use threads but not on Android, where there is no support for OpenMP yet.
Keir Mierle254f9d32012-08-02 21:18:49 -0700446IF ("${UNIX}" AND NOT ${BUILD_ANDROID})
Keir Mierleaefb8a82012-07-28 13:23:55 -0700447 # At least on Linux, we need pthreads to be enabled for mutex to compile.
448 # This may not work on windows or android.
Keir Mierle8ebb0732012-04-30 23:09:08 -0700449 FIND_PACKAGE(Threads REQUIRED)
450 SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_THREAD_LIBS_INIT}")
451 ADD_DEFINITIONS(-DCERES_HAVE_PTHREAD)
452 ADD_DEFINITIONS(-DCERES_HAVE_RWLOCK)
Keir Mierle254f9d32012-08-02 21:18:49 -0700453ENDIF ("${UNIX}" AND NOT ${BUILD_ANDROID})
Keir Mierleaefb8a82012-07-28 13:23:55 -0700454
455# Disable threads in mutex.h. Someday, after there is OpenMP support in
456# Android, this can get removed.
457IF (${BUILD_ANDROID})
Keir Mierleff71d742012-08-10 17:05:15 -0700458 ADD_DEFINITIONS(-DCERES_NO_THREADS)
Keir Mierleaefb8a82012-07-28 13:23:55 -0700459ENDIF (${BUILD_ANDROID})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700460
Keir Mierled2164902012-08-15 19:04:50 -0700461OPTION(DISABLE_TR1
462 "Don't use TR1. This replaces some hash tables with sets. Slower."
463 OFF)
464
465IF (${DISABLE_TR1})
466 MESSAGE("-- Replacing unordered_map/set with map/set (warning: slower!)")
467 ADD_DEFINITIONS(-DCERES_NO_TR1)
468ELSE (${DISABLE_TR1})
469 MESSAGE("-- Using normal TR1 unordered_map/set")
470 # Use the std namespace for the hash<> and related templates. This may vary by
471 # system.
472 IF (MSVC)
473 # This is known to work with Visual Studio 2010 Express.
474 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_START=namespace std {\"")
475 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_END=}\"")
476 ELSE (MSVC)
477 # This is known to work with recent versions of Linux and Mac OS X.
478 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_START=namespace std { namespace tr1 {\"")
479 ADD_DEFINITIONS("\"-DCERES_HASH_NAMESPACE_END=}}\"")
480 ENDIF (MSVC)
481ENDIF (${DISABLE_TR1})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700482
483INCLUDE_DIRECTORIES(
484 include
485 internal
486 internal/ceres
Keir Mierle8ebb0732012-04-30 23:09:08 -0700487 ${GLOG_INCLUDE}
Keir Mierle8ebb0732012-04-30 23:09:08 -0700488 ${EIGEN_INCLUDE}
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700489 )
490
Sameer Agarwald1146902012-05-30 01:40:22 -0700491IF (${SUITESPARSE})
Markus Mollc497bd62012-08-17 14:40:13 +0200492 INCLUDE_DIRECTORIES(${AMD_INCLUDE})
493 INCLUDE_DIRECTORIES(${CAMD_INCLUDE})
494 INCLUDE_DIRECTORIES(${COLAMD_INCLUDE})
495 INCLUDE_DIRECTORIES(${CCOLAMD_INCLUDE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700496 INCLUDE_DIRECTORIES(${CHOLMOD_INCLUDE})
Markus Mollc497bd62012-08-17 14:40:13 +0200497 IF (${SUITESPARSE_CONFIG_FOUND})
498 INCLUDE_DIRECTORIES(${SUITESPARSE_CONFIG_INCLUDE})
499 ENDIF (${SUITESPARSE_CONFIG_FOUND})
500 IF (${UFCONFIG_FOUND})
501 INCLUDE_DIRECTORIES(${UFCONFIG_INCLUDE})
502 ENDIF (${UFCONFIG_FOUND})
Sameer Agarwald1146902012-05-30 01:40:22 -0700503ENDIF(${SUITESPARSE})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700504
Sameer Agarwald1146902012-05-30 01:40:22 -0700505IF (${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700506 INCLUDE_DIRECTORIES(${CXSPARSE_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700507ENDIF(${CXSPARSE})
Sameer Agarwalb0518732012-05-29 00:27:57 -0700508
Sameer Agarwald1146902012-05-30 01:40:22 -0700509IF (${GFLAGS})
Sameer Agarwaldaa98242012-05-11 11:26:38 -0700510 INCLUDE_DIRECTORIES(${GFLAGS_INCLUDE})
Sameer Agarwald1146902012-05-30 01:40:22 -0700511ENDIF (${GFLAGS})
Keir Mierle8ebb0732012-04-30 23:09:08 -0700512
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700513# Change the default build type from Debug to Release, while still
514# supporting overriding the build type.
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700515#
516# The CACHE STRING logic here and elsewhere is needed to force CMake
517# to pay attention to the value of these variables.
518IF (NOT CMAKE_BUILD_TYPE)
519 MESSAGE("-- No build type specified; defaulting to CMAKE_BUILD_TYPE=Release.")
520 SET(CMAKE_BUILD_TYPE Release CACHE STRING
521 "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel."
522 FORCE)
523ELSE (NOT CMAKE_BUILD_TYPE)
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700524 IF (CMAKE_BUILD_TYPE STREQUAL "Debug")
525 MESSAGE("\n=================================================================================")
526 MESSAGE("\n-- Build type: Debug. Performance will be terrible!")
527 MESSAGE("-- Add -DCMAKE_BUILD_TYPE=Release to the CMake command line to get an optimized build.")
528 MESSAGE("\n=================================================================================")
Sameer Agarwal8e2420e2012-05-31 17:00:58 -0700529 ENDIF (CMAKE_BUILD_TYPE STREQUAL "Debug")
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700530ENDIF (NOT CMAKE_BUILD_TYPE)
531
532# Set the default Ceres flags to an empty string.
533SET (CERES_CXX_FLAGS)
534
535IF (CMAKE_BUILD_TYPE STREQUAL "Release")
536 IF (CMAKE_COMPILER_IS_GNUCXX)
Keir Mierleaefb8a82012-07-28 13:23:55 -0700537 IF (${BUILD_ANDROID})
538 # TODO(keir): Figure out what flags should go here to make an optimized
539 # native ARM binary for Android.
540 ELSE (${BUILD_ANDROID})
541 # Linux
542 IF (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
543 SET (CERES_CXX_FLAGS "${CERES_CXX_FLAGS} -march=native -mtune=native")
544 ENDIF (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
545 # Mac OS X
546 IF (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
547 SET (CERES_CXX_FLAGS "${CERES_CXX_FLAGS} -fast -msse3")
548 ENDIF (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
549 ENDIF (${BUILD_ANDROID})
Sameer Agarwal4845bc42012-06-05 21:32:57 -0700550 ENDIF (CMAKE_COMPILER_IS_GNUCXX)
551 SET (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} ${CERES_CXX_FLAGS}"
552 CACHE STRING "Release mode flags to the C++ Compiler" FORCE)
553ENDIF (CMAKE_BUILD_TYPE STREQUAL "Release")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700554
555# After the tweaks for the compile settings, disable some warnings on MSVC.
556IF (MSVC)
557 # Disable signed/unsigned int conversion warnings.
Keir Mierleaefb8a82012-07-28 13:23:55 -0700558 ADD_DEFINITIONS("/wd4018")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700559 # Disable warning about using struct/class for the same symobl.
Keir Mierleaefb8a82012-07-28 13:23:55 -0700560 ADD_DEFINITIONS("/wd4099")
Keir Mierleefe7ac62012-06-24 22:25:28 -0700561 # Disable warning about the insecurity of using "std::copy".
562 ADD_DEFINITIONS("/wd4996")
563 # Disable performance warning about int-to-bool conversion.
564 ADD_DEFINITIONS("/wd4800")
565 # Disable performance warning about fopen insecurity.
566 ADD_DEFINITIONS("/wd4996")
567 # Disable warning about int64 to int32 conversion. Disabling
568 # this warning may not be correct; needs investigation.
569 # TODO(keir): Investigate these warnings in more detail.
570 ADD_DEFINITIONS("/wd4244")
571 # It's not possible to use STL types in DLL interfaces in a portable and
572 # reliable way. However, that's what happens with Google Log and Google Flags
573 # on Windows. MSVC gets upset about this and throws warnings that we can't do
574 # much about. The real solution is to link static versions of Google Log and
575 # Google Test, but that seems tricky on Windows. So, disable the warning.
576 ADD_DEFINITIONS("/wd4251")
577
578 # Google Flags doesn't have their DLL import/export stuff set up correctly,
579 # which results in linker warnings. This is irrelevant for Ceres, so ignore
580 # the warnings.
581 SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /ignore:4049")
582ENDIF (MSVC)
583
584ADD_SUBDIRECTORY(internal/ceres)
585ADD_SUBDIRECTORY(examples)
Arnaud Gelasb12b9062012-08-15 16:27:38 +0200586
587OPTION(BUILD_DOCUMENTATION
588 "Build User's Guide (pdf)"
589 OFF)
590
591IF (${BUILD_DOCUMENTATION})
592 MESSAGE("-- Documentation building is enabled")
593
594 # Generate the User's Guide (pdf).
595 # The corresponding target is UserGuide, but is included in ALL.
596 ADD_SUBDIRECTORY(docs)
597ENDIF (${BUILD_DOCUMENTATION})