/usr/share/doc/libsprng2-doc/TESTS/communicate.c is in libsprng2-doc 2.0a-8.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88  | #ifdef SPRNG_MPI
#include <mpi.h>
#endif
#include "util.h"
#define SPRNG_MPI_KS 0
extern int proc_rank, init_nprocs, nsubsequences;
#ifdef __STDC__
void getKSdata (double *V, long ntests)
#else
void getKSdata (V, ntests)
double *V;
long ntests;
#endif
{
  int nprocs, myid, i, nsets;
  long first, last;
  
#ifdef SPRNG_MPI
  MPI_Status status;
  
  myid = proc_rank;
  nprocs = init_nprocs;
  nsets = ntests/nsubsequences;
  
  first = (nsets*myid/nprocs)*nsubsequences;
  last = (nsets*(myid+1)/nprocs)*nsubsequences - 1;
  
  if(myid != 0)
    MPI_Send(V, last-first+1, MPI_DOUBLE, 0, SPRNG_MPI_KS, MPI_COMM_WORLD);
  else
    for(i=1; i<nprocs; i++)
      MPI_Recv(V+(nsets*i/nprocs)*nsubsequences,
	       (nsets*(i+1)/nprocs - nsets*i/nprocs)*nsubsequences,
	       MPI_DOUBLE, i, SPRNG_MPI_KS, MPI_COMM_WORLD, &status);
  
  /*MPI_Finalize();*/
#endif
}
#ifdef __STDC__
void  reduce_sum(double *array,int n)
#else
void  reduce_sum(array,n)
double *array;
int n;
#endif
{
  double *temp;
  
#ifdef SPRNG_MPI
  temp = (double *) mymalloc(n*sizeof(double));
  MPI_Reduce(array, temp, n, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);
  
  if(proc_rank == 0)
    memcpy(array,temp,n*sizeof(double));
  free(temp);
#endif
}
  
void  reduce_sum_long(long *array,long n)
{
  long *temp;
  
#ifdef SPRNG_MPI
  temp = (long *) mymalloc(n*sizeof(long));
  MPI_Reduce(array, temp, n, MPI_LONG, MPI_SUM, 0, MPI_COMM_WORLD);
  
  if(proc_rank == 0)
    memcpy(array,temp,n*sizeof(long));
  free(temp);
#endif
}
  
 |