mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-28 12:57:03 +01:00
ggml : continue from #729 (wip)
This commit is contained in:
parent
bd166f7ffc
commit
71e6ae3779
22
ggml.c
22
ggml.c
@ -1188,13 +1188,17 @@ static void quantize_row_q4_2_reference(const float * restrict x, block_q4_2 * r
|
|||||||
|
|
||||||
for (int i = 0; i < nb; i++) {
|
for (int i = 0; i < nb; i++) {
|
||||||
float amax = 0.0f; // absolute max
|
float amax = 0.0f; // absolute max
|
||||||
|
float max = 0.0f;
|
||||||
|
|
||||||
for (int l = 0; l < QK4_2; l++) {
|
for (int l = 0; l < QK4_2; l++) {
|
||||||
const float v = x[i*QK4_2 + l];
|
const float v = x[i*QK4_2 + l];
|
||||||
amax = MAX(amax, fabsf(v));
|
if (amax < fabsf(v)) {
|
||||||
|
amax = fabsf(v);
|
||||||
|
max = v;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const float d = amax / ((1 << 3) - 1);
|
const float d = max / -8;
|
||||||
|
|
||||||
const float id = d ? 1.0f/d : 0.0f;
|
const float id = d ? 1.0f/d : 0.0f;
|
||||||
|
|
||||||
@ -1204,8 +1208,8 @@ static void quantize_row_q4_2_reference(const float * restrict x, block_q4_2 * r
|
|||||||
const float v0 = x[i*QK4_2 + l + 0]*id;
|
const float v0 = x[i*QK4_2 + l + 0]*id;
|
||||||
const float v1 = x[i*QK4_2 + l + 1]*id;
|
const float v1 = x[i*QK4_2 + l + 1]*id;
|
||||||
|
|
||||||
const uint8_t vi0 = (uint8_t)(v0 + 8.5f);
|
const uint8_t vi0 = MIN(15, (int8_t)roundf(v0) + 8);
|
||||||
const uint8_t vi1 = (uint8_t)(v1 + 8.5f);
|
const uint8_t vi1 = MIN(15, (int8_t)roundf(v1) + 8);
|
||||||
|
|
||||||
assert(vi0 < 16);
|
assert(vi0 < 16);
|
||||||
assert(vi1 < 16);
|
assert(vi1 < 16);
|
||||||
@ -1299,9 +1303,9 @@ static void quantize_row_q4_2(const float * restrict x, void * restrict vy, int
|
|||||||
|
|
||||||
block_q4_2 * restrict y = vy;
|
block_q4_2 * restrict y = vy;
|
||||||
|
|
||||||
//quantize_row_q4_2_reference(x, y, k);
|
quantize_row_q4_2_reference(x, y, k);
|
||||||
// This produces the exact same format, just better match to the input floats ("better" as measured by RMSE)
|
// This produces the exact same format, just better match to the input floats ("better" as measured by RMSE)
|
||||||
quantize_row_q4_2_rmse(x, y, k);
|
//quantize_row_q4_2_rmse(x, y, k);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void quantize_row_q4_3_reference(const float * restrict x, block_q4_3 * restrict y, int k) {
|
static void quantize_row_q4_3_reference(const float * restrict x, block_q4_3 * restrict y, int k) {
|
||||||
@ -1852,7 +1856,7 @@ static const quantize_fns_t quantize_fns[GGML_TYPE_COUNT] = {
|
|||||||
[GGML_TYPE_Q4_2] = {
|
[GGML_TYPE_Q4_2] = {
|
||||||
.dequantize_row_q = dequantize_row_q4_2,
|
.dequantize_row_q = dequantize_row_q4_2,
|
||||||
.quantize_row_q = quantize_row_q4_2,
|
.quantize_row_q = quantize_row_q4_2,
|
||||||
.quantize_row_q_reference = (quantize_row_q_t) quantize_row_q4_2_rmse, //quantize_row_q4_2_reference,
|
.quantize_row_q_reference = (quantize_row_q_t) quantize_row_q4_2_reference,
|
||||||
.quantize_row_q_dot = quantize_row_q8_0,
|
.quantize_row_q_dot = quantize_row_q8_0,
|
||||||
.vec_dot_q = ggml_vec_dot_q4_2_q8_0,
|
.vec_dot_q = ggml_vec_dot_q4_2_q8_0,
|
||||||
},
|
},
|
||||||
@ -12184,8 +12188,8 @@ size_t ggml_quantize_q4_2(const float * src, void * dst, int n, int k, int64_t *
|
|||||||
for (int j = 0; j < n; j += k) {
|
for (int j = 0; j < n; j += k) {
|
||||||
block_q4_2 * restrict y = (block_q4_2 *)dst + j/QK4_2;
|
block_q4_2 * restrict y = (block_q4_2 *)dst + j/QK4_2;
|
||||||
|
|
||||||
//quantize_row_q4_2_reference(src + j, y, k);
|
quantize_row_q4_2_reference(src + j, y, k);
|
||||||
quantize_row_q4_2_rmse(src + j, y, k);
|
//quantize_row_q4_2_rmse(src + j, y, k);
|
||||||
|
|
||||||
for (int i = 0; i < nb; i++) {
|
for (int i = 0; i < nb; i++) {
|
||||||
for (int l = 0; l < QK4_2; l += 2) {
|
for (int l = 0; l < QK4_2; l += 2) {
|
||||||
|
Loading…
Reference in New Issue
Block a user