From dfb24344031d2598e42583093bdd954999d58ac3 Mon Sep 17 00:00:00 2001 From: Tommy Hofmann Date: Wed, 8 Jan 2025 09:46:48 +0100 Subject: [PATCH] fix: aliasing bug in mul! of LocalFieldElem --- src/LocalField/Elem.jl | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/LocalField/Elem.jl b/src/LocalField/Elem.jl index 57a3554041..93624e76f6 100644 --- a/src/LocalField/Elem.jl +++ b/src/LocalField/Elem.jl @@ -629,11 +629,12 @@ function mul!(c::LocalFieldElem{S, T}, a::LocalFieldElem{S, T}, b::LocalFieldEle check_parent(a, b) K = parent(a) e = ramification_index(K) - c.data = mul!(c.data, data(a), data(b)) - c.data = mod(c.data, defining_polynomial(K, max(precision(data(c)), _precision_base(K)))) va = (iszero(a) ? 0 : Int(_valuation_integral(a))) vb = (iszero(b) ? 0 : Int(_valuation_integral(b))) pr = min(precision(a) + vb, precision(b) + va) + c.data = mul!(c.data, data(a), data(b)) + # from this point on, a, b might have changed (if c === a or c === b) + c.data = mod(c.data, defining_polynomial(K, max(precision(data(c)), _precision_base(K)))) c.precision = min(compute_precision(K, data(c)), pr) return c end