1
# 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/
5
# Redistribution and use in source and binary forms, with or without
6
# modification, are permitted provided that the following conditions are met:
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.
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.
29
# Author: keir@google.com (Keir Mierle)
31
SET(CERES_INTERNAL_SRC
33
block_evaluate_preparer.cc
34
block_jacobi_preconditioner.cc
35
block_jacobian_writer.cc
36
block_random_access_dense_matrix.cc
37
block_random_access_matrix.cc
38
block_random_access_sparse_matrix.cc
39
block_sparse_matrix.cc
41
canonical_views_clustering.cc
43
compressed_row_jacobian_writer.cc
44
compressed_row_sparse_matrix.cc
45
conditioned_cost_function.cc
46
conjugate_gradients_solver.cc
49
dense_sparse_matrix.cc
53
gradient_checking_cost_function.cc
54
implicit_schur_complement.cc
55
iterative_schur_complement_solver.cc
56
levenberg_marquardt.cc
57
linear_least_squares_problems.cc
60
local_parameterization.cc
63
partitioned_matrix_view.cc
68
residual_block_utils.cc
69
runtime_numeric_diff_cost_function.cc
70
schur_complement_solver.cc
73
scratch_evaluate_preparer.cc
77
sparse_normal_cholesky_solver.cc
81
triplet_sparse_matrix.cc
83
visibility_based_preconditioner.cc
88
PROTOBUF_GENERATE_CPP(PROTO_SRCS PROTO_HDRS matrix.proto)
89
ENDIF (PROTOBUF_FOUND)
91
# Also depend on the header files so that they appear in IDEs.
92
FILE(GLOB CERES_INTERNAL_HDRS *.h)
94
# Include the specialized schur solvers.
95
IF (SCHUR_SPECIALIZATIONS)
96
FILE(GLOB CERES_INTERNAL_SCHUR_FILES generated/*.cc)
97
ELSE (SCHUR_SPECIALIZATIONS)
98
# Only the fully dynamic solver.
99
FILE(GLOB CERES_INTERNAL_SCHUR_FILES generated/schur_eliminator_d_d_d.cc)
100
ENDIF (SCHUR_SPECIALIZATIONS)
105
${CERES_INTERNAL_SRC}
106
${CERES_INTERNAL_HDRS}
107
${CERES_INTERNAL_SCHUR_FILES})
109
SET(CERES_LIBRARY_DEPENDENCIES ${GLOG_LIB})
112
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${GFLAGS_LIB})
116
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CHOLMOD_LIB})
117
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CCOLCAMD_LIB})
118
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CAMD_LIB})
119
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${COLAMD_LIB})
120
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${AMD_LIB})
122
IF (EXISTS ${METIS_LIB})
123
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${METIS_LIB})
124
ENDIF (EXISTS ${METIS_LIB})
126
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${LAPACK_LIB})
128
IF (EXISTS ${BLAS_LIB})
129
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${BLAS_LIB})
130
ENDIF (EXISTS ${BLAS_LIB})
134
LIST(APPEND CERES_LIBRARY_DEPENDENCIES gomp)
138
LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${PROTOBUF_LIBRARY})
139
ENDIF (PROTOBUF_FOUND)
141
TARGET_LINK_LIBRARIES(ceres ${CERES_LIBRARY_DEPENDENCIES})
144
ADD_LIBRARY(gtest gmock_gtest_all.cc gmock_main.cc)
145
ADD_LIBRARY(test_util test_util.cc)
146
TARGET_LINK_LIBRARIES(gtest ${GFLAGS_LIB} ${GLOG_LIB})
148
MACRO (CERES_TEST NAME)
149
ADD_EXECUTABLE(${NAME}_test ${NAME}_test.cc)
150
TARGET_LINK_LIBRARIES(${NAME}_test test_util ceres gtest)
151
ADD_TEST(${NAME}_test
154
${CMAKE_SOURCE_DIR}/data)
155
ENDMACRO (CERES_TEST)
157
CERES_TEST(array_utils)
159
CERES_TEST(autodiff_cost_function)
160
CERES_TEST(block_random_access_dense_matrix)
161
CERES_TEST(block_random_access_sparse_matrix)
162
CERES_TEST(block_sparse_matrix)
163
CERES_TEST(canonical_views_clustering)
164
CERES_TEST(compressed_row_sparse_matrix)
165
CERES_TEST(conditioned_cost_function)
166
CERES_TEST(corrector)
167
CERES_TEST(dense_sparse_matrix)
168
CERES_TEST(evaluator)
169
CERES_TEST(gradient_checking_cost_function)
171
CERES_TEST(graph_algorithms)
172
CERES_TEST(implicit_schur_complement)
173
CERES_TEST(iterative_schur_complement_solver)
175
CERES_TEST(levenberg_marquardt)
176
CERES_TEST(local_parameterization)
177
CERES_TEST(loss_function)
178
CERES_TEST(normal_prior)
179
CERES_TEST(numeric_diff_cost_function)
180
CERES_TEST(parameter_block)
181
CERES_TEST(partitioned_matrix_view)
183
CERES_TEST(residual_block)
184
CERES_TEST(residual_block_utils)
186
CERES_TEST(runtime_numeric_diff_cost_function)
187
CERES_TEST(schur_complement_solver)
189
CERES_TEST(schur_eliminator)
191
CERES_TEST(schur_ordering)
192
CERES_TEST(solver_impl)
193
CERES_TEST(symmetric_linear_solver)
197
CERES_TEST(triplet_sparse_matrix)
198
CERES_TEST(unsymmetric_linear_solver)
199
CERES_TEST(visibility)
201
CERES_TEST(visibility_based_preconditioner)
203
ENDIF (BUILD_TESTING)