Adding a test on LinearExtrapolation() method.

This commit is contained in:
Vladimir Byko-Ianko 2018-05-07 19:01:51 +03:00 committed by mpimenov
parent c827ff4d8f
commit 779b1a05ec
5 changed files with 121 additions and 11 deletions

View file

@ -20,14 +20,16 @@ double LinearExtrapolationOfOneParam(double param1, double param2, uint64_t time
{
return (param2 - param1) * timeAfterPoint2Ms / timeBetweenPointsMs;
}
} // namespace
/// \brief Returns extrapolated position after |point2| in |timeAfterPoint2Ms|.
/// \note This function is assumed that between |point1| and |point2| passed one second.
/// \note |timeAfterPoint2Ms| should be relevantly small (several seconds maximum).
location::GpsInfo LinearExtrapolation(location::GpsInfo const & point1, location::GpsInfo & point2,
namespace position_extrapolator
{
using namespace std;
location::GpsInfo LinearExtrapolation(location::GpsInfo const & point1, location::GpsInfo const & point2,
uint64_t timeAfterPoint2Ms)
{
uint64_t const timeBetweenPointsMs =
auto const timeBetweenPointsMs =
static_cast<uint64_t>((point2.m_timestamp - point1.m_timestamp) * 1000);
location::GpsInfo extrapolated = point2;
@ -66,14 +68,8 @@ location::GpsInfo LinearExtrapolation(location::GpsInfo const & point1, location
}
return extrapolated;
}
} // namespace
namespace position_extrapolator
{
using namespace std;
// Extrapolator::Routine ---------------------------------------------------------------------------
Extrapolator::Routine::Routine(ExtrapolatedLocationUpdate const & update)
: m_extrapolatedLocationUpdate(update)
{

View file

@ -12,6 +12,12 @@
namespace position_extrapolator
{
/// \brief Returns extrapolated position after |point2| in |timeAfterPoint2Ms|.
/// \note This function is assumed that between |point1| and |point2| passed one second.
/// \note |timeAfterPoint2Ms| should be relevantly small (several seconds maximum).
location::GpsInfo LinearExtrapolation(location::GpsInfo const & point1, location::GpsInfo const & point2,
uint64_t timeAfterPoint2Ms);
class Extrapolator
{
public:

View file

@ -10,6 +10,7 @@ set(
bookmarks_test.cpp
chart_generator_tests.cpp
cloud_tests.cpp
extrapolator_tests.cpp
feature_getters_tests.cpp
framework_light_tests.cpp
ge0_parser_tests.cpp

View file

@ -0,0 +1,103 @@
#include "testing/testing.hpp"
#include "map/extrapolation/extrapolator.hpp"
#include "platform/location.hpp"
#include "base/math.hpp"
namespace
{
using namespace location;
using namespace position_extrapolator;
void TestGpsInfo(GpsInfo const & tested, GpsInfo const & expected)
{
double constexpr kEpsilon = 1e-5;
TEST_EQUAL(tested.m_source, expected.m_source, ());
TEST(my::AlmostEqualAbs(tested.m_latitude, expected.m_latitude, kEpsilon), ());
TEST(my::AlmostEqualAbs(tested.m_longitude, expected.m_longitude, kEpsilon), ());
TEST(my::AlmostEqualAbs(tested.m_horizontalAccuracy, expected.m_horizontalAccuracy, kEpsilon), ());
TEST(my::AlmostEqualAbs(tested.m_altitude, expected.m_altitude, kEpsilon), ());
TEST(my::AlmostEqualAbs(tested.m_verticalAccuracy, expected.m_verticalAccuracy, kEpsilon), ());
TEST(my::AlmostEqualAbs(tested.m_bearing, expected.m_bearing, kEpsilon), ());
TEST(my::AlmostEqualAbs(tested.m_speed, expected.m_speed, kEpsilon), ());
}
UNIT_TEST(LinearExtrapolation)
{
GpsInfo const point1 = {EAppleNative,
0.0 /* m_timestamp in seconds */,
1.0 /* m_latitude */,
1.0 /* m_longitude */,
10.0 /* m_horizontalAccuracy */,
1.0 /* m_altitude */,
10.0 /* m_verticalAccuracy */,
0.0 /* m_bearing */,
10.0 /* m_speed */};
GpsInfo const point2 = {EAppleNative,
1.0 /* m_timestamp in seconds */,
1.01 /* m_latitude */,
1.01 /* m_longitude */,
11.0 /* m_horizontalAccuracy */,
2.0 /* m_altitude */,
10.0 /* m_verticalAccuracy */,
1.0 /* m_bearing */,
12.0 /* m_speed */};
// 0 ms after |point2|.
{
GpsInfo const expected = {EAppleNative,
1.0 /* m_timestamp */,
1.01 /* m_latitude */,
1.01 /* m_longitude */,
11.0 /* m_horizontalAccuracy */,
2.0 /* m_altitude */,
10.0 /* m_verticalAccuracy */,
1.0 /* m_bearing */,
12.0 /* m_speed */};
TestGpsInfo(LinearExtrapolation(point1, point2, 0 /* timeAfterPoint2Ms */), expected);
}
// 100 ms after |point2|.
{
GpsInfo const expected = {EAppleNative,
1.1 /* m_timestamp */,
1.011 /* m_latitude */,
1.011 /* m_longitude */,
11.1 /* m_horizontalAccuracy */,
2.1 /* m_altitude */,
10.0 /* m_verticalAccuracy */,
1.1 /* m_bearing */,
12.2 /* m_speed */};
TestGpsInfo(LinearExtrapolation(point1, point2, 100 /* timeAfterPoint2Ms */), expected);
}
// 200 ms after |point2|.
{
GpsInfo const expected = {EAppleNative,
1.2 /* m_timestamp */,
1.012 /* m_latitude */,
1.012 /* m_longitude */,
11.2 /* m_horizontalAccuracy */,
2.2 /* m_altitude */,
10.0 /* m_verticalAccuracy */,
1.2 /* m_bearing */,
12.4 /* m_speed */};
TestGpsInfo(LinearExtrapolation(point1, point2, 200 /* timeAfterPoint2Ms */), expected);
}
// 1000 ms after |point2|.
{
GpsInfo const expected = {EAppleNative,
2.0 /* m_timestamp */,
1.02 /* m_latitude */,
1.02 /* m_longitude */,
12.0 /* m_horizontalAccuracy */,
3.0 /* m_altitude */,
10.0 /* m_verticalAccuracy */,
2.0 /* m_bearing */,
14.0 /* m_speed */};
TestGpsInfo(LinearExtrapolation(point1, point2, 1000 /* timeAfterPoint2Ms */), expected);
}
}
} // namespace

View file

@ -95,6 +95,7 @@
47A9D82420A19EC300E4671B /* libkml.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 47A9D82320A19EC300E4671B /* libkml.a */; };
56C116602090E5670068BBC0 /* extrapolator.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 56C1165E2090E5670068BBC0 /* extrapolator.cpp */; };
56C116612090E5670068BBC0 /* extrapolator.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56C1165F2090E5670068BBC0 /* extrapolator.hpp */; };
56D1C15E20A0AB9D005C689E /* extrapolator_tests.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 56D1C15D20A0AB9D005C689E /* extrapolator_tests.cpp */; };
56EE14D31FE80E900036F20C /* libtransit.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 56EE14D41FE80E900036F20C /* libtransit.a */; };
56EE14D51FE80EBD0036F20C /* libmwm_diff.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 56EE14D61FE80EBD0036F20C /* libmwm_diff.a */; };
56EE14D71FE80F290036F20C /* libbsdiff.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 56EE14D81FE80F290036F20C /* libbsdiff.a */; };
@ -301,6 +302,7 @@
47A9D82320A19EC300E4671B /* libkml.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; path = libkml.a; sourceTree = BUILT_PRODUCTS_DIR; };
56C1165E2090E5670068BBC0 /* extrapolator.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = extrapolator.cpp; path = extrapolation/extrapolator.cpp; sourceTree = "<group>"; };
56C1165F2090E5670068BBC0 /* extrapolator.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; name = extrapolator.hpp; path = extrapolation/extrapolator.hpp; sourceTree = "<group>"; };
56D1C15D20A0AB9D005C689E /* extrapolator_tests.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = extrapolator_tests.cpp; sourceTree = "<group>"; };
56EE14D41FE80E900036F20C /* libtransit.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; path = libtransit.a; sourceTree = BUILT_PRODUCTS_DIR; };
56EE14D61FE80EBD0036F20C /* libmwm_diff.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; path = libmwm_diff.a; sourceTree = BUILT_PRODUCTS_DIR; };
56EE14D81FE80F290036F20C /* libbsdiff.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; path = libbsdiff.a; sourceTree = BUILT_PRODUCTS_DIR; };
@ -580,6 +582,7 @@
674A29CA1B26FCC0001A525C /* map_tests */ = {
isa = PBXGroup;
children = (
56D1C15D20A0AB9D005C689E /* extrapolator_tests.cpp */,
679624A01D1017C200AE4E3C /* address_tests.cpp */,
674A29CB1B26FCFE001A525C /* bookmarks_test.cpp */,
454523AB202A00B9009275C1 /* cloud_tests.cpp */,
@ -1033,6 +1036,7 @@
348AB57C1D7EE0C6009F8301 /* chart_generator.cpp in Sources */,
342D833A1D5233E8000D8AEA /* displacement_mode_manager.cpp in Sources */,
3D47B2C71F20EF06000828D2 /* displayed_categories_modifiers.cpp in Sources */,
56D1C15E20A0AB9D005C689E /* extrapolator_tests.cpp in Sources */,
45201E931CE4AC90008A4842 /* api_mark_point.cpp in Sources */,
F6FC3CB61FC323430001D929 /* discovery_manager.cpp in Sources */,
675346661A4054E800A0A8C3 /* ge0_parser.cpp in Sources */,