00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00038 #include <iostream>
00039 #include <sstream>
00040 #include <gtest/gtest.h>
00041 #include <pcl/features/narf.h>
00042 #include <pcl/common/transform.h>
00043
00044 using namespace pcl;
00045
00046 TEST (PCL, Narf_save_load)
00047 {
00048 Narf narf;
00049 getTransformation(1.0f, 2.0f, 3.0f, deg2rad(10.0f), deg2rad(20.0f), deg2rad(30.0f), narf.getTransformation());
00050 narf.getPosition() = getTranslation(narf.getTransformation().inverse());
00051 narf.getSurfacePatchPixelSize() = 10;
00052 narf.setSurfacePatch(new float[narf.getSurfacePatchPixelSize()*narf.getSurfacePatchPixelSize()]);
00053 for (int i=0; i<narf.getSurfacePatchPixelSize()*narf.getSurfacePatchPixelSize(); ++i)
00054 narf.getSurfacePatch()[i] = i;
00055 narf.getSurfacePatchWorldSize() = 0.5f;
00056 narf.getSurfacePatchRotation() = deg2rad(10.0f);
00057 narf.extractDescriptor(36);
00058
00059 std::stringstream test_stream;
00060 narf.saveBinary(test_stream);
00061
00062 Narf narf2;
00063 narf2.loadBinary(test_stream);
00064
00065
00066
00067
00068 for (int i=0; i<narf.getTransformation().matrix().size(); ++i)
00069 EXPECT_EQ (narf.getTransformation().data()[i], narf2.getTransformation().data()[i]);
00070 EXPECT_EQ (narf.getPosition(), narf2.getPosition());
00071 EXPECT_EQ (narf.getSurfacePatchPixelSize(), narf2.getSurfacePatchPixelSize());
00072 for (int i=0; i<narf.getSurfacePatchPixelSize()*narf.getSurfacePatchPixelSize(); ++i)
00073 EXPECT_EQ (narf.getSurfacePatch()[i], narf2.getSurfacePatch()[i]);
00074 EXPECT_EQ (narf.getSurfacePatchWorldSize(), narf2.getSurfacePatchWorldSize());
00075 EXPECT_EQ (narf.getSurfacePatchRotation(), narf2.getSurfacePatchRotation());
00076 EXPECT_EQ (narf.getDescriptorSize(), narf2.getDescriptorSize());
00077 for (int i=0; i<narf.getDescriptorSize(); ++i)
00078 EXPECT_EQ (narf.getDescriptor()[i], narf2.getDescriptor()[i]);
00079 }
00080
00081
00082 int
00083 main (int argc, char** argv)
00084 {
00085 testing::InitGoogleTest (&argc, argv);
00086 return (RUN_ALL_TESTS ());
00087 }
00088