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