icl/test/test_interval_set_mixed.hpp
2017-12-05 19:21:36 +01:00

851 lines
30 KiB
C++

/*-----------------------------------------------------------------------------+
Copyright (c) 2008-2009: Joachim Faulhaber
+------------------------------------------------------------------------------+
Distributed under the Boost Software License, Version 1.0.
(See accompanying file LICENCE.txt or copy at
http://www.boost.org/LICENSE_1_0.txt)
+-----------------------------------------------------------------------------*/
#ifndef LIBS_ICL_TEST_TEST_INTERVAL_SET_MIXED_HPP_JOFA_090702
#define LIBS_ICL_TEST_TEST_INTERVAL_SET_MIXED_HPP_JOFA_090702
template <class T>
void interval_set_mixed_ctor_4_ordered_types()
{
T v0 = boost::icl::identity_element<T>::value();
split_interval_set<T> split_set(v0);
separate_interval_set<T> sep_set(split_set);
interval_set<T> join_set(sep_set);
BOOST_CHECK_EQUAL( hull(split_set).lower(), hull(sep_set).lower() );
BOOST_CHECK_EQUAL( hull(split_set).lower(), hull(join_set).lower() );
}
template <class T>
void interval_set_mixed_equal_4_ordered_types()
{
T v0 = boost::icl::identity_element<T>::value();
split_interval_set<T> split_empty, split_single(v0);
separate_interval_set<T> sep_empty, sep_single(v0);
interval_set<T> join_empty, join_single(v0);
// mixed ==-equality is a strange thing. Most times is does not
// make sense. It is better to allow only for same type == equality.
BOOST_CHECK_EQUAL( split_empty == split_empty, true );
BOOST_CHECK_EQUAL( sep_empty == sep_empty, true );
BOOST_CHECK_EQUAL( join_empty == join_empty, true );
// There were Problems with operator== and emtpy sets.
BOOST_CHECK_EQUAL( split_empty == split_single, false );
BOOST_CHECK_EQUAL( sep_empty == sep_single, false );
BOOST_CHECK_EQUAL( join_empty == join_single, false );
BOOST_CHECK_EQUAL( split_single == split_empty, false );
BOOST_CHECK_EQUAL( sep_single == sep_empty, false );
BOOST_CHECK_EQUAL( join_single == join_empty, false );
BOOST_CHECK_EQUAL( is_element_equal(split_empty, split_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(split_empty, sep_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(split_empty, join_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_empty, split_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_empty, sep_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_empty, join_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(join_empty, split_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(join_empty, sep_empty), true );
BOOST_CHECK_EQUAL( is_element_equal(join_empty, join_empty), true );
//--------------------------------------------------------------------------
BOOST_CHECK_EQUAL( is_element_equal(split_empty, split_single), false );
BOOST_CHECK_EQUAL( is_element_equal(split_empty, sep_single), false );
BOOST_CHECK_EQUAL( is_element_equal(split_empty, join_single), false );
BOOST_CHECK_EQUAL( is_element_equal(sep_empty, split_single), false );
BOOST_CHECK_EQUAL( is_element_equal(sep_empty, sep_single), false );
BOOST_CHECK_EQUAL( is_element_equal(sep_empty, join_single), false );
BOOST_CHECK_EQUAL( is_element_equal(join_empty, split_single), false );
BOOST_CHECK_EQUAL( is_element_equal(join_empty, sep_single), false );
BOOST_CHECK_EQUAL( is_element_equal(join_empty, join_single), false );
//--------------------------------------------------------------------------
BOOST_CHECK_EQUAL( is_element_equal(split_single, split_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(split_single, sep_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(split_single, join_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(sep_single, split_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(sep_single, sep_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(sep_single, join_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(join_single, split_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(join_single, sep_empty), false );
BOOST_CHECK_EQUAL( is_element_equal(join_single, join_empty), false );
}
template <class T>
void interval_set_mixed_assign_4_ordered_types()
{
T v0 = boost::icl::identity_element<T>::value();
T v1 = unit_element<T>::value();
split_interval_set<T> split_set;
separate_interval_set<T> sep_set;
interval_set<T> join_set;
split_set.add(v0);
sep_set = split_set;
join_set = sep_set;
BOOST_CHECK_EQUAL( hull(split_set).lower(), hull(sep_set).lower() );
BOOST_CHECK_EQUAL( hull(split_set).lower(), hull(join_set).lower() );
split_interval_set<T> split_self = split_interval_set<T>().add(v0);
separate_interval_set<T> sep_self = separate_interval_set<T>().add(v0).add(v1);
interval_set<T> join_self = interval_set<T>().add(v1);
split_self = split_self;
sep_self = sep_self;
join_self = join_self;
BOOST_CHECK_EQUAL( split_self, split_self );
BOOST_CHECK_EQUAL( sep_self, sep_self );
BOOST_CHECK_EQUAL( join_self, join_self );
}
template <class T>
void interval_set_mixed_ctor_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v1 = make<T>(1);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
IntervalT I1_3D = IntervalT::right_open(v1,v3);
IntervalT I2_4D = IntervalT::right_open(v2,v4);
IntervalT I4_5D = IntervalT::right_open(v4,v5);
split_interval_set<T> split_set;
split_set.add(I1_3D).add(I2_4D).add(I4_5D);
BOOST_CHECK_EQUAL( split_set.iterative_size(), 4 );
separate_interval_set<T> sep_set(split_set);
BOOST_CHECK_EQUAL( sep_set.iterative_size(), 4 );
interval_set<T> join_set(split_set);
BOOST_CHECK_EQUAL( join_set.iterative_size(), 1 );
separate_interval_set<T> sep_set2;
sep_set2.add(I1_3D).add(I2_4D).add(I4_5D);
BOOST_CHECK_EQUAL( sep_set2.iterative_size(), 2 );
split_interval_set<T> split_set2(sep_set2);
BOOST_CHECK_EQUAL( split_set2.iterative_size(), 2 );
interval_set<T> join_set2(sep_set2);
BOOST_CHECK_EQUAL( join_set2.iterative_size(), 1 );
}
template <class T>
void interval_set_mixed_assign_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v1 = make<T>(1);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
IntervalT I1_3D = IntervalT::right_open(v1,v3);
IntervalT I2_4D = IntervalT::right_open(v2,v4);
IntervalT I4_5D = IntervalT::right_open(v4,v5);
split_interval_set<T> split_set;
split_set.add(I1_3D).add(I2_4D).add(I4_5D);
BOOST_CHECK_EQUAL( split_set.iterative_size(), 4 );
separate_interval_set<T> sep_set;
sep_set = split_set;
BOOST_CHECK_EQUAL( sep_set.iterative_size(), 4 );
interval_set<T> join_set;
join_set = split_set;
BOOST_CHECK_EQUAL( join_set.iterative_size(), 1 );
separate_interval_set<T> sep_set2;
sep_set2.add(I1_3D).add(I2_4D).add(I4_5D);
BOOST_CHECK_EQUAL( sep_set2.iterative_size(), 2 );
split_interval_set<T> split_set2;
split_set2 = sep_set2;
BOOST_CHECK_EQUAL( split_set2.iterative_size(), 2 );
interval_set<T> join_set2;
join_set2 = sep_set2;
BOOST_CHECK_EQUAL( join_set2.iterative_size(), 1 );
}
template <class T>
void interval_set_mixed_equal_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v1 = make<T>(1);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
IntervalT I1_3D = IntervalT::right_open(v1,v3);
IntervalT I2_4D = IntervalT::right_open(v2,v4);
IntervalT I4_5D = IntervalT::right_open(v4,v5);
interval_set<T> join_set;
join_set.add(I1_3D).add(I2_4D).add(I4_5D);
interval_set<T> join_set2 = join_set;
BOOST_CHECK_EQUAL( join_set, join_set2 );
BOOST_CHECK_EQUAL( is_element_equal(join_set, join_set2), true );
separate_interval_set<T> sep_set;
sep_set.add(I1_3D).add(I2_4D).add(I4_5D);
separate_interval_set<T> sep_set2 = sep_set;
BOOST_CHECK_EQUAL( sep_set, sep_set2 );
BOOST_CHECK_EQUAL( is_element_equal(sep_set2, sep_set), true );
split_interval_set<T> split_set;
split_set.add(I1_3D).add(I2_4D).add(I4_5D);
split_interval_set<T> split_set2 = split_set;
BOOST_CHECK_EQUAL( split_set, split_set2 );
BOOST_CHECK_EQUAL( is_element_equal(split_set2, split_set), true );
BOOST_CHECK_EQUAL( is_element_equal(split_set, join_set), true );
BOOST_CHECK_EQUAL( is_element_equal(split_set, sep_set), true );
BOOST_CHECK_EQUAL( is_element_equal(join_set, sep_set), true );
BOOST_CHECK_EQUAL( is_element_equal(join_set, split_set), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_set, join_set), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_set, split_set), true );
}
template <class T>
void interval_set_mixed_contains_4_bicremental_types()
{
split_interval_set<T> split_set;
split_set.add(I_D(0,4)).add(I_D(4,8));
BOOST_CHECK_EQUAL( icl::contains(split_set, MK_v(4)), true );
BOOST_CHECK_EQUAL( icl::contains(split_set, C_D(2,5)), true );
interval_set<T> join_set_gap4(split_set.erase(MK_v(4)));
BOOST_CHECK_EQUAL( icl::contains(join_set_gap4, MK_v(4)), false );
BOOST_CHECK_EQUAL( icl::contains(join_set_gap4, C_D(2,5)), false );
BOOST_CHECK_EQUAL( icl::contains(split_set, split_set), true );
BOOST_CHECK_EQUAL( icl::contains(split_set, join_set_gap4), true );
}
template <class T>
void interval_set_mixed_add_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v1 = make<T>(1);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
IntervalT I1_3D = IntervalT::right_open(v1,v3);
IntervalT I2_4D = IntervalT::right_open(v2,v4);
IntervalT I4_5D = IntervalT::right_open(v4,v5);
split_interval_set<T> split_set;
split_set.add(I1_3D).add(I2_4D);
split_set += I4_5D;
BOOST_CHECK_EQUAL( split_set.iterative_size(), 4 );
separate_interval_set<T> sep_set;
sep_set += split_set;
BOOST_CHECK_EQUAL( sep_set.iterative_size(), 4 );
interval_set<T> join_set;
join_set += split_set;
BOOST_CHECK_EQUAL( join_set.iterative_size(), 1 );
separate_interval_set<T> sep_set2;
sep_set2.add(I1_3D).add(I2_4D);
sep_set2 += I4_5D;
BOOST_CHECK_EQUAL( sep_set2.iterative_size(), 2 );
split_interval_set<T> split_set2;
split_set2 += sep_set2;
BOOST_CHECK_EQUAL( split_set2.iterative_size(), 2 );
interval_set<T> join_set2;
join_set2 += sep_set2;
BOOST_CHECK_EQUAL( join_set2.iterative_size(), 1 );
interval_set<T> join_set3;
join_set3.add(v1).add(v3);
join_set3 += v5;
BOOST_CHECK_EQUAL( join_set3.iterative_size(), 3 );
split_interval_set<T> split_set3;
split_set3 += join_set3;
BOOST_CHECK_EQUAL( split_set3.iterative_size(), 3 );
separate_interval_set<T> sep_set3;
sep_set3 += join_set3;
BOOST_CHECK_EQUAL( join_set3.iterative_size(), 3 );
}
template <class T>
void interval_set_mixed_subtract_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v0 = make<T>(0);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
T v6 = make<T>(6);
T v7 = make<T>(7);
T v8 = make<T>(8);
T v9 = make<T>(9);
IntervalT I0_4D = IntervalT::right_open(v0,v4);
IntervalT I2_6D = IntervalT::right_open(v2,v6);
IntervalT I3_6D = IntervalT::right_open(v3,v6);
IntervalT I5_7D = IntervalT::right_open(v5,v7);
IntervalT I7_8D = IntervalT::right_open(v7,v8);
IntervalT I8_9D = IntervalT::right_open(v8,v9);
IntervalT I8_9I = IntervalT::closed(v8,v9);
split_interval_set<T> split_set;
split_set.add(I0_4D).add(I2_6D).add(I5_7D).add(I7_8D).add(I8_9I);
BOOST_CHECK_EQUAL( split_set.iterative_size(), 7 );
separate_interval_set<T> sep_set;
sep_set.add(I0_4D).add(I2_6D).add(I5_7D).add(I7_8D).add(I8_9I);
BOOST_CHECK_EQUAL( sep_set.iterative_size(), 3 );
interval_set<T> join_set;
join_set.add(I0_4D).add(I2_6D).add(I5_7D).add(I7_8D).add(I8_9I);
BOOST_CHECK_EQUAL( join_set.iterative_size(), 1 );
// Make sets to be subtracted
split_interval_set<T> split_sub;
split_sub.add(I3_6D).add(I8_9D);
separate_interval_set<T> sep_sub;
sep_sub.add(I3_6D).add(I8_9D);
interval_set<T> join_sub;
join_sub.add(I3_6D).add(I8_9D);
//--------------------------------------------------------------------------
// Test for split_interval_set
split_interval_set<T> split_diff = split_set;
separate_interval_set<T> sep_diff = sep_set;
interval_set<T> join_diff = join_set;
//subtraction combinations
split_diff -= split_sub;
sep_diff -= split_sub;
join_diff -= split_sub;
BOOST_CHECK_EQUAL( split_diff.iterative_size(), 5 );
BOOST_CHECK_EQUAL( sep_diff.iterative_size(), 4 );
BOOST_CHECK_EQUAL( join_diff.iterative_size(), 3 );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, split_diff), true );
//--------------------------------------------------------------------------
// Test for separate_interval_set. Reinitialize
split_diff = split_set;
sep_diff = sep_set;
join_diff = join_set;
//subtraction combinations
split_diff -= sep_sub;
sep_diff -= sep_sub;
join_diff -= sep_sub;
BOOST_CHECK_EQUAL( split_diff.iterative_size(), 5 );
BOOST_CHECK_EQUAL( sep_diff.iterative_size(), 4 );
BOOST_CHECK_EQUAL( join_diff.iterative_size(), 3 );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, sep_diff), true );
//--------------------------------------------------------------------------
// Test for interval_set. Reinitialize
split_diff = split_set;
sep_diff = sep_set;
join_diff = join_set;
//subtraction combinations
split_diff -= join_sub;
sep_diff -= join_sub;
join_diff -= join_sub;
BOOST_CHECK_EQUAL( split_diff.iterative_size(), 5 );
BOOST_CHECK_EQUAL( sep_diff.iterative_size(), 4 );
BOOST_CHECK_EQUAL( join_diff.iterative_size(), 3 );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, join_diff), true );
}
template <class T>
void interval_set_mixed_erase_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v0 = make<T>(0);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
T v6 = make<T>(6);
T v7 = make<T>(7);
T v8 = make<T>(8);
T v9 = make<T>(9);
IntervalT I0_4D = IntervalT::right_open(v0,v4);
IntervalT I2_6D = IntervalT::right_open(v2,v6);
IntervalT I3_6D = IntervalT::right_open(v3,v6);
IntervalT I5_7D = IntervalT::right_open(v5,v7);
IntervalT I7_8D = IntervalT::right_open(v7,v8);
IntervalT I8_9D = IntervalT::right_open(v8,v9);
IntervalT I8_9I = IntervalT::closed(v8,v9);
split_interval_set<T> split_set;
split_set.add(I0_4D).add(I2_6D).add(I5_7D).add(I7_8D).add(I8_9I);
BOOST_CHECK_EQUAL( split_set.iterative_size(), 7 );
separate_interval_set<T> sep_set;
sep_set.add(I0_4D).add(I2_6D).add(I5_7D).add(I7_8D).add(I8_9I);
BOOST_CHECK_EQUAL( sep_set.iterative_size(), 3 );
interval_set<T> join_set;
join_set.add(I0_4D).add(I2_6D).add(I5_7D).add(I7_8D).add(I8_9I);
BOOST_CHECK_EQUAL( join_set.iterative_size(), 1 );
// Make sets to be subtracted
split_interval_set<T> split_sub;
split_sub.add(I3_6D).add(I8_9D);
separate_interval_set<T> sep_sub;
sep_sub.add(I3_6D).add(I8_9D);
interval_set<T> join_sub;
join_sub.add(I3_6D).add(I8_9D);
//--------------------------------------------------------------------------
// Test for split_interval_set
split_interval_set<T> split_diff = split_set;
separate_interval_set<T> sep_diff = sep_set;
interval_set<T> join_diff = join_set;
//subtraction combinations
erase(split_diff, split_sub);
erase(sep_diff, split_sub);
erase(join_diff, split_sub);
BOOST_CHECK_EQUAL( split_diff.iterative_size(), 5 );
BOOST_CHECK_EQUAL( sep_diff.iterative_size(), 4 );
BOOST_CHECK_EQUAL( join_diff.iterative_size(), 3 );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, split_diff), true );
//--------------------------------------------------------------------------
// Test for separate_interval_set. Reinitialize
split_diff = split_set;
sep_diff = sep_set;
join_diff = join_set;
//subtraction combinations
erase(split_diff, sep_sub);
erase(sep_diff, sep_sub);
erase(join_diff, sep_sub);
BOOST_CHECK_EQUAL( split_diff.iterative_size(), 5 );
BOOST_CHECK_EQUAL( sep_diff.iterative_size(), 4 );
BOOST_CHECK_EQUAL( join_diff.iterative_size(), 3 );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(split_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, sep_diff), true );
//--------------------------------------------------------------------------
// Test for interval_set. Reinitialize
split_diff = split_set;
sep_diff = sep_set;
join_diff = join_set;
//subtraction combinations
erase(split_diff, join_sub);
erase(sep_diff, join_sub);
erase(join_diff, join_sub);
BOOST_CHECK_EQUAL( split_diff.iterative_size(), 5 );
BOOST_CHECK_EQUAL( sep_diff.iterative_size(), 4 );
BOOST_CHECK_EQUAL( join_diff.iterative_size(), 3 );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, split_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, sep_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(sep_diff, join_diff), true );
BOOST_CHECK_EQUAL( is_element_equal(join_diff, join_diff), true );
}
template <class T>
void interval_set_mixed_basic_intersect_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v0 = make<T>(0);
T v1 = make<T>(1);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v6 = make<T>(6);
T v7 = make<T>(7);
T v8 = make<T>(8);
T v9 = make<T>(9);
IntervalT I0_3D = IntervalT::right_open(v0,v3);
IntervalT I1_3D = IntervalT::right_open(v1,v3);
IntervalT I1_8D = IntervalT::right_open(v1,v8);
IntervalT I2_7D = IntervalT::right_open(v2,v7);
IntervalT I2_3D = IntervalT::right_open(v2,v3);
IntervalT I6_7D = IntervalT::right_open(v6,v7);
IntervalT I6_8D = IntervalT::right_open(v6,v8);
IntervalT I6_9D = IntervalT::right_open(v6,v9);
//--------------------------------------------------------------------------
// split_interval_set
//--------------------------------------------------------------------------
//split_A [0 3) [6 9)
// &= [1 8)
//split_AB -> [1 3) [6 8)
// &= [2 7)
// -> [2 3) [6 7)
split_interval_set<T> split_A, split_B, split_AB, split_ab, split_ab2;
split_A.add(I0_3D).add(I6_9D);
split_AB = split_A;
split_AB &= I1_8D;
split_ab.add(I1_3D).add(I6_8D);
BOOST_CHECK_EQUAL( split_AB, split_ab );
split_AB = split_A;
(split_AB &= I1_8D) &= I2_7D;
split_ab2.add(I2_3D).add(I6_7D);
BOOST_CHECK_EQUAL( split_AB, split_ab2 );
//--------------------------------------------------------------------------
//split_A [0 3) [6 9)
// &= 1
//split_AB -> [1]
// += (1 7)
// -> [1](1 7)
split_A.add(I0_3D).add(I6_9D);
split_AB = split_A;
split_AB &= v1;
split_ab.clear();
split_ab.add(v1);
BOOST_CHECK_EQUAL( split_AB, split_ab );
split_AB = split_A;
(split_AB &= v1) += IntervalT::open(v1,v7);
split_ab2.clear();
split_ab2 += IntervalT::right_open(v1,v7);
BOOST_CHECK_EQUAL( is_element_equal(split_AB, split_ab2), true );
}
template <class T>
void interval_set_mixed_intersect_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v0 = make<T>(0);
T v1 = make<T>(1);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v5 = make<T>(5);
T v6 = make<T>(6);
T v8 = make<T>(8);
T v9 = make<T>(9);
IntervalT I0_3D = IntervalT::right_open(v0,v3);
IntervalT I1_2D = IntervalT::right_open(v1,v2);
IntervalT I1_3D = IntervalT::right_open(v1,v3);
IntervalT I2_3D = IntervalT::right_open(v2,v3);
IntervalT I2_4D = IntervalT::right_open(v2,v4);
IntervalT I5_8D = IntervalT::right_open(v5,v8);
IntervalT I6_8D = IntervalT::right_open(v6,v8);
IntervalT I6_9D = IntervalT::right_open(v6,v9);
//--------------------------------------------------------------------------
// split_interval_set
//--------------------------------------------------------------------------
//split_A [0 3) [6 9)
//split_B &= [1 2)[2 4) [5 8)
//split_AB -> [1 2)[2 3) [6 8)
split_interval_set<T> split_A, split_B, split_AB, split_ab, split_ab_jn;
separate_interval_set<T> sep_A, sep_B, sep_AB, sep_ab;
interval_set<T> join_A, join_B, join_AB, join_ab;
split_A.add(I0_3D).add(I6_9D);
split_B.add(I1_2D).add(I2_4D).add(I5_8D);
split_ab.add(I1_2D).add(I2_3D).add(I6_8D);
split_ab_jn.add(I1_3D).add(I6_8D);
split_AB = split_A;
split_AB &= split_B;
BOOST_CHECK_EQUAL( split_AB.iterative_size(), 3 );
BOOST_CHECK_EQUAL( split_AB, split_ab );
//split_A [0 3) [6 9)
//sep_B &= [1 2)[2 4) [5 8)
//split_AB -> [1 2)[2 3) [6 8)
split_AB = split_A;
sep_B = split_B;
split_AB &= sep_B;
BOOST_CHECK_EQUAL( split_AB.iterative_size(), 3 );
BOOST_CHECK_EQUAL( split_AB, split_ab );
//split_A [0 3) [6 9)
//join_B &= [1 4) [5 8)
//split_AB -> [1 3) [6 8)
split_AB = split_A;
join_B = split_B;
split_AB &= join_B;
BOOST_CHECK_EQUAL( split_AB.iterative_size(), 2 );
BOOST_CHECK_EQUAL( split_AB, split_ab_jn );
//--------------------------------------------------------------------------
// separate_interval_set
//--------------------------------------------------------------------------
//sep_A [0 3) [6 9)
//sep_B &= [1 2)[2 4) [5 8)
//sep_AB -> [1 2)[2 3) [6 8)
sep_ab = split_ab;
BOOST_CHECK_EQUAL( sep_ab.iterative_size(), 3 );
sep_AB = split_A;
sep_B = split_B;
sep_AB &= sep_B;
BOOST_CHECK_EQUAL( sep_AB.iterative_size(), 3 );
BOOST_CHECK_EQUAL( sep_AB, sep_ab );
//sep_A [0 3) [6 9)
//split_B &= [1 2)[2 4) [5 8)
//sep_AB -> [1 2)[2 3) [6 8)
sep_AB = split_A;
sep_AB &= split_B;
BOOST_CHECK_EQUAL( sep_AB.iterative_size(), 3 );
BOOST_CHECK_EQUAL( sep_AB, sep_ab );
//sep_A [0 3) [6 9)
//join_B &= [1 4) [5 8)
//sep_AB -> [1 3) [6 8)
separate_interval_set<T> sep_ab_jn = split_ab_jn;
sep_AB = split_A;
join_B = split_B;
sep_AB &= join_B;
BOOST_CHECK_EQUAL( sep_AB.iterative_size(), 2 );
BOOST_CHECK_EQUAL( sep_AB, sep_ab_jn );
//--------------------------------------------------------------------------
// separate_interval_set
//--------------------------------------------------------------------------
//join_A [0 3) [6 9)
//join_B &= [1 4) [5 8)
//join_AB -> [1 3) [6 8)
join_ab = split_ab;
BOOST_CHECK_EQUAL( join_ab.iterative_size(), 2 );
join_AB = split_A;
join_B = split_B;
join_AB &= sep_B;
BOOST_CHECK_EQUAL( join_AB.iterative_size(), 2 );
BOOST_CHECK_EQUAL( join_AB, join_ab );
//join_A [0 3) [6 9)
//split_B &= [1 2)[2 4) [5 8)
//join_AB -> [1 3) [6 8)
join_AB = split_A;
join_AB &= split_B;
BOOST_CHECK_EQUAL( join_AB.iterative_size(), 2 );
BOOST_CHECK_EQUAL( join_AB, join_ab );
//join_A [0 3) [6 9)
//sep_B &= [1 2)[2 4) [5 8)
//join_AB -> [1 3) [6 8)
join_AB = split_A;
join_AB &= sep_B;
BOOST_CHECK_EQUAL( join_AB.iterative_size(), 2 );
BOOST_CHECK_EQUAL( join_AB, join_ab );
}
template <class T>
void interval_set_mixed_disjoint_4_bicremental_types()
{
typedef interval_set<T> IntervalSetT;
typedef typename IntervalSetT::interval_type IntervalT;
T v0 = make<T>(0);
T v2 = make<T>(2);
T v3 = make<T>(3);
T v4 = make<T>(4);
T v6 = make<T>(6);
IntervalT I0_2D = IntervalT::right_open(v0,v2);
IntervalT I2_3D = IntervalT::right_open(v2,v3);
IntervalT I3_4D = IntervalT::right_open(v3,v4);
IntervalT I4_4I = IntervalT::closed(v4,v4);
IntervalT C4_6D = IntervalT::open(v4,v6);
IntervalT I6_6I = IntervalT::closed(v6,v6);
//--------------------------------------------------------------------------
//split_A: [0 2) [4 4] [6 6]
//split_B: [2 3)[3 4) (4 6)
split_interval_set<T> split_A, split_B;
split_A.add(I0_2D).add(I4_4I).add(I6_6I);
split_B.add(I2_3D).add(I3_4D).add(C4_6D);
separate_interval_set<T> sep_A(split_A), sep_B(split_B);
interval_set<T> join_A(split_A), join_B(split_B);
BOOST_CHECK_EQUAL( disjoint(split_A, split_B), true );
BOOST_CHECK_EQUAL( disjoint(split_A, sep_B), true );
BOOST_CHECK_EQUAL( disjoint(split_A, join_B), true );
BOOST_CHECK_EQUAL( disjoint(sep_A, split_B), true );
BOOST_CHECK_EQUAL( disjoint(sep_A, sep_B), true );
BOOST_CHECK_EQUAL( disjoint(sep_A, join_B), true );
BOOST_CHECK_EQUAL( disjoint(join_A, split_B), true );
BOOST_CHECK_EQUAL( disjoint(join_A, sep_B), true );
BOOST_CHECK_EQUAL( disjoint(join_A, join_B), true );
}
template <class T>
void interval_set_mixed_infix_plus_overload_4_bicremental_types()
{
interval_set<T> join_a;
separate_interval_set<T> sep_a;
split_interval_set<T> split_a;
join_a.add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,9));
sep_a .add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,11));
split_a.add(I_I(0,0)).add(I_D(8,7)).add(I_I(6,11));
BOOST_CHECK_EQUAL(split_a + sep_a, sep_a + split_a );
BOOST_CHECK_EQUAL(split_a + join_a, join_a + split_a);
BOOST_CHECK_EQUAL(sep_a + join_a, join_a + sep_a );
}
template <class T> void interval_set_mixed_infix_pipe_overload_4_bicremental_types()
{
interval_set<T> join_a;
separate_interval_set<T> sep_a;
split_interval_set<T> split_a;
join_a.add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,9));
sep_a .add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,11));
split_a.add(I_I(0,0)).add(I_D(8,7)).add(I_I(6,11));
BOOST_CHECK_EQUAL(split_a | sep_a, sep_a | split_a );
BOOST_CHECK_EQUAL(split_a | join_a, join_a | split_a);
BOOST_CHECK_EQUAL(sep_a | join_a, join_a | sep_a );
}
template <class T>
void interval_set_mixed_infix_minus_overload_4_bicremental_types()
{
interval_set<T> join_a, join_b;
separate_interval_set<T> sep_a, sep_b;
split_interval_set<T> split_a, split_b;
join_a.add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,9));
sep_a .add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,11));
split_a.add(I_I(0,0)).add(I_D(8,7)).add(I_I(6,11));
BOOST_CHECK_EQUAL(split_a - sep_a, (split_b = split_a) -= sep_a );
BOOST_CHECK_EQUAL(split_a - join_a, (split_b = split_a) -= join_a );
BOOST_CHECK_EQUAL(sep_a - join_a, (sep_b = sep_a) -= join_a );
BOOST_CHECK_EQUAL(sep_a - split_a, (sep_b = sep_a) -= split_a);
BOOST_CHECK_EQUAL(join_a - split_a, (join_b = join_a) -= split_a);
BOOST_CHECK_EQUAL(join_a - sep_a, (join_b = join_a) -= sep_a );
}
template <class T> void interval_set_mixed_infix_et_overload_4_bicremental_types()
{
interval_set<T> join_a;
separate_interval_set<T> sep_a;
split_interval_set<T> split_a;
join_a.add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,9));
sep_a .add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,11));
split_a.add(I_I(0,0)).add(I_D(8,7)).add(I_I(6,11));
BOOST_CHECK_EQUAL(split_a & sep_a, sep_a & split_a );
BOOST_CHECK_EQUAL(split_a & join_a, join_a & split_a);
BOOST_CHECK_EQUAL(sep_a & join_a, join_a & sep_a );
}
template <class T> void interval_set_mixed_infix_caret_overload_4_bicremental_types()
{
interval_set<T> join_a;
separate_interval_set<T> sep_a;
split_interval_set<T> split_a;
join_a.add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,9));
sep_a .add(I_D(0,4)) .add(I_I(4,6)).add(I_D(5,11));
split_a.add(I_I(0,0)).add(I_D(8,7)).add(I_I(6,11));
BOOST_CHECK_EQUAL(split_a ^ sep_a, sep_a ^ split_a );
BOOST_CHECK_EQUAL(split_a ^ join_a, join_a ^ split_a);
BOOST_CHECK_EQUAL(sep_a ^ join_a, join_a ^ sep_a );
}
#endif // LIBS_ICL_TEST_TEST_INTERVAL_SET_MIXED_HPP_JOFA_090702