本文整理汇总了C++中MPI_Scatter函数的典型用法代码示例。如果您正苦于以下问题:C++ MPI_Scatter函数的具体用法?C++ MPI_Scatter怎么用?C++ MPI_Scatter使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了MPI_Scatter函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: slave
void slave(MPI_Comm ring_comm)
{
int numbers[2];
int n;
/* Receive n from root node */
MPI_Bcast(&n /* Receive n from root */, 1 /* rx 1 number */ , MPI_INT, 0, ring_comm);
for(int i=0; i<floorf((float)n/(2*p)); i++){
/* Receive 2 numbers from root */
MPI_Scatter(NULL, 2 /*Send 2 bytes to everyone from array */, MPI_INT,
numbers, 2 /* Receive 2 bytes from root */, MPI_INT, 0 /* id of root node */,
ring_comm);
int min_no;
work_t work;
work.no1 = numbers[0];
work.no2 = numbers[1];
work_result_t work_result;
do_work(work, &work_result);
min_no = work_result.min_no;
/* Slaves send the minimum of two numbers */
MPI_Reduce(&min_no /* everyone sends 1 number to root */, NULL ,1 /* 1 number */, MPI_INT,
MPI_MIN , 0 /* id of root node */,
ring_comm);
}/*for*/
return ;
}/* slave */
示例2: main
int main(int argc, char *argv[]) {
int send[DATA_SIZE], recv[DATA_SIZE];
int rank, size, count, root, res;
MPI_Status status;
MPI_Init(&argc, &argv); // initialize MPI
MPI_Comm_rank(MPI_COMM_WORLD, &rank); // get own rank/ID
MPI_Comm_size(MPI_COMM_WORLD, &size); // get total number of processes
if(rank == 0) { //If root: Generate data to be distributed.
}
//Send data to all nodes. here: an integer array of length "count".
count = (DATA_SIZE / size); // each receive gets chunk of same size
// scatter: if rank=0, send data (and get own share); otherwise: receive data
MPI_Scatter(send, count, MPI_INT, recv, count, MPI_INT, 0, MPI_COMM_WORLD);
// Each node processes its share of data and sends the result (here: int "res") to root.
MPI_Gather(&res, 1, MPI_INT, recv, 1, MPI_INT, 0, MPI_COMM_WORLD);
if(rank == 0) { //If root: process the received data.
}
MPI_Finalize(); // shut down MPI
return 0;
}
示例3: main
int main(int argc,char** argv){
int rank,size,epp;
int* dataSend=NULL;
int i;
MPI_Init(NULL,NULL);
MPI_Comm_rank(MPI_COMM_WORLD,&rank);
MPI_Comm_size(MPI_COMM_WORLD,&size);
epp=2;
if(rank==0){
printf("Master creating data...\n");
dataSend=(int*)malloc(sizeof(int)*size*epp);
for(i=0;i<epp*size;i++)
dataSend[i]=i;
}
int* dataRecv1=(int*)malloc(sizeof(int)*epp);
MPI_Scatter(dataSend,epp,MPI_INT,dataRecv1,epp,MPI_INT,0,MPI_COMM_WORLD);
float subavg=0.0f;
for(i=0;i<epp;i++)
subavg+=dataRecv1[i];
subavg/=epp;
printf("%d calculates subavg as %f\n",rank,subavg);
float finalAvg;
MPI_Reduce(&subavg,&finalAvg,1,MPI_FLOAT,MPI_SUM,0,MPI_COMM_WORLD);
if(rank==0){
printf("The average is : %f",finalAvg/size);
}
MPI_Finalize();
}
示例4: testAllCollective
void testAllCollective(){
int count = 1000;
int root=2;
int *in, *out;
MPI_Comm comm=MPI_COMM_WORLD;
if(rank==0){
MPI_Scatter( buf0, 100, MPI_INT, buf1, 100, MPI_INT, root, comm);
MPI_Allreduce( in, out, count, MPI_INT, MPI_SUM, MPI_COMM_WORLD );
}
else{
MPI_Scatter( buf0, 100, MPI_INT, buf1, 100, MPI_INT, root, comm);
MPI_Allreduce( in, out, count, MPI_INT, MPI_SUM, MPI_COMM_WORLD );
}
}
示例5: main
int main(int argc,char* argv[]){
int rank,size;
int i,n;
int* A=NULL;
int D[2],sum;
MPI_Init(&argc,&argv);
MPI_Comm_rank(MPI_COMM_WORLD,&rank);
MPI_Comm_size(MPI_COMM_WORLD,&size);
int ctr=size*2;
A=(int*)malloc(sizeof(int)*size*2);
if(rank==0){
printf("Enter %d Elements :\n",size*2);
for(i=0;i<size*2;i++)
scanf("%d",&A[i]);
}
while(ctr!=1){
MPI_Scatter(A,2,MPI_INT,D,2,MPI_INT,0,MPI_COMM_WORLD);
sum=D[0]+D[1];
MPI_Gather(&sum,1,MPI_INT,A,1,MPI_INT,0,MPI_COMM_WORLD);
ctr/=2;
}
if(rank==0)
printf("Total Sum : %d\n",A[0]);
MPI_Finalize();
}
示例6: parallelsumArray
double parallelsumArray(double * arr, int num, int id, int numProc){
int root = 0;
double sum, totalSum, end, start, scatter, s;
if(id == 0){ //master reads array and scatters value
MPI_Bcast(&num, 1, MPI_INT, root, MPI_COMM_WORLD);
printf("%i\t%g\n", numProc, *arr);
}
else{ //workers sum their part of the array
MPI_Bcast(&num, 1, MPI_INT, root, MPI_COMM_WORLD);
}
int numElements = num/numProc;
double* localA = malloc(sizeof(double) * numElements);
start = MPI_Wtime();
MPI_Scatter(arr, numElements, MPI_DOUBLE, localA, numElements, MPI_DOUBLE, root, MPI_COMM_WORLD);
end = MPI_Wtime();
scatter = end - start;
start = MPI_Wtime();
sum = sumArray(localA, numElements);
MPI_Reduce(&sum, &totalSum, numProc, MPI_DOUBLE, MPI_SUM, root, MPI_COMM_WORLD);
end = MPI_Wtime();
s = end - start;
if(id == 0){
printf("scatter: %f, sum: %f\n", scatter, s);
}
//free(localA);
return totalSum;
}
示例7: type_map
static PyObject *scatter_array(PyObject *self, PyObject *args) {
PyArrayObject *x;
PyArrayObject *d;
int source, error, count, numprocs;
MPI_Datatype mpi_type;
/* process the parameters */
if (!PyArg_ParseTuple(args, "OOi", &x, &d, &source))
return NULL;
/* Input check and determination of MPI type */
mpi_type = type_map(x, &count);
if (!mpi_type) return NULL;
error = MPI_Comm_size(MPI_COMM_WORLD,&numprocs);
count = count/numprocs;
/* call the MPI routine */
error = MPI_Scatter(x->data, count, mpi_type, d->data, count,
mpi_type, source, MPI_COMM_WORLD);
if (error != 0) {
rank_raise_mpi_runtime(error, "MPI_Scatter");
return NULL;
}
Py_INCREF(Py_None);
return (Py_None);
}
示例8: main
int main(int argc, char* argv[]) {
int numtasks, rank, sendcount, recvcount, source;
float sendbuf[SIZE][SIZE] = {
{1.0, 2.0, 3.0, 4.0},
{5.0, 6.0, 7.0, 8.0},
{9.0, 10.0, 11.0, 12.0},
{13.0, 14.0, 15.0, 16.0} };
float recvbuf[SIZE];
MPI_Init(&argc,&argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &numtasks);
if (numtasks == SIZE) {
source = 1;
sendcount = SIZE;
recvcount = SIZE;
MPI_Scatter(sendbuf,sendcount,MPI_FLOAT,recvbuf,recvcount,
MPI_FLOAT,source,MPI_COMM_WORLD);
printf("rank= %d Results: %f %f %f %f\n",rank,recvbuf[0],
recvbuf[1],recvbuf[2],recvbuf[3]);
}
else
printf("Must specify %d processors. Terminating.\n",SIZE);
MPI_Finalize();
}
示例9: main
int main(int argc, char *argv[]){
int numTasks, rank, sendCount, recvCount, source;
// Array which distributed over processes.
float sendBuf[SIZE][SIZE] = {{1.0,2.0,3.0,4.0},{5.0,6.0,7.0,8.0},{9.0,10.0,11.0,12.0},{13.0,14.0,15.0,16.0}};
float recvBuf[SIZE];
// Initilizae MPI enivronment.
MPI_Init(&argc,&argv);
MPI_Comm_rank(MPI_COMM_WORLD,&rank);
MPI_Comm_size(MPI_COMM_WORLD,&numTasks);
// Must Specify the #of proc is 4
if(numTasks == SIZE){
source = 1;
sendCount = SIZE;
recvCount = SIZE;
// Scattering array amoung the processes.
MPI_Scatter(sendBuf,sendCount,MPI_FLOAT,recvBuf,recvCount,MPI_FLOAT,source,MPI_COMM_WORLD);
printf("Process#%d Results: %f %f %f %f \n",rank,recvBuf[0],recvBuf[1],recvBuf[2],recvBuf[3]);
}
else{
printf("Must specify %d processors. Terminating \n",SIZE);
}
MPI_Finalize();
}
示例10: main
int main(int argc, char** argv) {
if (argc != 2) {
fprintf(stderr, "Usage: avg num_elements_per_proc\n");
exit(1);
}
int num_elements_per_proc = atoi(argv[1]);
// Seed the random number generator to get different results each time
srand(time(NULL));
MPI_Init(NULL, NULL);
int world_rank;
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);
int world_size;
MPI_Comm_size(MPI_COMM_WORLD, &world_size);
// Create a random array of elements on the root process. Its total
// size will be the number of elements per process times the number
// of processes
float *rand_nums = NULL;
if (world_rank == 0) {
rand_nums = create_rand_nums(num_elements_per_proc * world_size);
}
// For each process, create a buffer that will hold a subset of the entire
// array
float *sub_rand_nums = (float *)malloc(sizeof(float) * num_elements_per_proc);
assert(sub_rand_nums != NULL);
// Scatter the random numbers from the root process to all processes in
// the MPI world
MPI_Scatter(rand_nums, num_elements_per_proc, MPI_FLOAT, sub_rand_nums,
num_elements_per_proc, MPI_FLOAT, 0, MPI_COMM_WORLD);
// Compute the average of your subset
float sub_avg = compute_avg(sub_rand_nums, num_elements_per_proc);
// Gather all partial averages down to all the processes
float *sub_avgs = (float *)malloc(sizeof(float) * world_size);
assert(sub_avgs != NULL);
MPI_Allgather(&sub_avg, 1, MPI_FLOAT, sub_avgs, 1, MPI_FLOAT, MPI_COMM_WORLD);
// Now that we have all of the partial averages, compute the
// total average of all numbers. Since we are assuming each process computed
// an average across an equal amount of elements, this computation will
// produce the correct answer.
float avg = compute_avg(sub_avgs, world_size);
printf("Avg of all elements from proc %d is %f\n", world_rank, avg);
// Clean up
if (world_rank == 0) {
free(rand_nums);
}
free(sub_avgs);
free(sub_rand_nums);
MPI_Barrier(MPI_COMM_WORLD);
MPI_Finalize();
}
示例11: main
int main (int argc, char* argv[]) {
int miID, procesos, local[4], localplus[4], externo;
srand(time(NULL));
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &miID);
MPI_Comm_size(MPI_COMM_WORLD, &procesos);
if (miID == 0)
{
local[0] = rand() % 100 + 1;
local[1] = rand() % 100 + 1;
local[2] = rand() % 100 + 1;
local[3] = rand() % 100 + 1;
}
//MPI_Scatter(dato, n° de datos, tipo, variable de destino, n° de datos a recibir, comunicador)
MPI_Scatter(&local, 1, MPI_INT, &externo, 1, MPI_INT, 0, MPI_COMM_WORLD);
printf("El proceso %d tiene el número %d\n", miID, externo);
MPI_Gather(&externo, 1, MPI_INT, &localplus, 1, MPI_INT, 0, MPI_COMM_WORLD);
if (miID == 0)
printf ("Datos: [%d,%d,%d,%d]\n",localplus[0], localplus[1], localplus[2], localplus[3]);
MPI_Finalize();
return 0;
}
示例12: main
int main(int argc,char **argv){
MPI_Init(&argc,&argv);
int rank,size,r,q,*A,*B,*C,i,min=100;
MPI_Comm_rank(MPI_COMM_WORLD,&rank);
MPI_Comm_size(MPI_COMM_WORLD,&size);
r=N%(size);
if(r==0) q=N/size;
else q=(N+size-r)/size;
B=(int*)calloc(q,sizeof(int));
if(rank==0){
A=(int*)calloc(N,sizeof(int));
C=(int*)calloc(size,sizeof(int));
for(i=0;i<N;i++){
A[i]=rand()%100;
printf("%d\n",A[i]);
}
}
MPI_Scatter(A,q,MPI_INT,B,q,MPI_INT,0,MPI_COMM_WORLD);
for(i=0;i<q;i++) if(min>B[i]) min=B[i];
MPI_Gather(&min,1,MPI_INT,C,1,MPI_INT,0,MPI_COMM_WORLD);
if(rank==0){
for(i=1;i<size;i++){
if(min>C[i]) min=C[i];
}
printf("Wynik to %d\n",min);
free(A);
free(C);
}
free(B);
MPI_Finalize();
return 0;
}
示例13: mpi_scatter_
FORT_DLL_SPEC void FORT_CALL mpi_scatter_ ( void*v1, MPI_Fint *v2, MPI_Fint *v3, void*v4, MPI_Fint *v5, MPI_Fint *v6, MPI_Fint *v7, MPI_Fint *v8, MPI_Fint *ierr ){
#ifndef HAVE_MPI_F_INIT_WORKS_WITH_C
if (MPIR_F_NeedInit){ mpirinitf_(); MPIR_F_NeedInit = 0; }
#endif
if (v4 == MPIR_F_MPI_IN_PLACE) v4 = MPI_IN_PLACE;
*ierr = MPI_Scatter( v1, (int)*v2, (MPI_Datatype)(*v3), v4, (int)*v5, (MPI_Datatype)(*v6), (int)*v7, (MPI_Comm)(*v8) );
}
示例14: mpi_scatter
void mpi_scatter (void *sendbuf, MPI_Fint *sendcount, MPI_Fint *sendtype,
void *recvbuf, MPI_Fint *recvcount, MPI_Fint *recvtype,
MPI_Fint *root, MPI_Fint *comm, MPI_Fint *__ierr)
{
*__ierr = MPI_Scatter (sendbuf, *sendcount, MPI_Type_f2c (*sendtype),
recvbuf, *recvcount, MPI_Type_f2c (*recvtype),
*root, MPI_Comm_f2c (*comm));
}
示例15: mpi_random_seed_slave
void mpi_random_seed_slave(int pnode, int cnt) {
int this_seed;
MPI_Scatter(NULL, 1, MPI_INT, &this_seed, 1, MPI_INT, 0, comm_cart);
RANDOM_TRACE(printf("%d: Received seed %d\n", this_node, this_seed));
init_random_seed(this_seed);
}