void ShiftDiagonal ( SparseMatrix<T>& A, S alphaPre, Int offset, bool existingDiag ) { EL_DEBUG_CSE const Int m = A.Height(); const Int n = A.Width(); const T alpha = T(alphaPre); if( existingDiag ) { T* valBuf = A.ValueBuffer(); for( Int i=Max(0,-offset); i<Min(m,n-offset); ++i ) { const Int e = A.Offset( i, i+offset ); valBuf[e] += alpha; } } else { const Int diagLength = Min(m,n-offset) - Max(0,-offset); A.Reserve( diagLength ); for( Int i=Max(0,-offset); i<Min(m,n-offset); ++i ) A.QueueUpdate( i, i+offset, alpha ); A.ProcessQueues(); } }
void EntrywiseMap( SparseMatrix<T>& A, function<T(T)> func ) { DEBUG_CSE T* vBuf = A.ValueBuffer(); const Int numEntries = A.NumEntries(); for( Int k=0; k<numEntries; ++k ) vBuf[k] = func(vBuf[k]); }