mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-28 04:47:04 +01:00
Regroup q4_1 dot addition for better numerics.
This commit is contained in:
parent
580991bbed
commit
4aeee216fd
5
ggml.c
5
ggml.c
@ -1848,12 +1848,13 @@ inline static void ggml_vec_dot_q4_1(const int n, float * restrict s, const void
|
|||||||
|
|
||||||
// Apply the scales, and accumulate
|
// Apply the scales, and accumulate
|
||||||
// acc += d0*m1*x + d1*m0*y
|
// acc += d0*m1*x + d1*m0*y
|
||||||
acc = _mm256_fmadd_ps( cross_scales, sums, acc );
|
__m256 delta = _mm256_mul_ps( cross_scales, sums );
|
||||||
|
|
||||||
// Convert int32_t to float
|
// Convert int32_t to float
|
||||||
__m256 p = _mm256_cvtepi32_ps( i32 );
|
__m256 p = _mm256_cvtepi32_ps( i32 );
|
||||||
// acc += d0*d1*x*y
|
// acc += d0*d1*x*y
|
||||||
acc = _mm256_fmadd_ps( scale_01, p, acc );
|
delta = _mm256_fmadd_ps( scale_01, p, delta );
|
||||||
|
acc = _mm256_add_ps( acc, delta );
|
||||||
|
|
||||||
// acc_offset += m0*m1 (avoid reloading from RAM)
|
// acc_offset += m0*m1 (avoid reloading from RAM)
|
||||||
acc_offset = _mm_fmadd_ss( _mm256_castps256_ps128( m0v ), _mm256_castps256_ps128( m1v ), acc_offset );
|
acc_offset = _mm_fmadd_ss( _mm256_castps256_ps128( m0v ), _mm256_castps256_ps128( m1v ), acc_offset );
|
||||||
|
Loading…
Reference in New Issue
Block a user