ggml : ggml_get_rows support 2D indexing [n_tokens, n_experts] (cpu only)

This commit is contained in:
Georgi Gerganov 2023-12-09 13:18:58 +02:00
parent 8b185b7030
commit 7372b62271
No known key found for this signature in database
GPG Key ID: 449E073F9DC10735
2 changed files with 10 additions and 8 deletions

11
ggml.c
View File

@ -4735,7 +4735,8 @@ struct ggml_tensor * ggml_get_rows(
struct ggml_context * ctx, struct ggml_context * ctx,
struct ggml_tensor * a, struct ggml_tensor * a,
struct ggml_tensor * b) { struct ggml_tensor * b) {
GGML_ASSERT(ggml_is_matrix(a) && ggml_is_vector(b) && b->type == GGML_TYPE_I32); GGML_ASSERT(a->ne[2] == b->ne[1]);
GGML_ASSERT(ggml_is_matrix(b) && b->type == GGML_TYPE_I32);
bool is_node = false; bool is_node = false;
@ -4745,7 +4746,7 @@ struct ggml_tensor * ggml_get_rows(
// TODO: implement non F32 return // TODO: implement non F32 return
//struct ggml_tensor * result = ggml_new_tensor_2d(ctx, a->type, a->ne[0], b->ne[0]); //struct ggml_tensor * result = ggml_new_tensor_2d(ctx, a->type, a->ne[0], b->ne[0]);
struct ggml_tensor * result = ggml_new_tensor_2d(ctx, GGML_TYPE_F32, a->ne[0], b->ne[0]); struct ggml_tensor * result = ggml_new_tensor_3d(ctx, GGML_TYPE_F32, a->ne[0], b->ne[0], b->ne[1]);
result->op = GGML_OP_GET_ROWS; result->op = GGML_OP_GET_ROWS;
result->grad = is_node ? ggml_dup_tensor(ctx, result) : NULL; result->grad = is_node ? ggml_dup_tensor(ctx, result) : NULL;
@ -10349,7 +10350,7 @@ static void ggml_compute_forward_get_rows_q(
ggml_to_float_t const dequantize_row_q = type_traits[type].to_float; ggml_to_float_t const dequantize_row_q = type_traits[type].to_float;
assert( dst->ne[0] == nc); assert( dst->ne[0] == nc);
assert( dst->ne[1] == nr); assert(ggml_nrows(dst) == nr);
assert(src0->nb[0] == ggml_type_size(type)); assert(src0->nb[0] == ggml_type_size(type));
for (int i = 0; i < nr; ++i) { for (int i = 0; i < nr; ++i) {
@ -10376,7 +10377,7 @@ static void ggml_compute_forward_get_rows_f16(
const int nr = ggml_nelements(src1); const int nr = ggml_nelements(src1);
assert( dst->ne[0] == nc); assert( dst->ne[0] == nc);
assert( dst->ne[1] == nr); assert(ggml_nrows(dst) == nr);
assert(src0->nb[0] == sizeof(ggml_fp16_t)); assert(src0->nb[0] == sizeof(ggml_fp16_t));
for (int i = 0; i < nr; ++i) { for (int i = 0; i < nr; ++i) {
@ -10404,7 +10405,7 @@ static void ggml_compute_forward_get_rows_f32(
const int nr = ggml_nelements(src1); const int nr = ggml_nelements(src1);
assert( dst->ne[0] == nc); assert( dst->ne[0] == nc);
assert( dst->ne[1] == nr); assert(ggml_nrows(dst) == nr);
assert(src0->nb[0] == sizeof(float)); assert(src0->nb[0] == sizeof(float));
for (int i = 0; i < nr; ++i) { for (int i = 0; i < nr; ++i) {

1
ggml.h
View File

@ -1263,6 +1263,7 @@ extern "C" {
struct ggml_context * ctx, struct ggml_context * ctx,
struct ggml_tensor * a); struct ggml_tensor * a);
// supports 3D: a->ne[2] == b->ne[1]
GGML_API struct ggml_tensor * ggml_get_rows( GGML_API struct ggml_tensor * ggml_get_rows(
struct ggml_context * ctx, struct ggml_context * ctx,
struct ggml_tensor * a, struct ggml_tensor * a,