本文整理汇总了C++中Permutation::Preimage方法的典型用法代码示例。如果您正苦于以下问题:C++ Permutation::Preimage方法的具体用法?C++ Permutation::Preimage怎么用?C++ Permutation::Preimage使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Permutation
的用法示例。
在下文中一共展示了Permutation::Preimage方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Mod
//.........这里部分代码省略.........
// tol = deflationFudge eps max( || d ||_max, 2*|beta| )
// = deflationFudge eps.
//
// Cf. LAPACK's {s,d}lasd2 [CITATION] for this tolerance.
const Real eps = limits::Epsilon<Real>();
const Real deflationTol = dcCtrl.deflationFudge*eps;
Matrix<Real> z(n,1);
Matrix<Int> columnTypes(n,1);
const Real betaSgn = Sgn( beta, false );
const Int lastRowOfQ0 = ( ctrl.wantEigVecs ? n0-1 : 0 );
const Real sqrtTwo = Sqrt( Real(2) );
z(0) = betaSgn*Q0(lastRowOfQ0,n0-1) / sqrtTwo;
columnTypes(0) = DENSE_COLUMN;
for( Int j=0; j<n0-1; ++j )
{
z(j+1) = betaSgn*Q0(lastRowOfQ0,j) / sqrtTwo;
columnTypes(j+1) = COLUMN_NONZERO_IN_FIRST_BLOCK;
}
for( Int j=0; j<n1; ++j )
{
z(j+n0) = Q1(0,j) / sqrtTwo;
columnTypes(j+n0) = COLUMN_NONZERO_IN_SECOND_BLOCK;
}
Permutation combineSortPerm;
SortingPermutation( d, combineSortPerm, ASCENDING );
combineSortPerm.PermuteRows( d );
combineSortPerm.PermuteRows( z );
combineSortPerm.PermuteRows( columnTypes );
auto combinedToOrig = [&]( const Int& combinedIndex )
{
const Int preCombined = combineSortPerm.Preimage( combinedIndex );
if( preCombined < n0 )
// Undo the cyclic shift [0,n0) |-> [1,n0+1) mod n0 which
// pushed the removed row into the first position.
return Mod( preCombined-1, n0 );
else
return preCombined;
};
Permutation deflationPerm;
deflationPerm.MakeIdentity( n );
deflationPerm.MakeArbitrary();
// Since we do not yet know how many undeflated entries there will be, we
// must use the no-deflation case as our storage upper bound.
Matrix<Real> dUndeflated(n,1), zUndeflated(n,1);
dUndeflated(0) = 0;
zUndeflated(0) = z(0);
// Deflate all (off-diagonal) update entries sufficiently close to zero
Int numDeflated = 0;
Int numUndeflated = 0;
// We will keep track of the last column that we encountered that was not
// initially deflatable (but that could be deflated later due to close
// diagonal entries if another undeflatable column is not encountered
// first).
Int revivalCandidate = n;
for( Int j=0; j<n; ++j )
{
if( Abs(2*beta*z(j)) <= deflationTol )
{
// We can deflate due to the r component being sufficiently small
const Int deflationDest = (n-1) - numDeflated;
deflationPerm.SetImage( j, deflationDest );