#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void AlltoAll(char *sendbuf, char *recvbuf, int count, MPI_Comm comm) {
int world_rank, world_size;
MPI_Comm_rank(comm, &world_rank);
MPI_Comm_size(comm, &world_size);
// Calculate the size of each message
int message_size = count / world_size;
// Allocate memory for receiving data
char *temp_recvbuf
= (char *)malloc(count
* sizeof(char));
// Scatter data to other processes using point-to-point communication
for (int i = 0; i < world_size; i++) {
if (i != world_rank) {
MPI_Send(sendbuf + i * message_size, message_size, MPI_CHAR, i, 0, comm);
}
}
// Receive data from other processes using point-to-point communication
for (int i = 0; i < world_size; i++) {
if (i != world_rank) {
MPI_Recv(temp_recvbuf + i * message_size, message_size, MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
}
}
// Copy received data to receive buffer
memcpy(recvbuf
, temp_recvbuf
, count
* sizeof(char));
}
void Allgather(char *sendbuf, int sendcount, char *recvbuf, int recvcount, MPI_Comm comm) {
int world_rank, world_size;
MPI_Comm_rank(comm, &world_rank);
MPI_Comm_size(comm, &world_size);
int total_send_count = sendcount * world_size;
// Allocate memory for temporary receive buffer
char *temp_recvbuf
= (char *)malloc(total_send_count
* sizeof(char));
// Send data to all other processes
for (int i = 0; i < world_size; i++) {
if (i != world_rank) {
MPI_Send(sendbuf, sendcount, MPI_CHAR, i, 0, comm);
}
}
// Copy own data to receive buffer
memcpy(recvbuf
+ world_rank
* recvcount
, sendbuf
, sendcount
);
// Receive data from all other processes
for (int i = 0; i < world_size; i++) {
if (i != world_rank) {
MPI_Recv(temp_recvbuf + i * recvcount, recvcount, MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
}
}
// Copy received data to receive buffer
for (int i = 0; i < world_size; i++) {
if (i != world_rank) {
memcpy(recvbuf
+ i
* recvcount
, temp_recvbuf
+ i
* recvcount
, recvcount
); }
}
}
void Allgatherv(char *sendbuf, int sendcount, char *recvbuf, int *recvcounts, int *displs, MPI_Comm comm) {
int world_rank, world_size;
MPI_Comm_rank(comm, &world_rank);
MPI_Comm_size(comm, &world_size);
// Determine the total size of data to be received
int total_recv_count = 0;
for (int i = 0; i < world_size; ++i) {
total_recv_count += recvcounts[i];
}
// Allocate memory for temporary receive buffer
char *temp_recvbuf
= (char *)malloc(total_recv_count
* sizeof(char));
// Receive data from each process and store in temporary buffer
for (int i = 0; i < world_size; ++i) {
MPI_Recv(temp_recvbuf + displs[i], recvcounts[i], MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
}
// Copy data from temporary buffer to final receive buffer
memcpy(recvbuf
, temp_recvbuf
, total_recv_count
* sizeof(char));
// Free temporary buffer
}
void my_Alltoallv(char *sendbuf, int *sendcounts, int *sdispls, char *recvbuf, int *recvcounts, int *rdispls, MPI_Comm comm) {
int world_rank, world_size;
MPI_Comm_rank(comm, &world_rank);
MPI_Comm_size(comm, &world_size);
// Calculate total send and receive counts
int total_send_count = 0;
int total_recv_count = 0;
for (int i = 0; i < world_size; i++) {
total_send_count += sendcounts[i];
total_recv_count += recvcounts[i];
}
// Allocate memory for temporary send and receive buffers
char *temp_sendbuf
= (char *)malloc(total_send_count
* sizeof(char)); char *temp_recvbuf
= (char *)malloc(total_recv_count
* sizeof(char));
// Copy data to temporary send buffer based on send counts and displacements
int send_offset = 0;
for (int i = 0; i < world_size; i++) {
memcpy(temp_sendbuf
+ send_offset
, sendbuf
+ sdispls
[i
], sendcounts
[i
]); send_offset += sendcounts[i];
}
// Exchange data with all other processes using point-to-point communication
for (int i = 0; i < world_size; i++) {
if (i != world_rank) {
// Send data to process i
MPI_Sendrecv(temp_sendbuf + sdispls[i], sendcounts[i], MPI_CHAR, i, 0,
temp_recvbuf + rdispls[i], recvcounts[i], MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
}
}
// Copy data from temporary receive buffer to receive buffer based on receive counts and displacements
int recv_offset = 0;
for (int i = 0; i < world_size; i++) {
memcpy(recvbuf
+ rdispls
[i
], temp_recvbuf
+ recv_offset
, recvcounts
[i
]); recv_offset += recvcounts[i];
}
// Free temporary buffers
}
int main(int argc, char *argv[]) {
MPI_Init(&argc, &argv);
int world_rank, world_size;
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);
MPI_Comm_size(MPI_COMM_WORLD, &world_size);
// Input data from user
char sendbuf[100]; // Assuming a maximum of 100 characters
if (world_rank == 0) {
printf("Enter data to send: "); }
// AlltoAll
char recvbuf_alltoall[100 * world_size];
AlltoAll(sendbuf, recvbuf_alltoall, 100, MPI_COMM_WORLD);
if (world_rank == 0) {
printf("AlltoAll received data: %s\n", recvbuf_alltoall
); }
// Allgather
char recvbuf_allgather[100 * world_size];
Allgather
(sendbuf
, strlen(sendbuf
) + 1, recvbuf_allgather
, strlen(sendbuf
) + 1, MPI_COMM_WORLD
); if (world_rank == 0) {
printf("Allgather received data: %s\n", recvbuf_allgather
); }
// Allgatherv
int *recvcounts_allgatherv
= (int *)malloc(world_size
* sizeof(int)); int *displs_allgatherv
= (int *)malloc(world_size
* sizeof(int)); int sendcount_allgatherv
= strlen(sendbuf
) + 1; for (int i = 0; i < world_size; ++i) {
recvcounts_allgatherv
[i
] = strlen(sendbuf
) + 1; displs_allgatherv
[i
] = i
* (strlen(sendbuf
) + 1); }
char recvbuf_allgatherv[100 * world_size];
Allgatherv(sendbuf, sendcount_allgatherv, recvbuf_allgatherv, recvcounts_allgatherv, displs_allgatherv, MPI_COMM_WORLD);
if (world_rank == 0) {
printf("Allgatherv received data: %s\n", recvbuf_allgatherv
); }
// Alltoallv
int sendcounts_alltoallv[world_size];
int recvcounts_alltoallv[world_size];
int sdispls_alltoallv[world_size];
int rdispls_alltoallv[world_size];
for (int i = 0; i < world_size; i++) {
sendcounts_alltoallv
[i
] = strlen(sendbuf
) + 1; recvcounts_alltoallv
[i
] = strlen(sendbuf
) + 1; sdispls_alltoallv
[i
] = i
* (strlen(sendbuf
) + 1); rdispls_alltoallv
[i
] = i
* (strlen(sendbuf
) + 1); }
char recvbuf_alltoallv[100 * world_size];
my_Alltoallv(sendbuf, sendcounts_alltoallv, sdispls_alltoallv, recvbuf_alltoallv, recvcounts_alltoallv, rdispls_alltoallv, MPI_COMM_WORLD);
if (world_rank == 0) {
printf("Alltoallv received data: %s\n", recvbuf_alltoallv
); }
// Finalize MPI
MPI_Finalize();
return 0;
}
#include <mpi.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void AlltoAll(char *sendbuf, char *recvbuf, int count, MPI_Comm comm) {
    int world_rank, world_size;
    MPI_Comm_rank(comm, &world_rank);
    MPI_Comm_size(comm, &world_size);

    // Calculate the size of each message
    int message_size = count / world_size;

    // Allocate memory for receiving data
    char *temp_recvbuf = (char *)malloc(count * sizeof(char));

    // Scatter data to other processes using point-to-point communication
    for (int i = 0; i < world_size; i++) {
        if (i != world_rank) {
            MPI_Send(sendbuf + i * message_size, message_size, MPI_CHAR, i, 0, comm);
        }
    }

    // Receive data from other processes using point-to-point communication
    for (int i = 0; i < world_size; i++) {
        if (i != world_rank) {
            MPI_Recv(temp_recvbuf + i * message_size, message_size, MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
        } 
    }

    // Copy received data to receive buffer
    memcpy(recvbuf, temp_recvbuf, count * sizeof(char));

    free(temp_recvbuf);
}

void Allgather(char *sendbuf, int sendcount, char *recvbuf, int recvcount, MPI_Comm comm) {
    int world_rank, world_size;
    MPI_Comm_rank(comm, &world_rank);
    MPI_Comm_size(comm, &world_size);

    int total_send_count = sendcount * world_size;

    // Allocate memory for temporary receive buffer
    char *temp_recvbuf = (char *)malloc(total_send_count * sizeof(char));

    // Send data to all other processes
    for (int i = 0; i < world_size; i++) {
        if (i != world_rank) {
            MPI_Send(sendbuf, sendcount, MPI_CHAR, i, 0, comm);
        }
    }

    // Copy own data to receive buffer
    memcpy(recvbuf + world_rank * recvcount, sendbuf, sendcount);

    // Receive data from all other processes
    for (int i = 0; i < world_size; i++) {
        if (i != world_rank) {
            MPI_Recv(temp_recvbuf + i * recvcount, recvcount, MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
        }
    }

    // Copy received data to receive buffer
    for (int i = 0; i < world_size; i++) {
        if (i != world_rank) {
            memcpy(recvbuf + i * recvcount, temp_recvbuf + i * recvcount, recvcount);
        }
    }

    free(temp_recvbuf);
}

void Allgatherv(char *sendbuf, int sendcount, char *recvbuf, int *recvcounts, int *displs, MPI_Comm comm) {
    int world_rank, world_size;
    MPI_Comm_rank(comm, &world_rank);
    MPI_Comm_size(comm, &world_size);

    // Determine the total size of data to be received
    int total_recv_count = 0;
    for (int i = 0; i < world_size; ++i) {
        total_recv_count += recvcounts[i];
    }

    // Allocate memory for temporary receive buffer
    char *temp_recvbuf = (char *)malloc(total_recv_count * sizeof(char));

    // Receive data from each process and store in temporary buffer
    for (int i = 0; i < world_size; ++i) {
        MPI_Recv(temp_recvbuf + displs[i], recvcounts[i], MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
    }

    // Copy data from temporary buffer to final receive buffer
    memcpy(recvbuf, temp_recvbuf, total_recv_count * sizeof(char));

    // Free temporary buffer
    free(temp_recvbuf);
}

void my_Alltoallv(char *sendbuf, int *sendcounts, int *sdispls, char *recvbuf, int *recvcounts, int *rdispls, MPI_Comm comm) {
    int world_rank, world_size;
    MPI_Comm_rank(comm, &world_rank);
    MPI_Comm_size(comm, &world_size);

    // Calculate total send and receive counts
    int total_send_count = 0;
    int total_recv_count = 0;
    for (int i = 0; i < world_size; i++) {
        total_send_count += sendcounts[i];
        total_recv_count += recvcounts[i];
    }

    // Allocate memory for temporary send and receive buffers
    char *temp_sendbuf = (char *)malloc(total_send_count * sizeof(char));
    char *temp_recvbuf = (char *)malloc(total_recv_count * sizeof(char));

    // Copy data to temporary send buffer based on send counts and displacements
    int send_offset = 0;
    for (int i = 0; i < world_size; i++) {
        memcpy(temp_sendbuf + send_offset, sendbuf + sdispls[i], sendcounts[i]);
        send_offset += sendcounts[i];
    }

    // Exchange data with all other processes using point-to-point communication
    for (int i = 0; i < world_size; i++) {
        if (i != world_rank) {
            // Send data to process i
            MPI_Sendrecv(temp_sendbuf + sdispls[i], sendcounts[i], MPI_CHAR, i, 0,
                         temp_recvbuf + rdispls[i], recvcounts[i], MPI_CHAR, i, 0, comm, MPI_STATUS_IGNORE);
        }
    }

    // Copy data from temporary receive buffer to receive buffer based on receive counts and displacements
    int recv_offset = 0;
    for (int i = 0; i < world_size; i++) {
        memcpy(recvbuf + rdispls[i], temp_recvbuf + recv_offset, recvcounts[i]);
        recv_offset += recvcounts[i];
    }

    // Free temporary buffers
    free(temp_sendbuf);
    free(temp_recvbuf);
}

int main(int argc, char *argv[]) {
    MPI_Init(&argc, &argv);

    int world_rank, world_size;
    MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);
    MPI_Comm_size(MPI_COMM_WORLD, &world_size);

    // Input data from user
    char sendbuf[100]; // Assuming a maximum of 100 characters
    if (world_rank == 0) {
        printf("Enter data to send: ");
        scanf("%s", sendbuf);
    }

    // AlltoAll
    char recvbuf_alltoall[100 * world_size];
    AlltoAll(sendbuf, recvbuf_alltoall, 100, MPI_COMM_WORLD);
    if (world_rank == 0) {
        printf("AlltoAll received data: %s\n", recvbuf_alltoall);
    }

    // Allgather
    char recvbuf_allgather[100 * world_size];
    Allgather(sendbuf, strlen(sendbuf) + 1, recvbuf_allgather, strlen(sendbuf) + 1, MPI_COMM_WORLD);
    if (world_rank == 0) {
        printf("Allgather received data: %s\n", recvbuf_allgather);
    }

    // Allgatherv
    int *recvcounts_allgatherv = (int *)malloc(world_size * sizeof(int));
    int *displs_allgatherv = (int *)malloc(world_size * sizeof(int));
    int sendcount_allgatherv = strlen(sendbuf) + 1;
    for (int i = 0; i < world_size; ++i) {
        recvcounts_allgatherv[i] = strlen(sendbuf) + 1;
        displs_allgatherv[i] = i * (strlen(sendbuf) + 1);
    }
    char recvbuf_allgatherv[100 * world_size];
    Allgatherv(sendbuf, sendcount_allgatherv, recvbuf_allgatherv, recvcounts_allgatherv, displs_allgatherv, MPI_COMM_WORLD);
    if (world_rank == 0) {
        printf("Allgatherv received data: %s\n", recvbuf_allgatherv);
    }

    // Alltoallv
    int sendcounts_alltoallv[world_size];
    int recvcounts_alltoallv[world_size];
    int sdispls_alltoallv[world_size];
    int rdispls_alltoallv[world_size];
    for (int i = 0; i < world_size; i++) {
        sendcounts_alltoallv[i] = strlen(sendbuf) + 1;
        recvcounts_alltoallv[i] = strlen(sendbuf) + 1;
        sdispls_alltoallv[i] = i * (strlen(sendbuf) + 1);
        rdispls_alltoallv[i] = i * (strlen(sendbuf) + 1);
    }
    char recvbuf_alltoallv[100 * world_size];
    my_Alltoallv(sendbuf, sendcounts_alltoallv, sdispls_alltoallv, recvbuf_alltoallv, recvcounts_alltoallv, rdispls_alltoallv, MPI_COMM_WORLD);
    if (world_rank == 0) {
        printf("Alltoallv received data: %s\n", recvbuf_alltoallv);
    }

    // Finalize MPI
    MPI_Finalize();
    return 0;
}
