24 template<
typename P,
typename... X>
25 requires (std::is_same_v<X,IntervalVector> && ...)
26 class Paving :
public Domain
30 using Node_ = std::shared_ptr<const PavingNode<P>>;
31 using NodeTuple_ = std::tuple<X...>;
32 using NodeValue_ = std::function<std::list<IntervalVector>(Node_)>;
33 using ConnectedSubset_ = Subpaving<P>;
38 assert_release(n > 0);
42 : _tree(std::make_shared<PavingNode<P>>(*static_cast<P*>(this), x))
45 inline Index size()
const
47 return std::get<0>(_tree->boxes()).size();
50 inline std::shared_ptr<const PavingNode<P>> tree()
const
55 inline std::shared_ptr<PavingNode<P>> tree()
57 return std::const_pointer_cast<PavingNode<P>>(
const_cast<const Paving<P,X...
>*>(
this)->tree());
60 inline std::list<IntervalVector> boxes(
const NodeValue_& node_value)
const
65 inline std::list<IntervalVector> boxes(
const NodeValue_& node_value,
const IntervalVector& intersecting_box)
const
67 std::list<IntervalVector> l;
69 this->tree()->visit([&]
72 for(
const auto& bi : node_value(n))
73 if(bi.intersects(intersecting_box))
75 return n->hull().intersects(intersecting_box);
81 inline std::list<ConnectedSubset_> connected_subsets(
const NodeValue_& node_value)
const
86 std::list<ConnectedSubset_> connected_subsets(
const IntervalVector& x0,
const NodeValue_& node_value)
const
88 std::list<IntervalVector> l_boxes = boxes(node_value, x0);
89 [[maybe_unused]] Index nb_boxes = l_boxes.size();
90 std::list<ConnectedSubset_> l_subsets;
92 while(!l_boxes.empty())
94 auto current_box = l_boxes.front();
95 l_subsets.push_back({ current_box });
98 std::list<IntervalVector> l_neighbouring_boxes_to_visit { current_box };
102 current_box = l_neighbouring_boxes_to_visit.front();
103 l_neighbouring_boxes_to_visit.pop_front();
105 for(
const auto& ni : boxes(node_value, current_box))
107 if(std::find(l_boxes.begin(), l_boxes.end(), ni) != l_boxes.end())
110 l_neighbouring_boxes_to_visit.push_back(ni);
111 l_subsets.back().push_back(ni);
115 }
while(!l_neighbouring_boxes_to_visit.empty());
118 assert(l_boxes.empty() &&
"all the nodes should have been visited");
119 assert([&]() ->
bool { Index s = 0;
for(
const auto& si : l_subsets) s += si.size();
return s == nb_boxes; } ()
120 &&
"the total number of boxes should match the sum of number of boxes of each subset");
127 friend class PavingNode<P>;
131 return std::make_tuple(((X)x)...);
134 std::shared_ptr<PavingNode<P>> _tree;
139 using PavingOut_Node = PavingNode<PavingOut>;
141 class PavingOut :
public Paving<PavingOut,IntervalVector>
148 std::list<PavingOut::ConnectedSubset_> connected_subsets(
const PavingOut::NodeValue_& node_value = PavingOut::outer)
const;
149 std::list<PavingOut::ConnectedSubset_> connected_subsets(
const IntervalVector& x0,
const PavingOut::NodeValue_& node_value = PavingOut::outer)
const;
151 static const NodeValue_ outer, outer_complem;
156 using PavingInOut_Node = PavingNode<PavingInOut>;
158 class PavingInOut :
public Paving<PavingInOut,IntervalVector,IntervalVector>
162 PavingInOut(Index n);
165 std::list<PavingInOut::ConnectedSubset_> connected_subsets(
const PavingInOut::NodeValue_& node_value = PavingInOut::outer)
const;
166 std::list<PavingInOut::ConnectedSubset_> connected_subsets(
const IntervalVector& x0,
const PavingInOut::NodeValue_& node_value = PavingInOut::outer)
const;
168 static const NodeValue_ outer, outer_complem, inner, bound, all;
Definition codac2_OctaSym.h:21
Eigen::Matrix< Interval,-1, 1 > IntervalVector
Alias for a dynamic-size column vector of intervals.
Definition codac2_IntervalVector.h:25