From 34402d720ecae2befc0b602e67fc57189ab64de0 Mon Sep 17 00:00:00 2001 From: Stefano D'Angelo Date: Mon, 11 Sep 2023 13:29:36 +0200 Subject: [PATCH] now reset_state deals explicitly with initial values --- include/bw_ap1.h | 12 ++++++------ include/bw_ap2.h | 12 ++++++------ include/bw_hp1.h | 12 ++++++------ include/bw_hs1.h | 15 +++++++-------- include/bw_hs2.h | 11 +++++------ include/bw_lp1.h | 12 ++++++------ include/bw_ls1.h | 12 ++++++------ include/bw_ls2.h | 12 ++++++------ include/bw_mm1.h | 14 +++++++------- include/bw_mm2.h | 14 +++++++------- include/bw_notch.h | 12 ++++++------ include/bw_one_pole.h | 10 +++++----- include/bw_peak.h | 15 +++++++-------- include/bw_slew_lim.h | 10 +++++----- include/bw_svf.h | 16 ++++++++-------- 15 files changed, 93 insertions(+), 96 deletions(-) diff --git a/include/bw_ap1.h b/include/bw_ap1.h index b1c4e1d..23b013d 100644 --- a/include/bw_ap1.h +++ b/include/bw_ap1.h @@ -130,9 +130,9 @@ static inline float bw_ap1_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_ap1_reset_state_multi() * ```>>> */ @@ -144,11 +144,11 @@ static inline void bw_ap1_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_ap1_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_ap2.h b/include/bw_ap2.h index ff9c3fd..87dcb7e 100644 --- a/include/bw_ap2.h +++ b/include/bw_ap2.h @@ -127,9 +127,9 @@ static inline float bw_ap2_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_ap2_reset_state_multi() * ```>>> */ @@ -141,11 +141,11 @@ static inline void bw_ap2_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_ap2_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_hp1.h b/include/bw_hp1.h index e9d3aaf..2deb91c 100644 --- a/include/bw_hp1.h +++ b/include/bw_hp1.h @@ -128,9 +128,9 @@ static inline float bw_hp1_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_hp1_reset_state_multi() * ```>>> */ @@ -142,11 +142,11 @@ static inline void bw_hp1_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_hp1_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_hs1.h b/include/bw_hs1.h index 270b27a..0256894 100644 --- a/include/bw_hs1.h +++ b/include/bw_hs1.h @@ -129,9 +129,9 @@ static inline float bw_hs1_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_hs1_reset_state_multi() * ```>>> */ @@ -143,11 +143,11 @@ static inline void bw_hs1_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_hs1_update_coeffs_ctrl() * ```>>> */ @@ -436,8 +436,7 @@ static inline float bw_hs1_reset_state( BW_ASSERT(state != NULL); BW_ASSERT(bw_is_finite(x_0)); - const float y = x_0; - bw_mm1_reset_state(&coeffs->mm1_coeffs, &state->mm1_state, x_0); + const float y = bw_mm1_reset_state(&coeffs->mm1_coeffs, &state->mm1_state, x_0); #ifdef BW_DEBUG_DEEP state->hash = bw_hash_sdbm("bw_hs1_state"); diff --git a/include/bw_hs2.h b/include/bw_hs2.h index 7640401..6ed6afd 100644 --- a/include/bw_hs2.h +++ b/include/bw_hs2.h @@ -144,11 +144,11 @@ static inline void bw_hs2_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_hs2_update_coeffs_ctrl() * ```>>> */ @@ -462,8 +462,7 @@ static inline float bw_hs2_reset_state( BW_ASSERT(state != NULL); BW_ASSERT(bw_is_finite(x_0)); - const float y = x_0; - bw_mm2_reset_state(&coeffs->mm2_coeffs, &state->mm2_state, x_0); + const float y = bw_mm2_reset_state(&coeffs->mm2_coeffs, &state->mm2_state, x_0); #ifdef BW_DEBUG_DEEP state->hash = bw_hash_sdbm("bw_hs2_state"); diff --git a/include/bw_lp1.h b/include/bw_lp1.h index 7cb9440..a2e5054 100644 --- a/include/bw_lp1.h +++ b/include/bw_lp1.h @@ -130,9 +130,9 @@ static inline float bw_lp1_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_lp1_reset_state_multi() * ```>>> */ @@ -144,11 +144,11 @@ static inline void bw_lp1_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_lp1_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_ls1.h b/include/bw_ls1.h index 63ebc03..050af79 100644 --- a/include/bw_ls1.h +++ b/include/bw_ls1.h @@ -130,9 +130,9 @@ static inline float bw_ls1_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_ls1_reset_state_multi() * ```>>> */ @@ -144,11 +144,11 @@ static inline void bw_ls1_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_ls1_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_ls2.h b/include/bw_ls2.h index dc69121..7bc78ba 100644 --- a/include/bw_ls2.h +++ b/include/bw_ls2.h @@ -129,9 +129,9 @@ static inline float bw_ls2_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_ls2_reset_state_multi() * ```>>> */ @@ -143,11 +143,11 @@ static inline void bw_ls2_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_ls2_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_mm1.h b/include/bw_mm1.h index b597f63..6cea0d4 100644 --- a/include/bw_mm1.h +++ b/include/bw_mm1.h @@ -126,9 +126,9 @@ static inline float bw_mm1_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_mm1_reset_state_multi() * ```>>> */ @@ -140,11 +140,11 @@ static inline void bw_mm1_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_mm1_update_coeffs_ctrl() * ```>>> */ @@ -403,8 +403,8 @@ static inline float bw_mm1_reset_state( BW_ASSERT(state != NULL); BW_ASSERT(bw_is_finite(x_0)); - const float y = (bw_gain_get_gain_lin(&coeffs->gain_x_coeffs) + bw_gain_get_gain_lin(&coeffs->gain_lp_coeffs)) * x_0; bw_lp1_reset_state(&coeffs->lp1_coeffs, &state->lp1_state, x_0); + const float y = (bw_gain_get_gain_lin(&coeffs->gain_x_coeffs) + bw_gain_get_gain_lin(&coeffs->gain_lp_coeffs)) * x_0; #ifdef BW_DEBUG_DEEP state->hash = bw_hash_sdbm("bw_mm1_state"); diff --git a/include/bw_mm2.h b/include/bw_mm2.h index f251fed..fd26d36 100644 --- a/include/bw_mm2.h +++ b/include/bw_mm2.h @@ -126,9 +126,9 @@ static inline float bw_mm2_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_mm2_reset_state_multi() * ```>>> */ @@ -140,11 +140,11 @@ static inline void bw_mm2_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_mm2_update_coeffs_ctrl() * ```>>> */ @@ -452,9 +452,9 @@ static inline float bw_mm2_reset_state( BW_ASSERT(state != NULL); BW_ASSERT(bw_is_finite(x_0)); - const float y = (bw_gain_get_gain_lin(&coeffs->gain_x_coeffs) + bw_gain_get_gain_lin(&coeffs->gain_lp_coeffs)) * x_0; float lp, bp, hp; bw_svf_reset_state(&coeffs->svf_coeffs, &state->svf_state, x_0, &lp, &bp, &hp); + const float y = (bw_gain_get_gain_lin(&coeffs->gain_x_coeffs) + bw_gain_get_gain_lin(&coeffs->gain_lp_coeffs)) * x_0; #ifdef BW_DEBUG_DEEP state->hash = bw_hash_sdbm("bw_mm2_state"); diff --git a/include/bw_notch.h b/include/bw_notch.h index 5219021..80ecdcc 100644 --- a/include/bw_notch.h +++ b/include/bw_notch.h @@ -127,9 +127,9 @@ static inline float bw_notch_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_notch_reset_state_multi() * ```>>> */ @@ -141,11 +141,11 @@ static inline void bw_notch_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_notch_update_coeffs_ctrl() * ```>>> */ diff --git a/include/bw_one_pole.h b/include/bw_one_pole.h index e8e03a6..e7532f9 100644 --- a/include/bw_one_pole.h +++ b/include/bw_one_pole.h @@ -156,9 +156,9 @@ static inline float bw_one_pole_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_one_pole_reset_state_multi() * ```>>> */ @@ -170,10 +170,10 @@ static inline void bw_one_pole_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the + * The corresponding initial output values are written into the * `y_0` array, if not `NULL`. * * #### bw_one_pole_update_coeffs_ctrl() diff --git a/include/bw_peak.h b/include/bw_peak.h index 6738b67..ec8d179 100644 --- a/include/bw_peak.h +++ b/include/bw_peak.h @@ -138,9 +138,9 @@ static inline float bw_peak_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_peak_reset_state_multi() * ```>>> */ @@ -152,11 +152,11 @@ static inline void bw_peak_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the - * `y_0` array, if not `NULL`. + * The corresponding initial output values are written into the `y_0` array, + * if not `NULL`. * * #### bw_peak_update_coeffs_ctrl() * ```>>> */ @@ -500,8 +500,7 @@ static inline float bw_peak_reset_state( BW_ASSERT(state != NULL); BW_ASSERT(bw_is_finite(x_0)); - const float y = x_0; - bw_mm2_reset_state(&coeffs->mm2_coeffs, &state->mm2_state, x_0); + const float y = bw_mm2_reset_state(&coeffs->mm2_coeffs, &state->mm2_state, x_0); #ifdef BW_DEBUG_DEEP state->hash = bw_hash_sdbm("bw_peak_state"); diff --git a/include/bw_slew_lim.h b/include/bw_slew_lim.h index 8472389..0cecef2 100644 --- a/include/bw_slew_lim.h +++ b/include/bw_slew_lim.h @@ -132,9 +132,9 @@ static inline float bw_slew_lim_reset_state( float x_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/equilibrium value `x_0`. + * and the initial input value `x_0`. * - * Returns the corresponding quiescent/initial output value. + * Returns the corresponding initial output value. * * #### bw_slew_lim_reset_state_multi() * ```>>> */ @@ -146,10 +146,10 @@ static inline void bw_slew_lim_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial output values are written into the + * The corresponding initial output values are written into the * `y_0` array, if not `NULL`. * * #### bw_slew_lim_update_coeffs_ctrl() diff --git a/include/bw_svf.h b/include/bw_svf.h index 95e84dd..e6ffa84 100644 --- a/include/bw_svf.h +++ b/include/bw_svf.h @@ -162,10 +162,10 @@ static inline void bw_svf_reset_state( float * BW_RESTRICT y_hp_0); /*! <<<``` * Resets the given `state` to its initial values using the given `coeffs` - * and the quiescent/initial input value `x_0`. + * and the initial input value `x_0`. * - * The corresponding quiescent/initial lowpass, bandpass, and highpass output - * values are put into `y_lp_0`, `y_bp_0`, and `y_hp_0` respectively. + * The corresponding initial lowpass, bandpass, and highpass output values + * are put into `y_lp_0`, `y_bp_0`, and `y_hp_0` respectively. * * #### bw_svf_reset_state_multi() * ```>>> */ @@ -179,12 +179,12 @@ static inline void bw_svf_reset_state_multi( size_t n_channels); /*! <<<``` * Resets each of the `n_channels` `state`s to its initial values using the - * given `coeffs` and the corresponding quiescent/initial input value in the - * `x_0` array. + * given `coeffs` and the corresponding initial input value in the `x_0` + * array. * - * The corresponding quiescent/initial lowpass, bandpass, and highpass output - * values are put into `y_lp_0`, `y_bp_0`, and `y_hp_0` respectively, if they - * are not `NULL`. + * The corresponding initial lowpass, bandpass, and highpass output values + * are put into `y_lp_0`, `y_bp_0`, and `y_hp_0` respectively, if they are + * not `NULL`. * * #### bw_svf_update_coeffs_ctrl() * ```>>> */