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 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
/*!
@authors Andrei Novikov (pyclustering@yandex.ru)
@date 2014-2020
@copyright BSD-3-Clause
*/
#include <gtest/gtest.h>
#include <pyclustering/interface/sync_interface.h>
#include <pyclustering/interface/pyclustering_interface.h>
#include <pyclustering/interface/pyclustering_package.hpp>
#include <pyclustering/nnet/sync.hpp>
#include "utenv_utils.hpp"
using namespace pyclustering::nnet;
static void CHECK_FREE_PACKAGE(pyclustering_package * package, const std::size_t size = 0) {
ASSERT_NE(nullptr, package);
if (size > 0)
ASSERT_EQ(size, package->size);
else
ASSERT_TRUE(package->size > 0);
free_pyclustering_package(package);
}
TEST(utest_interface_sync, sync_api) {
void * network_pointer = sync_create_network(10, 1, 0, (unsigned int) connection_t::CONNECTION_ALL_TO_ALL, (unsigned int) initial_type::EQUIPARTITION);
ASSERT_NE(nullptr, network_pointer);
std::size_t network_size = sync_get_size(network_pointer);
ASSERT_EQ(10U, network_size);
void * dynamic_pointer = sync_simulate_static(network_pointer, 20, 10, (unsigned int) solve_type::FORWARD_EULER, true);
ASSERT_NE(nullptr, dynamic_pointer);
void * dynamic_flexi_pointer = sync_simulate_dynamic(network_pointer, 0.99, (unsigned int) solve_type::FORWARD_EULER, true, 0.1, 0.01, 0.01);
ASSERT_GT(sync_dynamic_get_size(dynamic_flexi_pointer), 0U);
sync_dynamic_destroy(dynamic_flexi_pointer);
double order_parameter = sync_order(network_pointer);
ASSERT_LT(0.9, order_parameter);
double local_order_parameter = sync_local_order(network_pointer);
ASSERT_LT(0.9, local_order_parameter);
std::size_t dynamic_size = sync_dynamic_get_size(dynamic_pointer);
ASSERT_EQ(21U, dynamic_size);
pyclustering_package * package = sync_connectivity_matrix(network_pointer);
CHECK_FREE_PACKAGE(package, 10);
package = sync_dynamic_allocate_sync_ensembles(dynamic_pointer, 0.01, dynamic_size - 1);
CHECK_FREE_PACKAGE(package, 1);
package = sync_dynamic_allocate_correlation_matrix(dynamic_pointer, dynamic_size - 1);
CHECK_FREE_PACKAGE(package, 10);
package = sync_dynamic_get_time(dynamic_pointer);
CHECK_FREE_PACKAGE(package, 21);
package = sync_dynamic_get_output(dynamic_pointer);
CHECK_FREE_PACKAGE(package, 21);
package = sync_dynamic_calculate_order(dynamic_pointer, 0, dynamic_size);
CHECK_FREE_PACKAGE(package, dynamic_size);
package = sync_dynamic_calculate_local_order(dynamic_pointer, network_pointer, 0, dynamic_size);
CHECK_FREE_PACKAGE(package, dynamic_size);
sync_dynamic_destroy(dynamic_pointer);
sync_destroy_network(network_pointer);
}
|