#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 |
Default constructor makes a 0-dimensional box
Definition at line 27 of file BoxND.h.
Referenced by npstat::BoxND< unsigned >::BoxND().
|
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 195 of file BoxND.h.
References npstat::BoxND< Numeric >::dim(), mps_fire::i, and relativeConstraints::value.
|
explicit |
Converting constructor
Definition at line 179 of file BoxND.h.
References npstat::BoxND< Numeric >::dim(), mps_fire::i, npstat::Interval< Numeric >::max(), and npstat::Interval< Numeric >::min().
|
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 494 of file BoxND.h.
References mps_fire::i, hpstanc_transforms::max, npstat::Interval< Numeric >::setMin(), and relativeConstraints::value.
Referenced by npstat::BoxND< unsigned >::dim().
|
inline |
|
static |
Definition at line 504 of file BoxND.h.
References AlCaHLTBitMon_QueryRunRegistry::string.
Referenced by npstat::BoxND< unsigned >::classId().
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.
Referenced by npstat::BoxND< unsigned >::BoxND().
BoxND<Numeric>& npstat::BoxND< Numeric >::copyFrom | ( | const BoxND< Num2 > & | r | ) |
Definition at line 215 of file BoxND.h.
References hitfit::clear(), mps_fire::i, npstat::Interval< Numeric >::max(), npstat::Interval< Numeric >::min(), and gen::n.
|
inline |
Box dimensionality
Definition at line 57 of file BoxND.h.
Referenced by npstat::BoxND< Numeric >::BoxND(), operator==(), and 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 363 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
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 385 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND< Numeric > & npstat::BoxND< Numeric >::expand | ( | const double * | scales, |
unsigned long | lenScales | ||
) |
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 271 of file BoxND.h.
References mps_fire::i, findQualityFiles::size, and mitigatedMETSequence_cff::U.
Referenced by npstat::BoxND< unsigned >::dim().
bool npstat::BoxND< Numeric >::isInside | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
Definition at line 332 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
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 287 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
bool npstat::BoxND< Numeric >::isInsideUpper | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
Definition at line 302 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
bool npstat::BoxND< Numeric >::isInsideWithBounds | ( | const Num2 * | coord, |
unsigned long | coordLen | ||
) | const |
Definition at line 317 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
BoxND< Numeric > & npstat::BoxND< Numeric >::moveToOrigin | ( | ) |
Moving this object so that the midpoint is (0, 0, ..., 0)
Definition at line 354 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
BoxND< Numeric > & npstat::BoxND< Numeric >::operator*= | ( | double | r | ) |
Scaling of all limits by a constant
Definition at line 345 of file BoxND.h.
References mps_fire::i, alignCSCRings::r, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
BoxND< Numeric > & npstat::BoxND< Numeric >::operator*= | ( | const std::vector< double > & | scales | ) |
Scaling by a different constant in each dimension
Definition at line 372 of file BoxND.h.
References mps_fire::i, and findQualityFiles::size.
BoxND& npstat::BoxND< Numeric >::operator+= | ( | const std::vector< Num2 > & | shifts | ) |
Shifting this object
Referenced by npstat::BoxND< unsigned >::dim().
BoxND<Numeric>& npstat::BoxND< Numeric >::operator+= | ( | const std::vector< Num2 > & | shifts | ) |
BoxND& npstat::BoxND< Numeric >::operator-= | ( | const std::vector< Num2 > & | shifts | ) |
Referenced by npstat::BoxND< unsigned >::dim().
BoxND<Numeric>& npstat::BoxND< Numeric >::operator-= | ( | const std::vector< Num2 > & | shifts | ) |
BoxND< Numeric > & npstat::BoxND< Numeric >::operator/= | ( | double | r | ) |
Definition at line 413 of file BoxND.h.
References mps_fire::i, alignCSCRings::r, and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::dim().
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 256 of file BoxND.h.
References f, mps_fire::i, findQualityFiles::size, and mitigatedMETSequence_cff::U.
Referenced by npstat::BoxND< unsigned >::dim().
Numeric npstat::BoxND< Numeric >::overlapVolume | ( | const BoxND< Numeric > & | r | ) | const |
Overlap volume with another box
Definition at line 241 of file BoxND.h.
References mps_fire::i, findQualityFiles::size, mitigatedMETSequence_cff::U, and findQualityFiles::v.
Referenced by npstat::BoxND< unsigned >::dim().
|
static |
Definition at line 525 of file BoxND.h.
References mps_fire::i, and mitigatedMETSequence_cff::U.
Referenced by npstat::BoxND< unsigned >::version().
BoxND& npstat::BoxND< Numeric >::shift | ( | const Num2 * | shifts, |
unsigned long | lenShifts | ||
) |
Referenced by npstat::BoxND< unsigned >::dim().
BoxND<Numeric>& npstat::BoxND< Numeric >::shift | ( | const Num2 * | shifts, |
const unsigned long | shiftsLen | ||
) |
|
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 486 of file BoxND.h.
References mps_fire::i.
Referenced by npstat::BoxND< unsigned >::dim().
|
static |
Box with lower limit 0 and upper limit 1 in all coordinates
Definition at line 478 of file BoxND.h.
References csvLumiCalc::unit.
Referenced by npstat::BoxND< unsigned >::dim().
|
inlinestatic |
Definition at line 155 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 231 of file BoxND.h.
References mps_fire::i, findQualityFiles::size, mitigatedMETSequence_cff::U, and findQualityFiles::v.
Referenced by npstat::BoxND< unsigned >::dim().
bool npstat::BoxND< Numeric >::write | ( | std::ostream & | of | ) | const |
Definition at line 511 of file BoxND.h.
References mps_fire::i, hpstanc_transforms::max, min(), and findQualityFiles::size.
Referenced by npstat::BoxND< unsigned >::classId().