本文整理汇总了C++中DistMatrix::GetLocalEntry方法的典型用法代码示例。如果您正苦于以下问题:C++ DistMatrix::GetLocalEntry方法的具体用法?C++ DistMatrix::GetLocalEntry怎么用?C++ DistMatrix::GetLocalEntry使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DistMatrix
的用法示例。
在下文中一共展示了DistMatrix::GetLocalEntry方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: PushCallStack
inline typename Base<F>::type
internal::FrobeniusNorm( const DistMatrix<F,MC,MR>& A )
{
#ifndef RELEASE
PushCallStack("internal::FrobeniusNorm");
#endif
typedef typename Base<F>::type R;
R localScale = 0;
R localScaledSquare = 1;
for( int jLocal=0; jLocal<A.LocalWidth(); ++jLocal )
{
for( int iLocal=0; iLocal<A.LocalHeight(); ++iLocal )
{
const R alphaAbs = Abs(A.GetLocalEntry(iLocal,jLocal));
if( alphaAbs != 0 )
{
if( alphaAbs <= localScale )
{
const R relScale = alphaAbs/localScale;
localScaledSquare += relScale*relScale;
}
else
{
const R relScale = localScale/alphaAbs;
localScaledSquare = localScaledSquare*relScale*relScale + 1;
localScale = alphaAbs;
}
}
}
}
// Find the maximum relative scale
R scale;
mpi::AllReduce( &localScale, &scale, 1, mpi::MAX, A.Grid().VCComm() );
R norm = 0;
if( scale != 0 )
{
// Equilibrate our local scaled sum to the maximum scale
R relScale = localScale/scale;
localScaledSquare *= relScale*relScale;
// The scaled square is now simply the sum of the local contributions
R scaledSquare;
mpi::AllReduce
( &localScaledSquare, &scaledSquare, 1, mpi::SUM, A.Grid().VCComm() );
norm = scale*Sqrt(scaledSquare);
}
#ifndef RELEASE
PopCallStack();
#endif
return norm;
}
示例2: PushCallStack
inline typename Base<F>::type
internal::InfinityNorm( const DistMatrix<F,MC,MR>& A )
{
#ifndef RELEASE
PushCallStack("internal::InfinityNorm");
#endif
typedef typename Base<F>::type R;
// Compute the partial row sums defined by our local matrix, A[MC,MR]
std::vector<R> myPartialRowSums(A.LocalHeight());
for( int iLocal=0; iLocal<A.LocalHeight(); ++iLocal )
{
myPartialRowSums[iLocal] = 0;
for( int jLocal=0; jLocal<A.LocalWidth(); ++jLocal )
myPartialRowSums[iLocal] += Abs(A.GetLocalEntry(iLocal,jLocal));
}
// Sum our partial row sums to get the row sums over A[MC,* ]
std::vector<R> myRowSums(A.LocalHeight());
mpi::AllReduce
( &myPartialRowSums[0], &myRowSums[0], A.LocalHeight(), mpi::SUM,
A.Grid().RowComm() );
// Find the maximum out of the row sums
R myMaxRowSum = 0;
for( int iLocal=0; iLocal<A.LocalHeight(); ++iLocal )
myMaxRowSum = std::max( myMaxRowSum, myRowSums[iLocal] );
// Find the global maximum row sum by searching over the MC team
R maxRowSum = 0;
mpi::AllReduce( &myMaxRowSum, &maxRowSum, 1, mpi::MAX, A.Grid().ColComm() );
#ifndef RELEASE
PopCallStack();
#endif
return maxRowSum;
}
示例3: logic_error
inline void
internal::PanelLU
( DistMatrix<F, STAR,STAR>& A,
DistMatrix<F, MC, STAR>& B,
DistMatrix<int,STAR,STAR>& p,
int pivotOffset )
{
#ifndef RELEASE
PushCallStack("internal::PanelLU");
if( A.Grid() != p.Grid() || p.Grid() != B.Grid() )
throw std::logic_error
("Matrices must be distributed over the same grid");
if( A.Width() != B.Width() )
throw std::logic_error("A and B must be the same width");
if( A.Height() != p.Height() || p.Width() != 1 )
throw std::logic_error("p must be a vector that conforms with A");
#endif
const Grid& g = A.Grid();
const int r = g.Height();
const int colShift = B.ColShift();
const int colAlignment = B.ColAlignment();
// Matrix views
DistMatrix<F,STAR,STAR>
ATL(g), ATR(g), A00(g), a01(g), A02(g),
ABL(g), ABR(g), a10(g), alpha11(g), a12(g),
A20(g), a21(g), A22(g);
DistMatrix<F,MC,STAR>
BL(g), BR(g),
B0(g), b1(g), B2(g);
DistMatrix<int,STAR,STAR>
pT(g), p0(g),
pB(g), psi1(g),
p2(g);
const int width = A.Width();
const int numBytes = (width+1)*sizeof(F)+sizeof(int);
std::vector<byte> sendData(numBytes);
std::vector<byte> recvData(numBytes);
// Extract pointers to send and recv data
F* sendBufFloat = (F*) &sendData[0];
F* recvBufFloat = (F*) &recvData[0];
int* sendBufInt = (int*) &sendData[(width+1)*sizeof(F)];
int* recvBufInt = (int*) &recvData[(width+1)*sizeof(F)];
// Start the algorithm
PushBlocksizeStack( 1 );
PartitionDownDiagonal
( A, ATL, ATR,
ABL, ABR, 0 );
PartitionRight( B, BL, BR, 0 );
PartitionDown
( p, pT,
pB, 0 );
while( ATL.Height() < A.Height() )
{
RepartitionDownDiagonal
( ATL, /**/ ATR, A00, /**/ a01, A02,
/*************/ /**********************/
/**/ a10, /**/ alpha11, a12,
ABL, /**/ ABR, A20, /**/ a21, A22 );
RepartitionRight
( BL, /**/ BR,
B0, /**/ b1, B2 );
RepartitionDown
( pT, p0,
/**/ /****/
psi1,
pB, p2 );
//--------------------------------------------------------------------//
// Store the index/value of the pivot candidate in A
F pivotValue = alpha11.GetLocalEntry(0,0);
int pivotIndex = a01.Height();
for( int i=0; i<a21.Height(); ++i )
{
F value = a21.GetLocalEntry(i,0);
if( FastAbs(value) > FastAbs(pivotValue) )
{
pivotValue = value;
pivotIndex = a01.Height() + i + 1;
}
}
// Update the pivot candidate to include local data from B
for( int i=0; i<B.LocalHeight(); ++i )
{
F value = b1.GetLocalEntry(i,0);
if( FastAbs(value) > FastAbs(pivotValue) )
{
pivotValue = value;
pivotIndex = A.Height() + colShift + i*r;
}
}
//.........这里部分代码省略.........