#include <BoxND.h>
Public Member Functions | |
BoxND () | |
BoxND (const unsigned long dim) | |
BoxND (const unsigned long dim, const Interval< Numeric > &v) | |
template<typename Num2 > | |
BoxND (const std::vector< Num2 > &limits) | |
template<typename Num2 > | |
BoxND (const BoxND< Num2 > &r) | |
template<typename Num2 > | |
BoxND & | copyFrom (const BoxND< Num2 > &r) |
template<typename Num2 > | |
BoxND< Numeric > & | copyFrom (const BoxND< Num2 > &r) |
unsigned long | dim () const |
BoxND & | expand (double r) |
void | getMidpoint (Numeric *coord, unsigned long coordLen) const |
BoxND & | moveToOrigin () |
template<typename Num2 > | |
BoxND< Numeric > & | operator+= (const std::vector< Num2 > &shifts) |
template<typename Num2 > | |
BoxND< Numeric > & | operator-= (const std::vector< Num2 > &shifts) |
double | overlapFraction (const BoxND &r) const |
Numeric | overlapVolume (const BoxND &r) const |
template<typename Num2 > | |
BoxND< Numeric > & | shift (const Num2 *shifts, const unsigned long shiftsLen) |
Numeric | volume () const |
template<typename Num2 > | |
bool | isInsideLower (const Num2 *coord, unsigned long coordLen) const |
template<typename Num2 > | |
bool | isInsideUpper (const Num2 *coord, unsigned long coordLen) const |
template<typename Num2 > | |
bool | isInsideWithBounds (const Num2 *coord, unsigned long coordLen) const |
template<typename Num2 > | |
bool | isInside (const Num2 *coord, unsigned long coordLen) const |
BoxND & | operator*= (double r) |
BoxND & | operator/= (double r) |
BoxND & | operator*= (const std::vector< double > &scales) |
BoxND & | operator/= (const std::vector< double > &scales) |
BoxND & | expand (const std::vector< double > &scales) |
BoxND & | expand (const double *scales, unsigned long lenScales) |
template<typename Num2 > | |
BoxND & | operator+= (const std::vector< Num2 > &shifts) |
template<typename Num2 > | |
BoxND & | operator-= (const std::vector< Num2 > &shifts) |
template<typename Num2 > | |
BoxND & | shift (const Num2 *shifts, unsigned long lenShifts) |
gs::ClassId | classId () const |
bool | write (std::ostream &of) const |
Static Public Member Functions | |
static BoxND | allSpace (unsigned long ndim) |
static const char * | classname () |
static void | restore (const gs::ClassId &id, std::istream &in, BoxND *box) |
static BoxND | sizeTwoBox (unsigned long ndim) |
static BoxND | unitBox (unsigned long ndim) |
static unsigned | version () |
Class to represent rectangles, boxes, and hyperboxes
|
inline |
|
inlineexplicit |
|
inline |
|
explicit |
Constructor where one of the limits will be 0 and the other will be generated from the given vector (which also determines the dimensionality)
Definition at line 189 of file BoxND.h.
References mps_fire::i, push_back(), relativeConstraints::value, and SiPixelPI::zero.
|
explicit |
Converting constructor
Definition at line 176 of file BoxND.h.
References mps_fire::i, npstat::Interval< Numeric >::max(), npstat::Interval< Numeric >::min(), and push_back().
|
static |
Box with all upper limits set to maximum possible Numeric number and with lower limits set to negative maximum (this will not work with unsigned long types)
Definition at line 451 of file BoxND.h.
References mps_fire::i, SiStripPI::max, npstat::Interval< Numeric >::setMin(), and relativeConstraints::value.
|
inline |
|
static |
BoxND& npstat::BoxND< Numeric >::copyFrom | ( | const BoxND< Num2 > & | r | ) |
Get the data from a box of a different type. This method works essentially as a converting assignment operator.
BoxND<Numeric>& npstat::BoxND< Numeric >::copyFrom | ( | const BoxND< Num2 > & | r | ) |
Definition at line 206 of file BoxND.h.
References clear(), mps_fire::i, npstat::Interval< Numeric >::max(), npstat::Interval< Numeric >::min(), dqmiodumpmetadata::n, and push_back().
|
inline |
Box dimensionality
Definition at line 54 of file BoxND.h.
Referenced by npstat::ArrayND< Numeric, StackLen, StackDim >::processSubrange().
BoxND< Numeric > & npstat::BoxND< Numeric >::expand | ( | double | r | ) |
Scaling of all limits by a constant in such a way that the midpoint remains unchanged
Definition at line 335 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::expand | ( | const std::vector< double > & | scales | ) |
Scaling of all limits in such a way that the midpoint remains unchanged, using a different scaling factor in each dimension
Definition at line 355 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::expand | ( | const double * | scales, |
unsigned long | lenScales | ||
) |
Definition at line 365 of file BoxND.h.
References cms::cuda::assert(), mps_fire::i, and findQualityFiles::size.
void npstat::BoxND< Numeric >::getMidpoint | ( | Numeric * | coord, |
unsigned long | coordLen | ||
) | const |
Midpoint for every coordinate. The size of the "coord" array should be at least as large as the box dimensionality.
Definition at line 253 of file BoxND.h.
References cms::cuda::assert(), mps_fire::i, and findQualityFiles::size.
bool npstat::BoxND< Numeric >::isInside | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
Definition at line 308 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
bool npstat::BoxND< Numeric >::isInsideLower | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
This method return "true" if the corresponding function of the Interval returns "true" for every coordinate. There must be an automatic conversion from Num2 type into Numeric.
Definition at line 266 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
bool npstat::BoxND< Numeric >::isInsideUpper | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
Definition at line 280 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
bool npstat::BoxND< Numeric >::isInsideWithBounds | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
Definition at line 294 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::moveToOrigin | ( | ) |
Moving this object so that the midpoint is (0, 0, ..., 0)
Definition at line 327 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::operator*= | ( | double | r | ) |
Scaling of all limits by a constant
Definition at line 319 of file BoxND.h.
References mps_fire::i, alignCSCRings::r, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::operator*= | ( | const std::vector< double > & | scales | ) |
Scaling by a different constant in each dimension
Definition at line 343 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND& npstat::BoxND< Numeric >::operator+= | ( | const std::vector< Num2 > & | shifts | ) |
Shifting this object
BoxND<Numeric>& npstat::BoxND< Numeric >::operator+= | ( | const std::vector< Num2 > & | shifts | ) |
BoxND& npstat::BoxND< Numeric >::operator-= | ( | const std::vector< Num2 > & | shifts | ) |
BoxND<Numeric>& npstat::BoxND< Numeric >::operator-= | ( | const std::vector< Num2 > & | shifts | ) |
BoxND< Numeric > & npstat::BoxND< Numeric >::operator/= | ( | double | r | ) |
Definition at line 378 of file BoxND.h.
References mps_fire::i, alignCSCRings::r, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::operator/= | ( | const std::vector< double > & | scales | ) |
double npstat::BoxND< Numeric >::overlapFraction | ( | const BoxND< Numeric > & | r | ) | const |
A faster way to calculate overlapVolume(r)/volume()
Definition at line 241 of file BoxND.h.
References validate-o2o-wbm::f, mps_fire::i, and findQualityFiles::size.
Numeric npstat::BoxND< Numeric >::overlapVolume | ( | const BoxND< Numeric > & | r | ) | const |
Overlap volume with another box
Definition at line 229 of file BoxND.h.
References mps_fire::i, findQualityFiles::size, and findQualityFiles::v.
|
static |
Definition at line 478 of file BoxND.h.
References cms::cuda::assert(), mps_fire::i, and TH2PolyOfflineMaps::limits.
BoxND& npstat::BoxND< Numeric >::shift | ( | const Num2 * | shifts, |
unsigned long | lenShifts | ||
) |
BoxND<Numeric>& npstat::BoxND< Numeric >::shift | ( | const Num2 * | shifts, |
const unsigned long | shiftsLen | ||
) |
Definition at line 412 of file BoxND.h.
References cms::cuda::assert(), mps_fire::i, and findQualityFiles::size.
|
static |
Box with lower limit -1 and upper limit 1 in all coordinates. Note that this will produce nonsense in case the Numeric type is unsigned.
Definition at line 444 of file BoxND.h.
References mps_fire::i, and SiPixelPI::one.
|
static |
|
inlinestatic |
Definition at line 152 of file BoxND.h.
Referenced by validation.Sample::datasetpattern(), and validation.Sample::filename().
Numeric npstat::BoxND< Numeric >::volume | ( | void | ) | const |
Box volume
Definition at line 220 of file BoxND.h.
References mps_fire::i, findQualityFiles::size, and findQualityFiles::v.
bool npstat::BoxND< Numeric >::write | ( | std::ostream & | of | ) | const |
Definition at line 466 of file BoxND.h.
References mps_fire::i, TH2PolyOfflineMaps::limits, SiStripPI::max, SiStripPI::min, and findQualityFiles::size.