本文整理汇总了C++中SparseVector::emplaceBack方法的典型用法代码示例。如果您正苦于以下问题:C++ SparseVector::emplaceBack方法的具体用法?C++ SparseVector::emplaceBack怎么用?C++ SparseVector::emplaceBack使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SparseVector
的用法示例。
在下文中一共展示了SparseVector::emplaceBack方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: incompleteLDLTDecomposition
void InLDLTPreconditioner::incompleteLDLTDecomposition(const BlockedSymSpMatrix& mat){
int columnCount = mat.getNumColumns();
MemoryPool<InvMatRowListNode, std::alignment_of<InvMatRowListNode>::value> nodePool(columnCount);
InvMatRowListNode *listPerRow = new InvMatRowListNode[columnCount];
std::vector<InvMatRowListNode *> *invRowNodes = new std::vector<InvMatRowListNode *>[columnCount];
//work space
FastSparseVector vec(columnCount);
FastSparseVector lowerColumn(columnCount);
SparseVector invColumn;
invColumn.Reserve(32);
constexpr int preAlloced = 32;
for (int i = 0; i < columnCount; i++) {
InvMatRowListNode *node = nodePool.Alloc();
node->row = i; node->col = i; node->value = 1.0;
listPerRow[i].prev = node;
listPerRow[i].next = node;
node->prev = &listPerRow[i];
node->next = &listPerRow[i];
invRowNodes[i].reserve(std::min(i + 1, preAlloced));
invRowNodes[i].push_back(node);
}
int count = 0;
pcol.push_back(0);
for (int i = 0; i < columnCount - 1; i++){
for (auto node : invRowNodes[i]) {
invColumn.emplaceBack(node->row, node->value);
node->prev->next = node->next;
node->next->prev = node->prev;
nodePool.Dealloc(node);
}
invRowNodes[i].clear();
invRowNodes[i].shrink_to_fit();
SpMSV(mat, matFullIndices, invColumn, vec);
Scalar diag = vec * invColumn;
Scalar inv = Scalar(1.0) / diag;
invDiagonal[i] = inv;
for (auto iter = vec.cbegin(); iter != vec.cend(); ++iter) {
int index = *iter.indexIterator;
Scalar value = *iter.valueIterator;
if (value != 0) {
InvMatRowListNode *node = listPerRow[index].next;
InvMatRowListNode *end = &listPerRow[index];
while (node != end) {
lowerColumn.Add(node->col, value * node->value);
node = node->next;
}
}
}
for (auto iter = lowerColumn.cbegin(); iter != lowerColumn.cend(); ++iter) {
int j = *iter.indexIterator;
Scalar lower = (*iter.valueIterator) * inv;
if (fabs(lower) > ldltEpsilon){
values.push_back(lower);
rows.push_back(j);
++count;
}
}
pcol.push_back(count);
vec.Clear();
for (auto iter = lowerColumn.cbegin(); iter != lowerColumn.cend(); ++iter) {
int j = *iter.indexIterator;
Scalar factor = *iter.valueIterator;
if (factor != 0) {
factor *= inv;
//copy invRowNodes[j] and clean node
for (auto node : invRowNodes[j]) {
vec.emplaceBack(node->row, node->value);
node->prev->next = node->next;
node->next->prev = node->prev;
nodePool.Dealloc(node);
}
invRowNodes[j].clear();
for (auto iter = invColumn.cbegin(); iter != invColumn.cend(); ++iter)
vec.Add(*(iter.indexIterator), -factor * (*(iter.valueIterator)));
//drop invRowNodes[j]
for (auto iter = vec.cbegin(); iter != vec.cend(); ++iter) {
int index = *iter.indexIterator;
Scalar val = *iter.valueIterator;
if (fabs(val) > sainvEpsilon) {
//insert to linked list
InvMatRowListNode *node = nodePool.Alloc();
node->row = index; node->col = j; node->value = val;
node->next = listPerRow[index].next;
node->prev = &listPerRow[index];
listPerRow[index].next->prev = node;
listPerRow[index].next = node;
invRowNodes[j].push_back(node);
}
}
//.........这里部分代码省略.........