[petsc-users] ISAllGather withoutduplicates
Blaise Bourdin
bourdin at lsu.edu
Fri Feb 17 13:46:13 CST 2012
Hi,
Is there an easy way to gather all values of an IS across all processes in a communicator while removing duplicates?
Basically, I want to go from
[0] Number of indices in set 2
[0] 0 1
[0] 1 2
[1] Number of indices in set 2
[1] 0 2
[1] 1 3
to
[0] Number of indices in set 3
[0] 0 1
[0] 1 2
[0] 2 3
[1] Number of indices in set 3
[1] 0 1
[1] 1 2
[1] 2 3
The way I do it right now is
ierr = ISGetTotalIndices(csIS,&labels);CHKERRQ(ierr);
ierr = ISGetSize(csIS,&num_cs_global);CHKERRQ(ierr);
ierr = PetscMalloc(num_cs_global * sizeof(PetscInt),&labels2);
for (i = 0; i < num_cs_global; i++) {
labels2[i] = labels[i];
}
ierr = PetscSortRemoveDupsInt(&num_cs_global,labels2);CHKERRQ(ierr);
ierr = ISCreateGeneral(comm,num_cs_global,labels2,PETSC_COPY_VALUES,&csIS_global);CHKERRQ(ierr);
ierr = ISRestoreTotalIndices(csIS,&labels);CHKERRQ(ierr);
ierr = PetscFree(labels2);CHKERRQ(ierr);
but there has to be a better way (or at least one that does not involve copying from const PetscInt *labels to PetscInt *labels2, and then uses again PETSC_COPY_VALUES).
Blaise
--
Department of Mathematics and Center for Computation & Technology
Louisiana State University, Baton Rouge, LA 70803, USA
Tel. +1 (225) 578 1612, Fax +1 (225) 578 4276 http://www.math.lsu.edu/~bourdin
More information about the petsc-users
mailing list