53 template<
typename... X>
54 class CtcInter :
public Ctc<CtcInter<X...>,X...>
71 if constexpr(std::is_same_v<X...,
Interval>)
86 requires (IsCtcBaseOrPtr<C,X...> && !std::is_same_v<
CtcInter<X...>,C>)
99 template<
typename... C>
100 requires (IsCtcBaseOrPtr<C,X...> && ...)
102 : Ctc<
CtcInter<X...>,X...>(size_first_item(c...)),
_ctcs(c...)
104 assert_release(all_same_size(c...));
114 CtcInter(
const Collection<CtcBase<IntervalVector>>& ctcs)
115 : Ctc<
CtcInter<X...>,X...>(ctcs.front()->size()),
_ctcs(ctcs)
117 for(
const auto& ci :
_ctcs)
119 assert_release(ci->size() == this->size());
143 for(
const auto& ci :
_ctcs)
146 if((x.is_empty() | ...))
162 requires IsCtcBaseOrPtr<C,X...>
165 assert_release(size_of(c) == this->size());
191 template<
typename Tuple>
199 template<
typename... T>
215 template<
typename C1,
typename C2>
230 template<
typename C1,
typename C2>
245 template<
typename C1,
typename C2>
260 template<
typename C1,
typename C2>
276 template<
typename C2>
277 requires std::is_base_of_v<CtcBase<IntervalVector>,C2>
280 assert_release(c1.size() == c2.size());
294 template<
typename C1>
295 requires std::is_base_of_v<CtcBase<IntervalVector>,C1>
298 assert_release(c1.size() == c2.size());
304 CtcInter(Index) -> CtcInter<IntervalVector>;
Sequential intersection of several contractors:
Definition codac2_CtcInter.h:55
size_t nb() const
Returns the number of stored contractors.
Definition codac2_CtcInter.h:128
CtcInter(const C &c)
Builds an intersection contractor from a single contractor.
Definition codac2_CtcInter.h:87
Collection< CtcBase< X... > > _ctcs
Definition codac2_CtcInter.h:173
CtcInter< X... > & operator&=(const C &c)
Appends a contractor to the current intersection.
Definition codac2_CtcInter.h:163
CtcInter(const C &... c)
Builds an intersection contractor from several contractors.
Definition codac2_CtcInter.h:101
void contract(X &... x) const
Contracts the given domain(s) by applying all stored contractors in sequence.
Definition codac2_CtcInter.h:141
CtcInter(const Collection< CtcBase< IntervalVector > > &ctcs)
Builds an intersection contractor from a collection of contractors.
Definition codac2_CtcInter.h:114
CtcInter(Index n)
Builds a neutral intersection contractor with a prescribed domain size.
Definition codac2_CtcInter.h:68
Interval class, for representing closed and connected subsets of .
Definition codac2_Interval.h:49
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
CtcInterType< typenameC1::ContractedTypes >::Ctc operator&(const C1 &c1, const C2 &c2)
Builds an intersection contractor from two contractors.
Definition codac2_CtcInter.h:216
Helper meta-function returning the appropriate CtcInter type from a tuple.
Definition codac2_CtcInter.h:192