aboutsummaryrefslogtreecommitdiff
path: root/internal/ceres/CMakeLists.txt
diff options
context:
space:
mode:
Diffstat (limited to 'internal/ceres/CMakeLists.txt')
-rw-r--r--internal/ceres/CMakeLists.txt264
1 files changed, 264 insertions, 0 deletions
diff --git a/internal/ceres/CMakeLists.txt b/internal/ceres/CMakeLists.txt
new file mode 100644
index 0000000..adad6dc
--- /dev/null
+++ b/internal/ceres/CMakeLists.txt
@@ -0,0 +1,264 @@
+# Ceres Solver - A fast non-linear least squares minimizer
+# Copyright 2010, 2011, 2012 Google Inc. All rights reserved.
+# http://code.google.com/p/ceres-solver/
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are met:
+#
+# * Redistributions of source code must retain the above copyright notice,
+# this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above copyright notice,
+# this list of conditions and the following disclaimer in the documentation
+# and/or other materials provided with the distribution.
+# * Neither the name of Google Inc. nor the names of its contributors may be
+# used to endorse or promote products derived from this software without
+# specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# Author: keir@google.com (Keir Mierle)
+
+SET(CERES_INTERNAL_SRC
+ array_utils.cc
+ block_evaluate_preparer.cc
+ block_jacobi_preconditioner.cc
+ block_jacobian_writer.cc
+ block_random_access_dense_matrix.cc
+ block_random_access_matrix.cc
+ block_random_access_sparse_matrix.cc
+ block_sparse_matrix.cc
+ block_structure.cc
+ canonical_views_clustering.cc
+ cgnr_solver.cc
+ compressed_row_jacobian_writer.cc
+ compressed_row_sparse_matrix.cc
+ conditioned_cost_function.cc
+ conjugate_gradients_solver.cc
+ coordinate_descent_minimizer.cc
+ corrector.cc
+ cxsparse.cc
+ dense_normal_cholesky_solver.cc
+ dense_qr_solver.cc
+ dense_sparse_matrix.cc
+ detect_structure.cc
+ dogleg_strategy.cc
+ evaluator.cc
+ file.cc
+ gradient_checking_cost_function.cc
+ implicit_schur_complement.cc
+ iterative_schur_complement_solver.cc
+ levenberg_marquardt_strategy.cc
+ linear_least_squares_problems.cc
+ linear_operator.cc
+ linear_solver.cc
+ local_parameterization.cc
+ loss_function.cc
+ normal_prior.cc
+ parameter_block_ordering.cc
+ partitioned_matrix_view.cc
+ polynomial_solver.cc
+ problem.cc
+ problem_impl.cc
+ program.cc
+ residual_block.cc
+ residual_block_utils.cc
+ runtime_numeric_diff_cost_function.cc
+ schur_complement_solver.cc
+ schur_eliminator.cc
+ scratch_evaluate_preparer.cc
+ solver.cc
+ solver_impl.cc
+ sparse_matrix.cc
+ sparse_normal_cholesky_solver.cc
+ split.cc
+ stringprintf.cc
+ suitesparse.cc
+ triplet_sparse_matrix.cc
+ trust_region_minimizer.cc
+ trust_region_strategy.cc
+ types.cc
+ visibility.cc
+ visibility_based_preconditioner.cc
+ wall_time.cc
+)
+
+If (${PROTOBUF_FOUND})
+ PROTOBUF_GENERATE_CPP(PROTO_SRCS PROTO_HDRS matrix.proto)
+ENDIF (${PROTOBUF_FOUND})
+
+# Also depend on the header files so that they appear in IDEs.
+FILE(GLOB CERES_INTERNAL_HDRS *.h)
+
+# Include the specialized schur solvers.
+IF (${SCHUR_SPECIALIZATIONS})
+ FILE(GLOB CERES_INTERNAL_SCHUR_FILES generated/*.cc)
+ELSE (${SCHUR_SPECIALIZATIONS})
+ # Only the fully dynamic solver. The build is much faster this way.
+ FILE(GLOB CERES_INTERNAL_SCHUR_FILES generated/schur_eliminator_d_d_d.cc)
+ENDIF (${SCHUR_SPECIALIZATIONS})
+
+# For Android, use the internal Glog implementation.
+IF (${BUILD_ANDROID})
+ ADD_LIBRARY(miniglog STATIC
+ miniglog/glog/logging.cc)
+
+ # The Android logging library that defines e.g. __android_log_print is
+ # creatively named "log".
+ TARGET_LINK_LIBRARIES(miniglog log)
+
+ INSTALL(TARGETS miniglog
+ RUNTIME DESTINATION bin
+ LIBRARY DESTINATION lib
+ ARCHIVE DESTINATION lib)
+ENDIF (${BUILD_ANDROID})
+
+SET(CERES_LIBRARY_DEPENDENCIES ${GLOG_LIB})
+
+IF (${GFLAGS})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${GFLAGS_LIB})
+ENDIF (${GFLAGS})
+
+IF (${SUITESPARSE_FOUND})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CHOLMOD_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CCOLAMD_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CAMD_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${COLAMD_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${AMD_LIB})
+ IF (EXISTS ${SUITESPARSE_CONFIG_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${SUITESPARSE_CONFIG_LIB})
+ ENDIF (EXISTS ${SUITESPARSE_CONFIG_LIB})
+
+ IF (EXISTS ${METIS_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${METIS_LIB})
+ ENDIF (EXISTS ${METIS_LIB})
+
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${LAPACK_LIB})
+
+ IF (EXISTS ${BLAS_LIB})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${BLAS_LIB})
+ ENDIF (EXISTS ${BLAS_LIB})
+ENDIF (${SUITESPARSE_FOUND})
+
+IF (${CXSPARSE_FOUND})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${CXSPARSE_LIB})
+ENDIF (${CXSPARSE_FOUND})
+
+IF (${OPENMP_FOUND})
+ IF (NOT MSVC)
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES gomp)
+ ENDIF (NOT MSVC)
+ENDIF (${OPENMP_FOUND})
+
+IF (${PROTOBUF_FOUND})
+ LIST(APPEND CERES_LIBRARY_DEPENDENCIES ${PROTOBUF_LIBRARY})
+ENDIF (${PROTOBUF_FOUND})
+
+SET(CERES_LIBRARY_SOURCE
+ ${PROTO_SRCS}
+ ${PROTO_HDRS}
+ ${CERES_INTERNAL_SRC}
+ ${CERES_INTERNAL_HDRS}
+ ${CERES_INTERNAL_SCHUR_FILES})
+
+ADD_LIBRARY(ceres STATIC ${CERES_LIBRARY_SOURCE})
+TARGET_LINK_LIBRARIES(ceres ${CERES_LIBRARY_DEPENDENCIES})
+
+INSTALL(TARGETS ceres
+ RUNTIME DESTINATION bin
+ LIBRARY DESTINATION lib
+ ARCHIVE DESTINATION lib)
+
+# Don't build a DLL on MSVC. Supporting Ceres as a DLL on Windows involves
+# nontrivial changes that we haven't made yet.
+IF (NOT MSVC AND NOT ${BUILD_ANDROID})
+ ADD_LIBRARY(ceres_shared SHARED ${CERES_LIBRARY_SOURCE})
+ TARGET_LINK_LIBRARIES(ceres_shared ${CERES_LIBRARY_DEPENDENCIES})
+ SET_TARGET_PROPERTIES(ceres_shared PROPERTIES
+ VERSION ${CERES_VERSION}
+ SOVERSION ${CERES_ABI_VERSION})
+
+ INSTALL(TARGETS ceres_shared
+ RUNTIME DESTINATION bin
+ LIBRARY DESTINATION lib
+ ARCHIVE DESTINATION lib)
+
+ENDIF (NOT MSVC AND NOT ${BUILD_ANDROID})
+
+IF (${BUILD_TESTING} AND ${GFLAGS})
+ ADD_LIBRARY(gtest gmock_gtest_all.cc gmock_main.cc)
+ ADD_LIBRARY(test_util test_util.cc)
+ TARGET_LINK_LIBRARIES(gtest ${GFLAGS_LIB} ${GLOG_LIB})
+
+ MACRO (CERES_TEST NAME)
+ ADD_EXECUTABLE(${NAME}_test ${NAME}_test.cc)
+ TARGET_LINK_LIBRARIES(${NAME}_test test_util ceres gtest)
+ ADD_TEST(NAME ${NAME}_test
+ COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${NAME}_test
+ --test_srcdir
+ ${CMAKE_SOURCE_DIR}/data)
+ ENDMACRO (CERES_TEST)
+
+ CERES_TEST(array_utils)
+ CERES_TEST(autodiff)
+ CERES_TEST(autodiff_cost_function)
+ CERES_TEST(block_random_access_dense_matrix)
+ CERES_TEST(block_random_access_sparse_matrix)
+ CERES_TEST(block_sparse_matrix)
+ CERES_TEST(canonical_views_clustering)
+ CERES_TEST(compressed_row_sparse_matrix)
+ CERES_TEST(conditioned_cost_function)
+ CERES_TEST(corrector)
+ CERES_TEST(dense_sparse_matrix)
+ CERES_TEST(evaluator)
+ CERES_TEST(gradient_checker)
+ CERES_TEST(gradient_checking_cost_function)
+ CERES_TEST(graph)
+ CERES_TEST(graph_algorithms)
+ CERES_TEST(implicit_schur_complement)
+ CERES_TEST(iterative_schur_complement_solver)
+ CERES_TEST(jet)
+ CERES_TEST(levenberg_marquardt_strategy)
+ CERES_TEST(dogleg_strategy)
+ CERES_TEST(local_parameterization)
+ CERES_TEST(loss_function)
+ CERES_TEST(minimizer)
+ CERES_TEST(normal_prior)
+ CERES_TEST(numeric_diff_cost_function)
+ CERES_TEST(ordered_groups)
+ CERES_TEST(parameter_block)
+ CERES_TEST(parameter_block_ordering)
+ CERES_TEST(partitioned_matrix_view)
+ CERES_TEST(polynomial_solver)
+ CERES_TEST(problem)
+ CERES_TEST(residual_block)
+ CERES_TEST(residual_block_utils)
+ CERES_TEST(rotation)
+ CERES_TEST(runtime_numeric_diff_cost_function)
+ CERES_TEST(schur_complement_solver)
+ CERES_TEST(schur_eliminator)
+ CERES_TEST(solver_impl)
+
+ IF (${SUITESPARSE_FOUND})
+ CERES_TEST(suitesparse)
+ ENDIF (${SUITESPARSE_FOUND})
+
+ CERES_TEST(symmetric_linear_solver)
+ CERES_TEST(triplet_sparse_matrix)
+ CERES_TEST(trust_region_minimizer)
+ CERES_TEST(unsymmetric_linear_solver)
+ CERES_TEST(visibility)
+ CERES_TEST(visibility_based_preconditioner)
+
+ # Put the large end to end test last.
+ CERES_TEST(system)
+ENDIF (${BUILD_TESTING} AND ${GFLAGS})