| # 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}) |