482 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
		
		
			
		
	
	
			482 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
|  | #LyX 2.0 created this file. For more info see http://www.lyx.org/ | ||
|  | \lyxformat 413 | ||
|  | \begin_document | ||
|  | \begin_header | ||
|  | \textclass article | ||
|  | \begin_preamble | ||
|  | \usepackage{color} | ||
|  | 
 | ||
|  | \definecolor{mygreen}{rgb}{0,0.6,0} | ||
|  | \definecolor{mygray}{rgb}{0.5,0.5,0.5} | ||
|  | \definecolor{mymauve}{rgb}{0.58,0,0.82} | ||
|  | 
 | ||
|  | \lstset{ % | ||
|  |   backgroundcolor=\color{white},   % choose the background color; you must add \usepackage{color} or \usepackage{xcolor} | ||
|  |   basicstyle=\footnotesize,        % the size of the fonts that are used for the code | ||
|  |   breakatwhitespace=false,         % sets if automatic breaks should only happen at whitespace | ||
|  |   breaklines=true,                 % sets automatic line breaking | ||
|  |   captionpos=b,                    % sets the caption-position to bottom | ||
|  |   commentstyle=\color{mygreen},    % comment style | ||
|  | %  deletekeywords={...},            % if you want to delete keywords from the given language | ||
|  |   escapeinside={\%*}{*)},          % if you want to add LaTeX within your code | ||
|  |   extendedchars=true,              % lets you use non-ASCII characters; for 8-bits encodings only, does not work with UTF-8 | ||
|  |   frame=single,                    % adds a frame around the code | ||
|  |   keepspaces=true,                 % keeps spaces in text, useful for keeping indentation of code (possibly needs columns=flexible) | ||
|  |   keywordstyle=\color{blue},       % keyword style | ||
|  |   language=C++,                 % the language of the code | ||
|  |   morekeywords={*,...},            % if you want to add more keywords to the set | ||
|  |   numbers=left,                    % where to put the line-numbers; possible values are (none, left, right) | ||
|  |   numbersep=5pt,                   % how far the line-numbers are from the code | ||
|  |   numberstyle=\tiny\color{mygray}, % the style that is used for the line-numbers | ||
|  |   rulecolor=\color{black},         % if not set, the frame-color may be changed on line-breaks within not-black text (e.g. comments (green here)) | ||
|  |   showspaces=false,                % show spaces everywhere adding particular underscores; it overrides 'showstringspaces' | ||
|  |   showstringspaces=false,          % underline spaces within strings only | ||
|  |   showtabs=false,                  % show tabs within strings adding particular underscores | ||
|  |   stepnumber=2,                    % the step between two line-numbers. If it's 1, each line will be numbered | ||
|  |   stringstyle=\color{mymauve},     % string literal style | ||
|  |   tabsize=2,                       % sets default tabsize to 2 spaces | ||
|  |   title=\lstname                   % show the filename of files included with \lstinputlisting; also try caption instead of title | ||
|  | } | ||
|  | \end_preamble | ||
|  | \use_default_options true | ||
|  | \maintain_unincluded_children false | ||
|  | \language english | ||
|  | \language_package default | ||
|  | \inputencoding auto | ||
|  | \fontencoding global | ||
|  | \font_roman lmodern | ||
|  | \font_sans lmss | ||
|  | \font_typewriter lmtt | ||
|  | \font_default_family default | ||
|  | \use_non_tex_fonts false | ||
|  | \font_sc false | ||
|  | \font_osf false | ||
|  | \font_sf_scale 100 | ||
|  | \font_tt_scale 100 | ||
|  | 
 | ||
|  | \graphics default | ||
|  | \default_output_format default | ||
|  | \output_sync 0 | ||
|  | \bibtex_command default | ||
|  | \index_command default | ||
|  | \paperfontsize default | ||
|  | \spacing single | ||
|  | \use_hyperref false | ||
|  | \papersize default | ||
|  | \use_geometry false | ||
|  | \use_amsmath 1 | ||
|  | \use_esint 1 | ||
|  | \use_mhchem 1 | ||
|  | \use_mathdots 1 | ||
|  | \cite_engine basic | ||
|  | \use_bibtopic false | ||
|  | \use_indices false | ||
|  | \paperorientation portrait | ||
|  | \suppress_date false | ||
|  | \use_refstyle 1 | ||
|  | \index Index | ||
|  | \shortcut idx | ||
|  | \color #008000 | ||
|  | \end_index | ||
|  | \secnumdepth 3 | ||
|  | \tocdepth 3 | ||
|  | \paragraph_separation indent | ||
|  | \paragraph_indentation default | ||
|  | \quotes_language english | ||
|  | \papercolumns 1 | ||
|  | \papersides 1 | ||
|  | \paperpagestyle default | ||
|  | \tracking_changes false | ||
|  | \output_changes false | ||
|  | \html_math_output 0 | ||
|  | \html_css_as_file 0 | ||
|  | \html_be_strict false | ||
|  | \end_header | ||
|  | 
 | ||
|  | \begin_body | ||
|  | 
 | ||
|  | \begin_layout Section | ||
|  | Template Classes | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Standard | ||
|  | Templated classes are great for writing generic code for multiple types | ||
|  |  (e.g. | ||
|  |  the same elimination algorithm code for symbolic, discrete, and Gaussian | ||
|  |  elimination) without the drawbacks of virtual inheritance (which include | ||
|  |  rigid class interfaces, downcasting from returned base class pointers, | ||
|  |  and additional runtime overhead). | ||
|  |  Depending on how they're used, though, templates can result in very slow | ||
|  |  compile times, large binary files, and hard-to-use code. | ||
|  |  This section describes the  | ||
|  | \begin_inset Quotes eld | ||
|  | \end_inset | ||
|  | 
 | ||
