From bfe3599b286f30d561e4df0b0785fa78d6652628 Mon Sep 17 00:00:00 2001 From: Tom M Date: Tue, 20 Sep 2022 19:41:20 +0200 Subject: [PATCH] Add linear interpolation to convex and concave transfer functions (#1156) Co-authored-by: md1872b <72792887+md1872b@users.noreply.github.com> --- src/utils/fluid_conv.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/src/utils/fluid_conv.c b/src/utils/fluid_conv.c index 65dcde309..ce80f2326 100644 --- a/src/utils/fluid_conv.c +++ b/src/utils/fluid_conv.c @@ -298,16 +298,17 @@ fluid_real_t fluid_balance(fluid_real_t balance, int left) fluid_real_t fluid_concave(fluid_real_t val) { + int ival = (int)val; if(val < 0.f) { return 0.f; } - else if(val >= (fluid_real_t)FLUID_VEL_CB_SIZE) + else if (ival >= FLUID_VEL_CB_SIZE - 1) { - return 1.f; + return fluid_concave_tab[FLUID_VEL_CB_SIZE - 1]; } - return fluid_concave_tab[(int) val]; + return fluid_concave_tab[ival] + (fluid_concave_tab[ival + 1] - fluid_concave_tab[ival]) * (val - ival); } /* @@ -316,15 +317,17 @@ fluid_concave(fluid_real_t val) fluid_real_t fluid_convex(fluid_real_t val) { + int ival = (int)val; if(val < 0.f) { return 0.f; } - else if(val >= (fluid_real_t)FLUID_VEL_CB_SIZE) + else if (ival >= FLUID_VEL_CB_SIZE - 1) { - return 1.f; + return fluid_convex_tab[FLUID_VEL_CB_SIZE - 1]; } - return fluid_convex_tab[(int) val]; + // interpolation between convex steps: fixes bad sounds with modenv and filter cutoff + return fluid_convex_tab[ival] + (fluid_convex_tab[ival + 1] - fluid_convex_tab[ival]) * (val - ival); }