Go to the documentation of this file.00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 #ifndef _GRAPH_OPTIMIZER2D_AUX_HH_
00018 #define _GRAPH_OPTIMIZER2D_AUX_HH_
00019 
00020 #include "hogman_minimal/math/transformation.h"
00021 #include <set>
00022 #include <iostream>
00023 
00024 namespace AISNavigation {
00025   struct LoadedEdge{
00026     int id1, id2;
00027     Transformation2 mean;
00028     Matrix3 informationMatrix;
00029   };
00030 
00031   struct LoadedEdgeComparator{
00032     inline bool operator()(const LoadedEdge& e1, const LoadedEdge& e2){
00033       int i11=e1.id1, i12=e1.id2;
00034       if (i11>i12){
00035         i11=e1.id2;
00036       i12=e1.id1;
00037       }
00038       int i21=e2.id1, i22=e2.id2;
00039       if (i21>i22){
00040         i21=e2.id2;
00041         i22=e2.id1;
00042       }
00043       if (i12<i22)
00044         return true;
00045       if (i12>i22)
00046         return false;
00047       return (i11<i21);
00048     }
00049   };
00050 
00051   typedef std::set<LoadedEdge, LoadedEdgeComparator> LoadedEdgeSet;
00052 
00053   void loadEdges(LoadedEdgeSet& edges, std::istream& is, bool overrideCovariances=false);
00054 
00055 }
00056 #endif