00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017 #include "loadEdges3d.h"
00018
00019 #include <string>
00020 #include <sstream>
00021 using namespace std;
00022
00023 namespace AISNavigation {
00024
00025 void loadEdges3D(LoadedEdgeSet3D& edges, std::istream& is, bool overrideCovariances)
00026 {
00027 if (! is)
00028 return;
00029 string line;
00030 while (getline(is, line)) {
00031 if (line.size() > 0 && line[0] == '#')
00032 continue;
00033 istringstream ls(line);
00034 string tag;
00035 ls >> tag;
00036 if (tag == "EDGE3"){
00037 int id1, id2;
00038 Vector6 p;
00039 Matrix6 m;
00040 ls >> id1 >> id2 >> p.x() >> p.y() >> p.z() >> p.roll() >> p.pitch() >> p.yaw();
00041 if (overrideCovariances) {
00042 m = Matrix6::eye(1.0);
00043 } else {
00044 for (int i=0; i<6; i++)
00045 for (int j=i; j<6; j++) {
00046 ls >> m[i][j];
00047 if (i != j)
00048 m[j][i] = m[i][j];
00049 }
00050 }
00051
00052 LoadedEdge3D e;
00053 e.id1 = id1;
00054 e.id2 = id2;
00055 e.mean = Transformation3::fromVector(p);
00056 e.informationMatrix = m;
00057 edges.insert(e);
00058 }
00059
00060 else if (tag == "EDGE2") {
00061 int id1, id2;
00062 Vector6 p;
00063 Matrix6 m = Matrix6::eye(1.0) * 1e9;
00064 ls >> id1 >> id2 >> p.x() >> p.y() >> p.yaw();
00065 ls >> m[0][0] >> m[0][1] >> m[1][1] >> m[5][5] >> m[0][5] >> m[1][5];
00066 m[1][0] = m[0][1];
00067 m[5][0] = m[0][5];
00068 m[5][1] = m[1][5];
00069 LoadedEdge3D e;
00070 e.id1 = id1;
00071 e.id2 = id2;
00072 e.mean = Transformation3::fromVector(p);
00073 e.informationMatrix = m;
00074 edges.insert(e);
00075 }
00076 }
00077
00078 }
00079
00080 }