Go to the documentation of this file.
10 #ifndef EIGEN_ALIGNEDBOX_H
11 #define EIGEN_ALIGNEDBOX_H
29 template <
typename _Scalar,
int _AmbientDim>
74 template<
typename OtherVectorType1,
typename OtherVectorType2>
75 EIGEN_DEVICE_FUNC
inline AlignedBox(
const OtherVectorType1& _min,
const OtherVectorType2& _max) :
m_min(_min),
m_max(_max) {}
78 template<
typename Derived>
95 EIGEN_DEVICE_FUNC
inline bool isEmpty()
const {
return (
m_min.array() >
m_max.array()).any(); }
128 {
return sizes().prod(); }
156 else res[d] =
m_min[d];
181 template<
typename Derived>
185 return (
m_min.array()<=p_n.array()).all() && (p_n.array()<=
m_max.array()).all();
190 {
return (
m_min.array()<=(
b.min)().array()).all() && ((
b.max)().array()<=
m_max.array()).all(); }
195 {
return (
m_min.array()<=(
b.max)().array()).all() && ((
b.min)().array()<=
m_max.array()).all(); }
199 template<
typename Derived>
240 template<
typename Derived>
253 template<
typename Derived>
266 template<
typename Derived>
282 template<
typename NewScalarType>
291 template<
typename OtherScalarType>
294 m_min = (other.min)().template cast<Scalar>();
295 m_max = (other.max)().template cast<Scalar>();
303 {
return m_min.isApprox(other.m_min, prec) &&
m_max.isApprox(other.m_max, prec); }
312 template<
typename Scalar,
int AmbientDim>
313 template<
typename Derived>
319 for (
Index k=0; k<dim(); ++k)
321 if( m_min[k] > p[k] )
323 aux = m_min[k] - p[k];
326 else if( p[k] > m_max[k] )
328 aux = p[k] - m_max[k];
335 template<
typename Scalar,
int AmbientDim>
340 for (
Index k=0; k<dim(); ++k)
342 if( m_min[k] >
b.m_max[k] )
344 aux = m_min[k] -
b.m_max[k];
347 else if(
b.m_min[k] > m_max[k] )
349 aux =
b.m_min[k] - m_max[k];
372 #define EIGEN_MAKE_TYPEDEFS(Type, TypeSuffix, Size, SizeSuffix) \
374 typedef AlignedBox<Type, Size> AlignedBox##SizeSuffix##TypeSuffix;
376 #define EIGEN_MAKE_TYPEDEFS_ALL_SIZES(Type, TypeSuffix) \
377 EIGEN_MAKE_TYPEDEFS(Type, TypeSuffix, 1, 1) \
378 EIGEN_MAKE_TYPEDEFS(Type, TypeSuffix, 2, 2) \
379 EIGEN_MAKE_TYPEDEFS(Type, TypeSuffix, 3, 3) \
380 EIGEN_MAKE_TYPEDEFS(Type, TypeSuffix, 4, 4) \
381 EIGEN_MAKE_TYPEDEFS(Type, TypeSuffix, Dynamic, X)
387 #undef EIGEN_MAKE_TYPEDEFS_ALL_SIZES
388 #undef EIGEN_MAKE_TYPEDEFS
392 #endif // EIGEN_ALIGNEDBOX_H
ScalarTraits::Real RealScalar
const EIGEN_DEVICE_FUNC SqrtReturnType sqrt() const
EIGEN_DEVICE_FUNC ~AlignedBox()
EIGEN_DEVICE_FUNC AlignedBox merged(const AlignedBox &b) const
Generic expression where a coefficient-wise binary operator is applied to two expressions.
EIGEN_DEVICE_FUNC bool isApprox(const AlignedBox &other, const RealScalar &prec=ScalarTraits::dummy_precision()) const
const EIGEN_DEVICE_FUNC VectorType &() min() const
const EIGEN_DEVICE_FUNC VectorType &() max() const
EIGEN_DEVICE_FUNC AlignedBox intersection(const AlignedBox &b) const
EIGEN_DEVICE_FUNC AlignedBox & clamp(const AlignedBox &b)
EIGEN_DEVICE_FUNC AlignedBox & extend(const AlignedBox &b)
EIGEN_DEVICE_FUNC VectorType sample() const
EIGEN_DEVICE_FUNC Derived & setConstant(Index size, const Scalar &val)
EIGEN_DEVICE_FUNC AlignedBox & translate(const MatrixBase< Derived > &a_t)
EIGEN_DEVICE_FUNC bool isEmpty() const
@ AmbientDimAtCompileTime
EIGEN_DEVICE_FUNC Index dim() const
const EIGEN_DEVICE_FUNC EIGEN_EXPR_BINARYOP_SCALAR_RETURN_TYPE(VectorTypeSum, RealScalar, quotient) center() const
NumTraits< Scalar > ScalarTraits
EIGEN_DEVICE_FUNC VectorType &() min()
EIGEN_DEVICE_FUNC void setNull()
EIGEN_DEVICE_FUNC bool contains(const MatrixBase< Derived > &p) const
Matrix< Scalar, AmbientDimAtCompileTime, 1 > VectorType
EIGEN_DEVICE_FUNC CwiseBinaryOp< internal::scalar_difference_op< Scalar, Scalar >, const VectorType, const VectorType > diagonal() const
EIGEN_DEVICE_FUNC bool isNull() const
EIGEN_DEVICE_FUNC void setEmpty()
EIGEN_DEVICE_FUNC AlignedBox & extend(const MatrixBase< Derived > &p)
EIGEN_DEVICE_FUNC AlignedBox(const OtherVectorType1 &_min, const OtherVectorType2 &_max)
EIGEN_DEVICE_FUNC AlignedBox(const AlignedBox< OtherScalarType, AmbientDimAtCompileTime > &other)
#define EIGEN_MAKE_TYPEDEFS_ALL_SIZES(Type, TypeSuffix)
#define EIGEN_STATIC_ASSERT(CONDITION, MSG)
EIGEN_DEVICE_FUNC internal::cast_return_type< AlignedBox, AlignedBox< NewScalarType, AmbientDimAtCompileTime > >::type cast() const
EIGEN_DEVICE_FUNC Scalar squaredExteriorDistance(const MatrixBase< Derived > &p) const
EIGEN_DEVICE_FUNC VectorType &() max()
EIGEN_DEVICE_FUNC bool contains(const AlignedBox &b) const
EIGEN_DEVICE_FUNC AlignedBox(const MatrixBase< Derived > &p)
Base class for all dense matrices, vectors, and expressions.
EIGEN_DEVICE_FUNC AlignedBox(Index _dim)
EIGEN_DEVICE_FUNC AlignedBox()
EIGEN_DEVICE_FUNC Scalar volume() const
CwiseBinaryOp< internal::scalar_sum_op< Scalar >, const VectorType, const VectorType > VectorTypeSum
ScalarTraits::NonInteger NonInteger
const EIGEN_DEVICE_FUNC CwiseBinaryOp< internal::scalar_difference_op< Scalar, Scalar >, const VectorType, const VectorType > sizes() const
EIGEN_DEVICE_FUNC VectorType corner(CornerType corner) const
EIGEN_DEVICE_FUNC bool intersects(const AlignedBox &b) const
EIGEN_DEVICE_FUNC NonInteger exteriorDistance(const AlignedBox &b) const
#define EIGEN_MAKE_ALIGNED_OPERATOR_NEW_IF_VECTORIZABLE_FIXED_SIZE(Scalar, Size)
EIGEN_DEVICE_FUNC NonInteger exteriorDistance(const MatrixBase< Derived > &p) const
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:05:36