AdjointContract

Perform B:=iAHi, where the summation is performed over the local data of each member of the process team that was redundantly assigned entries of A but is not redundantly assigned entries of B. Thus, in the general case where each column and row of A is respectively distributed over the process sets U0×U1 and V0×V1, while each column and row of B is respectively distributed over U0 and V0, then the result is of the form

B=iU1×V1AHi.

C++ API

void AdjointContract(const ElementalMatrix<T> &A, ElementalMatrix<T> &B)
void AdjointContract(const BlockMatrix<T> &A, BlockMatrix<T> &B)

C API

TODO

Python API

TODO