LCOV - code coverage report
Current view: top level - lib_com - ivas_mc_com.c (source / functions) Hit Total Coverage
Test: Coverage on main -- short test vectors @ 6c9ddc4024a9c0e1ecb8f643f114a84a0e26ec6b Lines: 92 101 91.1 %
Date: 2025-05-23 08:37:30 Functions: 4 4 100.0 %

          Line data    Source code
       1             : /******************************************************************************************************
       2             : 
       3             :    (C) 2022-2025 IVAS codec Public Collaboration with portions copyright Dolby International AB, Ericsson AB,
       4             :    Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V., Huawei Technologies Co. LTD.,
       5             :    Koninklijke Philips N.V., Nippon Telegraph and Telephone Corporation, Nokia Technologies Oy, Orange,
       6             :    Panasonic Holdings Corporation, Qualcomm Technologies, Inc., VoiceAge Corporation, and other
       7             :    contributors to this repository. All Rights Reserved.
       8             : 
       9             :    This software is protected by copyright law and by international treaties.
      10             :    The IVAS codec Public Collaboration consisting of Dolby International AB, Ericsson AB,
      11             :    Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V., Huawei Technologies Co. LTD.,
      12             :    Koninklijke Philips N.V., Nippon Telegraph and Telephone Corporation, Nokia Technologies Oy, Orange,
      13             :    Panasonic Holdings Corporation, Qualcomm Technologies, Inc., VoiceAge Corporation, and other
      14             :    contributors to this repository retain full ownership rights in their respective contributions in
      15             :    the software. This notice grants no license of any kind, including but not limited to patent
      16             :    license, nor is any license granted by implication, estoppel or otherwise.
      17             : 
      18             :    Contributors are required to enter into the IVAS codec Public Collaboration agreement before making
      19             :    contributions.
      20             : 
      21             :    This software is provided "AS IS", without any express or implied warranties. The software is in the
      22             :    development stage. It is intended exclusively for experts who have experience with such software and
      23             :    solely for the purpose of inspection. All implied warranties of non-infringement, merchantability
      24             :    and fitness for a particular purpose are hereby disclaimed and excluded.
      25             : 
      26             :    Any dispute, controversy or claim arising under or in relation to providing this software shall be
      27             :    submitted to and settled by the final, binding jurisdiction of the courts of Munich, Germany in
      28             :    accordance with the laws of the Federal Republic of Germany excluding its conflict of law rules and
      29             :    the United Nations Convention on Contracts on the International Sales of Goods.
      30             : 
      31             : *******************************************************************************************************/
      32             : 
      33             : #include <assert.h>
      34             : #include <stdint.h>
      35             : #include "options.h"
      36             : #ifdef DEBUGGING
      37             : #include "debug.h"
      38             : #endif
      39             : #include <math.h>
      40             : #include "prot.h"
      41             : #include "ivas_prot.h"
      42             : #include "wmc_auto.h"
      43             : 
      44             : 
      45             : /*---------------------------------------------------------------
      46             :  * ivas_mc_mode_select()
      47             :  *
      48             :  * selects the multichannel mode base on bitrate and LS setup
      49             :  * ---------------------------------------------------------------*/
      50             : 
      51             : /*! r : MC format mode */
      52      346160 : MC_MODE ivas_mc_mode_select(
      53             :     const MC_LS_SETUP mc_ls_setup, /* i  : MC loudspeaker setup           */
      54             :     const int32_t total_brate      /* i  : IVAS total bitrate             */
      55             : )
      56             : {
      57      346160 :     MC_MODE mc_mode = MC_MODE_MCT;
      58             : 
      59      346160 :     switch ( mc_ls_setup )
      60             :     {
      61      304205 :         case MC_LS_SETUP_5_1:
      62      304205 :             if ( total_brate < IVAS_48k )
      63             :             {
      64       70732 :                 mc_mode = MC_MODE_MCMASA;
      65             :             }
      66      233473 :             else if ( total_brate < IVAS_96k )
      67             :             {
      68       68884 :                 mc_mode = MC_MODE_PARAMMC;
      69             :             }
      70      304205 :             break;
      71        4426 :         case MC_LS_SETUP_7_1:
      72        4426 :             if ( total_brate < IVAS_48k )
      73             :             {
      74        1049 :                 mc_mode = MC_MODE_MCMASA;
      75             :             }
      76        3377 :             else if ( total_brate < IVAS_128k )
      77             :             {
      78         988 :                 mc_mode = MC_MODE_PARAMMC;
      79             :             }
      80        4426 :             break;
      81        6432 :         case MC_LS_SETUP_5_1_2:
      82        6432 :             if ( total_brate < IVAS_48k )
      83             :             {
      84        1701 :                 mc_mode = MC_MODE_MCMASA;
      85             :             }
      86        4731 :             else if ( total_brate < IVAS_128k )
      87             :             {
      88        2786 :                 mc_mode = MC_MODE_PARAMMC;
      89             :             }
      90        6432 :             break;
      91        6384 :         case MC_LS_SETUP_5_1_4:
      92        6384 :             if ( total_brate < IVAS_96k )
      93             :             {
      94        1736 :                 mc_mode = MC_MODE_MCMASA;
      95             :             }
      96        4648 :             else if ( total_brate < IVAS_160k )
      97             :             {
      98           0 :                 mc_mode = MC_MODE_PARAMMC;
      99             :             }
     100        6384 :             break;
     101       24713 :         case MC_LS_SETUP_7_1_4:
     102       24713 :             if ( total_brate < IVAS_128k )
     103             :             {
     104        7671 :                 mc_mode = MC_MODE_MCMASA;
     105             :             }
     106       17042 :             else if ( total_brate < IVAS_160k )
     107             :             {
     108         638 :                 mc_mode = MC_MODE_PARAMMC;
     109             :             }
     110       16404 :             else if ( total_brate < IVAS_192k )
     111             :             {
     112        5553 :                 mc_mode = MC_MODE_PARAMUPMIX;
     113             :             }
     114       24713 :             break;
     115           0 :         default:
     116           0 :             assert( 0 && "LS Setup not supported or defined for MC mode!\n" );
     117             :     }
     118             : 
     119      346160 :     return mc_mode;
     120             : }
     121             : 
     122             : 
     123             : /*---------------------------------------------------------------
     124             :  * ivas_mc_setup_get_num_channels()
     125             :  *
     126             :  * returns the number of channels (including the LFE) for a MC LS setup
     127             :  * ---------------------------------------------------------------*/
     128             : 
     129             : /*! r : number of loudspeaker channels */
     130       79858 : int16_t ivas_mc_ls_setup_get_num_channels(
     131             :     const MC_LS_SETUP mc_ls_setup /* i  : multi channel loudspeaker setup */
     132             : )
     133             : {
     134             :     int16_t nchan;
     135             : 
     136       79858 :     nchan = 0;
     137             : 
     138       79858 :     switch ( mc_ls_setup )
     139             :     {
     140       71164 :         case MC_LS_SETUP_5_1:
     141       71164 :             nchan = 6;
     142       71164 :             break;
     143        1063 :         case MC_LS_SETUP_7_1:
     144        1063 :             nchan = 8;
     145        1063 :             break;
     146         864 :         case MC_LS_SETUP_5_1_2:
     147         864 :             nchan = 8;
     148         864 :             break;
     149        2022 :         case MC_LS_SETUP_5_1_4:
     150        2022 :             nchan = 10;
     151        2022 :             break;
     152        4745 :         case MC_LS_SETUP_7_1_4:
     153        4745 :             nchan = 12;
     154        4745 :             break;
     155           0 :         default:
     156           0 :             assert( 0 && "LS Setup not supported or defined for MC mode!\n" );
     157             :     }
     158             : 
     159       79858 :     return nchan;
     160             : }
     161             : 
     162             : 
     163             : /*---------------------------------------------------------------
     164             :  * ivas_mc_map_output_config_to_mc_ls_setup()
     165             :  *
     166             :  * maps output configuration multi channel loudspeaker setup
     167             :  * ---------------------------------------------------------------*/
     168             : 
     169             : /*! r : multi channel loudspeaker setup */
     170      412272 : MC_LS_SETUP ivas_mc_map_output_config_to_mc_ls_setup(
     171             :     const AUDIO_CONFIG output_config /* i  : output audio configuration */
     172             : )
     173             : {
     174             :     MC_LS_SETUP mc_ls_setup;
     175             : 
     176      412272 :     mc_ls_setup = MC_LS_SETUP_INVALID;
     177             : 
     178      412272 :     switch ( output_config )
     179             :     {
     180      362583 :         case IVAS_AUDIO_CONFIG_5_1:
     181      362583 :             mc_ls_setup = MC_LS_SETUP_5_1;
     182      362583 :             break;
     183        5316 :         case IVAS_AUDIO_CONFIG_7_1:
     184        5316 :             mc_ls_setup = MC_LS_SETUP_7_1;
     185        5316 :             break;
     186        7107 :         case IVAS_AUDIO_CONFIG_5_1_2:
     187        7107 :             mc_ls_setup = MC_LS_SETUP_5_1_2;
     188        7107 :             break;
     189        8205 :         case IVAS_AUDIO_CONFIG_5_1_4:
     190        8205 :             mc_ls_setup = MC_LS_SETUP_5_1_4;
     191        8205 :             break;
     192       29061 :         case IVAS_AUDIO_CONFIG_7_1_4:
     193       29061 :             mc_ls_setup = MC_LS_SETUP_7_1_4;
     194       29061 :             break;
     195           0 :         default:
     196           0 :             assert( 0 && "Output config is not a valid MC loudspeaker setup!\n" );
     197             :     }
     198             : 
     199      412272 :     return mc_ls_setup;
     200             : }
     201             : 
     202             : 
     203             : /*---------------------------------------------------------------
     204             :  * ivas_mc_map_ls_setup_to_output_config
     205             :  *
     206             :  * maps multi channel loudspeaker setup to audio configuration
     207             :  * ---------------------------------------------------------------*/
     208             : 
     209             : /*! r: audio configuration*/
     210      290760 : AUDIO_CONFIG ivas_mc_map_ls_setup_to_output_config(
     211             :     const MC_LS_SETUP mc_ls_setup /* i  : multi channel loudspeaker setup*/
     212             : )
     213             : {
     214             :     AUDIO_CONFIG audio_config;
     215      290760 :     audio_config = IVAS_AUDIO_CONFIG_INVALID;
     216             : 
     217      290760 :     switch ( mc_ls_setup )
     218             :     {
     219      255858 :         case MC_LS_SETUP_5_1:
     220      255858 :             audio_config = IVAS_AUDIO_CONFIG_5_1;
     221      255858 :             break;
     222        3582 :         case MC_LS_SETUP_7_1:
     223        3582 :             audio_config = IVAS_AUDIO_CONFIG_7_1;
     224        3582 :             break;
     225        5364 :         case MC_LS_SETUP_5_1_2:
     226        5364 :             audio_config = IVAS_AUDIO_CONFIG_5_1_2;
     227        5364 :             break;
     228        5400 :         case MC_LS_SETUP_5_1_4:
     229        5400 :             audio_config = IVAS_AUDIO_CONFIG_5_1_4;
     230        5400 :             break;
     231       20556 :         case MC_LS_SETUP_7_1_4:
     232       20556 :             audio_config = IVAS_AUDIO_CONFIG_7_1_4;
     233       20556 :             break;
     234           0 :         default:
     235           0 :             assert( 0 && "MC loudspeaker setup is not valid!\n" );
     236             :     }
     237             : 
     238      290760 :     return audio_config;
     239             : }

Generated by: LCOV version 1.14