|  | best practices | ||
|  | \begin_inset Quotes erd | ||
|  | \end_inset | ||
|  | 
 | ||
|  |  we have developed for gaining the benefits of templates without the drawbacks. | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Standard | ||
|  | If you need to write generic code or classes, here are several programming | ||
|  |  patterns we have found to work very well: | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Subsection | ||
|  | The  | ||
|  | \begin_inset Quotes eld | ||
|  | \end_inset | ||
|  | 
 | ||
|  | Templated Base, Specialized Derived | ||
|  | \begin_inset Quotes erd | ||
|  | \end_inset | ||
|  | 
 | ||
|  |  Pattern | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Standard | ||
|  | This pattern is for when you have a generic class containing algorithm or | ||
|  |  data structure code that will be specialized to several types. | ||
|  |  The templated base class should never be used directly, instead only the | ||
|  |  specializations should be used. | ||
|  |  Some specialized types can be pre-compiled into the library, but the option | ||
|  |  remains to specialize new types in external libraries or projects. | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Subsubsection | ||
|  | Basic Class Structure | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Standard | ||
|  | We'll use  | ||
|  | \family typewriter | ||
|  | FactorGraph | ||
|  | \family default | ||
|  |  as an example. | ||
|  |  It is templated on the factor type stored in it and has several specializations. | ||
|  |  The templated base class  | ||
|  | \family typewriter | ||
|  | FactorGraph<class FACTOR> | ||
|  | \family default | ||
|  |  is divided into a header file ( | ||
|  | \family typewriter | ||
|  | .h | ||
|  | \family default | ||
|  | ) and an  | ||
|  | \begin_inset Quotes eld | ||
|  | \end_inset | ||
|  | 
 | ||
|  | instantiation | ||
|  | \begin_inset Quotes erd | ||
|  | \end_inset | ||
|  | 
 | ||
|  |  file ( | ||
|  | \family typewriter | ||
|  | -inst.h | ||
|  | \family default | ||
|  | ). | ||
|  |  The basic class structure is as follows. | ||
|  | \begin_inset listings | ||
|  | lstparams "basicstyle={\scriptsize\ttfamily},language={C++}" | ||
|  | inline false | ||
|  | status open | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | // File FactorGraph.h | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | %* | ||
|  | \backslash | ||
|  | bfseries{ | ||
|  | \backslash | ||
|  | emph{ | ||
|  | \backslash | ||
|  | color{red}{// Include a minimal set of headers. | ||
|  |   Do not include any '-inst.h' files (this is the key to fast compiles).}}}*) | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | #include <boost/serialization/nvp.hpp> | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | ... | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | namespace gtsam { | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   /** Class description */ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   template<class FACTOR> | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   class FactorGraph | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   { | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   %* | ||
|  | \backslash | ||
|  | bfseries{ | ||
|  | \backslash | ||
|  | emph{ | ||
|  | \backslash | ||
|  | color{red}{// Make 'private' any typedefs that must be redefined in derived | ||
|  |  classes. | ||
|  |   E.g. | ||
|  |  'This' in the context of the derived class should refer to the derived | ||
|  |  class. | ||
|  |   These typedefs will be used only by the generic code in this base class.}}}*) | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   private: | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     typedef FactorGraph<FACTOR> This;  ///< Typedef for this class | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     typedef boost::shared_ptr<This> shared_ptr;  ///< Shared pointer to | ||
|  |  this | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |      | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   %* | ||
|  | \backslash | ||
|  | bfseries{ | ||
|  | \backslash | ||
|  | emph{ | ||
|  | \backslash | ||
|  | color{red}{// Make 'public' the typedefs that will be valid in the derived | ||
|  |  class.}}}*) | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   public: | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     typedef FACTOR FactorType; ///< Factor type stored in this graph | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     typedef boost::shared_ptr<FACTOR> sharedFactor; ///< Shared pointer | ||
|  |  to a factor | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     ... | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   %* | ||
|  | \backslash | ||
|  | bfseries{ | ||
|  | \backslash | ||
|  | emph{ | ||
|  | \backslash | ||
|  | color{red}{// Normally, data is 'protected' so the derived class can access | ||
|  |  it.}}}*) | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   protected: | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /** Collection of factors */ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     std::vector<sharedFactor> factors_; | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   %* | ||
|  | \backslash | ||
|  | bfseries{ | ||
|  | \backslash | ||
|  | emph{ | ||
|  | \backslash | ||
|  | color{red}{// Make 'protected' all constructors, named constructors, or | ||
|  |  methods returning the base class type. | ||
|  |   These are not public - the derived class will call them and properly convert | ||
|  |  returned base classes to the derived class.}}}*) | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /// @name Standard Constructors | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /// @{ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /** Default constructor */ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     FactorGraphUnordered() {} | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /** Named constructor from iterator over factors */ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     template<typename ITERATOR> | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     static This FromIterator(ITERATOR firstFactor, ITERATOR lastFactor); | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /// @} | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   %* | ||
|  | \backslash | ||
|  | bfseries{ | ||
|  | \backslash | ||
|  | emph{ | ||
|  | \backslash | ||
|  | color{red}{// Make 'public' standard methods that will be available in the | ||
|  |  derived class's API.}}}*) | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   public: | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /// @name Adding Factors | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /// @{ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /** ... | ||
|  |  */ | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     void reserve(size_t size); | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     ... | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |     /// @} | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  |   }; | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \begin_layout Plain Layout | ||
|  | 
 | ||
|  | } | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \end_inset | ||
|  | 
 | ||
|  | 
 | ||
|  | \end_layout | ||
|  | 
 | ||
|  | \end_body | ||
|  | \end_document |