Commit 0bb7c3d0 authored by Dominik Weckbecker's avatar Dominik Weckbecker 💬
Browse files

Merge branch '1615_ref-port-mr-1413' into 'float-pc'

Port MR 1413 from float

See merge request !1635
parents 1eaec7f4 11d4e872
Loading
Loading
Loading
Loading
+4 −1
Original line number Diff line number Diff line
@@ -803,7 +803,10 @@ void dtx_read_padding_bits(
);

void ivas_apply_non_diegetic_panning( 
    float *output_f[],                                          /* i/o: core-coder transport mono channel/stereo output             */
#ifdef FIX_1009_ISM_NONDIEGETIC_PANNING
    float *input_f,                                             /* i  : non-diegetic object                                         */
#endif
    float *output_f[],                                          /* o  : core-coder transport mono channel/stereo output             */
    const float non_diegetic_pan_gain,                          /* i  : non-diegetic panning gain                                   */
    const int16_t output_frame                                  /* i  : output frame length per channel                             */
);
+1 −0
Original line number Diff line number Diff line
@@ -223,6 +223,7 @@
#define NONBE_FIX_1004_USAN_DTX_MASA_NO_DIRS             /* Nokia: fix USAN error caused by non-setting of correctly the number of MASA directions in DTX */
#define FIX_1008_EXTORIENT_TARGET_INTERPOLATION          /* FhG: issue #1008, external orientation init was wrong for 5ms */
/* #define NONBE_FIX_991_PARAMBIN_BINARY_HRTF */             /* Nokia: issue #991: fix using of binary file HRTF in ParamBin (to actiate when USE_NEW_HRTF_BINARY_FILE_FORMAT and FIX_777_COMBI_RENDER_CONFIG_FILE are on  )*/
#define FIX_1009_ISM_NONDIEGETIC_PANNING                /* FhG: issue #1009: use correct object buffer for ISM1 non-diegetic pan      */

/* #################### End BASOP porting switches ############################ */

+4 −0
Original line number Diff line number Diff line
@@ -1080,7 +1080,11 @@ ivas_error ivas_jbm_dec_render(
            }
            else if ( st_ivas->renderer_type == RENDERER_NON_DIEGETIC_DOWNMIX )
            {
#ifdef FIX_1009_ISM_NONDIEGETIC_PANNING
                ivas_apply_non_diegetic_panning( p_tc[0], p_output, st_ivas->hDecoderConfig->non_diegetic_pan_gain, *nSamplesRendered );
#else
                ivas_apply_non_diegetic_panning( p_output, st_ivas->hDecoderConfig->non_diegetic_pan_gain, *nSamplesRendered );
#endif
            }

#ifdef DEBUGGING
+9 −1
Original line number Diff line number Diff line
@@ -220,7 +220,10 @@ void ivas_mono_stereo_downmix_mcmasa(
 *------------------------------------------------------------------------*/

void ivas_apply_non_diegetic_panning(
    float *output_f[],                 /* i/o: core-coder transport mono channel/stereo output  */
#ifdef FIX_1009_ISM_NONDIEGETIC_PANNING
    float *input_f, /* i  : non-diegetic object                              */
#endif
    float *output_f[],                 /* o: core-coder transport mono channel/stereo output    */
    const float non_diegetic_pan_gain, /* i  : non-diegetic panning gain                        */
    const int16_t output_frame         /* i  : output frame length per channel                  */
)
@@ -230,8 +233,13 @@ void ivas_apply_non_diegetic_panning(
    pan_left = ( non_diegetic_pan_gain + 1.f ) * 0.5f;
    pan_right = 1.f - pan_left;

#ifdef FIX_1009_ISM_NONDIEGETIC_PANNING
    v_multc( input_f, pan_right, output_f[1], output_frame );
    v_multc( input_f, pan_left, output_f[0], output_frame );
#else
    v_multc( output_f[0], pan_right, output_f[1], output_frame );
    v_multc( output_f[0], pan_left, output_f[0], output_frame );
#endif

    return;
}