LSST Applications
21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
|
Object to compute the bounding box which just encloses another box after it has been transformed by a mapping. More...
#include <MapBox.h>
Public Member Functions | |
MapBox (Mapping const &map, std::vector< double > const &lbnd, std::vector< double > const &ubnd, int minOutCoord=1, int maxOutCoord=0) | |
Find a bounding box for a Mapping. More... | |
MapBox (MapBox const &)=default | |
MapBox (MapBox &&)=default | |
MapBox & | operator= (MapBox const &)=default |
MapBox & | operator= (MapBox &&)=default |
Public Attributes | |
std::vector< double > | lbndIn |
Lower bound of the input box. More... | |
std::vector< double > | ubndIn |
Upper bound of the input box. More... | |
int | minOutCoord |
Minimum output coordinate axis for which to compute an output bounding box, starting from 1. More... | |
int | maxOutCoord |
Maximum output coordinate axis for which to compute an output bounding box, starting from 1. More... | |
std::vector< double > | lbndOut |
Lower bound of the output box. More... | |
std::vector< double > | ubndOut |
Upper bound of the output box. More... | |
Array2D | xl |
2-d array of [out coord, an input point at which the lower bound occurred] More... | |
Array2D | xu |
2-d array of [out coord, an input point at which the upper bound occurred] More... | |
Object to compute the bounding box which just encloses another box after it has been transformed by a mapping.
xl
and xu
are not predictable if more than one input value gives the same output boundary value.
|
explicit |
Find a bounding box for a Mapping.
Find the "bounding box" which just encloses another box after it has been transformed by a mapping. A typical use might be to calculate the size which an image would have after being transformed by this mapping.
[in] | map | Mapping for which to find the output bounding box. |
[in] | lbnd | Lower bound of the input box. |
[in] | ubnd | Upper bound of the input box. Note that it is permissible for the lower bound to exceed the corresponding upper bound, as the values will simply be swapped before use. |
[in] | minOutCoord | Minimum output coordinate axis for which to compute an output bounding box, starting from 1 |
[in] | maxOutCoord | Maximum output coordinate axis for which to compute an output bounding box, starting from 1, or 0 for all remaining output coordinate axes (in which case the field of the same name will be set to the number of outputs) |
std::invalid_argument | if minOutCoord is not in the range [1, getNOut()] or maxOutCoord is neither 0 nor in the range [minOutCoord, getNOut()]. |
std::runtime_error | if the required output bounds cannot be found. Typically, this might occur if all the input points which the function considers turn out to be invalid (see above). The number of points considered before generating such an error is quite large, however, so this is unlikely to occur by accident unless valid points are restricted to a very small subset of the input coordinate space. |
AST__BAD
are regarded as invalid and are ignored, They will make no contribution to determining the output bounds, even although the nominated output coordinate might still have a valid value at such points. Definition at line 34 of file MapBox.cc.
|
default |
|
default |
std::vector<double> ast::MapBox::lbndIn |
std::vector<double> ast::MapBox::lbndOut |
int ast::MapBox::maxOutCoord |
int ast::MapBox::minOutCoord |
std::vector<double> ast::MapBox::ubndIn |
std::vector<double> ast::MapBox::ubndOut |
Array2D ast::MapBox::xl |
Array2D ast::MapBox::xu |