blob: b51380a07210b6b73020294e3052efae8c8aa491 [file] [log] [blame]
.. _chapter-modeling_faqs:
.. default-domain:: cpp
.. cpp:namespace:: ceres
========
Modeling
========
Use analytical/automatic derivatives
====================================
This is the single most important piece of advice we can give to you. It is
tempting to take the easy way out and use numeric differentiation. This is a bad
idea. Numeric differentiation is slow, ill-behaved, hard to get right, and
results in poor convergence behaviour.
Ceres allows the user to define templated functors which will be automatically
differentiated. For most situations this is enough and we recommend using this
facility. In some cases the derivatives are simple enough or the performance
considerations are such that the overhead of automatic differentiation is too
much. In such cases, analytic derivatives are recommended.
The use of numerical derivatives should be a measure of last resort, where it is
simply not possible to write a templated implementation of the cost function.
In many cases it is not possible to do analytic or automatic differentiation of
the entire cost function, but it is generally the case that it is possible to
decompose the cost function into parts that need to be numerically
differentiated and parts that can be automatically or analytically
differentiated.
To this end, Ceres has extensive support for mixing analytic, automatic and
numeric differentiation. See :class:`CostFunctionToFunctor`.
When using Quaternions, consider using :class:`QuaternionManifold`
==================================================================
`Quaternions <https://en.wikipedia.org/wiki/Quaternion>`_ are a four dimensional
parameterization of the space of three dimensional rotations :math:`SO(3)`.
However, the :math:`SO(3)` is a three dimensional set, and so is the tangent
space of a Quaternion. Therefore, it is sometimes (not always) beneficial to
associate a local parameterization with parameter blocks representing a
Quaternion. Assuming that the order of entries in your parameter block is
:math:`w,x,y,z`, you can use :class:`QuaternionManifold`.
.. NOTE::
If you are using `Eigen's Quaternion
<http://eigen.tuxfamily.org/dox/classEigen_1_1Quaternion.html>`_
object, whose layout is :math:`x,y,z,w`, then you should use
:class:`EigenQuaternionManifold`.
How do I solve problems with general linear & non-linear **inequality** constraints with Ceres Solver?
======================================================================================================
Currently, Ceres Solver only supports upper and lower bounds constraints on the
parameter blocks.
A crude way of dealing with inequality constraints is have one or more of your
cost functions check if the inequalities you are interested in are satisfied,
and if not return false instead of true. This will prevent the solver from ever
stepping into an infeasible region.
This requires that the starting point for the optimization be a feasible point.
You also risk pre-mature convergence using this method.
How do I solve problems with general linear & non-linear **equality** constraints with Ceres Solver?
====================================================================================================
There is no built in support in ceres for solving problems with equality
constraints. Currently, Ceres Solver only supports upper and lower bounds
constraints on the parameter blocks.
The trick described above for dealing with inequality constraints will **not**
work for equality constraints.
How do I set one or more components of a parameter block constant?
==================================================================
Using :class:`SubsetManifold`.