1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
/*!
@authors Andrei Novikov (pyclustering@yandex.ru)
@date 2014-2020
@copyright BSD-3-Clause
*/
#include <gtest/gtest.h>
#include <pyclustering/interface/metric_interface.h>
#include <pyclustering/interface/pyclustering_package.hpp>
#include <pyclustering/utils/metric.hpp>
#include "utenv_utils.hpp"
#include <memory>
using namespace pyclustering;
using namespace pyclustering::utils::metric;
TEST(utest_interface_metric, euclidean) {
std::shared_ptr<pyclustering_package> arguments = pack(std::vector<double>());
double (*p_solver)(const void *, const void *) = nullptr;
void * metric_pointer = metric_create(metric_t::EUCLIDEAN, arguments.get(), p_solver);
ASSERT_NE(nullptr, metric_pointer);
std::shared_ptr<pyclustering_package> point1 = pack(point({1.0, 1.0}));
std::shared_ptr<pyclustering_package> point2 = pack(point({2.0, 1.0}));
double distance = metric_calculate(metric_pointer, point1.get(), point2.get());
ASSERT_EQ(1.0, distance);
metric_destroy(metric_pointer);
}
TEST(utest_interface_metric, gower) {
std::shared_ptr<pyclustering_package> arguments = pack(std::vector<double>({1.0, 0.0}));
double (*p_solver)(const void *, const void *) = nullptr;
void * metric_pointer = metric_create(metric_t::GOWER, arguments.get(), p_solver);
ASSERT_NE(nullptr, metric_pointer);
std::shared_ptr<pyclustering_package> point1 = pack(point({1.0, 1.0}));
std::shared_ptr<pyclustering_package> point2 = pack(point({2.0, 1.0}));
double distance = metric_calculate(metric_pointer, point1.get(), point2.get());
ASSERT_EQ(0.5, distance);
metric_destroy(metric_pointer);
}
|