mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-07 19:33:58 +01:00
mpi : various fixes - communication now works but results are wrong
This commit is contained in:
parent
01abb3b3b9
commit
c717c5185f
21
ggml-mpi.c
21
ggml-mpi.c
@ -108,19 +108,17 @@ void ggml_mpi_graph_compute(
|
|||||||
|
|
||||||
const int mpi_rank_src = mpi_rank - 1;
|
const int mpi_rank_src = mpi_rank - 1;
|
||||||
|
|
||||||
// fprintf(stderr, "(%d) Receiving from (%d)\n", mpi_rank, mpi_rank_src);
|
//printf("%s: node %d: waiting for %d elements from %d\n", __func__, mpi_rank, (int) ggml_nelements(embd), mpi_rank_src);
|
||||||
const int retval = MPI_Recv(embd, ggml_nelements(embd), MPI_FLOAT, mpi_rank_src, MPI_ANY_TAG, MPI_COMM_WORLD, &status);
|
const int retval = MPI_Recv(embd->data, ggml_nelements(embd), MPI_FLOAT, mpi_rank_src, MPI_ANY_TAG, MPI_COMM_WORLD, &status);
|
||||||
GGML_ASSERT(retval == MPI_SUCCESS);
|
GGML_ASSERT(retval == MPI_SUCCESS);
|
||||||
// fprintf(stderr, "(%d) Received from (%d)\n", mpi_rank, mpi_rank_src);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// node 0 sends the input data to node 1
|
// node 0 sends the input data to node 1
|
||||||
{
|
{
|
||||||
const int mpi_rank_dst = mpi_rank + 1;
|
const int mpi_rank_dst = mpi_rank + 1;
|
||||||
|
|
||||||
const int retval = MPI_Send(embd, ggml_nelements(embd), MPI_FLOAT, mpi_rank_dst, 0, MPI_COMM_WORLD);
|
const int retval = MPI_Send(embd->data, ggml_nelements(embd), MPI_FLOAT, mpi_rank_dst, 0, MPI_COMM_WORLD);
|
||||||
GGML_ASSERT(retval == MPI_SUCCESS);
|
GGML_ASSERT(retval == MPI_SUCCESS);
|
||||||
// fprintf(stderr, "(%d) Sent to (%d)\n", mpi_rank, mpi_rank_dst);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// recv the output data from the last node
|
// recv the output data from the last node
|
||||||
@ -129,7 +127,8 @@ void ggml_mpi_graph_compute(
|
|||||||
|
|
||||||
const int mpi_rank_src = mpi_size - 1;
|
const int mpi_rank_src = mpi_size - 1;
|
||||||
|
|
||||||
const int retval = MPI_Recv(embd, ggml_nelements(embd), MPI_FLOAT, mpi_rank_src, MPI_ANY_TAG, MPI_COMM_WORLD, &status);
|
//fprintf(stderr, "%s: node %d: waiting for %d elements from %d\n", __func__, mpi_rank, (int) ggml_nelements(embd), mpi_rank_src);
|
||||||
|
const int retval = MPI_Recv(embd->data, ggml_nelements(embd), MPI_FLOAT, mpi_rank_src, MPI_ANY_TAG, MPI_COMM_WORLD, &status);
|
||||||
GGML_ASSERT(retval == MPI_SUCCESS);
|
GGML_ASSERT(retval == MPI_SUCCESS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -165,20 +164,28 @@ void ggml_mpi_graph_compute(
|
|||||||
for (int i = 1; i < idx_l1 - idx_l0; i++) {
|
for (int i = 1; i < idx_l1 - idx_l0; i++) {
|
||||||
gf->nodes[i] = gf->nodes[idx_l0 + i];
|
gf->nodes[i] = gf->nodes[idx_l0 + i];
|
||||||
gf->grads[i] = gf->grads[idx_l0 + i];
|
gf->grads[i] = gf->grads[idx_l0 + i];
|
||||||
|
|
||||||
|
//fprintf(stderr, "%s: node %d: %d -> %d\n", __func__, mpi_rank, idx_l0 + i, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
gf->n_nodes = idx_l1 - idx_l0;
|
gf->n_nodes = idx_l1 - idx_l0;
|
||||||
|
|
||||||
|
//fprintf(stderr, "%s: node %d: processing %d nodes [%d, %d)\n", __func__, mpi_rank, gf->n_nodes, il0, il1);
|
||||||
}
|
}
|
||||||
|
|
||||||
ggml_graph_compute(ctx, gf);
|
ggml_graph_compute(ctx, gf);
|
||||||
|
|
||||||
|
//fprintf(stderr, "%s: node %d: done\n", __func__, mpi_rank);
|
||||||
|
|
||||||
// send the output data to the next node
|
// send the output data to the next node
|
||||||
if (mpi_rank > 0) {
|
if (mpi_rank > 0) {
|
||||||
struct ggml_tensor * output = gf->nodes[gf->n_nodes - 1];
|
struct ggml_tensor * output = gf->nodes[gf->n_nodes - 1];
|
||||||
|
|
||||||
const int mpi_rank_dst = (mpi_rank + 1) % mpi_size;
|
const int mpi_rank_dst = (mpi_rank + 1) % mpi_size;
|
||||||
|
|
||||||
const int retval = MPI_Send(output, ggml_nelements(output), MPI_FLOAT, mpi_rank_dst, 0, MPI_COMM_WORLD);
|
//fprintf(stderr, "%s: node %d: sending %d elements to node %d\n", __func__, mpi_rank, ggml_nelements(output), mpi_rank_dst);
|
||||||
|
|
||||||
|
const int retval = MPI_Send(output->data, ggml_nelements(output), MPI_FLOAT, mpi_rank_dst, 0, MPI_COMM_WORLD);
|
||||||
GGML_ASSERT(retval == MPI_SUCCESS);
|
GGML_ASSERT(retval == MPI_SUCCESS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
10
llama.cpp
10
llama.cpp
@ -1287,6 +1287,10 @@ static bool llama_eval_internal(
|
|||||||
|
|
||||||
LLAMA_ASSERT((!tokens && embd) || (tokens && !embd));
|
LLAMA_ASSERT((!tokens && embd) || (tokens && !embd));
|
||||||
|
|
||||||
|
#ifdef GGML_USE_MPI
|
||||||
|
ggml_mpi_eval_init(lctx.ctx_mpi, &n_tokens, &n_past, &n_threads);
|
||||||
|
#endif
|
||||||
|
|
||||||
// enforce that the first token is BOS
|
// enforce that the first token is BOS
|
||||||
if (tokens && n_past == 0 && tokens[0] != llama_token_bos()) {
|
if (tokens && n_past == 0 && tokens[0] != llama_token_bos()) {
|
||||||
fprintf(stderr, "%s: first token must be BOS\n", __func__);
|
fprintf(stderr, "%s: first token must be BOS\n", __func__);
|
||||||
@ -1331,10 +1335,6 @@ static bool llama_eval_internal(
|
|||||||
struct ggml_tensor * cur;
|
struct ggml_tensor * cur;
|
||||||
struct ggml_tensor * inpL;
|
struct ggml_tensor * inpL;
|
||||||
|
|
||||||
#ifdef GGML_USE_MPI
|
|
||||||
ggml_mpi_eval_init(lctx.ctx_mpi, &n_tokens, &n_past, &n_threads);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (tokens) {
|
if (tokens) {
|
||||||
struct ggml_tensor * embd = ggml_new_tensor_1d(ctx0, GGML_TYPE_I32, N);
|
struct ggml_tensor * embd = ggml_new_tensor_1d(ctx0, GGML_TYPE_I32, N);
|
||||||
memcpy(embd->data, tokens, N*ggml_element_size(embd));
|
memcpy(embd->data, tokens, N*ggml_element_size(embd));
|
||||||
@ -1636,7 +1636,7 @@ static bool llama_eval_internal(
|
|||||||
ggml_graph_compute(ctx0, &gf);
|
ggml_graph_compute(ctx0, &gf);
|
||||||
}
|
}
|
||||||
#elif GGML_USE_MPI
|
#elif GGML_USE_MPI
|
||||||
ggml_mpi_graph_compute(lctx.ctx_mpi, ctx0, &gf, n_layer, n_embd, n_tokens);
|
ggml_mpi_graph_compute(lctx.ctx_mpi, ctx0, &gf, n_layer);
|
||||||
#else
|
#else
|
||||||
ggml_graph_compute(ctx0, &gf);
|
ggml_graph_compute(ctx0, &gf);
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user