9 #ifndef METIS_SUPPORT_H
10 #define METIS_SUPPORT_H
21 template <
typename StorageIndex>
28 template <
typename MatrixType>
32 eigen_assert((
A.rows() ==
A.cols()) &&
"ONLY FOR SQUARED MATRICES");
39 for (StorageIndex j = 0; j < m; j++)
44 for (
typename MatrixType::InnerIterator it(
A, j); it; ++it)
46 Index idx = it.index();
47 if (visited(idx) != j )
54 for (
typename MatrixType::InnerIterator it(At, j); it; ++it)
56 Index idx = it.index();
70 StorageIndex CurNz = 0;
71 for (StorageIndex j = 0; j < m; j++)
77 for (
typename MatrixType::InnerIterator it(
A,j); it; ++it)
79 StorageIndex idx = it.index();
80 if (visited(idx) != j )
88 for (
typename MatrixType::InnerIterator it(At, j); it; ++it)
90 StorageIndex idx = it.index();
102 template <
typename MatrixType>
105 StorageIndex m = internal::convert_index<StorageIndex>(
A.cols());
114 if(output_error != METIS_OK)
117 std::cerr <<
"ERROR WHILE CALLING THE METIS PACKAGE \n";
126 for (
int j = 0; j < m; j++)
127 matperm.
indices()(iperm(j)) = j;