| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 | // Ceres Solver - A fast non-linear least squares minimizer// Copyright 2015 Google Inc. All rights reserved.// http://ceres-solver.org///// 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: sameeragarwal@google.com (Sameer Agarwal)//         keir@google.com (Keir Mierle)#include "ceres/problem.h"#include <vector>#include "ceres/crs_matrix.h"#include "ceres/problem_impl.h"namespace ceres {using std::vector;Problem::Problem() : problem_impl_(new internal::ProblemImpl) {}Problem::Problem(const Problem::Options& options)    : problem_impl_(new internal::ProblemImpl(options)) {}Problem::~Problem() {}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    const vector<double*>& parameter_blocks) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         parameter_blocks);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2, x3);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3, double* x4) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2, x3, x4);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3, double* x4, double* x5) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2, x3, x4, x5);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3, double* x4, double* x5,    double* x6) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2, x3, x4, x5, x6);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3, double* x4, double* x5,    double* x6, double* x7) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2, x3, x4, x5, x6, x7);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3, double* x4, double* x5,    double* x6, double* x7, double* x8) {  return problem_impl_->AddResidualBlock(cost_function,                                         loss_function,                                         x0, x1, x2, x3, x4, x5, x6, x7, x8);}ResidualBlockId Problem::AddResidualBlock(    CostFunction* cost_function,    LossFunction* loss_function,    double* x0, double* x1, double* x2, double* x3, double* x4, double* x5,    double* x6, double* x7, double* x8, double* x9) {  return problem_impl_->AddResidualBlock(      cost_function,      loss_function,      x0, x1, x2, x3, x4, x5, x6, x7, x8, x9);}void Problem::AddParameterBlock(double* values, int size) {  problem_impl_->AddParameterBlock(values, size);}void Problem::AddParameterBlock(double* values,                                int size,                                LocalParameterization* local_parameterization) {  problem_impl_->AddParameterBlock(values, size, local_parameterization);}void Problem::RemoveResidualBlock(ResidualBlockId residual_block) {  problem_impl_->RemoveResidualBlock(residual_block);}void Problem::RemoveParameterBlock(double* values) {  problem_impl_->RemoveParameterBlock(values);}void Problem::SetParameterBlockConstant(double* values) {  problem_impl_->SetParameterBlockConstant(values);}void Problem::SetParameterBlockVariable(double* values) {  problem_impl_->SetParameterBlockVariable(values);}bool Problem::IsParameterBlockConstant(double* values) const {  return problem_impl_->IsParameterBlockConstant(values);}void Problem::SetParameterization(    double* values,    LocalParameterization* local_parameterization) {  problem_impl_->SetParameterization(values, local_parameterization);}const LocalParameterization* Problem::GetParameterization(    double* values) const {  return problem_impl_->GetParameterization(values);}void Problem::SetParameterLowerBound(double* values,                                     int index,                                     double lower_bound) {  problem_impl_->SetParameterLowerBound(values, index, lower_bound);}void Problem::SetParameterUpperBound(double* values,                                     int index,                                     double upper_bound) {  problem_impl_->SetParameterUpperBound(values, index, upper_bound);}bool Problem::Evaluate(const EvaluateOptions& evaluate_options,                       double* cost,                       vector<double>* residuals,                       vector<double>* gradient,                       CRSMatrix* jacobian) {  return problem_impl_->Evaluate(evaluate_options,                                 cost,                                 residuals,                                 gradient,                                 jacobian);}int Problem::NumParameterBlocks() const {  return problem_impl_->NumParameterBlocks();}int Problem::NumParameters() const {  return problem_impl_->NumParameters();}int Problem::NumResidualBlocks() const {  return problem_impl_->NumResidualBlocks();}int Problem::NumResiduals() const {  return problem_impl_->NumResiduals();}int Problem::ParameterBlockSize(const double* parameter_block) const {  return problem_impl_->ParameterBlockSize(parameter_block);}int Problem::ParameterBlockLocalSize(const double* parameter_block) const {  return problem_impl_->ParameterBlockLocalSize(parameter_block);}bool Problem::HasParameterBlock(const double* values) const {  return problem_impl_->HasParameterBlock(values);}void Problem::GetParameterBlocks(vector<double*>* parameter_blocks) const {  problem_impl_->GetParameterBlocks(parameter_blocks);}void Problem::GetResidualBlocks(    vector<ResidualBlockId>* residual_blocks) const {  problem_impl_->GetResidualBlocks(residual_blocks);}void Problem::GetParameterBlocksForResidualBlock(    const ResidualBlockId residual_block,    vector<double*>* parameter_blocks) const {  problem_impl_->GetParameterBlocksForResidualBlock(residual_block,                                                    parameter_blocks);}const CostFunction* Problem::GetCostFunctionForResidualBlock(    const ResidualBlockId residual_block) const {  return problem_impl_->GetCostFunctionForResidualBlock(residual_block);}const LossFunction* Problem::GetLossFunctionForResidualBlock(    const ResidualBlockId residual_block) const {  return problem_impl_->GetLossFunctionForResidualBlock(residual_block);}void Problem::GetResidualBlocksForParameterBlock(    const double* values,    vector<ResidualBlockId>* residual_blocks) const {  problem_impl_->GetResidualBlocksForParameterBlock(values,                                                    residual_blocks);}}  // namespace ceres
 |