LSST Applications g0f08755f38+9c285cab97,g1635faa6d4+13f3999e92,g1653933729+a8ce1bb630,g1a0ca8cf93+bf6eb00ceb,g28da252d5a+0829b12dee,g29321ee8c0+5700dc9eac,g2bbee38e9b+9634bc57db,g2bc492864f+9634bc57db,g2cdde0e794+c2c89b37c4,g3156d2b45e+41e33cbcdc,g347aa1857d+9634bc57db,g35bb328faa+a8ce1bb630,g3a166c0a6a+9634bc57db,g3e281a1b8c+9f2c4e2fc3,g414038480c+077ccc18e7,g41af890bb2+fde0dd39b6,g5fbc88fb19+17cd334064,g781aacb6e4+a8ce1bb630,g80478fca09+55a9465950,g82479be7b0+d730eedb7d,g858d7b2824+9c285cab97,g9125e01d80+a8ce1bb630,g9726552aa6+10f999ec6a,ga5288a1d22+2a84bb7594,gacf8899fa4+c69c5206e8,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc28159a63d+9634bc57db,gcf0d15dbbd+4b7d09cae4,gda3e153d99+9c285cab97,gda6a2b7d83+4b7d09cae4,gdaeeff99f8+1711a396fd,ge2409df99d+5e831397f4,ge79ae78c31+9634bc57db,gf0baf85859+147a0692ba,gf3967379c6+41c94011de,gf3fb38a9a8+8f07a9901b,gfb92a5be7c+9c285cab97,w.2024.46
LSST Data Management Base Package
|
A Mapping split off as a subset of another Mapping. More...
#include <MapSplit.h>
Public Member Functions | |
MapSplit (Mapping const &map, std::vector< int > const &in) | |
Construct a MapSplit. | |
MapSplit (MapSplit const &)=default | |
MapSplit (MapSplit &&)=default | |
MapSplit & | operator= (MapSplit const &)=default |
MapSplit & | operator= (MapSplit &&)=default |
Public Attributes | |
std::shared_ptr< Mapping > | splitMap |
The Mapping that was split off. | |
std::vector< int > | origIn |
Indices of the inputs of the original mapping were picked for the split mapping. | |
std::vector< int > | origOut |
Indices of the outputs of the original mapping which are fed by the picked inputs. | |
A Mapping split off as a subset of another Mapping.
Definition at line 38 of file MapSplit.h.
|
explicit |
Construct a MapSplit.
The subset is specified by choosing a subset of inputs from an existing Mapping. Such a split is only possible if the specified inputs correspond to some subset of the original Mapping's outputs. That is, there must exist a subset of the Mapping outputs for which each output depends only on the selected Mapping inputs, and not on any of the inputs which have not been selected. Also, any output which is not in this subset must not depend on any of the selected inputs.
[in] | map | Mapping to split. |
[in] | in | Indices of inputs of map to pick. Each element should have a value in the range [1, map.getNIn()]. |
std::runtime_error | if map cannot be split as specified. |
Definition at line 35 of file MapSplit.cc.
|
default |
|
default |
std::vector<int> ast::MapSplit::origIn |
Indices of the inputs of the original mapping were picked for the split mapping.
This is a copy of the in
argument of the constructor.
Definition at line 73 of file MapSplit.h.
std::vector<int> ast::MapSplit::origOut |
Indices of the outputs of the original mapping which are fed by the picked inputs.
This will contain splitMap->getNOut() elements, each in the range [1, nout of the original mapping]. The i
th element holds the index within the original mapping which corresponds to the i
th output of the split mapping. For example if the 1st output of the split mapping came from the 5th output of the original mapping, then origOut[0] = 5 (0 because vectors use 0-based indexing, and 5 because AST index values are 1-based).
Definition at line 83 of file MapSplit.h.
std::shared_ptr<Mapping> ast::MapSplit::splitMap |
The Mapping that was split off.
Definition at line 67 of file MapSplit.h.