int n;
int x[10];
float y[10];
+ int no_repeat_mask;
int pitch_lag;
float pitch_fac;
} AMRFixed;
*
* Table contains only first the pulse indexes.
*
- * Used in G.729 @8k, G.729 @4.4k, AMR @7.95k, AMR @7.40k
+ * Used in G.729 @@8k, G.729 @@4.4k, AMR @@7.95k, AMR @@7.40k
*/
extern const uint8_t ff_fc_4pulses_8bits_tracks_13[16];
*
* @remark Track in the table should be read top-to-bottom, left-to-right.
*
- * Used in G.729 @8k, G.729 @4.4k, AMR @7.95k, AMR @7.40k
+ * Used in G.729 @@8k, G.729 @@4.4k, AMR @@7.95k, AMR @@7.40k
*/
extern const uint8_t ff_fc_4pulses_8bits_track_4[32];
* @note (EE) Reference G.729D code also uses gray decoding for each
* pulse index before looking up the value in the table.
*
- * Used in G.729 @6.4k (with gray coding), AMR @5.9k (without gray coding)
+ * Used in G.729 @@6.4k (with gray coding), AMR @@5.9k (without gray coding)
*/
extern const uint8_t ff_fc_2pulses_9bits_track1[16];
extern const uint8_t ff_fc_2pulses_9bits_track1_gray[16];
* @note (EE.2) Reference G.729D code also uses gray decoding for each
* pulse index before looking up the value in the table.
*
- * Used in G.729 @6.4k (with gray coding)
+ * Used in G.729 @@6.4k (with gray coding)
*/
extern const uint8_t ff_fc_2pulses_9bits_track2_gray[32];
/**
* Decode fixed-codebook vector (3.8 and D.5.8 of G.729, 5.7.1 of AMR).
- * @param fc_v [out] decoded fixed codebook vector (2.13)
+ * @param[out] fc_v decoded fixed codebook vector (2.13)
* @param tab1 table used for first pulse_count pulses
* @param tab2 table used for last pulse
* @param pulse_indexes fixed codebook indexes
* @param pulse_count number of pulses decoded using first table
* @param bits length of one pulse index in bits
*
- * Used in G.729 @8k, G.729 @4.4k, G.729 @6.4k, AMR @7.95k, AMR @7.40k
+ * Used in G.729 @@8k, G.729 @@4.4k, G.729 @@6.4k, AMR @@7.95k, AMR @@7.40k
*/
-void ff_acelp_fc_pulse_per_track(
- int16_t* fc_v,
- const uint8_t *tab1,
- const uint8_t *tab2,
- int pulse_indexes,
- int pulse_signs,
- int pulse_count,
- int bits);
+void ff_acelp_fc_pulse_per_track(int16_t* fc_v,
+ const uint8_t *tab1,
+ const uint8_t *tab2,
+ int pulse_indexes,
+ int pulse_signs,
+ int pulse_count,
+ int bits);
/**
* Decode the algebraic codebook index to pulse positions and signs and
/**
* weighted sum of two vectors with rounding.
- * @param out [out] result of addition
+ * @param[out] out result of addition
* @param in_a first vector
* @param in_b second vector
* @param weight_coeff_a first vector weight coefficient
*
* out[i] = (in_a[i]*weight_a + in_b[i]*weight_b + rounder) >> shift
*/
-void ff_acelp_weighted_vector_sum(
- int16_t* out,
- const int16_t *in_a,
- const int16_t *in_b,
- int16_t weight_coeff_a,
- int16_t weight_coeff_b,
- int16_t rounder,
- int shift,
- int length);
+void ff_acelp_weighted_vector_sum(int16_t* out,
+ const int16_t *in_a,
+ const int16_t *in_b,
+ int16_t weight_coeff_a,
+ int16_t weight_coeff_b,
+ int16_t rounder,
+ int shift,
+ int length);
/**
* float implementation of weighted sum of two vectors.
- * @param out [out] result of addition
+ * @param[out] out result of addition
* @param in_a first vector
* @param in_b second vector
* @param weight_coeff_a first vector weight coefficient
* @note It is safe to pass the same buffer for out and in_a or in_b.
*/
void ff_weighted_vector_sumf(float *out, const float *in_a, const float *in_b,
- float weight_coeff_a, float weight_coeff_b, int length);
+ float weight_coeff_a, float weight_coeff_b,
+ int length);
/**
- * Adaptative gain control (as used in AMR postfiltering)
+ * Adaptive gain control (as used in AMR postfiltering)
*
- * @param buf_out the input speech buffer
+ * @param out output buffer for filtered speech data
+ * @param in the input speech buffer (may be the same as out)
* @param speech_energ input energy
* @param size the input buffer size
* @param alpha exponential filter factor
* @param gain_mem a pointer to the filter memory (single float of size)
*/
-void ff_adaptative_gain_control(float *buf_out, float speech_energ,
- int size, float alpha, float *gain_mem);
+void ff_adaptive_gain_control(float *out, const float *in, float speech_energ,
+ int size, float alpha, float *gain_mem);
/**
* Set the sum of squares of a signal by scaling