melody_coef_cal32.h
上传用户:gelin96
上传日期:2017-01-08
资源大小:20993k
文件大小:6k
源码类别:

MTK

开发平台:

C++ Builder

  1. /*****************************************************************************
  2. *  Copyright Statement:
  3. *  --------------------
  4. *  This software is protected by Copyright and the information contained
  5. *  herein is confidential. The software may not be copied and the information
  6. *  contained herein may not be used or disclosed except with the written
  7. *  permission of MediaTek Inc. (C) 2005
  8. *
  9. *  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
  10. *  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
  11. *  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
  12. *  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
  13. *  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
  14. *  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
  15. *  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
  16. *  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
  17. *  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
  18. *  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
  19. *  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
  20. *  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
  21. *
  22. *  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
  23. *  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
  24. *  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
  25. *  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
  26. *  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
  27. *
  28. *  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
  29. *  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
  30. *  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
  31. *  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
  32. *  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
  33. *
  34. *****************************************************************************/
  35. /*****************************************************************************
  36.  *
  37.  * Filename:
  38.  * ---------
  39.  *   melody_coef_cal32.h
  40.  *
  41.  * Project:
  42.  * --------
  43.  *   Maui META APP
  44.  *
  45.  * Description:
  46.  * ------------
  47.  *  Melody FIR coefficient calibration header
  48.  *
  49.  * Author:
  50.  * -------
  51.  *  Andy Ueng (mtk00490)
  52.  *
  53.  *============================================================================
  54.  *             HISTORY
  55.  * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
  56.  *------------------------------------------------------------------------------
  57.  * $Revision$
  58.  * $Modtime$
  59.  * $Log$
  60.  *
  61.  *------------------------------------------------------------------------------
  62.  * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
  63.  *============================================================================
  64.  ****************************************************************************/
  65. #ifndef  _MELODY_COEF_CAL32_H_
  66. #define  _MELODY_COEF_CAL32_H_
  67. /*---------------------------------------------------------------------------*/
  68. #ifndef META_DLL_H
  69. #include "meta.h"
  70. #endif
  71. #ifndef _AUDIO_COMMON_H_
  72. #include "Audio_common.h"
  73. #endif
  74. #ifndef  _SP_COEF_H_
  75. #include "sp_coef.h"
  76. #endif
  77. #ifndef AFTDLL_DLL_H
  78. #include "aftdll.h"
  79. #endif
  80. #ifndef  _MAN_HANDLE_H_
  81. #include "man_handle.h"
  82. #endif
  83. #define  STATE_COEF_CAL32_OK            0
  84. #define  STATE_COEF_CAL32_FAIL          1
  85. #define  STATE_COEF_CAL32_TIMEOUT       2
  86. #define  STATE_COEF_CAL32_STOP          3
  87. #define  TOTAL_SEL_MELODY_FREQ_NUM     22
  88. #define  TOTAL_MELODY_SAMPLE_NUM      160
  89. #define  MELODY_FIR_TAPS               25
  90. #define  MELODY_FIR_COEFF_SCALE     32767.0
  91. typedef struct
  92. {
  93.    unsigned int num;
  94.    double  Hz[TOTAL_SEL_MELODY_FREQ_NUM];
  95.    double  Mag[TOTAL_SEL_MELODY_FREQ_NUM];
  96.    double  MagdB[TOTAL_SEL_MELODY_FREQ_NUM];
  97. }sMelodySelected;
  98. typedef struct
  99. {
  100.     double  Hz[TOTAL_MELODY_SAMPLE_NUM];
  101.     double  Mag[TOTAL_MELODY_SAMPLE_NUM];
  102.     double  MagdB[TOTAL_MELODY_SAMPLE_NUM];
  103. }sMelodyInterpolate;
  104. typedef struct
  105. {
  106.     double  Mag[MELODY_FIR_TAPS];
  107. }sMelodyFir;
  108. /*---------------------------------------------------------------------------*/
  109. class  CMELODYCOEFCAL32
  110. {
  111. private:
  112.     int   m_iConfirmState;
  113.     CMETAHANDLE m_META_HANDLE_Obj;
  114. protected:
  115.    void  Confirm( int confirm_state );
  116. public:
  117.    short         MELODYID_COEF_CAL;
  118.    char        *CoefCalBuf;
  119.    int          CoefCalBufSize;
  120. /*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
  121.   // Public member
  122.     CMELODYCOEFCAL32( void );
  123.    ~CMELODYCOEFCAL32( );
  124.     void  (*ConfirmCallback)( void );
  125.   // Public interface
  126.     void  REQ_Finish( void );
  127.     void  REQ_TimeOut( void );
  128.     void  REQ_Stop( void );
  129.     
  130.     // file
  131.     bool  REQ_Write_FIR_File( char *filename, sMelodyFir *p_MelodyFirCoef );
  132.     bool  CheckLicenseDat( void );
  133.     // Matlab
  134.     AFT_RESULT  firls( int N, double Fs, sMelodyInterpolate *p_MelodyInterpolate, sMelodyFir *p_MelodyFir);
  135.     AFT_RESULT  freqz( sMelodyFir *p_MelodyFir, int A, int N, double Fs, sMelodyInterpolate *p_MelodyInterpolate);
  136.     const char* Get_ErrorString(AFT_RESULT code);
  137.     void  getSelHzIndex(int *p_TplHz, int *p_SelHz, int* p_SelHzIndex);
  138.     void  getSeldB( double *p_TpldB, double *p_SeldB, int* p_SelHzIndex);
  139.     bool  CheckEngineExist( void );
  140.     bool  getInterpolateFreq( double start_freq, double step_freq, double end_freq, sMelodyInterpolate *p_interpolate );
  141.     bool  interp1(sMelodySelected *p_mSel, sMelodyInterpolate *p_xi_Coeff);
  142.     bool  getIndexRange( double source_Hz, double *p_dest_Hz, int &idx1, int &idx2);
  143.     bool getInterpolateValue(sMelodySelected *p_mSel, int idx1, int idx2, double source_Hz, double &interpolate_value);
  144.     // Global information
  145.     int  Get_ConfirmState( void );
  146. };
  147. /*---------------------------------------------------------------------------*/
  148. #endif