|  | @@ -1,8 +1,8 @@
 | 
	
		
			
				|  |  | -.. _chapter-building:
 | 
	
		
			
				|  |  | +.. _chapter-installation:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -=======================
 | 
	
		
			
				|  |  | -Building & Installation
 | 
	
		
			
				|  |  | -=======================
 | 
	
		
			
				|  |  | +============
 | 
	
		
			
				|  |  | +Installation
 | 
	
		
			
				|  |  | +============
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Getting the source code
 | 
	
		
			
				|  |  |  =======================
 | 
	
	
		
			
				|  | @@ -37,30 +37,41 @@ optional. For details on customizing the build process, see
 | 
	
		
			
				|  |  |  - `CMake <http://www.cmake.org>`_ 2.8.0 or later.
 | 
	
		
			
				|  |  |    **Required on all platforms except for Android.**
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -- `Google Log <http://code.google.com/p/google-glog>`_ 0.3.1 or
 | 
	
		
			
				|  |  | +- `glog <https://github.com/google/glog>`_ 0.3.1 or
 | 
	
		
			
				|  |  |    later. **Recommended**
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  .. NOTE::
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    Ceres has a minimal replacement of ``glog`` called ``miniglog``
 | 
	
		
			
				|  |  | -    that can be enabled with the ``MINIGLOG`` build
 | 
	
		
			
				|  |  | -    option. ``miniglog`` is needed on Android as ``glog`` currently
 | 
	
		
			
				|  |  | -    does not build using the NDK. It can however be used on other
 | 
	
		
			
				|  |  | -    platforms too.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    **We do not advise using** ``miniglog`` **on platforms other than
 | 
	
		
			
				|  |  | -    Android due to the various performance and functionality
 | 
	
		
			
				|  |  | -    compromises in** ``miniglog``.
 | 
	
		
			
				|  |  | +  ``glog`` is used extensively throughout Ceres for logging detailed
 | 
	
		
			
				|  |  | +  information about memory allocations and time consumed in various
 | 
	
		
			
				|  |  | +  parts of the solve, internal error conditions etc. The Ceres
 | 
	
		
			
				|  |  | +  developers use it extensively to observe and analyze Ceres's
 | 
	
		
			
				|  |  | +  performance. `glog <https://github.com/google/glog>`_ allows you to
 | 
	
		
			
				|  |  | +  control its behaviour from the command line. Starting with
 | 
	
		
			
				|  |  | +  ``-logtostderr`` you can add ``-v=N`` for increasing values of ``N``
 | 
	
		
			
				|  |  | +  to get more and more verbose and detailed information about Ceres
 | 
	
		
			
				|  |  | +  internals.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  Unfortunately, the current version of `google-glog
 | 
	
		
			
				|  |  | +  <https://github.com/google/glog>`_ does not build using the Android
 | 
	
		
			
				|  |  | +  NDK. So, Ceres also ships with a minimal replacement of ``glog``
 | 
	
		
			
				|  |  | +  called ``miniglog`` that can be enabled with the ``MINIGLOG`` build
 | 
	
		
			
				|  |  | +  option.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  So, in an attempt to reduce dependencies, it is tempting to use
 | 
	
		
			
				|  |  | +  `miniglog` on platforms other than Android. While there is nothing
 | 
	
		
			
				|  |  | +  preventing the user from doing so, we strongly recommend against
 | 
	
		
			
				|  |  | +  it. ``miniglog`` has worse performance than ``glog`` and is much
 | 
	
		
			
				|  |  | +  harder to control and use.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    .. NOTE ::
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -     If you are compiling ``glog`` from source, please note that currently,
 | 
	
		
			
				|  |  | -     the unit tests for ``glog`` (which are enabled by default) do not compile
 | 
	
		
			
				|  |  | -     against a default build of ``gflags`` 2.1 as the gflags namespace changed
 | 
	
		
			
				|  |  | -     from ``google::`` to ``gflags::``.  A patch to fix this is available from
 | 
	
		
			
				|  |  | -     `here <https://code.google.com/p/google-glog/issues/detail?id=194>`_.
 | 
	
		
			
				|  |  | +     If you are compiling ``glog`` from source, please note that
 | 
	
		
			
				|  |  | +     currently, the unit tests for ``glog`` (which are enabled by
 | 
	
		
			
				|  |  | +     default) do not compile against a default build of ``gflags`` 2.1
 | 
	
		
			
				|  |  | +     as the gflags namespace changed from ``google::`` to
 | 
	
		
			
				|  |  | +     ``gflags::``.  A patch to fix this is available from `here
 | 
	
		
			
				|  |  | +     <https://code.google.com/p/google-glog/issues/detail?id=194>`_.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -- `Google Flags <http://code.google.com/p/gflags>`_. Needed to build
 | 
	
		
			
				|  |  | +- `gflags <https://github.com/gflags/gflags>`_. Needed to build
 | 
	
		
			
				|  |  |    examples and tests.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  - `SuiteSparse
 | 
	
	
		
			
				|  | @@ -110,8 +121,9 @@ distribution.
 | 
	
		
			
				|  |  |   package repository (built from SuiteSparse v3.4.0) **cannot** be used
 | 
	
		
			
				|  |  |   to build Ceres as a *shared* library.  Thus if you want to build
 | 
	
		
			
				|  |  |   Ceres as a shared library using SuiteSparse, you must perform a
 | 
	
		
			
				|  |  | - source install of SuiteSparse or use an external PPA (see
 | 
	
		
			
				|  |  | - `bug report here <https://bugs.launchpad.net/ubuntu/+source/suitesparse/+bug/1333214>`_).
 | 
	
		
			
				|  |  | + source install of SuiteSparse or use an external PPA (see `bug report
 | 
	
		
			
				|  |  | + here
 | 
	
		
			
				|  |  | + <https://bugs.launchpad.net/ubuntu/+source/suitesparse/+bug/1333214>`_).
 | 
	
		
			
				|  |  |   It is recommended that you use the current version of SuiteSparse
 | 
	
		
			
				|  |  |   (4.2.1 at the time of writing).
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -333,15 +345,16 @@ dependencies.
 | 
	
		
			
				|  |  |   are at least two possible fixes to this problem:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |   #. Use ``google-glog`` and define ``GLOG_NO_ABBREVIATED_SEVERITIES``
 | 
	
		
			
				|  |  | -    when building Ceres and your own project, as documented
 | 
	
		
			
				|  |  | -    `here <http://google-glog.googlecode.com/svn/trunk/doc/glog.html>`__.
 | 
	
		
			
				|  |  | -    Note that this fix will not work for ``miniglog``,
 | 
	
		
			
				|  |  | -    but use of ``miniglog`` is strongly discouraged on any platform for which
 | 
	
		
			
				|  |  | +    when building Ceres and your own project, as documented `here
 | 
	
		
			
				|  |  | +    <http://google-glog.googlecode.com/svn/trunk/doc/glog.html>`__.
 | 
	
		
			
				|  |  | +    Note that this fix will not work for ``miniglog``, but use of
 | 
	
		
			
				|  |  | +    ``miniglog`` is strongly discouraged on any platform for which
 | 
	
		
			
				|  |  |      ``google-glog`` is available (which includes Windows).
 | 
	
		
			
				|  |  | - #. If you do not require GDI, then define ``NOGDI`` **before** including
 | 
	
		
			
				|  |  | -    windows.h.  This solution should work for both ``google-glog`` and
 | 
	
		
			
				|  |  | -    ``miniglog`` and is documented for ``google-glog``
 | 
	
		
			
				|  |  | -    `here <https://code.google.com/p/google-glog/issues/detail?id=33>`__.
 | 
	
		
			
				|  |  | + #. If you do not require GDI, then define ``NOGDI`` **before**
 | 
	
		
			
				|  |  | +    including windows.h.  This solution should work for both
 | 
	
		
			
				|  |  | +    ``google-glog`` and ``miniglog`` and is documented for
 | 
	
		
			
				|  |  | +    ``google-glog`` `here
 | 
	
		
			
				|  |  | +    <https://code.google.com/p/google-glog/issues/detail?id=33>`__.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. Make a toplevel directory for deps & build & src somewhere: ``ceres/``
 | 
	
		
			
				|  |  |  #. Get dependencies; unpack them as subdirectories in ``ceres/``
 | 
	
	
		
			
				|  | @@ -353,17 +366,19 @@ dependencies.
 | 
	
		
			
				|  |  |     #. ``google-glog`` Open up the Visual Studio solution and build it.
 | 
	
		
			
				|  |  |     #. ``gflags`` Open up the Visual Studio solution and build it.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   #. (Experimental) ``SuiteSparse`` Previously SuiteSparse was not available
 | 
	
		
			
				|  |  | -      on Windows, recently it has become possible to build it on Windows using
 | 
	
		
			
				|  |  | -      the `suitesparse-metis-for-windows <https://github.com/jlblancoc/suitesparse-metis-for-windows>`_
 | 
	
		
			
				|  |  | -      project.  If you wish to use ``SuiteSparse``, follow their instructions
 | 
	
		
			
				|  |  | -      for obtaining and building it.
 | 
	
		
			
				|  |  | +   #. (Experimental) ``SuiteSparse`` Previously SuiteSparse was not
 | 
	
		
			
				|  |  | +      available on Windows, recently it has become possible to build
 | 
	
		
			
				|  |  | +      it on Windows using the `suitesparse-metis-for-windows
 | 
	
		
			
				|  |  | +      <https://github.com/jlblancoc/suitesparse-metis-for-windows>`_
 | 
	
		
			
				|  |  | +      project.  If you wish to use ``SuiteSparse``, follow their
 | 
	
		
			
				|  |  | +      instructions for obtaining and building it.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   #. (Experimental) ``CXSparse`` Previously CXSparse was not available on
 | 
	
		
			
				|  |  | -      Windows, there are now several ports that enable it to be, including:
 | 
	
		
			
				|  |  | -      `[1] <https://github.com/PetterS/CXSparse>`_ and
 | 
	
		
			
				|  |  | -      `[2] <https://github.com/TheFrenchLeaf/CXSparse>`_.  If you wish to use
 | 
	
		
			
				|  |  | -      ``CXSparse``, follow their instructions for obtaining and building it.
 | 
	
		
			
				|  |  | +   #. (Experimental) ``CXSparse`` Previously CXSparse was not
 | 
	
		
			
				|  |  | +      available on Windows, there are now several ports that enable it
 | 
	
		
			
				|  |  | +      to be, including: `[1] <https://github.com/PetterS/CXSparse>`_
 | 
	
		
			
				|  |  | +      and `[2] <https://github.com/TheFrenchLeaf/CXSparse>`_.  If you
 | 
	
		
			
				|  |  | +      wish to use ``CXSparse``, follow their instructions for
 | 
	
		
			
				|  |  | +      obtaining and building it.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. Unpack the Ceres tarball into ``ceres``. For the tarball, you
 | 
	
		
			
				|  |  |     should get a directory inside ``ceres`` similar to
 | 
	
	
		
			
				|  | @@ -391,12 +406,13 @@ dependencies.
 | 
	
		
			
				|  |  |     #. (Optional) ``CXSPARSE_INCLUDE_DIR_HINTS``
 | 
	
		
			
				|  |  |     #. (Optional) ``CXSPARSE_LIBRARY_DIR_HINTS``
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   to the appropriate directories where you unpacked/built them. If any of
 | 
	
		
			
				|  |  | -   the variables are not visible in the ``CMake`` GUI, create a new entry
 | 
	
		
			
				|  |  | -   for them.  We recommend using the ``<NAME>_(INCLUDE/LIBRARY)_DIR_HINTS``
 | 
	
		
			
				|  |  | -   variables rather than setting the ``<NAME>_INCLUDE_DIR`` &
 | 
	
		
			
				|  |  | -   ``<NAME>_LIBRARY`` variables directly to keep all of the validity
 | 
	
		
			
				|  |  | -   checking, and to avoid having to specify the library files manually.
 | 
	
		
			
				|  |  | +   to the appropriate directories where you unpacked/built them. If
 | 
	
		
			
				|  |  | +   any of the variables are not visible in the ``CMake`` GUI, create a
 | 
	
		
			
				|  |  | +   new entry for them.  We recommend using the
 | 
	
		
			
				|  |  | +   ``<NAME>_(INCLUDE/LIBRARY)_DIR_HINTS`` variables rather than
 | 
	
		
			
				|  |  | +   setting the ``<NAME>_INCLUDE_DIR`` & ``<NAME>_LIBRARY`` variables
 | 
	
		
			
				|  |  | +   directly to keep all of the validity checking, and to avoid having
 | 
	
		
			
				|  |  | +   to specify the library files manually.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. You may have to tweak some more settings to generate a MSVC
 | 
	
		
			
				|  |  |     project.  After each adjustment, try pressing Configure & Generate
 | 
	
	
		
			
				|  | @@ -442,8 +458,9 @@ iOS
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     You need iOS version 7.0 or higher to build Ceres Solver.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -To build Ceres for iOS, we need to force ``CMake`` to find the toolchains from
 | 
	
		
			
				|  |  | -the iOS SDK instead of using the standard ones. For example:
 | 
	
		
			
				|  |  | +To build Ceres for iOS, we need to force ``CMake`` to find the
 | 
	
		
			
				|  |  | +toolchains from the iOS SDK instead of using the standard ones. For
 | 
	
		
			
				|  |  | +example:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. code-block:: bash
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -454,21 +471,24 @@ the iOS SDK instead of using the standard ones. For example:
 | 
	
		
			
				|  |  |     <PATH_TO_CERES_SOURCE>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  ``PLATFORM`` can be: ``OS``, ``SIMULATOR`` or ``SIMULATOR64``. You can
 | 
	
		
			
				|  |  | -build for ``OS`` (``armv7``, ``armv7s``, ``arm64``), ``SIMULATOR`` (``i386``) or
 | 
	
		
			
				|  |  | -``SIMULATOR64`` (``x86_64``) separately and use ``lipo`` to merge them into
 | 
	
		
			
				|  |  | -one static library.  See ``cmake/iOS.cmake`` for more options.
 | 
	
		
			
				|  |  | +build for ``OS`` (``armv7``, ``armv7s``, ``arm64``), ``SIMULATOR``
 | 
	
		
			
				|  |  | +(``i386``) or ``SIMULATOR64`` (``x86_64``) separately and use ``lipo``
 | 
	
		
			
				|  |  | +to merge them into one static library.  See ``cmake/iOS.cmake`` for
 | 
	
		
			
				|  |  | +more options.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -After building, you will get a ``libceres.a`` library, which you will need to
 | 
	
		
			
				|  |  | -add to your Xcode project.
 | 
	
		
			
				|  |  | +After building, you will get a ``libceres.a`` library, which you will
 | 
	
		
			
				|  |  | +need to add to your Xcode project.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  The default CMake configuration builds a bare bones version of Ceres
 | 
	
		
			
				|  |  | -Solver that only depends on Eigen (``MINIGLOG`` is compiled into Ceres if it is
 | 
	
		
			
				|  |  | -used), this should be sufficient for solving small to moderate sized problems
 | 
	
		
			
				|  |  | -(No ``SPARSE_SCHUR``, ``SPARSE_NORMAL_CHOLESKY`` linear solvers and no
 | 
	
		
			
				|  |  | -``CLUSTER_JACOBI`` and ``CLUSTER_TRIDIAGONAL`` preconditioners).
 | 
	
		
			
				|  |  | +Solver that only depends on Eigen (``MINIGLOG`` is compiled into Ceres
 | 
	
		
			
				|  |  | +if it is used), this should be sufficient for solving small to
 | 
	
		
			
				|  |  | +moderate sized problems (No ``SPARSE_SCHUR``,
 | 
	
		
			
				|  |  | +``SPARSE_NORMAL_CHOLESKY`` linear solvers and no ``CLUSTER_JACOBI``
 | 
	
		
			
				|  |  | +and ``CLUSTER_TRIDIAGONAL`` preconditioners).
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -If you decide to use ``LAPACK`` and ``BLAS``, then you also need to add
 | 
	
		
			
				|  |  | -``Accelerate.framework`` to your Xcode project's linking dependency.
 | 
	
		
			
				|  |  | +If you decide to use ``LAPACK`` and ``BLAS``, then you also need to
 | 
	
		
			
				|  |  | +add ``Accelerate.framework`` to your Xcode project's linking
 | 
	
		
			
				|  |  | +dependency.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. _section-customizing:
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -477,28 +497,30 @@ Customizing the build
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  It is possible to reduce the libraries needed to build Ceres and
 | 
	
		
			
				|  |  |  customize the build process by setting the appropriate options in
 | 
	
		
			
				|  |  | -``CMake``.  These options can either be set in the ``CMake`` GUI,
 | 
	
		
			
				|  |  | -or via ``-D<OPTION>=<ON/OFF>`` when running ``CMake`` from the
 | 
	
		
			
				|  |  | -command line.  In general, you should only modify these options from
 | 
	
		
			
				|  |  | -their defaults if you know what you are doing.
 | 
	
		
			
				|  |  | +``CMake``.  These options can either be set in the ``CMake`` GUI, or
 | 
	
		
			
				|  |  | +via ``-D<OPTION>=<ON/OFF>`` when running ``CMake`` from the command
 | 
	
		
			
				|  |  | +line.  In general, you should only modify these options from their
 | 
	
		
			
				|  |  | +defaults if you know what you are doing.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. NOTE::
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | - If you are setting variables via ``-D<VARIABLE>=<VALUE>`` when calling
 | 
	
		
			
				|  |  | - ``CMake``, it is important to understand that this forcibly **overwrites** the
 | 
	
		
			
				|  |  | - variable ``<VARIABLE>`` in the ``CMake`` cache at the start of *every configure*.
 | 
	
		
			
				|  |  | + If you are setting variables via ``-D<VARIABLE>=<VALUE>`` when
 | 
	
		
			
				|  |  | + calling ``CMake``, it is important to understand that this forcibly
 | 
	
		
			
				|  |  | + **overwrites** the variable ``<VARIABLE>`` in the ``CMake`` cache at
 | 
	
		
			
				|  |  | + the start of *every configure*.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | - This can lead to confusion if you are invoking the ``CMake``
 | 
	
		
			
				|  |  | - `curses <http://www.gnu.org/software/ncurses/ncurses.html>`_ terminal GUI
 | 
	
		
			
				|  |  | - (via ``ccmake``, e.g. ```ccmake -D<VARIABLE>=<VALUE> <PATH_TO_SRC>``).
 | 
	
		
			
				|  |  | - In this case, even if you change the value of ``<VARIABLE>`` in the ``CMake``
 | 
	
		
			
				|  |  | - GUI, your changes will be **overwritten** with the value passed via
 | 
	
		
			
				|  |  | - ``-D<VARIABLE>=<VALUE>`` (if one exists) at the start of each configure.
 | 
	
		
			
				|  |  | + This can lead to confusion if you are invoking the ``CMake`` `curses
 | 
	
		
			
				|  |  | + <http://www.gnu.org/software/ncurses/ncurses.html>`_ terminal GUI
 | 
	
		
			
				|  |  | + (via ``ccmake``, e.g. ```ccmake -D<VARIABLE>=<VALUE>
 | 
	
		
			
				|  |  | + <PATH_TO_SRC>``).  In this case, even if you change the value of
 | 
	
		
			
				|  |  | + ``<VARIABLE>`` in the ``CMake`` GUI, your changes will be
 | 
	
		
			
				|  |  | + **overwritten** with the value passed via ``-D<VARIABLE>=<VALUE>``
 | 
	
		
			
				|  |  | + (if one exists) at the start of each configure.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | - As such, it is generally easier not to pass values to ``CMake`` via ``-D``
 | 
	
		
			
				|  |  | - and instead interactively experiment with their values in the ``CMake`` GUI.
 | 
	
		
			
				|  |  | - If they are not present in the *Standard View*, toggle to the *Advanced View*
 | 
	
		
			
				|  |  | - with ``<t>``.
 | 
	
		
			
				|  |  | + As such, it is generally easier not to pass values to ``CMake`` via
 | 
	
		
			
				|  |  | + ``-D`` and instead interactively experiment with their values in the
 | 
	
		
			
				|  |  | + ``CMake`` GUI.  If they are not present in the *Standard View*,
 | 
	
		
			
				|  |  | + toggle to the *Advanced View* with ``<t>``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Options controlling Ceres configuration
 | 
	
		
			
				|  |  |  ---------------------------------------
 | 
	
	
		
			
				|  | @@ -548,33 +570,35 @@ Options controlling Ceres configuration
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. ``CXX11 [Default: OFF]`` *Non-MSVC compilers only*.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   Although Ceres does not currently use C++11, it does use ``shared_ptr``
 | 
	
		
			
				|  |  | -   (required) and ``unordered_map`` (if available); both of which existed in the
 | 
	
		
			
				|  |  | -   previous iterations of what became the C++11 standard: TR1 & C++0x.  As such,
 | 
	
		
			
				|  |  | -   Ceres can compile on pre-C++11 compilers, using the TR1/C++0x versions of
 | 
	
		
			
				|  |  | -   ``shared_ptr`` & ``unordered_map``.
 | 
	
		
			
				|  |  | +   Although Ceres does not currently use C++11, it does use
 | 
	
		
			
				|  |  | +   ``shared_ptr`` (required) and ``unordered_map`` (if available);
 | 
	
		
			
				|  |  | +   both of which existed in the previous iterations of what became the
 | 
	
		
			
				|  |  | +   C++11 standard: TR1 & C++0x.  As such, Ceres can compile on
 | 
	
		
			
				|  |  | +   pre-C++11 compilers, using the TR1/C++0x versions of ``shared_ptr``
 | 
	
		
			
				|  |  | +   & ``unordered_map``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   Note that when using GCC & Clang, compiling against the TR1/C++0x versions:
 | 
	
		
			
				|  |  | -   ``CXX11=OFF`` (the default) *does not* require ``-std=c++11`` when compiling
 | 
	
		
			
				|  |  | -   Ceres, *nor* does it require that any client code using Ceres use
 | 
	
		
			
				|  |  | -   ``-std=c++11``.   However, this will cause compile errors if any client code
 | 
	
		
			
				|  |  | -   that uses Ceres also uses C++11 (mismatched versions of ``shared_ptr`` &
 | 
	
		
			
				|  |  | -   ``unordered_map``).
 | 
	
		
			
				|  |  | +   Note that when using GCC & Clang, compiling against the TR1/C++0x
 | 
	
		
			
				|  |  | +   versions: ``CXX11=OFF`` (the default) *does not* require
 | 
	
		
			
				|  |  | +   ``-std=c++11`` when compiling Ceres, *nor* does it require that any
 | 
	
		
			
				|  |  | +   client code using Ceres use ``-std=c++11``.  However, this will
 | 
	
		
			
				|  |  | +   cause compile errors if any client code that uses Ceres also uses
 | 
	
		
			
				|  |  | +   C++11 (mismatched versions of ``shared_ptr`` & ``unordered_map``).
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     Enabling this option: ``CXX11=ON`` forces Ceres to use the C++11
 | 
	
		
			
				|  |  | -   versions of ``shared_ptr`` & ``unordered_map`` if they are available, and
 | 
	
		
			
				|  |  | -   thus imposes the requirement that all client code using Ceres also
 | 
	
		
			
				|  |  | -   compile with ``-std=c++11``.  This requirement is handled automatically
 | 
	
		
			
				|  |  | -   through CMake target properties on the exported Ceres target for CMake >=
 | 
	
		
			
				|  |  | -   2.8.12 (when it was introduced).  Thus, any client code which uses CMake will
 | 
	
		
			
				|  |  | -   automatically be compiled with ``-std=c++11``.  **On CMake versions <
 | 
	
		
			
				|  |  | -   2.8.12, you are responsible for ensuring that any code which uses Ceres is
 | 
	
		
			
				|  |  | +   versions of ``shared_ptr`` & ``unordered_map`` if they are
 | 
	
		
			
				|  |  | +   available, and thus imposes the requirement that all client code
 | 
	
		
			
				|  |  | +   using Ceres also compile with ``-std=c++11``.  This requirement is
 | 
	
		
			
				|  |  | +   handled automatically through CMake target properties on the
 | 
	
		
			
				|  |  | +   exported Ceres target for CMake >= 2.8.12 (when it was introduced).
 | 
	
		
			
				|  |  | +   Thus, any client code which uses CMake will automatically be
 | 
	
		
			
				|  |  | +   compiled with ``-std=c++11``.  **On CMake versions < 2.8.12, you
 | 
	
		
			
				|  |  | +   are responsible for ensuring that any code which uses Ceres is
 | 
	
		
			
				|  |  |     compiled with** ``-std=c++11``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   On OS X 10.9+, Clang will use the C++11 versions of ``shared_ptr`` &
 | 
	
		
			
				|  |  | -   ``unordered_map`` without ``-std=c++11`` and so this option does not change
 | 
	
		
			
				|  |  | -   the versions detected, although enabling it *will* require that client code
 | 
	
		
			
				|  |  | -   compile with ``-std=c++11``.
 | 
	
		
			
				|  |  | +   On OS X 10.9+, Clang will use the C++11 versions of ``shared_ptr``
 | 
	
		
			
				|  |  | +   & ``unordered_map`` without ``-std=c++11`` and so this option does
 | 
	
		
			
				|  |  | +   not change the versions detected, although enabling it *will*
 | 
	
		
			
				|  |  | +   require that client code compile with ``-std=c++11``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     The following table summarises the effects of the ``CXX11`` option:
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -587,61 +611,68 @@ Options controlling Ceres configuration
 | 
	
		
			
				|  |  |     OS X 10.9+           ON          std               **Yes**
 | 
	
		
			
				|  |  |     ===================  ==========  ================  ======================================
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   The ``CXX11`` option does does not exist when using MSVC, as there any new
 | 
	
		
			
				|  |  | -   C++ features available are enabled by default, and there is no analogue of
 | 
	
		
			
				|  |  | -   ``-std=c++11``.  It will however be available on MinGW & CygWin, which can
 | 
	
		
			
				|  |  | -   support ``-std=c++11``.
 | 
	
		
			
				|  |  | +   The ``CXX11`` option does does not exist when using MSVC, as there
 | 
	
		
			
				|  |  | +   any new C++ features available are enabled by default, and there is
 | 
	
		
			
				|  |  | +   no analogue of ``-std=c++11``.  It will however be available on
 | 
	
		
			
				|  |  | +   MinGW & CygWin, which can support ``-std=c++11``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. ``BUILD_SHARED_LIBS [Default: OFF]``: By default Ceres is built as
 | 
	
		
			
				|  |  |     a static library, turn this ``ON`` to instead build Ceres as a
 | 
	
		
			
				|  |  |     shared library.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -#. ``EXPORT_BUILD_DIR [Default: OFF]``: By default Ceres is configured solely
 | 
	
		
			
				|  |  | -   for installation, and so must be installed in order for clients to use it.
 | 
	
		
			
				|  |  | -   Turn this ``ON`` to export Ceres' build directory location into the
 | 
	
		
			
				|  |  | -   `user's local CMake package registry <http://www.cmake.org/cmake/help/v3.2/manual/cmake-packages.7.html#user-package-registry>`_
 | 
	
		
			
				|  |  | -   where it will be detected **without requiring installation** in a client
 | 
	
		
			
				|  |  | -   project using CMake when `find_package(Ceres) <http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  | +#. ``EXPORT_BUILD_DIR [Default: OFF]``: By default Ceres is configured
 | 
	
		
			
				|  |  | +   solely for installation, and so must be installed in order for
 | 
	
		
			
				|  |  | +   clients to use it.  Turn this ``ON`` to export Ceres' build
 | 
	
		
			
				|  |  | +   directory location into the `user's local CMake package registry
 | 
	
		
			
				|  |  | +   <http://www.cmake.org/cmake/help/v3.2/manual/cmake-packages.7.html#user-package-registry>`_
 | 
	
		
			
				|  |  | +   where it will be detected **without requiring installation** in a
 | 
	
		
			
				|  |  | +   client project using CMake when `find_package(Ceres)
 | 
	
		
			
				|  |  | +   <http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  |     is invoked.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. ``BUILD_DOCUMENTATION [Default: OFF]``: Use this to enable building
 | 
	
		
			
				|  |  | -   the documentation, requires `Sphinx <http://sphinx-doc.org/>`_ and the
 | 
	
		
			
				|  |  | -   `sphinx_rtd_theme <https://pypi.python.org/pypi/sphinx_rtd_theme>`_
 | 
	
		
			
				|  |  | -   package available from the Python package index. In addition,
 | 
	
		
			
				|  |  | -   ``make ceres_docs`` can be used to build only the documentation.
 | 
	
		
			
				|  |  | +   the documentation, requires `Sphinx <http://sphinx-doc.org/>`_ and
 | 
	
		
			
				|  |  | +   the `sphinx-better-theme
 | 
	
		
			
				|  |  | +   <https://pypi.python.org/pypi/sphinx-better-theme>`_ package
 | 
	
		
			
				|  |  | +   available from the Python package index. In addition, ``make
 | 
	
		
			
				|  |  | +   ceres_docs`` can be used to build only the documentation.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. ``MSVC_USE_STATIC_CRT [Default: OFF]`` *Windows Only*: By default
 | 
	
		
			
				|  |  | -   Ceres will use the Visual Studio default, *shared* C-Run Time (CRT) library.
 | 
	
		
			
				|  |  | -   Turn this ``ON`` to use the *static* C-Run Time library instead.
 | 
	
		
			
				|  |  | +   Ceres will use the Visual Studio default, *shared* C-Run Time (CRT)
 | 
	
		
			
				|  |  | +   library.  Turn this ``ON`` to use the *static* C-Run Time library
 | 
	
		
			
				|  |  | +   instead.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -#. ``LIB_SUFFIX [Default: "64" on non-Debian/Arch based 64-bit Linux, otherwise: ""]``:
 | 
	
		
			
				|  |  | -   The suffix to append to the library install directory, built from:
 | 
	
		
			
				|  |  | +#. ``LIB_SUFFIX [Default: "64" on non-Debian/Arch based 64-bit Linux,
 | 
	
		
			
				|  |  | +   otherwise: ""]``: The suffix to append to the library install
 | 
	
		
			
				|  |  | +   directory, built from:
 | 
	
		
			
				|  |  |     ``${CMAKE_INSTALL_PREFIX}/lib${LIB_SUFFIX}``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   The filesystem hierarchy standard recommends that 64-bit systems install
 | 
	
		
			
				|  |  | -   native libraries to lib64 rather than lib.  Most Linux distributions follow
 | 
	
		
			
				|  |  | -   this convention, but Debian and Arch based distros do not.  Note that the
 | 
	
		
			
				|  |  | -   only generally sensible values for ``LIB_SUFFIX`` are "" and "64".
 | 
	
		
			
				|  |  | +   The filesystem hierarchy standard recommends that 64-bit systems
 | 
	
		
			
				|  |  | +   install native libraries to lib64 rather than lib.  Most Linux
 | 
	
		
			
				|  |  | +   distributions follow this convention, but Debian and Arch based
 | 
	
		
			
				|  |  | +   distros do not.  Note that the only generally sensible values for
 | 
	
		
			
				|  |  | +   ``LIB_SUFFIX`` are "" and "64".
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   Although by default Ceres will auto-detect non-Debian/Arch based 64-bit
 | 
	
		
			
				|  |  | -   Linux distributions and default ``LIB_SUFFIX`` to "64", this can always be
 | 
	
		
			
				|  |  | -   overridden by manually specifying LIB_SUFFIX using: ``-DLIB_SUFFIX=<VALUE>``
 | 
	
		
			
				|  |  | -   when invoking CMake.
 | 
	
		
			
				|  |  | +   Although by default Ceres will auto-detect non-Debian/Arch based
 | 
	
		
			
				|  |  | +   64-bit Linux distributions and default ``LIB_SUFFIX`` to "64", this
 | 
	
		
			
				|  |  | +   can always be overridden by manually specifying LIB_SUFFIX using:
 | 
	
		
			
				|  |  | +   ``-DLIB_SUFFIX=<VALUE>`` when invoking CMake.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Options controlling Ceres dependency locations
 | 
	
		
			
				|  |  |  ----------------------------------------------
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Ceres uses the ``CMake``
 | 
	
		
			
				|  |  | -`find_package <http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  | +Ceres uses the ``CMake`` `find_package
 | 
	
		
			
				|  |  | +<http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  |  function to find all of its dependencies using
 | 
	
		
			
				|  |  | -``Find<DEPENDENCY_NAME>.cmake`` scripts which are either included in Ceres
 | 
	
		
			
				|  |  | -(for most dependencies) or are shipped as standard with ``CMake``
 | 
	
		
			
				|  |  | -(for ``LAPACK`` & ``BLAS``).  These scripts will search all of the "standard"
 | 
	
		
			
				|  |  | -install locations for various OSs for each dependency.  However, particularly
 | 
	
		
			
				|  |  | -for Windows, they may fail to find the library, in this case you will have to
 | 
	
		
			
				|  |  | -manually specify its installed location.  The ``Find<DEPENDENCY_NAME>.cmake``
 | 
	
		
			
				|  |  | -scripts shipped with Ceres support two ways for you to do this:
 | 
	
		
			
				|  |  | +``Find<DEPENDENCY_NAME>.cmake`` scripts which are either included in
 | 
	
		
			
				|  |  | +Ceres (for most dependencies) or are shipped as standard with
 | 
	
		
			
				|  |  | +``CMake`` (for ``LAPACK`` & ``BLAS``).  These scripts will search all
 | 
	
		
			
				|  |  | +of the "standard" install locations for various OSs for each
 | 
	
		
			
				|  |  | +dependency.  However, particularly for Windows, they may fail to find
 | 
	
		
			
				|  |  | +the library, in this case you will have to manually specify its
 | 
	
		
			
				|  |  | +installed location.  The ``Find<DEPENDENCY_NAME>.cmake`` scripts
 | 
	
		
			
				|  |  | +shipped with Ceres support two ways for you to do this:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #. Set the *hints* variables specifying the *directories* to search in
 | 
	
		
			
				|  |  |     preference, but in addition, to the search directories in the
 | 
	
	
		
			
				|  | @@ -663,58 +694,62 @@ scripts shipped with Ceres support two ways for you to do this:
 | 
	
		
			
				|  |  |     ``Find<DEPENDENCY_NAME>.cmake`` script, but validation is still
 | 
	
		
			
				|  |  |     performed.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   These variables are available to set in the ``CMake`` GUI. They
 | 
	
		
			
				|  |  | -   are visible in the *Standard View* if the library has not been
 | 
	
		
			
				|  |  | -   found (but the current Ceres configuration requires it), but
 | 
	
		
			
				|  |  | -   are always visible in the *Advanced View*.  They can also be
 | 
	
		
			
				|  |  | -   set directly via ``-D<VAR>=<VALUE>`` arguments to ``CMake``.
 | 
	
		
			
				|  |  | +   These variables are available to set in the ``CMake`` GUI. They are
 | 
	
		
			
				|  |  | +   visible in the *Standard View* if the library has not been found
 | 
	
		
			
				|  |  | +   (but the current Ceres configuration requires it), but are always
 | 
	
		
			
				|  |  | +   visible in the *Advanced View*.  They can also be set directly via
 | 
	
		
			
				|  |  | +   ``-D<VAR>=<VALUE>`` arguments to ``CMake``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Building using custom BLAS & LAPACK installs
 | 
	
		
			
				|  |  |  ----------------------------------------------
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -If the standard find package scripts for ``BLAS`` & ``LAPACK`` which ship with
 | 
	
		
			
				|  |  | -``CMake`` fail to find the desired libraries on your system, try setting
 | 
	
		
			
				|  |  | -``CMAKE_LIBRARY_PATH`` to the path(s) to the directories containing the
 | 
	
		
			
				|  |  | -``BLAS`` & ``LAPACK`` libraries when invoking ``CMake`` to build Ceres via
 | 
	
		
			
				|  |  | -``-D<VAR>=<VALUE>``.  This should result in the libraries being found for any
 | 
	
		
			
				|  |  | -common variant of each.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -If you are building on an exotic system, or setting ``CMAKE_LIBRARY_PATH``
 | 
	
		
			
				|  |  | -does not work, or is not appropriate for some other reason, one option would be
 | 
	
		
			
				|  |  | -to write your own custom versions of ``FindBLAS.cmake`` &
 | 
	
		
			
				|  |  | -``FindLAPACK.cmake`` specific to your environment.  In this case you must set
 | 
	
		
			
				|  |  | -``CMAKE_MODULE_PATH`` to the directory containing these custom scripts when
 | 
	
		
			
				|  |  | -invoking ``CMake`` to build Ceres and they will be used in preference to the
 | 
	
		
			
				|  |  | -default versions.  However, in order for this to work, your scripts must provide
 | 
	
		
			
				|  |  | -the full set of variables provided by the default scripts.  Also, if you are
 | 
	
		
			
				|  |  | -building Ceres with ``SuiteSparse``, the versions of ``BLAS`` & ``LAPACK``
 | 
	
		
			
				|  |  | -used by ``SuiteSparse`` and Ceres should be the same.
 | 
	
		
			
				|  |  | +If the standard find package scripts for ``BLAS`` & ``LAPACK`` which
 | 
	
		
			
				|  |  | +ship with ``CMake`` fail to find the desired libraries on your system,
 | 
	
		
			
				|  |  | +try setting ``CMAKE_LIBRARY_PATH`` to the path(s) to the directories
 | 
	
		
			
				|  |  | +containing the ``BLAS`` & ``LAPACK`` libraries when invoking ``CMake``
 | 
	
		
			
				|  |  | +to build Ceres via ``-D<VAR>=<VALUE>``.  This should result in the
 | 
	
		
			
				|  |  | +libraries being found for any common variant of each.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +If you are building on an exotic system, or setting
 | 
	
		
			
				|  |  | +``CMAKE_LIBRARY_PATH`` does not work, or is not appropriate for some
 | 
	
		
			
				|  |  | +other reason, one option would be to write your own custom versions of
 | 
	
		
			
				|  |  | +``FindBLAS.cmake`` & ``FindLAPACK.cmake`` specific to your
 | 
	
		
			
				|  |  | +environment.  In this case you must set ``CMAKE_MODULE_PATH`` to the
 | 
	
		
			
				|  |  | +directory containing these custom scripts when invoking ``CMake`` to
 | 
	
		
			
				|  |  | +build Ceres and they will be used in preference to the default
 | 
	
		
			
				|  |  | +versions.  However, in order for this to work, your scripts must
 | 
	
		
			
				|  |  | +provide the full set of variables provided by the default scripts.
 | 
	
		
			
				|  |  | +Also, if you are building Ceres with ``SuiteSparse``, the versions of
 | 
	
		
			
				|  |  | +``BLAS`` & ``LAPACK`` used by ``SuiteSparse`` and Ceres should be the
 | 
	
		
			
				|  |  | +same.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. _section-using-ceres:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Using Ceres with CMake
 | 
	
		
			
				|  |  |  ======================
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -In order to use Ceres in client code with CMake using
 | 
	
		
			
				|  |  | -`find_package() <http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  | +In order to use Ceres in client code with CMake using `find_package()
 | 
	
		
			
				|  |  | +<http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  |  then either:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -#. Ceres must have been installed with ``make install``.
 | 
	
		
			
				|  |  | -    If the install location is non-standard (i.e. is not in CMake's default
 | 
	
		
			
				|  |  | +#. Ceres must have been installed with ``make install``.  If the
 | 
	
		
			
				|  |  | +    install location is non-standard (i.e. is not in CMake's default
 | 
	
		
			
				|  |  |      search paths) then it will not be detected by default, see:
 | 
	
		
			
				|  |  |      :ref:`section-local-installations`.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    Note that if you are using a non-standard install location you should
 | 
	
		
			
				|  |  | -    consider exporting Ceres instead, as this will not require any extra
 | 
	
		
			
				|  |  | -    information to be provided in client code for Ceres to be detected.
 | 
	
		
			
				|  |  | +    Note that if you are using a non-standard install location you
 | 
	
		
			
				|  |  | +    should consider exporting Ceres instead, as this will not require
 | 
	
		
			
				|  |  | +    any extra information to be provided in client code for Ceres to
 | 
	
		
			
				|  |  | +    be detected.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -#. Or Ceres' build directory must have been exported
 | 
	
		
			
				|  |  | -    by enabling the ``EXPORT_BUILD_DIR`` option when Ceres was configured.
 | 
	
		
			
				|  |  | +#. Or Ceres' build directory must have been exported by enabling the
 | 
	
		
			
				|  |  | +    ``EXPORT_BUILD_DIR`` option when Ceres was configured.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  As an example of how to use Ceres, to compile `examples/helloworld.cc
 | 
	
		
			
				|  |  |  <https://ceres-solver.googlesource.com/ceres-solver/+/master/examples/helloworld.cc>`_
 | 
	
		
			
				|  |  | -in a separate standalone project, the following CMakeList.txt can be used:
 | 
	
		
			
				|  |  | +in a separate standalone project, the following CMakeList.txt can be
 | 
	
		
			
				|  |  | +used:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. code-block:: cmake
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -729,22 +764,25 @@ in a separate standalone project, the following CMakeList.txt can be used:
 | 
	
		
			
				|  |  |      add_executable(helloworld helloworld.cc)
 | 
	
		
			
				|  |  |      target_link_libraries(helloworld ${CERES_LIBRARIES})
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Irrespective of whether Ceres was installed or exported, if multiple versions
 | 
	
		
			
				|  |  | -are detected, set: ``Ceres_DIR`` to control which is used.  If Ceres was
 | 
	
		
			
				|  |  | -installed ``Ceres_DIR`` should be the path to the directory containing the
 | 
	
		
			
				|  |  | -installed ``CeresConfig.cmake`` file (e.g. ``/usr/local/share/Ceres``).  If
 | 
	
		
			
				|  |  | -Ceres was exported, then ``Ceres_DIR`` should be the path to the exported
 | 
	
		
			
				|  |  | -Ceres build directory.
 | 
	
		
			
				|  |  | +Irrespective of whether Ceres was installed or exported, if multiple
 | 
	
		
			
				|  |  | +versions are detected, set: ``Ceres_DIR`` to control which is used.
 | 
	
		
			
				|  |  | +If Ceres was installed ``Ceres_DIR`` should be the path to the
 | 
	
		
			
				|  |  | +directory containing the installed ``CeresConfig.cmake`` file
 | 
	
		
			
				|  |  | +(e.g. ``/usr/local/share/Ceres``).  If Ceres was exported, then
 | 
	
		
			
				|  |  | +``Ceres_DIR`` should be the path to the exported Ceres build
 | 
	
		
			
				|  |  | +directory.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Specify Ceres components
 | 
	
		
			
				|  |  |  -------------------------------------
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -You can specify particular Ceres components that you require (in order for Ceres
 | 
	
		
			
				|  |  | -to be reported as found) when invoking ``find_package(Ceres)``.  This allows you
 | 
	
		
			
				|  |  | -to specify, for example, that you require a version of Ceres built with
 | 
	
		
			
				|  |  | -SuiteSparse support.  By definition, if you do not specify any components when
 | 
	
		
			
				|  |  | -calling ``find_package(Ceres)`` (the default) any version of Ceres detected will
 | 
	
		
			
				|  |  | -be reported as found, irrespective of which components it was built with.
 | 
	
		
			
				|  |  | +You can specify particular Ceres components that you require (in order
 | 
	
		
			
				|  |  | +for Ceres to be reported as found) when invoking
 | 
	
		
			
				|  |  | +``find_package(Ceres)``.  This allows you to specify, for example,
 | 
	
		
			
				|  |  | +that you require a version of Ceres built with SuiteSparse support.
 | 
	
		
			
				|  |  | +By definition, if you do not specify any components when calling
 | 
	
		
			
				|  |  | +``find_package(Ceres)`` (the default) any version of Ceres detected
 | 
	
		
			
				|  |  | +will be reported as found, irrespective of which components it was
 | 
	
		
			
				|  |  | +built with.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  The Ceres components which can be specified are:
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -801,95 +839,102 @@ Local installations
 | 
	
		
			
				|  |  |  -------------------
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  If Ceres was installed in a non-standard path by specifying
 | 
	
		
			
				|  |  | -``-DCMAKE_INSTALL_PREFIX="/some/where/local"``, then the user should add
 | 
	
		
			
				|  |  | -the **PATHS** option to the ``find_package()`` command, e.g.,
 | 
	
		
			
				|  |  | +``-DCMAKE_INSTALL_PREFIX="/some/where/local"``, then the user should
 | 
	
		
			
				|  |  | +add the **PATHS** option to the ``find_package()`` command, e.g.,
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. code-block:: cmake
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     find_package(Ceres REQUIRED PATHS "/some/where/local/")
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Note that this can be used to have multiple versions of Ceres
 | 
	
		
			
				|  |  | -installed.  However, particularly if you have only a single version of Ceres
 | 
	
		
			
				|  |  | -which you want to use but do not wish to install to a system location, you
 | 
	
		
			
				|  |  | -should consider exporting Ceres using the ``EXPORT_BUILD_DIR`` option instead
 | 
	
		
			
				|  |  | -of a local install, as exported versions of Ceres will be automatically detected
 | 
	
		
			
				|  |  | -by CMake, irrespective of their location.
 | 
	
		
			
				|  |  | +installed.  However, particularly if you have only a single version of
 | 
	
		
			
				|  |  | +Ceres which you want to use but do not wish to install to a system
 | 
	
		
			
				|  |  | +location, you should consider exporting Ceres using the
 | 
	
		
			
				|  |  | +``EXPORT_BUILD_DIR`` option instead of a local install, as exported
 | 
	
		
			
				|  |  | +versions of Ceres will be automatically detected by CMake,
 | 
	
		
			
				|  |  | +irrespective of their location.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Understanding the CMake Package System
 | 
	
		
			
				|  |  |  ----------------------------------------
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Although a full tutorial on CMake is outside the scope of this guide, here
 | 
	
		
			
				|  |  | -we cover some of the most common CMake misunderstandings that crop up
 | 
	
		
			
				|  |  | -when using Ceres.  For more detailed CMake usage, the following references are
 | 
	
		
			
				|  |  | -very useful:
 | 
	
		
			
				|  |  | +Although a full tutorial on CMake is outside the scope of this guide,
 | 
	
		
			
				|  |  | +here we cover some of the most common CMake misunderstandings that
 | 
	
		
			
				|  |  | +crop up when using Ceres.  For more detailed CMake usage, the
 | 
	
		
			
				|  |  | +following references are very useful:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  - The `official CMake tutorial <http://www.cmake.org/cmake-tutorial/>`_
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     Provides a tour of the core features of CMake.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -- `ProjectConfig tutorial <http://www.cmake.org/Wiki/CMake/Tutorials/How_to_create_a_ProjectConfig.cmake_file>`_ and the `cmake-packages documentation <http://www.cmake.org/cmake/help/git-master/manual/cmake-packages.7.html>`_
 | 
	
		
			
				|  |  | +- `ProjectConfig tutorial
 | 
	
		
			
				|  |  | +  <http://www.cmake.org/Wiki/CMake/Tutorials/How_to_create_a_ProjectConfig.cmake_file>`_
 | 
	
		
			
				|  |  | +  and the `cmake-packages documentation
 | 
	
		
			
				|  |  | +  <http://www.cmake.org/cmake/help/git-master/manual/cmake-packages.7.html>`_
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -   Cover how to write a ``ProjectConfig.cmake`` file, discussed below, for
 | 
	
		
			
				|  |  | -   your own project when installing or exporting it using CMake.  It also covers
 | 
	
		
			
				|  |  | -   how these processes in conjunction with ``find_package()`` are actually
 | 
	
		
			
				|  |  | -   handled by CMake.  The
 | 
	
		
			
				|  |  | -   `ProjectConfig tutorial <http://www.cmake.org/Wiki/CMake/Tutorials/How_to_create_a_ProjectConfig.cmake_file>`_
 | 
	
		
			
				|  |  | -   is the older style, currently used by Ceres for compatibility with older
 | 
	
		
			
				|  |  | -   versions of CMake.
 | 
	
		
			
				|  |  | +   Cover how to write a ``ProjectConfig.cmake`` file, discussed below,
 | 
	
		
			
				|  |  | +   for your own project when installing or exporting it using CMake.
 | 
	
		
			
				|  |  | +   It also covers how these processes in conjunction with
 | 
	
		
			
				|  |  | +   ``find_package()`` are actually handled by CMake.  The
 | 
	
		
			
				|  |  | +   `ProjectConfig tutorial
 | 
	
		
			
				|  |  | +   <http://www.cmake.org/Wiki/CMake/Tutorials/How_to_create_a_ProjectConfig.cmake_file>`_
 | 
	
		
			
				|  |  | +   is the older style, currently used by Ceres for compatibility with
 | 
	
		
			
				|  |  | +   older versions of CMake.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    .. NOTE :: **Targets in CMake.**
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      All libraries and executables built using CMake are represented as
 | 
	
		
			
				|  |  | -    *targets* created using
 | 
	
		
			
				|  |  | -    `add_library()
 | 
	
		
			
				|  |  | +    *targets* created using `add_library()
 | 
	
		
			
				|  |  |      <http://www.cmake.org/cmake/help/v3.2/command/add_library.html>`_
 | 
	
		
			
				|  |  | -    and
 | 
	
		
			
				|  |  | -    `add_executable()
 | 
	
		
			
				|  |  | +    and `add_executable()
 | 
	
		
			
				|  |  |      <http://www.cmake.org/cmake/help/v3.2/command/add_executable.html>`_.
 | 
	
		
			
				|  |  | -    Targets encapsulate the rules and dependencies (which can be other targets)
 | 
	
		
			
				|  |  | -    required to build or link against an object.  This allows CMake to
 | 
	
		
			
				|  |  | -    implicitly manage dependency chains.  Thus it is sufficient to tell CMake
 | 
	
		
			
				|  |  | -    that a library target: ``B`` depends on a previously declared library target
 | 
	
		
			
				|  |  | -    ``A``, and CMake will understand that this means that ``B`` also depends on
 | 
	
		
			
				|  |  | -    all of the public dependencies of ``A``.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -When a project like Ceres is installed using CMake, or its build directory is
 | 
	
		
			
				|  |  | -exported into the local CMake package registry
 | 
	
		
			
				|  |  | -(see :ref:`section-install-vs-export`), in addition to the public
 | 
	
		
			
				|  |  | -headers and compiled libraries, a set of CMake-specific project configuration
 | 
	
		
			
				|  |  | -files are also installed to: ``<INSTALL_ROOT>/share/Ceres`` (if Ceres is
 | 
	
		
			
				|  |  | -installed), or created in the build directory (if Ceres' build directory is
 | 
	
		
			
				|  |  | -exported).  When `find_package
 | 
	
		
			
				|  |  | -<http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_
 | 
	
		
			
				|  |  | -is invoked, CMake checks various standard install locations (including
 | 
	
		
			
				|  |  | -``/usr/local`` on Linux & UNIX systems), and the local CMake package registry
 | 
	
		
			
				|  |  | -for CMake configuration files for the project to be found (i.e. Ceres in the
 | 
	
		
			
				|  |  | -case of ``find_package(Ceres)``).  Specifically it looks for:
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -- ``<PROJECT_NAME>Config.cmake`` (or ``<lower_case_project_name>-config.cmake``)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -   Which is written by the developers of the project, and is configured with
 | 
	
		
			
				|  |  | -   the selected options and installed locations when the project is built and
 | 
	
		
			
				|  |  | -   defines the CMake variables: ``<PROJECT_NAME>_INCLUDE_DIRS`` &
 | 
	
		
			
				|  |  | -   ``<PROJECT_NAME>_LIBRARIES`` which are used by the caller to import
 | 
	
		
			
				|  |  | -   the project.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -The ``<PROJECT_NAME>Config.cmake`` typically includes a second file installed to
 | 
	
		
			
				|  |  | -the same location:
 | 
	
		
			
				|  |  | +    Targets encapsulate the rules and dependencies (which can be other
 | 
	
		
			
				|  |  | +    targets) required to build or link against an object.  This allows
 | 
	
		
			
				|  |  | +    CMake to implicitly manage dependency chains.  Thus it is
 | 
	
		
			
				|  |  | +    sufficient to tell CMake that a library target: ``B`` depends on a
 | 
	
		
			
				|  |  | +    previously declared library target ``A``, and CMake will
 | 
	
		
			
				|  |  | +    understand that this means that ``B`` also depends on all of the
 | 
	
		
			
				|  |  | +    public dependencies of ``A``.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +When a project like Ceres is installed using CMake, or its build
 | 
	
		
			
				|  |  | +directory is exported into the local CMake package registry (see
 | 
	
		
			
				|  |  | +:ref:`section-install-vs-export`), in addition to the public headers
 | 
	
		
			
				|  |  | +and compiled libraries, a set of CMake-specific project configuration
 | 
	
		
			
				|  |  | +files are also installed to: ``<INSTALL_ROOT>/share/Ceres`` (if Ceres
 | 
	
		
			
				|  |  | +is installed), or created in the build directory (if Ceres' build
 | 
	
		
			
				|  |  | +directory is exported).  When `find_package
 | 
	
		
			
				|  |  | +<http://www.cmake.org/cmake/help/v3.2/command/find_package.html>`_ is
 | 
	
		
			
				|  |  | +invoked, CMake checks various standard install locations (including
 | 
	
		
			
				|  |  | +``/usr/local`` on Linux & UNIX systems), and the local CMake package
 | 
	
		
			
				|  |  | +registry for CMake configuration files for the project to be found
 | 
	
		
			
				|  |  | +(i.e. Ceres in the case of ``find_package(Ceres)``).  Specifically it
 | 
	
		
			
				|  |  | +looks for:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +- ``<PROJECT_NAME>Config.cmake`` (or
 | 
	
		
			
				|  |  | +  ``<lower_case_project_name>-config.cmake``)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +   Which is written by the developers of the project, and is
 | 
	
		
			
				|  |  | +   configured with the selected options and installed locations when
 | 
	
		
			
				|  |  | +   the project is built and defines the CMake variables:
 | 
	
		
			
				|  |  | +   ``<PROJECT_NAME>_INCLUDE_DIRS`` & ``<PROJECT_NAME>_LIBRARIES``
 | 
	
		
			
				|  |  | +   which are used by the caller to import the project.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +The ``<PROJECT_NAME>Config.cmake`` typically includes a second file
 | 
	
		
			
				|  |  | +installed to the same location:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  - ``<PROJECT_NAME>Targets.cmake``
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     Which is autogenerated by CMake as part of the install process and defines
 | 
	
		
			
				|  |  |     **imported targets** for the project in the caller's CMake scope.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -An **imported target** contains the same information about a library as a CMake
 | 
	
		
			
				|  |  | -target that was declared locally in the current CMake project using
 | 
	
		
			
				|  |  | -``add_library()``.  However, imported targets refer to objects that have already
 | 
	
		
			
				|  |  | -been built by a different CMake project.  Principally, an imported
 | 
	
		
			
				|  |  | -target contains the location of the compiled object and all of its public
 | 
	
		
			
				|  |  | -dependencies required to link against it.  Any locally declared target can
 | 
	
		
			
				|  |  | -depend on an imported target, and CMake will manage the dependency chain, just
 | 
	
		
			
				|  |  | -as if the imported target had been declared locally by the current project.
 | 
	
		
			
				|  |  | +An **imported target** contains the same information about a library
 | 
	
		
			
				|  |  | +as a CMake target that was declared locally in the current CMake
 | 
	
		
			
				|  |  | +project using ``add_library()``.  However, imported targets refer to
 | 
	
		
			
				|  |  | +objects that have already been built by a different CMake project.
 | 
	
		
			
				|  |  | +Principally, an imported target contains the location of the compiled
 | 
	
		
			
				|  |  | +object and all of its public dependencies required to link against it.
 | 
	
		
			
				|  |  | +Any locally declared target can depend on an imported target, and
 | 
	
		
			
				|  |  | +CMake will manage the dependency chain, just as if the imported target
 | 
	
		
			
				|  |  | +had been declared locally by the current project.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Crucially, just like any locally declared CMake target, an imported target is
 | 
	
		
			
				|  |  |  identified by its **name** when adding it as a dependency to another target.
 | 
	
	
		
			
				|  | @@ -901,41 +946,46 @@ Thus, if in a project using Ceres you had the following in your CMakeLists.txt:
 | 
	
		
			
				|  |  |      find_package(Ceres REQUIRED)
 | 
	
		
			
				|  |  |      message("CERES_LIBRARIES = ${CERES_LIBRARIES}")
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -You would see the output: ``CERES_LIBRARIES = ceres``.  **However**, here
 | 
	
		
			
				|  |  | -``ceres`` is an **imported target** created when ``CeresTargets.cmake`` was
 | 
	
		
			
				|  |  | -read as part of ``find_package(Ceres REQUIRED)``.  It does **not** refer
 | 
	
		
			
				|  |  | -(directly) to the compiled Ceres library: ``libceres.a/so/dylib/lib``.  This
 | 
	
		
			
				|  |  | -distinction is important, as depending on the options selected when it was
 | 
	
		
			
				|  |  | -built, Ceres can have public link dependencies which are encapsulated in the
 | 
	
		
			
				|  |  | -imported target and automatically added to the link step when Ceres is added
 | 
	
		
			
				|  |  | -as a dependency of another target by CMake.  In this case, linking only against
 | 
	
		
			
				|  |  | -``libceres.a/so/dylib/lib`` without these other public dependencies would
 | 
	
		
			
				|  |  | -result in a linker error.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -Note that this description applies both to projects that are **installed**
 | 
	
		
			
				|  |  | -using CMake, and to those whose **build directory is exported** using
 | 
	
		
			
				|  |  | -`export() <http://www.cmake.org/cmake/help/v3.2/command/export.html>`_
 | 
	
		
			
				|  |  | -(instead of
 | 
	
		
			
				|  |  | -`install() <http://www.cmake.org/cmake/help/v3.2/command/install.html>`_).
 | 
	
		
			
				|  |  | -Ceres supports both installation and export of its build directory if the
 | 
	
		
			
				|  |  | -``EXPORT_BUILD_DIR`` option is enabled, see :ref:`section-customizing`.
 | 
	
		
			
				|  |  | +You would see the output: ``CERES_LIBRARIES = ceres``.  **However**,
 | 
	
		
			
				|  |  | +here ``ceres`` is an **imported target** created when
 | 
	
		
			
				|  |  | +``CeresTargets.cmake`` was read as part of ``find_package(Ceres
 | 
	
		
			
				|  |  | +REQUIRED)``.  It does **not** refer (directly) to the compiled Ceres
 | 
	
		
			
				|  |  | +library: ``libceres.a/so/dylib/lib``.  This distinction is important,
 | 
	
		
			
				|  |  | +as depending on the options selected when it was built, Ceres can have
 | 
	
		
			
				|  |  | +public link dependencies which are encapsulated in the imported target
 | 
	
		
			
				|  |  | +and automatically added to the link step when Ceres is added as a
 | 
	
		
			
				|  |  | +dependency of another target by CMake.  In this case, linking only
 | 
	
		
			
				|  |  | +against ``libceres.a/so/dylib/lib`` without these other public
 | 
	
		
			
				|  |  | +dependencies would result in a linker error.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Note that this description applies both to projects that are
 | 
	
		
			
				|  |  | +**installed** using CMake, and to those whose **build directory is
 | 
	
		
			
				|  |  | +exported** using `export()
 | 
	
		
			
				|  |  | +<http://www.cmake.org/cmake/help/v3.2/command/export.html>`_ (instead
 | 
	
		
			
				|  |  | +of `install()
 | 
	
		
			
				|  |  | +<http://www.cmake.org/cmake/help/v3.2/command/install.html>`_).  Ceres
 | 
	
		
			
				|  |  | +supports both installation and export of its build directory if the
 | 
	
		
			
				|  |  | +``EXPORT_BUILD_DIR`` option is enabled, see
 | 
	
		
			
				|  |  | +:ref:`section-customizing`.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. _section-install-vs-export:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Installing a project with CMake vs Exporting its build directory
 | 
	
		
			
				|  |  |  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -When a project is **installed**, the compiled libraries and headers are copied
 | 
	
		
			
				|  |  | -from the source & build directory to the install location, and it is these
 | 
	
		
			
				|  |  | -copied files that are used by any client code.  When a project's build directory
 | 
	
		
			
				|  |  | -is **exported**, instead of copying the compiled libraries and headers, CMake
 | 
	
		
			
				|  |  | -creates an entry for the project in the
 | 
	
		
			
				|  |  | -`user's local CMake package registry <http://www.cmake.org/cmake/help/v3.2/manual/cmake-packages.7.html#user-package-registry>`_,
 | 
	
		
			
				|  |  | -``<USER_HOME>/.cmake/packages`` on Linux & OS X, which contains the path to
 | 
	
		
			
				|  |  | -the project's build directory which will be checked by CMake during a call to
 | 
	
		
			
				|  |  | -``find_package()``.  The effect of which is that any client code uses the
 | 
	
		
			
				|  |  | -compiled libraries and headers in the build directory directly, **thus not
 | 
	
		
			
				|  |  | -requiring the project to be installed to be used**.
 | 
	
		
			
				|  |  | +When a project is **installed**, the compiled libraries and headers
 | 
	
		
			
				|  |  | +are copied from the source & build directory to the install location,
 | 
	
		
			
				|  |  | +and it is these copied files that are used by any client code.  When a
 | 
	
		
			
				|  |  | +project's build directory is **exported**, instead of copying the
 | 
	
		
			
				|  |  | +compiled libraries and headers, CMake creates an entry for the project
 | 
	
		
			
				|  |  | +in the `user's local CMake package registry
 | 
	
		
			
				|  |  | +<http://www.cmake.org/cmake/help/v3.2/manual/cmake-packages.7.html#user-package-registry>`_,
 | 
	
		
			
				|  |  | +``<USER_HOME>/.cmake/packages`` on Linux & OS X, which contains the
 | 
	
		
			
				|  |  | +path to the project's build directory which will be checked by CMake
 | 
	
		
			
				|  |  | +during a call to ``find_package()``.  The effect of which is that any
 | 
	
		
			
				|  |  | +client code uses the compiled libraries and headers in the build
 | 
	
		
			
				|  |  | +directory directly, **thus not requiring the project to be installed
 | 
	
		
			
				|  |  | +to be used**.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Installing / Exporting a project that uses Ceres
 | 
	
		
			
				|  |  |  --------------------------------------------------
 | 
	
	
		
			
				|  | @@ -945,25 +995,28 @@ the ``CERES_LIBRARIES`` variable is the **name** of an imported target which
 | 
	
		
			
				|  |  |  represents Ceres.  If you are installing / exporting your *own* project which
 | 
	
		
			
				|  |  |  *uses* Ceres, it is important to understand that:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -**imported targets are not (re)exported when a project which imported them is
 | 
	
		
			
				|  |  | +**Imported targets are not (re)exported when a project which imported them is
 | 
	
		
			
				|  |  |  exported**.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Thus, when a project ``Foo`` which uses Ceres is exported, its list of
 | 
	
		
			
				|  |  | -dependencies as seen by another project ``Bar`` which imports ``Foo`` via:
 | 
	
		
			
				|  |  | -``find_package(Foo REQUIRED)`` will contain: ``ceres``.  However, the
 | 
	
		
			
				|  |  | -definition of ``ceres`` as an imported target is **not (re)exported** when Foo
 | 
	
		
			
				|  |  | -is exported.  Hence, without any additional steps, when processing ``Bar``,
 | 
	
		
			
				|  |  | -``ceres`` will not be defined as an imported target.  Thus, when processing
 | 
	
		
			
				|  |  | -``Bar``, CMake will assume that ``ceres`` refers only to:
 | 
	
		
			
				|  |  | -``libceres.a/so/dylib/lib`` (the compiled Ceres library) directly if it is on
 | 
	
		
			
				|  |  | -the current list of search paths.  In which case, no CMake errors will occur,
 | 
	
		
			
				|  |  | -but ``Bar`` will not link properly, as it does not have the required public link
 | 
	
		
			
				|  |  | -dependencies of Ceres, which are stored in the imported target defintion.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -The solution to this is for ``Foo`` (i.e., the project that uses Ceres) to
 | 
	
		
			
				|  |  | -invoke ``find_package(Ceres)`` in ``FooConfig.cmake``, thus ``ceres`` will be
 | 
	
		
			
				|  |  | -defined as an imported target when CMake processes ``Bar``.  An example of the
 | 
	
		
			
				|  |  | -required modifications to ``FooConfig.cmake`` are show below:
 | 
	
		
			
				|  |  | +dependencies as seen by another project ``Bar`` which imports ``Foo``
 | 
	
		
			
				|  |  | +via: ``find_package(Foo REQUIRED)`` will contain: ``ceres``.  However,
 | 
	
		
			
				|  |  | +the definition of ``ceres`` as an imported target is **not
 | 
	
		
			
				|  |  | +(re)exported** when Foo is exported.  Hence, without any additional
 | 
	
		
			
				|  |  | +steps, when processing ``Bar``, ``ceres`` will not be defined as an
 | 
	
		
			
				|  |  | +imported target.  Thus, when processing ``Bar``, CMake will assume
 | 
	
		
			
				|  |  | +that ``ceres`` refers only to: ``libceres.a/so/dylib/lib`` (the
 | 
	
		
			
				|  |  | +compiled Ceres library) directly if it is on the current list of
 | 
	
		
			
				|  |  | +search paths.  In which case, no CMake errors will occur, but ``Bar``
 | 
	
		
			
				|  |  | +will not link properly, as it does not have the required public link
 | 
	
		
			
				|  |  | +dependencies of Ceres, which are stored in the imported target
 | 
	
		
			
				|  |  | +defintion.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +The solution to this is for ``Foo`` (i.e., the project that uses
 | 
	
		
			
				|  |  | +Ceres) to invoke ``find_package(Ceres)`` in ``FooConfig.cmake``, thus
 | 
	
		
			
				|  |  | +``ceres`` will be defined as an imported target when CMake processes
 | 
	
		
			
				|  |  | +``Bar``.  An example of the required modifications to
 | 
	
		
			
				|  |  | +``FooConfig.cmake`` are show below:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. code-block:: cmake
 | 
	
		
			
				|  |  |  
 |