gtsam/base/TestableAssertions.h

35 lines
779 B
C++

/**
* @file TestableAssertions.h
* @brief Provides additional testing facilities for common data structures
* @author Alex Cunningham
*/
#pragma once
#include <vector>
#include <boost/foreach.hpp>
#include <gtsam/base/Testable.h>
namespace gtsam {
/**
* Version of assert_equals to work with vectors
*/
template<class V>
bool assert_equal(const std::vector<V>& expected, const std::vector<V>& actual, double tol = 1e-9) {
if (expected.size() != actual.size()) {
printf("Sizes not equal:\n");
printf("expected size: %lu\n", expected.size());
printf("actual size: %lu\n", actual.size());
return false;
}
size_t i = 0;
BOOST_FOREACH(const V& a, expected) {
if (!assert_equal(a, expected[i++], tol))
return false;
}
return true;
}
} // \namespace gtsam