24 #include <gtsam/dllexport.h> 43 typedef std::shared_ptr<VariableIndex> shared_ptr;
44 typedef FactorIndices::iterator Factor_iterator;
45 typedef FactorIndices::const_iterator Factor_const_iterator;
54 typedef KeyMap::const_iterator const_iterator;
55 typedef KeyMap::const_iterator iterator;
56 typedef KeyMap::value_type value_type;
69 explicit VariableIndex(
const FG& factorGraph) : nFactors_(0), nEntries_(0) {
78 size_t size()
const {
return index_.size(); }
88 KeyMap::const_iterator item = index_.find(variable);
89 if(item == index_.end())
90 throw std::invalid_argument(
"Requested non-existent variable from VariableIndex");
97 return (*
this)[variable].empty();
108 void print(
const std::string& str =
"VariableIndex: ",
109 const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const;
115 void outputMetisFormat(std::ostream& os)
const;
127 void augment(
const FG& factors,
const FactorIndices* newFactorIndices =
nullptr);
135 augment(factor, &newFactorIndices);
143 void augmentExistingFactor(
const FactorIndex factorIndex,
const KeySet & newKeys);
155 template<
typename ITERATOR,
class FG>
156 void remove(ITERATOR firstFactor, ITERATOR lastFactor,
const FG& factors);
159 template<
typename ITERATOR>
160 void removeUnusedVariables(ITERATOR firstKey, ITERATOR lastKey);
163 const_iterator
begin()
const {
return index_.begin(); }
166 const_iterator
end()
const {
return index_.end(); }
169 const_iterator
find(
Key key)
const {
return index_.find(key); }
172 Factor_iterator factorsBegin(
Key variable) {
return internalAt(variable).begin(); }
173 Factor_iterator factorsEnd(
Key variable) {
return internalAt(variable).end(); }
175 Factor_const_iterator factorsBegin(
Key variable)
const {
return internalAt(variable).begin(); }
176 Factor_const_iterator factorsEnd(
Key variable)
const {
return internalAt(variable).end(); }
180 const KeyMap::const_iterator item = index_.find(variable);
181 assert(item != index_.end());
187 const KeyMap::iterator item = index_.find(variable);
188 assert(item != index_.end());
193 #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION 195 friend class boost::serialization::access;
196 template<
class ARCHIVE>
197 void serialize(ARCHIVE & ar,
const unsigned int ) {
198 ar & BOOST_SERIALIZATION_NVP(index_);
199 ar & BOOST_SERIALIZATION_NVP(nFactors_);
200 ar & BOOST_SERIALIZATION_NVP(nEntries_);
void augment(const FG &factor, const FactorIndices &newFactorIndices)
Definition: VariableIndex.h:134
const_iterator find(Key key) const
Find the iterator for the requested variable entry.
Definition: VariableIndex.h:169
size_t size() const
The number of variable entries. This is equal to the number of unique variable Keys.
Definition: VariableIndex.h:78
std::string serialize(const T &input)
serializes to a string
Definition: serialization.h:113
Definition: Testable.h:152
FastVector< FactorIndex > FactorIndices
Define collection types:
Definition: Factor.h:36
size_t nEntries() const
The number of nonzero blocks, i.e. the number of variable-factor entries.
Definition: VariableIndex.h:84
size_t nFactors() const
The number of factors in the original factor graph.
Definition: VariableIndex.h:81
const_iterator end() const
Iterator to the first variable entry.
Definition: VariableIndex.h:166
Definition: Testable.h:112
GTSAM_EXPORT void print(const Matrix &A, const std::string &s, std::ostream &stream)
VariableIndex()
Default constructor, creates an empty VariableIndex.
Definition: VariableIndex.h:62
std::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Definition: Key.h:35
const FactorIndices & internalAt(Key variable) const
Internal version of 'at' that asserts existence.
Definition: VariableIndex.h:179
const_iterator begin() const
Iterator to the first variable entry.
Definition: VariableIndex.h:163
A thin wrapper around std::vector that uses a custom allocator.
Definition: chartTesting.h:28
A thin wrapper around std::map that uses boost's fast_pool_allocator.
VariableIndex(const FG &factorGraph)
Definition: VariableIndex.h:69
Definition: VariableIndex.h:41
FactorIndices & internalAt(Key variable)
Internal version of 'at' that asserts existence.
Definition: VariableIndex.h:186
std::uint64_t FactorIndex
Integer nonlinear factor index type.
Definition: types.h:105
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:102
const FactorIndices & operator[](Key variable) const
Access a list of factors by variable.
Definition: VariableIndex.h:87
The base class for all factors.
bool empty(Key variable) const
Return true if no factors associated with a variable.
Definition: VariableIndex.h:96