summaryrefslogtreecommitdiff
path: root/plugins/fast_float/src/fast_float_sup.c
diff options
context:
space:
mode:
authorMarti Maria <marti.maria@littlecms.com>2020-05-25 19:44:47 +0200
committerMarti Maria <marti.maria@littlecms.com>2020-05-25 19:44:47 +0200
commitd881cc6791858f67e1bfd6fa306c2184a99f99e9 (patch)
treeb097bdc641d4e8bec80ecd070ef3c481c5258bd7 /plugins/fast_float/src/fast_float_sup.c
parentf9e2e80ab45a91dc99a9ca8eee39aa1986900b64 (diff)
downloadlcms2-d881cc6791858f67e1bfd6fa306c2184a99f99e9.tar.gz
Merged SSE matrix-shaper optimizer
It makes small difference, but here you go! In my computer, matrix shaper runs times x 2.4 faster the core lcms2 without SSE is about times x 2
Diffstat (limited to 'plugins/fast_float/src/fast_float_sup.c')
-rw-r--r--plugins/fast_float/src/fast_float_sup.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/plugins/fast_float/src/fast_float_sup.c b/plugins/fast_float/src/fast_float_sup.c
index 67c4e90..4b25705 100644
--- a/plugins/fast_float/src/fast_float_sup.c
+++ b/plugins/fast_float/src/fast_float_sup.c
@@ -40,6 +40,9 @@ cmsBool Floating_Point_Transforms_Dispatcher(_cmsTransformFn* TransformFn,
// Try to optimize by joining curves
if (Optimize8ByJoiningCurves(TransformFn, UserData, FreeUserData, Lut, InputFormat, OutputFormat, dwFlags)) return TRUE;
+ // Try to use SSE2 to optimize as a set of curves plus a matrix plus a set of curves
+ if (Optimize8MatrixShaperSSE(TransformFn, UserData, FreeUserData, Lut, InputFormat, OutputFormat, dwFlags)) return TRUE;
+
// Try to optimize as a set of curves plus a matrix plus a set of curves
if (Optimize8MatrixShaper(TransformFn, UserData, FreeUserData, Lut, InputFormat, OutputFormat, dwFlags)) return TRUE;