mirror of
https://github.com/WinampDesktop/winamp.git
synced 2024-12-12 01:21:00 -05:00
6241 lines
292 KiB
C
6241 lines
292 KiB
C
/* /////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// INTEL CORPORATION PROPRIETARY INFORMATION
|
|
// This software is supplied under the terms of a license agreement or
|
|
// nondisclosure agreement with Intel Corporation and may not be copied
|
|
// or disclosed except in accordance with the terms of that agreement.
|
|
// Copyright (c) 2001-2009 Intel Corporation. All Rights Reserved.
|
|
//
|
|
// Intel(R) Integrated Performance Primitives
|
|
// Speech Recognition Reference Library
|
|
//
|
|
*/
|
|
|
|
#if !defined( __IPPSR_H__ ) || defined( _OWN_BLDPCS )
|
|
#define __IPPSR_H__
|
|
|
|
#if defined (_WIN32_WCE) && defined (_M_IX86) && defined (__stdcall)
|
|
#define _IPP_STDCALL_CDECL
|
|
#undef __stdcall
|
|
#endif
|
|
|
|
#ifndef __IPPDEFS_H__
|
|
#include "ippdefs.h"
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#if !defined( _OWN_BLDPCS )
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Common Types & Definitions
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
typedef enum {
|
|
IPP_DELTA_BEGIN=0x0001,
|
|
IPP_DELTA_END=0x0002
|
|
} DeltaMode;
|
|
|
|
#define ippsDeltaBegin IPP_DELTA_BEGIN
|
|
#define ippsDeltaEnd IPP_DELTA_END
|
|
|
|
typedef enum {
|
|
IPP_FBANK_MELWGT = 1,
|
|
IPP_FBANK_FREQWGT = 2,
|
|
IPP_POWER_SPECTRUM = 4
|
|
} IppMelMode;
|
|
|
|
typedef enum {
|
|
IPP_VOICE = 1,
|
|
IPP_UNVOICE = 2,
|
|
IPP_PREPARE = 4
|
|
} IppVADDecision_Aurora;
|
|
|
|
typedef enum {
|
|
IPP_CDBK_FULL = 1,
|
|
IPP_CDBK_KMEANS_LONG = 2,
|
|
IPP_CDBK_KMEANS_NUM = 3
|
|
} Ipp_Cdbk_Hint;
|
|
|
|
struct BlockDMatrix_32f;
|
|
struct BlockDMatrix_64f;
|
|
struct BlockDMatrix_16s;
|
|
|
|
typedef struct BlockDMatrix_32f IppsBlockDMatrix_32f;
|
|
typedef struct BlockDMatrix_64f IppsBlockDMatrix_64f;
|
|
typedef struct BlockDMatrix_16s IppsBlockDMatrix_16s;
|
|
|
|
struct FBankState_16s;
|
|
struct DCTLifterState_16s;
|
|
struct FBankState_32f;
|
|
struct DCTLifterState_32f;
|
|
struct VADDrop_32f;
|
|
struct VADDrop_16s;
|
|
struct ResamplingPolyphase_16s;
|
|
struct ResamplingPolyphaseFixed_16s;
|
|
struct ResamplingPolyphase_32f;
|
|
struct ResamplingPolyphaseFixed_32f;
|
|
struct FBankState_32s;
|
|
|
|
typedef struct ResamplingPolyphase_16s IppsResamplingPolyphase_16s;
|
|
typedef struct ResamplingPolyphaseFixed_16s IppsResamplingPolyphaseFixed_16s;
|
|
typedef struct ResamplingPolyphase_32f IppsResamplingPolyphase_32f;
|
|
typedef struct ResamplingPolyphaseFixed_32f IppsResamplingPolyphaseFixed_32f;
|
|
|
|
#define IppsResamlingPolyphase_16s IppsResamplingPolyphase_16s
|
|
#define IppsResamlingPolyphaseFixed_16s IppsResamplingPolyphaseFixed_16s
|
|
#define IppsResamlingPolyphase_32f IppsResamplingPolyphase_32f
|
|
#define IppsResamlingPolyphaseFixed_32f IppsResamplingPolyphaseFixed_32f
|
|
|
|
typedef struct VADDrop_32f IppsVADDrop_32f;
|
|
typedef struct VADDrop_16s IppsVADDrop_16s;
|
|
typedef struct FBankState_16s IppsFBankState_16s;
|
|
typedef struct DCTLifterState_16s IppsDCTLifterState_16s;
|
|
typedef struct FBankState_32f IppsFBankState_32f;
|
|
typedef struct DCTLifterState_32f IppsDCTLifterState_32f;
|
|
typedef struct FBankState_32s IppsFBankState_32s;
|
|
|
|
struct CdbkState_32f;
|
|
typedef struct CdbkState_32f IppsCdbkState_32f;
|
|
|
|
struct CdbkState_16s;
|
|
typedef struct CdbkState_16s IppsCdbkState_16s;
|
|
|
|
#endif /* _OWN_BLDPCS */
|
|
|
|
#define IPP_TRUNC(a,b) ((a)&~((b)-1))
|
|
#define IPP_APPEND(a,b) (((a)+(b)-1)&~((b)-1))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Definitions for LogAdd Functions
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
/*Ipp64f*/
|
|
#define IPPSLOGZERO (-1.0e+10)
|
|
#define IPPSLOGSMALL (-0.9e+10)
|
|
#define IPPSMINLOGEXP -23.0258509299405 /*-log(-LOGZERO)*/
|
|
#define IPPSMAXFWDP (-1.0e-8) /* highest p<0: exp(p) < DBL_EPSILON */
|
|
#define IPPSMINFWDP -20.0 /* minimum forward probability */
|
|
/*Ipp32f*/
|
|
#define IPPSLOGZERO_F (-4.5e+6)
|
|
#define IPPSLOGSMALL_F (-4.5e+6)
|
|
#define IPPSMINLOGEXP_F -15.3195879547406 /*-log(-LOGZERO) */
|
|
#define IPPSMAXFWDP_F (-1.0e-4) /* highest p<0: exp(p) < FLT_EPSILON */
|
|
#define IPPSMINFWDP_F -10.0 /* minimum forward probability */
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Definitions for LogSub Functions
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
#define IPPSMINLARG (2.45E-308) /* lowest log() arg = exp(MINEARG) */
|
|
#define IPPSMINMIX (-11.5129254649702) /* log(1.0e-5) */
|
|
#define IPPSMINEARG (-708.3) /* lowest exp() arg = log(MINLARG) */
|
|
#define IPPSMINEARG_F (-85.19) /* lowest exp() arg = log(MINLARG_F) */
|
|
#define IPPSMINLARG_F (1.0057e-037) /* lowest log() arg = exp(MINEARG_F) */
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
// Functions declarations
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsrGetLibVersion
|
|
// Purpose: getting of the library version
|
|
// Returns: the structure of information about version of ippsr library
|
|
// Parameters:
|
|
//
|
|
// Notes: not necessary to release the returned structure
|
|
*/
|
|
IPPAPI( const IppLibraryVersion*, ippsrGetLibVersion, (void) )
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Basic Arithmetics
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsAddAllRowSum_32f_D2
|
|
// Purpose: Calculates the sums of column vectors in a matrix
|
|
// and adds the sums to a vector.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*sStep].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// step The row step in pSrc.
|
|
// height The number of rows in the input matrix mSrc.
|
|
// width Number of columns in the input matrix mSrc, and also the
|
|
// length of the output vector pSrcDst.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, or mSrc, or pSrcDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsAddAllRowSum_32f_D2, (const Ipp32f* pSrc, int step,
|
|
int height, Ipp32f* pSrcDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsAddAllRowSum_32f_D2L, (const Ipp32f** mSrc, int height,
|
|
Ipp32f* pSrcDst, int width))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumColumn_*
|
|
// Purpose: Calculates sums of column vectors in a matrix.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// step The row step in the input vector pSrc.
|
|
// height The number of rows in the input matrix mSrc.
|
|
// pDst Pointer to the output vector [width].
|
|
// width The number of columns in the input matrix and the length
|
|
// of the result vector pDst.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, mSrc, or pDst pointer
|
|
// is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSumColumn_16s32s_D2Sfs,(const Ipp16s* pSrc, int step,
|
|
int height, Ipp32s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_16s32f_D2,(const Ipp16s* pSrc, int step,
|
|
int height, Ipp32f* pDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_16s32s_D2LSfs,(const Ipp16s** mSrc, int height,
|
|
Ipp32s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_16s32f_D2L,(const Ipp16s** mSrc, int height,
|
|
Ipp32f* pDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_32f_D2,(const Ipp32f* pSrc, int step,
|
|
int height, Ipp32f* pDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_64f_D2,(const Ipp64f* pSrc, int step,
|
|
int height, Ipp64f* pDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_32f_D2L,(const Ipp32f** mSrc, int height,
|
|
Ipp32f* pDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsSumColumn_64f_D2L,(const Ipp64f** mSrc, int height,
|
|
Ipp64f* pDst, int width))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumRow_*
|
|
// Purpose: Computes the sum of a list of vectors row-wise.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// height The number of rows in the matrix mSrc and also the length
|
|
// of the output vector pDst.
|
|
// step The row step in input vector pSrc.
|
|
// pDst Pointer to the output vector [height].
|
|
// width The number of columns in the matrix mSrc.
|
|
// scaleFactor
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, mSrc, or pDst pointer
|
|
// is null.
|
|
// ippStsSizeErr Indicates an error when height or srcWidth is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when srcWidth > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSumRow_32f_D2,(const Ipp32f* pSrc, int width,
|
|
int step, Ipp32f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_64f_D2,(const Ipp64f* pSrc, int width,
|
|
int step, Ipp64f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_32f_D2L,(const Ipp32f** mSrc, int width,
|
|
Ipp32f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_64f_D2L,(const Ipp64f** mSrc, int width,
|
|
Ipp64f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_16s32s_D2Sfs,(const Ipp16s* pSrc, int width,
|
|
int step, Ipp32s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_16s32f_D2,(const Ipp16s* pSrc, int width,
|
|
int step, Ipp32f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_16s32s_D2LSfs,(const Ipp16s** mSrc, int width,
|
|
Ipp32s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsSumRow_16s32f_D2L,(const Ipp16s** mSrc, int width,
|
|
Ipp32f* pDst, int height))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSubRow_*
|
|
// Purpose: Subtracts a vector from all matrix rows.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [width].
|
|
// pSrcDst Pointer to the the source and destination vector
|
|
// [height*dstStep].
|
|
// mSrcDst Pointer to the source and destination matrix
|
|
// [height][width].
|
|
// width The number of columns in the matrix mSrcDst.
|
|
// dstStep The row step in the vector pSrcDst.
|
|
// height The number of rows in the matrix mSrcDst.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pSrcDst, or mSrcDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > dstStep.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSubRow_32f_D2, (const Ipp32f* pSrc, int width,
|
|
Ipp32f* pSrcDst, int dstStep, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSubRow_32f_D2L, (const Ipp32f* pSrc, Ipp32f** mSrcDst,
|
|
int width, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSubRow_16s_D2,(const Ipp16s* pSrc, int width,
|
|
Ipp16s* pSrcDst, int dstStep, int height))
|
|
|
|
IPPAPI(IppStatus, ippsSubRow_16s_D2L,(const Ipp16s* pSrc, Ipp16s** mSrcDst,
|
|
int width, int height))
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCopyColumn_Indirect_*
|
|
// Purpose: Copies the input matrix with columns redirection.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*srcStep].
|
|
// mSrc Pointer to the input matrix [height][srcLen].
|
|
// srcLen The number of columns in the input matrix mSrc.
|
|
// srcStep The row step in pSrc
|
|
// pDst Pointer to the output vector [height*dstStep]
|
|
// mDst Pointer to the output matrix [height][dstLen]
|
|
// pIndx Pointer to the redirection vector [dstLen]
|
|
// dstLen The number of columns in the output matrix mDst
|
|
// dstStep The row step in pDst
|
|
// height The number of rows in both the input and output matrices.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, mSrc, pDst, mDst or
|
|
// pIndx pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, srcLen, or dstLen is less
|
|
// than or equal to 0,
|
|
// pIndx[j]>=srcLen or pIndx[j]<0 for j=0,:,dstlen-1
|
|
// ippStsStrideErr Indicates an error when srcLen > srcStep, dstLen > dstStep.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsCopyColumn_Indirect_64f_D2, (const Ipp64f* pSrc,
|
|
int srcLen, int srcStep, Ipp64f* pDst, const Ipp32s* pIndx, int dstLen,
|
|
int dstStep, int height))
|
|
|
|
IPPAPI(IppStatus, ippsCopyColumn_Indirect_32f_D2, (const Ipp32f* pSrc,
|
|
int srcLen, int srcStep, Ipp32f* pDst, const Ipp32s* pIndx, int dstLen,
|
|
int dstStep, int height))
|
|
|
|
IPPAPI(IppStatus, ippsCopyColumn_Indirect_16s_D2, (const Ipp16s* pSrc,
|
|
int srcLen, int srcStep, Ipp16s* pDst, const Ipp32s* pIndx, int dstLen,
|
|
int dstStep, int height))
|
|
|
|
IPPAPI(IppStatus, ippsCopyColumn_Indirect_64f_D2L, (const Ipp64f** mSrc,
|
|
int srcLen, Ipp64f** mDst, const Ipp32s* pIndx, int dstLen, int height))
|
|
|
|
IPPAPI(IppStatus, ippsCopyColumn_Indirect_32f_D2L, (const Ipp32f** mSrc,
|
|
int srcLen, Ipp32f** mDst, const Ipp32s* pIndx, int dstLen, int height))
|
|
|
|
IPPAPI(IppStatus, ippsCopyColumn_Indirect_16s_D2L, (const Ipp16s** mSrc,
|
|
int srcLen, Ipp16s** mDst, const Ipp32s* pIndx, int dstLen, int height))
|
|
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsBlockDMatrixInitAlloc_*
|
|
// Purpose: Initializes the structure that represents a symmetric
|
|
// block diagonal matrix.
|
|
// Parameters:
|
|
// pMatrix Pointer to the block diagonal matrix to be created.
|
|
// mSrc Pointer to the vector of pointers to matrix rows.
|
|
// bSize Pointer to vector of block sizes [nBlocks].
|
|
// nBlocks Number of blocks.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pMatrix or mSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when bSize or nBlocks is less than or
|
|
// equal to 0
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsBlockDMatrixInitAlloc_64f,(IppsBlockDMatrix_64f** pMatrix,
|
|
const Ipp64f** mSrc, const int* bSize, int nBlocks))
|
|
|
|
IPPAPI(IppStatus, ippsBlockDMatrixInitAlloc_16s,(IppsBlockDMatrix_16s** pMatrix,
|
|
const Ipp16s** mSrc, const int* bSize, int nBlocks))
|
|
|
|
IPPAPI(IppStatus, ippsBlockDMatrixInitAlloc_32f,(IppsBlockDMatrix_32f** pMatrix,
|
|
const Ipp32f** mSrc, const int* bSize, int nBlocks))
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsBlockDMatrixFree_*
|
|
// Purpose: Deallocates the block diagonal matrix structure.
|
|
//
|
|
// Parameters:
|
|
// pMatrix Pointer to the block diagonal matrix.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrc.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsBlockDMatrixFree_32f,(IppsBlockDMatrix_32f* pMatrix))
|
|
|
|
IPPAPI(IppStatus, ippsBlockDMatrixFree_64f,(IppsBlockDMatrix_64f* pMatrix))
|
|
|
|
IPPAPI(IppStatus, ippsBlockDMatrixFree_16s,(IppsBlockDMatrix_16s* pMatrix))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Feature Processing functions
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsZeroMean_16s
|
|
// Purpose: Subtracts the mean value from all elements of
|
|
// the input vector.
|
|
//
|
|
// Parameters:
|
|
// pSrcDst Pointer to the source and destination vector [len].
|
|
// len The number of elements in the vector.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsZeroMean_16s, (Ipp16s *pSrcDst, int len))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCompensateOffset_*
|
|
// Purpose: Removes the DC offset of the input signals.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector[len].
|
|
// pDst Pointer to the destination vector[len].
|
|
// pSrcDst Pointer to the source and destination vector for in-place
|
|
// operations [len].
|
|
// pSrcDst0 Pointer to the previous source element.
|
|
// pSrc0 Pointer to previous source element. The last source
|
|
// element is saved there.
|
|
// dst0 Previous destination element.
|
|
// val Constant of offset compensation formula.
|
|
// len The number of elements in the vector.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pSrcDst or pDst or
|
|
// pSrc0 pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsCompensateOffset_32f, (const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len, Ipp32f* pSrc0, Ipp32f dst0, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsCompensateOffset_16s, (const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, Ipp16s* pSrcDst0, Ipp16s dst0, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsCompensateOffset_32f_I, (Ipp32f* pSrcDst, int len,
|
|
Ipp32f* pSrc0, Ipp32f dst0, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsCompensateOffset_16s_I, (Ipp16s* pSrcDst, int len,
|
|
Ipp16s* pSrcDst0, Ipp16s dst0, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsCompensateOffsetQ15_16s, (const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, Ipp16s* pSrcDst0, Ipp16s dst0, Ipp16s valQ15))
|
|
|
|
IPPAPI(IppStatus, ippsCompensateOffsetQ15_16s_I, (Ipp16s* pSrcDst, int len,
|
|
Ipp16s* pSrc0, Ipp16s dst0, Ipp16s valQ15))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSignChangeRate_*
|
|
// Purpose: Counts the zero-cross rate for the input signal.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input signal [len].
|
|
// len Number of elements in the input signal.
|
|
// pRes Pointer to the result variable.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pRes pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSignChangeRate_16s,(const Ipp16s* pSrc, int len,
|
|
Ipp32s* pRes))
|
|
|
|
IPPAPI(IppStatus, ippsSignChangeRate_32f,(const Ipp32f* pSrc, int len,
|
|
Ipp32f* pRes))
|
|
|
|
IPPAPI(IppStatus, ippsSignChangeRateXor_32f,(const Ipp32f* pSrc, int len,
|
|
Ipp32s* pRes))
|
|
|
|
IPPAPI(IppStatus, ippsSignChangeRate_Count0_16s,(const Ipp16s* pSrc, int len,
|
|
Ipp32s* pRes))
|
|
|
|
IPPAPI(IppStatus, ippsSignChangeRate_Count0_32f,(const Ipp32f* pSrc, int len,
|
|
Ipp32f* pRes))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLinearPrediction_*
|
|
// Purpose: Performs linear prediction analysis on the input vector.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [lenSrc]
|
|
// lenSrc Length of the input vector pSrc.
|
|
// pDst Pointer to the output LPC coefficients vector [lenDst].
|
|
// lenDst Length of the output vector pDst.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenSrc or lenDst is less than or
|
|
// equal to 0, lenDst is greater or equal than lenSrc.
|
|
// ippStsNoOperation Indicates no solution to the LPC problem.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLinearPrediction_Cov_32f,(const Ipp32f *pSrc, int lenSrc,
|
|
Ipp32f *pDst, int lenDst))
|
|
|
|
IPPAPI(IppStatus, ippsLinearPrediction_Cov_16s_Sfs,(const Ipp16s* pSrc, int lenSrc,
|
|
Ipp16s* pDst, int lenDst, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLinearPrediction_Auto_32f,(const Ipp32f *pSrc, int lenSrc,
|
|
Ipp32f *pDst, int lenDst))
|
|
|
|
IPPAPI(IppStatus, ippsLinearPrediction_Auto_16s_Sfs,(const Ipp16s* pSrc, int lenSrc,
|
|
Ipp16s* pDst, int lenDst, int scaleFactor))
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLinearPredictionNeg_Auto_*
|
|
// Purpose: Performs linear prediction analysis on the input vector.
|
|
// The same formula as ippsLinearPrediction_Auto with -r[k] in the right part
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [lenSrc]
|
|
// lenSrc Length of the input vector pSrc.
|
|
// pDst Pointer to the output LPC coefficients vector [lenDst].
|
|
// lenDst Length of the output vector pDst.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenSrc or lenDst is less than or
|
|
// equal to 0, lenDst is greater or equal than lenSrc.
|
|
// ippStsNoOperation Indicates no solution to the LPC problem.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLinearPredictionNeg_Auto_32f,(const float *pSrc,int lenSrc,float *pDst,
|
|
int lenDst))
|
|
IPPAPI(IppStatus, ippsLinearPredictionNeg_Auto_16s_Sfs, (const Ipp16s* pSrc, int lenSrc,
|
|
Ipp16s* pDst, int lenDst, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDurbin_*
|
|
// Purpose: Performs Durbin's recursion on an input vector
|
|
// of autocorrelations.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [ len+1].
|
|
// pDst Pointer to the output LPC coefficients vector [len].
|
|
// len Length of the input and output vectors.
|
|
// pErr Pointer to the residual prediction error.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst or pErr
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0
|
|
// ippStsMemAllocErr memory alllocation error
|
|
// ippStsNoOperation ndicates no solution to the LPC problem.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsDurbin_32f,(const Ipp32f *pSrc, Ipp32f *pDst, int lenDst,
|
|
Ipp32f* pErr))
|
|
|
|
IPPAPI(IppStatus, ippsDurbin_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int lenDst,Ipp32f* pErr, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLPToCepstrum_*
|
|
// Purpose: Calculates cepstrum coefficients from linear
|
|
// prediction coefficients.
|
|
// Parameters:
|
|
// pSrc Pointer to the linear prediction coefficients [len].
|
|
// pDst Pointer to the cepstrum coefficients [len].
|
|
// len Number of elements in the source and destination vectors.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLPToCepstrum_32f,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len))
|
|
|
|
IPPAPI(IppStatus, ippsLPToCepstrum_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCepstrumToLP_*
|
|
// Purpose: Calculates linear prediction coefficients from
|
|
// cepstrum coefficients.
|
|
// Parameters:
|
|
// pSrc Pointer to the cepstrum coefficients [len].
|
|
// pDst Pointer to the linear prediction coefficients [len].
|
|
// len Number of elements in the source and destination vectors.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsCepstrumToLP_32f,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len))
|
|
|
|
IPPAPI(IppStatus, ippsCepstrumToLP_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLPToReflection_*
|
|
// Purpose: Calculates the linear prediction reflection
|
|
// coefficients from the linear prediction coefficients.
|
|
// Parameters:
|
|
// pSrc Pointer to the linear prediction coefficients [len].
|
|
// pDst Pointer to the linear prediction reflection coefficients [len].
|
|
// len Number of elements in the source and destination vectors.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsNoOperation Indicates that reflection coefficients could not be calculated
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLPToReflection_32f,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len))
|
|
|
|
IPPAPI(IppStatus, ippsLPToReflection_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, int scaleFactor))
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: ippsDTW_L2_32f_D2L*
|
|
// Purpose: Computes the distance between observation and reference vector
|
|
// sequences using Dynamic Time Warping algorithm.
|
|
//
|
|
// Parameters:
|
|
// pSrc1 Pointer to the first input (observation) vector [height1*step].
|
|
// pSrc2 Pointer to the second input (reference) vector [height2*step].
|
|
// mSrc1 Pointer to the first input (observation) matrix [height1][width].
|
|
// mSrc2 Pointer to the second input (reference) matrix [height2][width].
|
|
// height1 Number of rows in the first input matrix N1.
|
|
// height2 Number of rows in the first input matrix N2.
|
|
// width Length of the input matrices row M.
|
|
// step Row step in pSrc1 and pSrc2.
|
|
// pDist Pointer to the distance value.
|
|
// beam Beam value, used if positive.
|
|
// delta Endpoint constraint value.
|
|
// scaleFactor Scale factor for input values .
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc1, pSrc2, mSrc1, mSrc2, or pDist pointer is null.
|
|
// ippStsSizeErr Indicates an error when height1, height2, or width is less than or equal to 0 or delta is less than 0 or greater than height2.
|
|
// ippStsStrideErr Indicates an error when step is less than width.
|
|
// ippStsLPCCalcErr Indicates that there are now admissible paths for height1, height2 and delta values.
|
|
*/
|
|
IPPAPI(IppStatus, ippsDTW_L2_32f_D2L,(const Ipp32f** mSrc1, int height1,
|
|
const Ipp32f** mSrc2, int height2,
|
|
int width, Ipp32f* pDist, int delta,
|
|
Ipp32f beam))
|
|
IPPAPI(IppStatus, ippsDTW_L2_32f_D2,(const Ipp32f* mSrc1, int height1,
|
|
const Ipp32f* mSrc2, int height2,
|
|
int width, int step, Ipp32f* pDist, int delta,
|
|
Ipp32f beam))
|
|
IPPAPI(IppStatus, ippsDTW_L2_8u32s_D2Sfs,(const Ipp8u* pSrc1, int height1,
|
|
const Ipp8u* pSrc2, int height2,
|
|
int width, int step, Ipp32s* pDist, int delta,
|
|
Ipp32s beam, int scaleFactor))
|
|
IPPAPI(IppStatus, ippsDTW_L2_8u32s_D2LSfs,(const Ipp8u** mSrc1, int height1,
|
|
const Ipp8u** mSrc2, int height2,
|
|
int width, Ipp32s* pDist, int delta,
|
|
Ipp32s beam, int scaleFactor))
|
|
IPPAPI(IppStatus, ippsDTW_L2Low_16s32s_D2Sfs,(const Ipp16s* pSrc1, int height1,
|
|
const Ipp16s* pSrc2, int height2,
|
|
int width, int step, Ipp32s* pDist, int delta,
|
|
Ipp32s beam, int scaleFactor))
|
|
IPPAPI(IppStatus, ippsDTW_L2Low_16s32s_D2LSfs,(const Ipp16s** mSrc1, int height1,
|
|
const Ipp16s** mSrc2, int height2,
|
|
int width, Ipp32s* pDist, int delta,
|
|
Ipp32s beam, int scaleFactor))
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSchur_*
|
|
// Purpose: Schur's recursion for an input vector of
|
|
// autocorrelations.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input autocorrelations vector [len+1].
|
|
// pDst Pointer to the output reflection coefficients vector [len].
|
|
// len Length of the output vectors.
|
|
// pErr Pointer to the resulting prediction error.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst or pErr pointer
|
|
// is null.
|
|
// ippStsSizeErr Indicates an error when lenSrc or lenDst is less than or
|
|
// equal to 0 or pSrc < pDst.
|
|
// ippStsMemAllocErr memory alllocation error
|
|
// ippStsDivByZeroErr Indicates no solution to the LPC problem
|
|
*/
|
|
IPPAPI(IppStatus, ippsSchur_32f,(const Ipp32f* pSrc, Ipp32f* pDst, int len, Ipp32f* pErr))
|
|
IPPAPI(IppStatus, ippsSchur_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst, int len,
|
|
Ipp32f* pErr,int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsReflectionToLP_*
|
|
// Purpose: Calculates the linear prediction coefficients from
|
|
// the linear prediction reflection coefficients.
|
|
// Parameters:
|
|
// pSrc Pointer to the linear prediction reflection coefficients [len].
|
|
// pDst Pointer to the linear prediction coefficients [len].
|
|
// len Number of elements in the source and destination vectors.
|
|
// scaleFactor
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsReflectionToLP_32f,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len))
|
|
IPPAPI(IppStatus, ippsReflectionToLP_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, int scaleFactor))
|
|
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsReflectionToAR_*
|
|
// ippsReflectionToLAR_*
|
|
// ippsReflectionToTrueAR_*
|
|
// Purpose: Converts reflection coefficients to area ratios.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pDst Pointer to the destination vector [len].
|
|
// val Threshold value ( 0 < val < 1 ).
|
|
// len Length of the input and output vectors.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsDivByZero Indicates a warning for zero-valued divisor vector
|
|
// element. Operation execution is not aborted. The value of
|
|
// the destination vector element in the floating-point
|
|
// operations +Inf. The value of the destination vector
|
|
// element in the integer operations IPP_MAX_16S.
|
|
// ippStsNoOperation Indicates an error when 0<val<1 is not true.
|
|
// Notes:
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsReflectionToAR_16s_Sfs, (const Ipp16s* pSrc,
|
|
int srcShiftVal, Ipp16s* pDst, int len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToAR_32f, (const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToLAR_16s_Sfs, (const Ipp16s* pSrc,
|
|
int srcShiftVal, Ipp16s* pDst, int len, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToLAR_32f, (const Ipp32f* pSrc,
|
|
Ipp32f* pDst, int len, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToTrueAR_16s_Sfs, (const Ipp16s* pSrc,
|
|
int srcShiftVal, Ipp16s* pDst, int len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToTrueAR_32f, (const Ipp32f* pSrc,
|
|
Ipp32f* pDst, int len))
|
|
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsPitchmarkToF0Cand_*
|
|
// Purpose: Calculates rise and fall amplitude and duration for tilt.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pDst Pointer to the destination vector [len].
|
|
// len Length of the input and output vectors.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsDivByZero Indicates a warning for zero-valued divisor vector
|
|
// element. Operation execution is not aborted. The value of
|
|
// the destination vector element in the floating-point
|
|
// operations +Inf. The value of the destination vector
|
|
// element in the integer operations IPP_MAX_16S.
|
|
// Notes:
|
|
*/
|
|
IPPAPI(IppStatus, ippsPitchmarkToF0Cand_32f, (const Ipp32f* pSrc,
|
|
Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsPitchmarkToF0Cand_16s_Sfs, (const Ipp16s* pSrc,
|
|
Ipp16s* pDst, int len, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsUnitCurve_*_*
|
|
//
|
|
// Purpose: Calculates tilt for rise and fall coefficients.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input array [len].
|
|
// pSrcDst Pointer to the input and destination vector [len].
|
|
// pDst Pointer to the output array [len].
|
|
// len Number of elements in the input vector.
|
|
// srcShiftVal Input scale factor.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pSrcDst or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsUnitCurve_16s_Sfs, (const Ipp16s* pSrc, int srcShiftVal,
|
|
Ipp16s* pDst, int len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsUnitCurve_32f, (const Ipp32f* pSrc,
|
|
Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsUnitCurve_16s_ISfs, (Ipp16s* pSrcDst, int srcShiftVal,
|
|
int len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsUnitCurve_32f_I, (Ipp32f* pSrcDst, int len))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLPToLSP_32f
|
|
// Purpose: computes linear spectral pairs from LPC (in the cosine domain).
|
|
//
|
|
// Parameters:
|
|
// pSrcLPC Pointer to the input LPC coefficients vector [len].
|
|
// pDstLSP Pointer to the output LSP coefficients vector [len].
|
|
// len Number of LPC coefficients.
|
|
// nRoots Number of found LSP values.
|
|
// nInt Number of intervals while roots finding.
|
|
// nDiv Number of interval divisions while roots finding.
|
|
// inScale Scale factor for pSrcLPC values.
|
|
// scaleFactor Scale factor for pDstLSP values .
|
|
// srcShiftVal Scale factor for pSrcLP values .
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenSrc or len is less than or equal to 0
|
|
// or pSrc < pDst.
|
|
// ippStsMemAllocErr memory alllocation error
|
|
// ippStsNoRootFoundErr if no decision exists2
|
|
*/
|
|
IPPAPI(IppStatus, ippsLPToLSP_32f,(const Ipp32f* pSrcLPC, Ipp32f* pDstLSP, int len,
|
|
int* nRoots,int nInt, int nDiv))
|
|
IPPAPI(IppStatus, ippsLPToLSP_16s_Sfs,(const Ipp16s* pSrcLP, int srcShiftVal, Ipp16s* pDstLSP,
|
|
int len,int* nRoots,int nInt, int nDiv, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLSPToLP_32f
|
|
// Purpose: computes linear spectral pairs from LPC (in the cosine domain).
|
|
//
|
|
// Arguments:
|
|
// pDstLPC Pointer to the output LPC coefficients vector [len].
|
|
// pSrcLSP Pointer to the input LSP coefficients vector [len].
|
|
// len Number of LPC coefficients.
|
|
// inScale Scale factor for pSrcLPC values.
|
|
// scaleFactor Scale factor for pDstLSP values .
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenSrc or len is less than or equal to 0
|
|
// or pSrc < pDst.
|
|
// ippStsMemAllocErr memory alllocation error
|
|
*/
|
|
IPPAPI(IppStatus, ippsLSPToLP_32f,(const Ipp32f* pSrcLSP, Ipp32f* pDstLPC, int len))
|
|
IPPAPI(IppStatus, ippsLSPToLP_16s_Sfs,(const Ipp16s* pSrcLSP, int srcShiftVal, Ipp16s* pDstLP,
|
|
int len, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLPToSpectrum_32f
|
|
// Purpose: Computes first half of a LP magnitude spectrum
|
|
// ippsLPToSpectrum_32f
|
|
// Arguments:
|
|
// pSrc Pointer to the input LPC coefficients vector [len].
|
|
// pDst Pointer to the output LP spectrum coefficients vector [2order-1].
|
|
// len Number of LPC coefficients.
|
|
// order FFT order for spectrum calculation.
|
|
// val The value of add to spectrum.
|
|
// scaleFactor Scale factor for pDst values .
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsFftOrderErr Indicates an error when the order value is incorrect.
|
|
// ippStsDivByZero Indicates a warning for zero-valued divisor vector element. Operation
|
|
// execution is not aborted. The value of the destination vector element in the floating-point
|
|
// operations is equal to +Inf : and in the integer operations is equal to IPP_MAX_16S.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLPToSpectrum_32f,(const Ipp32f *LPCoeffs,int nLP,Ipp32f *pDst,
|
|
int lenFFT,Ipp32f val))
|
|
IPPAPI(IppStatus, ippsLPToSpectrum_16s_Sfs,(const Ipp16s* pSrc, int len, Ipp16s* pDst, int order,
|
|
Ipp32s val, int scaleFactor))
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMelToLinear_32f
|
|
// Purpose: Converts Mel-scaled values to linear scale values.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len]
|
|
// pDst Pointer to the output vector [len]
|
|
// len The length of input and output vectors
|
|
// melMul Multiply factor in the mel-scale equation
|
|
// melDiv Divide factor in the mel-scale equation
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0,
|
|
// of melMul or melDiv is equal to 0.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsMelToLinear_32f,(const Ipp32f* pSrc, Ipp32f* pDst, int len,
|
|
Ipp32f melMul, Ipp32f melDiv))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLinearToMel_32f
|
|
// Purpose: Converts linear-scale values to Mel-scale values.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len]
|
|
// pDst Pointer to the output vector [len]
|
|
// len The length of input and output vectors
|
|
// melMul Multiply factor in the mel-scale equation
|
|
// melDiv Divide factor in the mel-scale equation
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0,
|
|
// of melMul or melDiv is equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLinearToMel_32f,(const Ipp32f* pSrc, Ipp32f* pDst, int len,
|
|
Ipp32f melMul, Ipp32f melDiv))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCopyWithPadding_*
|
|
// Purpose: Copies the input signal to the output with zero padding
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [lenSrc]
|
|
// pDst Pointer to the output vector [lenDst]
|
|
// lenSrc The length of pSrc vector.
|
|
// lenDst The length of pDst vector.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenSrc or lenDst is less than or
|
|
// equal to 0 or lenDst is less than lenSrc
|
|
*/
|
|
|
|
|
|
IPPAPI(IppStatus, ippsCopyWithPadding_16s,(const Ipp16s* pSrc, int lenSrc,
|
|
Ipp16s* pDst, int lenDst))
|
|
|
|
IPPAPI(IppStatus, ippsCopyWithPadding_32f,(const Ipp32f* pSrc, int lenSrc,
|
|
Ipp32f* pDst, int lenDst))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: IppStatus ippsMelFBankGetSize_* (int winSize,
|
|
// int nFilter,
|
|
// IppMelMode mode,
|
|
// int* pSize))
|
|
// IppStatus ippsMelFBankGetSizeLow_Aurora_* (int* pSize)
|
|
// IppStatus ippsMelFBankGetSizeHigh_Aurora_* (int* pSize)
|
|
//
|
|
// Description: Mel-frequency filter bank structure size - this function determines the
|
|
// size required for the Mel-frequency filter bank structure and associated
|
|
// storage. It should be called before memory allocation and before ippsMelFBankInit_32s.
|
|
//
|
|
// Input Arguments: winSize - frame length in samples (32 = winSize = 8192).
|
|
// sampFreq - input signal sampling frequency Fs in Hz (0 < sampFreq = 48000).
|
|
// nFilter - number of Mel-scale filter banks K (0 < nFilter = winSize).
|
|
// mode - flag that determines the execution mode. Currently only
|
|
// IPP_FBANK_FREQWGT is supported.
|
|
//
|
|
// Output Arguments:pSize - pointer to the variable to contain the size of the filter bank structure.
|
|
//
|
|
//
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsFBankFlagErr - Indicates an error when the mode value is incorrect.
|
|
// ippStsNullPtrErr - Indicates an error when pSize pointer is null.
|
|
// ippStsSizeErr - Indicates an error when winSize, nFilter, or sampFreq is less than or equal to 0.
|
|
//
|
|
// Notes:
|
|
*/
|
|
IPPAPI(IppStatus, ippsMelFBankGetSize_32s,(int winSize, int nFilter,
|
|
IppMelMode mode, int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankGetSize_16s,(int winSize, int nFilter,
|
|
IppMelMode mode, int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankGetSize_32f,(int winSize, int nFilter,
|
|
IppMelMode mode, int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankGetSizeLow_Aurora_32f,(int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankGetSizeHigh_Aurora_32f,(int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankGetSizeLow_Aurora_16s,(int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankGetSizeHigh_Aurora_16s,(int* pSize))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMelFBankInitAlloc_*
|
|
// Purpose: Initializes the structure for performing the Mel
|
|
// frequency filter bank analysis.
|
|
// Parameters:
|
|
// pFBank Pointer to the Mel-scale filter bank structure to be created.
|
|
// pFFTLen Pointer to the order of FFT used for the filter bank evaluation.
|
|
// winSize Frame length (samples)
|
|
// sampFreq Input signal sampling frequency (in Hz)
|
|
// lowFreq Start frequency of the first band pass filter (in Hz)
|
|
// highFreq End frequency of the last band pass filter (in Hz)
|
|
// nFilter Number of Mel-scale filters banks K.
|
|
// melMul Mel-scale formula multiply factor.
|
|
// melDiv Mel-scale formula divisor.
|
|
// mode Flags that determine the execution mode; can have
|
|
// the following values:
|
|
// IPP_FBANK_MELWGT - the function calculates filter bank
|
|
// weights in Mel-scale;
|
|
// IPP_FBANK_FREQWGT - the function calculates filter bank
|
|
// weights in the frequency space.
|
|
// One of the above two flags should necessarily be set.
|
|
// IPP_POWER_SPECTRUM - indicates that the FFT power
|
|
// spectrum is used during the filter bank analysis.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pFBank or pFFTLen pointer is null.
|
|
// ippStsSizeErr Indicates an error when winSize, nFilter, sampFreq, or
|
|
// lowFreqis less than or equal to 0.
|
|
// ippStsFBankFreqErr Indicates an error when highFreqis less than lowFreqor
|
|
// highFreq is greater than sampFreq/2.
|
|
// ippStsFBankFlagErr Indicates an error when the modevalue is incorrect.
|
|
// ippStsMemAllocErr Indicates an error when no memory was allocated.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitAlloc_16s,(IppsFBankState_16s** pFBank,
|
|
int* pFFTLen, int winSize, Ipp32f sampFreq, Ipp32f lowFreq,
|
|
Ipp32f highFreq, int nFilter, Ipp32f melMul, Ipp32f melDiv,
|
|
IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitAlloc_32f,(IppsFBankState_32f** pFBank,
|
|
int* pFFTLen, int winSize, Ipp32f sampFreq, Ipp32f lowFreq,
|
|
Ipp32f highFreq, int nFilter, Ipp32f melMul, Ipp32f melDiv,
|
|
IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitAllocLow_Aurora_32f,(IppsFBankState_32f** pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitAllocHigh_Aurora_32f,(IppsFBankState_32f** pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitAllocLow_Aurora_16s,(IppsFBankState_16s** pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitAllocHigh_Aurora_16s,(IppsFBankState_16s** pFBank))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMelFBankInit_*
|
|
// Purpose: Initializes the structure for performing the Mel
|
|
// frequency filter bank analysis.
|
|
// Parameters:
|
|
// pFBank Pointer to the Mel-scale filter bank structure to be created.
|
|
// pFFTLen Pointer to the order of FFT used for the filter bank evaluation.
|
|
// winSize Frame length (samples)
|
|
// sampFreq Input signal sampling frequency (in Hz)
|
|
// lowFreq Start frequency of the first band pass filter (in Hz)
|
|
// highFreq End frequency of the last band pass filter (in Hz)
|
|
// nFilter Number of Mel-scale filters banks K.
|
|
// melMul Mel-scale formula multiply factor.
|
|
// melDiv Mel-scale formula divisor.
|
|
// mode Flags that determine the execution mode; can have
|
|
// the following values:
|
|
// IPP_FBANK_MELWGT - the function calculates filter bank
|
|
// weights in Mel-scale;
|
|
// IPP_FBANK_FREQWGT - the function calculates filter bank
|
|
// weights in the frequency space.
|
|
// One of the above two flags should necessarily be set.
|
|
// IPP_POWER_SPECTRUM - indicates that the FFT power
|
|
// spectrum is used during the filter bank analysis.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pFBank or pFFTLen pointer is null.
|
|
// ippStsSizeErr Indicates an error when winSize, nFilter, sampFreq, or
|
|
// lowFreqis less than or equal to 0.
|
|
// ippStsFBankFreqErr Indicates an error when highFreqis less than lowFreqor
|
|
// highFreq is greater than sampFreq/2.
|
|
// ippStsFBankFlagErr Indicates an error when the modevalue is incorrect.
|
|
// ippStsMemAllocErr Indicates an error when no memory was allocated.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInit_32s,(IppsFBankState_32s* pFBank,
|
|
int* pFFTLen, int winSize, Ipp32s sampFreq,
|
|
Ipp32s lowFreq, Ipp32s highFreq, int nFilter,
|
|
Ipp32s melMulQ15, Ipp32s melDivQ15, IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInit_16s,(IppsFBankState_16s* pFBank,
|
|
int* pFFTLen, int winSize, Ipp32f sampFreq, Ipp32f lowFreq,
|
|
Ipp32f highFreq, int nFilter, Ipp32f melMul, Ipp32f melDiv,
|
|
IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInit_32f,(IppsFBankState_32f* pFBank,
|
|
int* pFFTLen, int winSize, Ipp32f sampFreq, Ipp32f lowFreq,
|
|
Ipp32f highFreq, int nFilter, Ipp32f melMul, Ipp32f melDiv,
|
|
IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitLow_Aurora_32f,(IppsFBankState_32f* pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitHigh_Aurora_32f,(IppsFBankState_32f* pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitLow_Aurora_16s,(IppsFBankState_16s* pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsMelFBankInitHigh_Aurora_16s,(IppsFBankState_16s* pFBank))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMelLinFBankInitAlloc_*
|
|
// Purpose: Initializes the linear and mel-frequency filter banks
|
|
// Parameters:
|
|
// pFBank Pointer to the mel scale filter bank structure to be created.
|
|
// FFTLen Pointer to the length of FFT N used for filter bank evaluation.
|
|
// winSize Frame length (samples)
|
|
// sampFreq Input signal sampling frequency (in Hz)
|
|
// lowFreq Start frequency of the first band pass filter (in Hz)
|
|
// highLinFreq End frequency of the last band pass filter on linear
|
|
// scale (in Hz)
|
|
// highFreq End frequency of the last band pass filter (in Hz)
|
|
// nFilter Number of Mel-scale filters in the filter bank
|
|
// nLinFilter umber of Linear-scale filters in the filter bank
|
|
// melMul Mel scale formula factor
|
|
// melDiv Mel scale formula divisor
|
|
// mode One of the following values:
|
|
// IPP_FBANK_MELWGT - calculate fbank weights in Mel-scale
|
|
// IPP_FBANK_FREQWGT - calculate fbank weights in
|
|
// frequency space
|
|
// IPP_POWER_SPECTRUM - indicates that FFT power logarithm
|
|
// of input signal is calculated before filter bank
|
|
// evaluation by ippsEvalFBank function.
|
|
// Corresponding internal structures are initialized in
|
|
// the result filter bank structure.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsSizeErr Indicates an error when winSize, nFilter, nLinFilter,
|
|
// freq, lowFreq is less than or equal to 0 or nLinFilter
|
|
// is greater than nFilter;
|
|
// ippStsFBankFreqErr Indicates an error when (lowFreq > highlinFreq)
|
|
// or (highlinFreq > highFreq) or (highFreq > sampFreq/2)
|
|
// or (highLinFreq> lowFreq)&&(nLinFilter==0)
|
|
// or (highLinFreq< highFreq)&&(nLinFilter==nFilter)
|
|
// ippStsFBankFlagErr Indicates an error when the mode value is incorrect.
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsMelLinFBankInitAlloc_32f,(IppsFBankState_32f** pFBank,
|
|
int* pFFTLen, int winSize, Ipp32f sampFreq, Ipp32f lowFreq,
|
|
Ipp32f highFreq, int nFilter, Ipp32f highLinFreq, int nLinFilter,
|
|
Ipp32f melMul, Ipp32f melDiv, IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsMelLinFBankInitAlloc_16s,(IppsFBankState_16s** pFBank,
|
|
int* pFFTLen, int winSize, Ipp32f sampFreq, Ipp32f lowFreq,
|
|
Ipp32f highFreq, int nFilter, Ipp32f highLinFreq, int nLinFilter,
|
|
Ipp32f melMul, Ipp32f melDiv, IppMelMode mode))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsEmptyFBankInitAlloc_*
|
|
// Purpose: Initializes an empty filter bank structure.
|
|
// Parameters:
|
|
// pFBank Pointer to the filter bank structure to be created.
|
|
// pFFTLen Pointer to the order of FFT used for the
|
|
// filter bank evaluation.
|
|
// winSize Frame length (samples)
|
|
// nFilter Number of filters banks K.
|
|
// mode Flag determining the function's execution mode; can have
|
|
// the following value:
|
|
// IPP_POWER_SPECTRUM - indicates that the logarithm of the
|
|
// FFT power spectrum is used during the filter
|
|
// bank analysis.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pFBank or pFFTLen pointer is null.
|
|
// ippStsSizeErr Indicates an error when winSize or nFilter or pFBank
|
|
// is less than or equal to 0;
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsEmptyFBankInitAlloc_32f,(IppsFBankState_32f** pFBank, int* pFFTLen,
|
|
int winSize, int nFilter, IppMelMode mode))
|
|
|
|
IPPAPI(IppStatus, ippsEmptyFBankInitAlloc_16s,(IppsFBankState_16s** pFBank, int* pFFTLen,
|
|
int winSize, int nFilter, IppMelMode mode))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFBankFree_*
|
|
// Purpose: Destroys the structure for the filter bank analysis.
|
|
// Parameters:
|
|
// pFBank Pointer to the filter bank structure.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pFBank pointer is null.
|
|
*/
|
|
IPPAPI(IppStatus, ippsFBankFree_16s,(IppsFBankState_16s* pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsFBankFree_32f,(IppsFBankState_32f* pFBank))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFBankGetCenters_*
|
|
// Purpose: Retrieves the center frequencies of the
|
|
// triangular filter banks.
|
|
// Parameters:
|
|
// pFBank Pointer to the filter bank structure.
|
|
// pCenters Pointer to the output vector that contains the center
|
|
// frequencies.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pFBank or pCenters pointer is null.
|
|
// ippStsFBankErr Indicates an error when filter centers are not valid after filter
|
|
// bank initialization by ippsEmptyFBankInitAlloc function.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFBankGetCenters_32f,(const IppsFBankState_32f* pFBank, int* pCenters))
|
|
|
|
IPPAPI(IppStatus, ippsFBankGetCenters_16s,(const IppsFBankState_16s* pFBank, int* pCenters))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFBankSetCenters_*
|
|
// Purpose: Sets the center frequencies of the
|
|
// triangular filter banks.
|
|
// Parameters:
|
|
// pFBank Pointer to the filter bank structure
|
|
// pCenters Pointer to the vector that contains center frequencies.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pFBank or pCenters pointer is null.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFBankSetCenters_16s,(IppsFBankState_16s* pFBank,
|
|
const int* pCenters))
|
|
|
|
IPPAPI(IppStatus, ippsFBankSetCenters_32f,(IppsFBankState_32f* pFBank,
|
|
const int* pCenters))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFBankGetCoeffs_*
|
|
// Purpose: Retrieves the filter bank weight coefficients.
|
|
// Parameters:
|
|
// pFBank Pointer to the filter bank structure
|
|
// fIdx Filter index.
|
|
// pCoeffs Pointer to the filter coefficients vector.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pFBank or pCoeffs pointer is null.
|
|
// ippStsSizeErr Indicates an error when fIdx is less then 1 or greater
|
|
// then nFilter.
|
|
// ippStsFBankErr Indicates an error when fIdx filter coeffitients are not
|
|
// valid after filter centers reset or filter centers are not
|
|
// valid after filter bank initialization by
|
|
// ippsEmptyFBankInitAlloc function.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFBankGetCoeffs_16s,(const IppsFBankState_16s* pFBank,
|
|
int fIdx, Ipp32f* pCoeffs))
|
|
|
|
IPPAPI(IppStatus, ippsFBankGetCoeffs_32f,(const IppsFBankState_32f* pFBank,
|
|
int fIdx, Ipp32f* pCoeffs))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFBankSetCoeffs_*
|
|
// Purpose: Sets the filter bank weight coefficients.
|
|
// Parameters:
|
|
// pFBank Pointer to the filter bank structure
|
|
// fIdx Filter index.
|
|
// pCoeffs Pointer to the output coefficients vector.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pFBank or pCoeffs pointer is null.
|
|
// ippStsSizeErr Indicates an error when fIdx is less then 1 or greater
|
|
// then nFilter.
|
|
// ippStsFBankErr Indicates an error when the weight coefficients are not
|
|
// available or valid.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsFBankSetCoeffs_16s,(IppsFBankState_16s* pFBank, int fIdx,
|
|
const Ipp32f* pCoeffs))
|
|
|
|
IPPAPI(IppStatus, ippsFBankSetCoeffs_32f,(IppsFBankState_32f* pFBank, int fIdx,
|
|
const Ipp32f* pCoeffs))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsEvalFBank_*
|
|
// Purpose: Performs the filter bank analysis
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector
|
|
// pDst Pointer to the filter bank coefficients vector [nFilter].
|
|
// pFBank Pointer to the filter bank structure.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pDst pointer is null.
|
|
// ippStsFBankErr Indicates an error when pFBank structure is not ready for
|
|
// calculation.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsEvalFBank_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
const IppsFBankState_16s* pFBank, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsEvalFBank_16s32s_Sfs,(const Ipp16s* pSrc, Ipp32s* pDst,
|
|
const IppsFBankState_16s* pFBank, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsEvalFBank_32f,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
const IppsFBankState_32f* pFBank))
|
|
|
|
IPPAPI(IppStatus, ippsEvalFBank_32s_Sfs,(const Ipp32s* pSrc, Ipp32s* pDst,
|
|
const IppsFBankState_32s* pFBank, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDCTLifterGetSize_*
|
|
// Purpose: This function determines the
|
|
// size required for initializes the structure to perform DCT
|
|
// and lift the DCT coefficients. It should be called before
|
|
// memory allocation and before ippsDCTLifterInit_*
|
|
// Parameters:
|
|
// lenDCT Length of DCT will be used for MFCC calculation
|
|
// lenCeps Number (without c0) of cepstral coefficients to be calculated.
|
|
// nLifter Liftering factor
|
|
// pSize output
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSize pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenDCT, lenCeps or nLifter is
|
|
// less than or equal to 0 or lenDCT is less than lenCeps.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_32f,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_C0_32f,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_Mul_32f,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_MulC0_32f,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_16s,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_C0_16s,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_Mul_16s,(int lenDCT, int lenCeps, int *pSize))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterGetSize_MulC0_16s,(int lenDCT, int lenCeps, int* pSize))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDCTLifterInit_*
|
|
// Purpose: Initializes the structure to perform DCT
|
|
// and lift the DCT coefficients.
|
|
// Parameters:
|
|
// pDCTLifter Pointer to the created structure for DCT calculation and
|
|
// liftering.
|
|
// lenDCT Length of DCT will be used for MFCC calculation
|
|
// lenCeps Number (without c0) of cepstral coefficients to be calculated.
|
|
// nLifter Liftering factor
|
|
// pLifter Pointer to liftering coefficients vector
|
|
// val Value to multiply output MFCC except c0 coefficient
|
|
// val0 Value to multiply output c0 coefficient
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pLifter pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenDCT, lenCeps or nLifter is
|
|
// less than or equal to 0 or lenDCT is less than lenCeps.
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_32f,(IppsDCTLifterState_32f* pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_C0_32f,(IppsDCTLifterState_32f* pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val, Ipp32f val0))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_Mul_32f,(IppsDCTLifterState_32f* pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_MulC0_32f,(IppsDCTLifterState_32f* pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_16s,(IppsDCTLifterState_16s* pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_C0_16s,(IppsDCTLifterState_16s* pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val, Ipp32f val0))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_Mul_16s,(IppsDCTLifterState_16s* pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInit_MulC0_16s,(IppsDCTLifterState_16s* pDCTLifter,
|
|
int lenDCT, const Ipp32s* pLifter, int lenCeps))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDCTLifterInitAlloc_MulC0_*
|
|
// Purpose: Initializes the structure to perform DCT
|
|
// and lift the DCT coefficients.
|
|
// Parameters:
|
|
// pDCTLifter Pointer to the created structure for DCT calculation and
|
|
// liftering.
|
|
// lenDCT Length of DCT will be used for MFCC calculation
|
|
// lenCeps Number (without c0) of cepstral coefficients to be calculated.
|
|
// nLifter Liftering factor
|
|
// pLifter Pointer to liftering coefficients vector
|
|
// val Value to multiply output MFCC except c0 coefficient
|
|
// val0 Value to multiply output c0 coefficient
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pLifter pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenDCT, lenCeps or nLifter is
|
|
// less than or equal to 0 or lenDCT is less than lenCeps.
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_32f,(IppsDCTLifterState_32f** pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_C0_32f,(IppsDCTLifterState_32f** pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val, Ipp32f val0))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_Mul_32f,(IppsDCTLifterState_32f** pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_MulC0_32f,(IppsDCTLifterState_32f** pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_16s,(IppsDCTLifterState_16s** pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_C0_16s,(IppsDCTLifterState_16s** pDCTLifter,
|
|
int lenDCT, int lenCeps, int nLifter, Ipp32f val, Ipp32f val0))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_Mul_16s,(IppsDCTLifterState_16s** pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterInitAlloc_MulC0_16s,(IppsDCTLifterState_16s** pDCTLifter,
|
|
int lenDCT, const Ipp32f* pLifter, int lenCeps))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDCTLifterFree_*
|
|
// Purpose: Destroys the structure for DCT and liftering
|
|
// Parameters:
|
|
// pDCTLifter Pointer to the filter bank structure
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pDCTLifter pointer is null.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterFree_32f,(IppsDCTLifterState_32f* pDCTLifter))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifterFree_16s,(IppsDCTLifterState_16s* pDCTLifter))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDCTLifter_*
|
|
// Purpose: Performs DCT and lifts the DCT coefficients.
|
|
// Parameters:
|
|
// pSrc Pointer to the filter output vector [lenDCT]
|
|
// pDst Pointer to the MFCC feature vector.
|
|
// pDCTLifter Pointer to the filter bank structure
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicate an error when the pSrc, pDst, pFBank pointer is null.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifter_32f,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
const IppsDCTLifterState_32f* pDCTLifter))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifter_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
const IppsDCTLifterState_16s* pDCTLifter, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDCTLifter_32s16s_Sfs, (const Ipp32s* pSrc, Ipp16s* pDst,
|
|
const IppsDCTLifterState_16s* pDCTLifter, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNormEnergy_*
|
|
// Purpose: Normalizes a vector of energy values.
|
|
// Parameters:
|
|
// pSrcDst Pointer to the input/output vector [height*step].
|
|
// step Sample step in the vector pSrcDst.
|
|
// height Number of samples for normalization
|
|
// silFloor Silence floor in log10 value
|
|
// val Coefficient value.
|
|
// maxE Maximum energy value
|
|
// enScale Energy scale
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when step or height is less than
|
|
// or equal to 0
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsNormEnergy_32f,(Ipp32f* pSrcDst, int step, int height,
|
|
Ipp32f silFloor, Ipp32f enScale))
|
|
|
|
IPPAPI(IppStatus, ippsNormEnergy_16s,(Ipp16s* pSrcDst, int step, int height,
|
|
Ipp16s silFloor, Ipp16s val, Ipp32f enScale))
|
|
|
|
IPPAPI(IppStatus, ippsNormEnergy_RT_32f,(Ipp32f* pSrcDst, int step, int height,
|
|
Ipp32f silFloor, Ipp32f maxE, Ipp32f enScale))
|
|
|
|
IPPAPI(IppStatus, ippsNormEnergy_RT_16s,(Ipp16s* pSrcDst, int step, int height,
|
|
Ipp16s silFloor, Ipp16s maxE, Ipp16s val, Ipp32f enScale))
|
|
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumMeanVar_*
|
|
// Purpose: The function sums the vector elements and their
|
|
// squares according.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector [height* srcStep].
|
|
// pDstMean Pointer to the result vector that contains sums [width].
|
|
// pdstVar Pointer to the result vector that contains square sums [width].
|
|
// width Number of columns in the pSrc.
|
|
// srcStep Row step in pSrc.
|
|
// height Number of rows in pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pDstMean, pDstVar,
|
|
// pSrcDstMean or pSrcDstVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when srcStep, width or height is less
|
|
// than or equal to 0 or width is greater than srcStep;
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus,ippsSumMeanVar_32f,(const Ipp32f* pSrc, int srcStep, int height,
|
|
Ipp32f* pDstMean, Ipp32f* pDstVar, int width))
|
|
|
|
IPPAPI(IppStatus,ippsSumMeanVar_16s32f,(const Ipp16s* pSrc, int srcStep,
|
|
int height, Ipp32f* pDstMean, Ipp32f* pDstVar, int width))
|
|
|
|
IPPAPI(IppStatus,ippsSumMeanVar_16s32s_Sfs,(const Ipp16s* pSrc, int srcStep,
|
|
int height, Ipp32s* pDstMean, Ipp32s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus,ippsSumMeanVar_32f_I,(const Ipp32f* pSrc, int srcStep,
|
|
int height, Ipp32f* pSrcDstMean, Ipp32f* pSrcDstVar, int width))
|
|
|
|
IPPAPI(IppStatus,ippsSumMeanVar_16s32f_I,(const Ipp16s* pSrc, int srcStep,
|
|
int height, Ipp32f* pSrcDstMean, Ipp32f* pSrcDstVar, int width))
|
|
|
|
IPPAPI(IppStatus,ippsSumMeanVar_16s32s_ISfs,(const Ipp16s* pSrc, int srcStep,
|
|
int height, Ipp32s* pSrcDstMean, Ipp32s* pSrcDstVar, int width,
|
|
int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNewVar_*
|
|
// Purpose: The function computes the variance vector.
|
|
//
|
|
// Parameters:
|
|
// pSrcMean Pointer to the source vector of element sums [width].
|
|
// pSrcVar Pointer to the source vector of element sum squares [width].
|
|
// pSrcDstVar Pointer to the source and result vector of element sum squares [width].
|
|
// width Number of columns in the pSrc.
|
|
// val1, val2 Multiplicative constants.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcMean, pSrcVar, pDstVar or
|
|
// pSrcDstVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when width is less than or equal to 0;
|
|
//
|
|
*/
|
|
|
|
|
|
|
|
IPPAPI(IppStatus, ippsNewVar_32s_Sfs,(const Ipp32s* pSrcMean,
|
|
const Ipp32s* pSrcVar, Ipp32s* pDstVar, int width, Ipp32f val1,
|
|
Ipp32f val2, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsNewVar_32s_ISfs,(const Ipp32s* pSrcMean,
|
|
Ipp32s* pSrcDstVar, int width, Ipp32f val1, Ipp32f val2, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsNewVar_32f,(const Ipp32f* pSrcMean, const Ipp32f* pSrcVar,
|
|
Ipp32f* pDstVar, int width, Ipp32f val1, Ipp32f val2))
|
|
|
|
IPPAPI(IppStatus, ippsNewVar_32f_I,(const Ipp32f* pSrcMean, Ipp32f* pSrcDstVar,
|
|
int width, Ipp32f val1, Ipp32f val2))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsRecSqrt_*
|
|
// Purpose: Computes square root reciprocals of vector
|
|
// elements in-place.
|
|
// Parameters:
|
|
// pSrcDst Pointer to the source and destination vector pSrcDst.
|
|
// len The number of elements in the vector.
|
|
// val The threshold factor.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcDst pointer is null.
|
|
// ippStsInvByZero Indicates an error when pSrcDst[i]is less than val.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when val is less than or equal to 0
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus,ippsRecSqrt_32s_Sfs,(Ipp32s* pSrcDst, int len,Ipp32s val,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus,ippsRecSqrt_32s16s_Sfs,(const Ipp32s* pSrc, Ipp16s* pDst, int len,Ipp32s val,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsRecSqrt_32f, (Ipp32f* pSrcDst, int len, Ipp32f val))
|
|
|
|
|
|
/*//////////////////////////////////////////////////////////////////////
|
|
// Name: ippsAccCovarianceMatrix_*
|
|
// Purpose: Accumulate covariance matrix.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*srcStep].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// srcStep Row step in pSrc.
|
|
// pMean Pointer to the mean vector [width].
|
|
// width Length of the input matrix row, mean, and variance vectors.
|
|
// pSrcDst Pointer to the source and result matrix [width*dstStep].
|
|
// mSrcDst Pointer to the source and result matrix [width][width].
|
|
// dstStep Row step in pDst.
|
|
// height Number of rows in the input matrix.
|
|
// val Value to multiply to each distance.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, mSrc, pMean, pSrcDst,
|
|
// or mSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when width or height is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when srcStep or dstStep is less
|
|
// than width.
|
|
*/
|
|
IPPAPI(IppStatus, ippsAccCovarianceMatrix_16s64f_D2L,(const Ipp16s** mSrc,
|
|
int height, const Ipp16s* pMean, Ipp64f** mSrcDst, int width, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsAccCovarianceMatrix_32f64f_D2L, (const Ipp32f** mSrc,
|
|
int height, const Ipp32f* pMean, Ipp64f** mSrcDst, int width, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsAccCovarianceMatrix_16s64f_D2, (const Ipp16s* pSrc,
|
|
int srcStep, int height, const Ipp16s* pMean, Ipp64f* pSrcDst, int width,
|
|
int dstStep, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsAccCovarianceMatrix_32f64f_D2, (const Ipp32f* pSrc,
|
|
int srcStep, int height, const Ipp32f* pMean, Ipp64f* pSrcDst, int width,
|
|
int dstStep, Ipp64f val))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Derivatives
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
*/
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCopyColumn_*_D2
|
|
// Purpose: Copies the input sequence into the output sequence.
|
|
// Parameters:
|
|
// pSrc Pointer to the input feature sequence [height*srcWidth].
|
|
// srcWidth Length of each input feature vector.
|
|
// pDst Pointer to the output feature sequence [height*dstWidth].
|
|
// dstWidth Length of each output feature vector.
|
|
// height Number of features in the sequence.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or srcWidth is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when dstWidth is less than srcWidth.
|
|
*/
|
|
IPPAPI(IppStatus, ippsCopyColumn_16s_D2, (const Ipp16s* pSrc, int srcWidth,
|
|
Ipp16s* pDst, int dstWidth, int height))
|
|
|
|
IPPAPI(IppStatus, ippsCopyColumn_32f_D2, (const Ipp32f* pSrc, int srcWidth,
|
|
Ipp32f* pDst, int dstWidth, int height))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsEvalDelta_D2
|
|
// Purpose: Computes the derivatives of vector elements.
|
|
//
|
|
// Parameters:
|
|
// pSrcDst Pointer to the input and output vector [height*step].
|
|
// height The number of rows in pSrcDst.
|
|
// step Length of each feature in pSrcDst
|
|
// width The number of derivatives to be calculated for each feature.
|
|
// offset Offset to place the derivative values.
|
|
// winSize The delta window size
|
|
// val The delta coefficient.
|
|
// pVal Pointer to the delta coefficients vector [width].
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, width, or winSize
|
|
// is less than or equal to 0 or offset is less than 0
|
|
// or width is less than or equal to offset or height is
|
|
// less than 2*winSize.
|
|
// ippStsStrideErr Indicates an error when step is less than offset+2*width.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsEvalDelta_16s_D2Sfs, (Ipp16s*pSrcDst, int height, int step,
|
|
int width, int offset, int winSize, Ipp16s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsEvalDelta_32f_D2, (Ipp32f *pSrcDst, int height, int step,
|
|
int width, int offset, int winSize, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsEvalDeltaMul_16s_D2Sfs, (Ipp16s* pSrcDst, int height,
|
|
int step, const Ipp16s* pVal, int width, int offset, int winSize,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsEvalDeltaMul_32f_D2, (Ipp32f* pSrcDst, int height,
|
|
int step, const Ipp32f* pVal, int width, int offset, int winSize))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDelta*_D2
|
|
// Purpose: Copies the base features and calculates the
|
|
// derivatives of feature vectors.
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector [height*srcWidth].
|
|
// srcWidth The number of columns in the pSrc.
|
|
// pDst Pointer to the result vector [height*dstStep].
|
|
// dstStep The row step in pDst.
|
|
// val The delta coefficient.
|
|
// height Number of feature vectors.
|
|
// deltaMode Execution mode.
|
|
// pVal Pointer to the delta coefficients vector [width].
|
|
// scaleFactor
|
|
//
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pDst or pVal pointer is null.
|
|
// ippStsSizeErr Indicates an error when srcWidth is less than or equal to 0;
|
|
// or height is less than 0;
|
|
// or height is less than 2*winSize when deltaMode is equal to IPP_DELTA_BEGIN;
|
|
// or height is equal to 0 when deltaMode is not equal to IPP_DELTA_END.
|
|
// ippStsStrideErr Indicates an error when dstStep is less than 2*srcWidth.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDelta_Win1_16s_D2Sfs, (const Ipp16s* pSrc, int srcWidth,
|
|
Ipp16s* pDst, int dstStep, int height, Ipp16s val, int deltaMode,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDelta_Win2_16s_D2Sfs, (const Ipp16s* pSrc, int srcWidth,
|
|
Ipp16s* pDst, int dstStep, int height, Ipp16s val, int deltaMode,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDelta_Win1_32f_D2, (const Ipp32f* pSrc, int srcWidth,
|
|
Ipp32f* pDst, int dstStep, int height, Ipp32f val, int deltaMode))
|
|
|
|
IPPAPI(IppStatus, ippsDelta_Win2_32f_D2, (const Ipp32f* pSrc, int srcWidth,
|
|
Ipp32f* pDst, int dstStep, int height, Ipp32f val, int deltaMode))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaMul_Win1_16s_D2Sfs, (const Ipp16s* pSrc,
|
|
const Ipp16s* pVal, int srcWidth, Ipp16s* pDst, int dstStep,
|
|
int height, int deltaMode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaMul_Win2_16s_D2Sfs, (const Ipp16s* pSrc,
|
|
const Ipp16s* pSrc1, int srcWidth, Ipp16s* pDst, int dstStep,
|
|
int height, int deltaMode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaMul_Win1_32f_D2, (const Ipp32f* pSrc,
|
|
const Ipp32f* pVal, int srcWidth, Ipp32f* pDst, int dstStep,
|
|
int height, int deltamode))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaMul_Win2_32f_D2, (const Ipp32f* pSrc,
|
|
const Ipp32f* pVal, int srcWidth, Ipp32f* pDst, int dstStep,
|
|
int height, int deltamode))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDeltaDelta*_D2
|
|
// Purpose: Copies the base features and calculates their first
|
|
// and second derivatives.
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector [height*srcWidth].
|
|
// srcWidth Length of the input feature in the input sequence pSrc.
|
|
// pDst Pointer to the result vector [height*dstStep].
|
|
// dstStep The row step in pDst.
|
|
// height The number of rows in pSrc and pDst.
|
|
// val1, val2 The first and second delta coefficients.
|
|
// deltaMode Execution mode.
|
|
// pVal Pointer to the delta coefficients vector [width].
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when srcWidth is less than or equal to 0;
|
|
// or height is less than 0;
|
|
// or height is less than 3*winSize when deltaMode is equal to IPP_DELTA_BEGIN;
|
|
// or height is equal to 0 when deltaMode is not equal to IPP_DELTA_END.
|
|
// ippStsStrideErr Indicates an error when dstStep is less than 3*srcWidth.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDelta_Win1_16s_D2Sfs, (const Ipp16s* pSrc, int srcWidth,
|
|
Ipp16s* pDst, int dstStep, int height, Ipp16s val1,
|
|
Ipp16s val2, int deltaMode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDelta_Win2_16s_D2Sfs, (const Ipp16s* pSrc, int srcWidth,
|
|
Ipp16s* pDst, int dstStep, int height, Ipp16s val1,
|
|
Ipp16s val2, int deltaMode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDeltaMul_Win1_16s_D2Sfs, (const Ipp16s* pSrc,
|
|
const Ipp16s* pVal, int srcWidth, Ipp16s* pDst, int dstStep, int height,
|
|
int deltamode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDeltaMul_Win2_16s_D2Sfs, (const Ipp16s* pSrc,
|
|
const Ipp16s* pVal, int srcWidth, Ipp16s* pDst, int dstStep, int height,
|
|
int deltamode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDeltaMul_Win1_32f_D2, (const Ipp32f* pSrc,
|
|
const Ipp32f* pSrc1, int srcWidth, Ipp32f* pDst, int dstStep, int height,
|
|
int deltamode))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDeltaMul_Win2_32f_D2, (const Ipp32f* pSrc,
|
|
const Ipp32f* pSrc1, int srcWidth, Ipp32f* pDst, int dstStep, int height,
|
|
int deltamode))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDelta_Win1_32f_D2, (const Ipp32f* pSrc, int srcWidth,
|
|
Ipp32f* pDst, int dstStep, int height, Ipp32f val1,
|
|
Ipp32f val2, int deltaMode))
|
|
|
|
IPPAPI(IppStatus, ippsDeltaDelta_Win2_32f_D2, (const Ipp32f* pSrc, int srcWidth,
|
|
Ipp32f* pDst, int dstStep, int height, Ipp32f val1,
|
|
Ipp32f val2, int deltaMode))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDeltaDelta_Aurora_*
|
|
// Purpose: The function ippsDeltaDelta_Aurora calculate full feature vectors
|
|
// according to ETSI ES 202 050 standard.
|
|
// Context:
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pDst, or pVal pointer is NULL.
|
|
// ippStsSizeErr Indicates an error when height is less than 0;
|
|
// or height is less than 8 when deltaMode is equal to IPP_DELTA_BEGIN;
|
|
// or height is equal to 0 when deltaMode is not equal to IPP_DELTA_END.
|
|
// ippStsStrideErr Indicates an error when dstStep is less than 39.
|
|
// Parameters:
|
|
// pSrc Pointer to the input feature sequence [height*14].
|
|
// pDst Pointer to the output feature sequence [height*dstStep].
|
|
// dstStep Length of the output feature in the output sequence pDst.
|
|
// height Number of feature vectors.
|
|
// deltaMode Execution mode.
|
|
// pVal Pointer to the delta coefficients vector [39].
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus,ippsDeltaDelta_Aurora_16s_D2Sfs,(const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int dstStep, int height, int deltaMode, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus,ippsDeltaDelta_Aurora_32f_D2,(const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int dstStep, int height, int deltaMode))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDeltaDeltaMul_Aurora_*
|
|
// Purpose: The function ippsDeltaDelta_Aurora calculate full feature vectors
|
|
// according to ETSI ES 202 050 standard.
|
|
// Context:
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pDst, or pVal pointer is NULL.
|
|
// ippStsSizeErr Indicates an error when height is less than 0;
|
|
// or height is less than 8 when deltaMode is equal to IPP_DELTA_BEGIN;
|
|
// or height is equal to 0 when deltaMode is not equal to IPP_DELTA_END.
|
|
// ippStsStrideErr Indicates an error when dstStep is less than 39.
|
|
// Parameters:
|
|
// pSrc Pointer to the input feature sequence [height*14].
|
|
// pDst Pointer to the output feature sequence [height*dstStep].
|
|
// dstStep Length of the output feature in the output sequence pDst.
|
|
// height Number of feature vectors.
|
|
// deltaMode Execution mode.
|
|
// pVal Pointer to the delta coefficients vector [39].
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus,ippsDeltaDeltaMul_Aurora_32f_D2,(const Ipp32f* pSrc, const Ipp32f* pVal,
|
|
Ipp32f* pDst, int dstStep, int height, int deltaMode))
|
|
IPPAPI(IppStatus,ippsDeltaDeltaMul_Aurora_16s_D2Sfs,(const Ipp16s* pSrc, const Ipp16s* pVal,
|
|
Ipp16s* pDst, int dstStep, int height, int deltaMode, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Model Evaluation
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsAddNRows_32f
|
|
// Purpose: Adds N vectors from the table
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// height The number of rows in the pSrc.
|
|
// offset
|
|
// step The row step in pSrc.
|
|
// pInd Pointer to the indexes vector [rows].
|
|
// pAddInd Pointer to the indexes addition vector [rows].
|
|
// rows The number of rows to add.
|
|
// pDst Pointer to the output vector [width].
|
|
// width The number of elements in the output vector pDst.
|
|
// weight The value to add to output vector elements.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pInd, pAddIndex, or
|
|
// pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, width, rows, or
|
|
// (pInd[i]+pAddIndex[i]) is less than 0;
|
|
// or (pInd[i]+pAddIndex[i]) >= height;
|
|
// or offset>segCount.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsAddNRows_32f_D2, (Ipp32f* pSrc, int height, int offset,
|
|
int step, Ipp32s* pInd, Ipp16u* pAddInd, int rows, Ipp32f* pDst, int width,
|
|
Ipp32f weight))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsScaleLM_*
|
|
// Purpose: Scales vector elements with thresholding.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pDst Pointer to the output vector [len].
|
|
// len The number of elements in the pSrc and pDst vectors.
|
|
// floor A value used to limit each element of pSrc.
|
|
// scale The multiplier factor value.
|
|
// base The additive value.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsScaleLM_32f, (const Ipp32f *pSrc, Ipp32f *pDst,
|
|
int len, Ipp32f floor, Ipp32f scale, Ipp32f base))
|
|
|
|
IPPAPI(IppStatus, ippsScaleLM_16s32s, (const Ipp16s* pSrc, Ipp32s* pDst,
|
|
int len, Ipp16s floor, Ipp16s scale, Ipp32s base))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogAdd_*
|
|
// Purpose: Logarithmically adds two vectors in-place.
|
|
// Parameters:
|
|
// pSrc The first input vector [len].
|
|
// pDst The second input and output vector [len].
|
|
// len The number of elements in the input and output vectors.
|
|
// hint Recommends to use a specific code for the
|
|
// Logarithmically adds.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus,ippsLogAdd_64f,(const Ipp64f* pSrc, Ipp64f* pSrcDst, int len,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus,ippsLogAdd_32f,(const Ipp32f* pSrc, Ipp32f* pSrcDst, int len,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus,ippsLogAdd_32s_Sfs,(const Ipp32s* pSrc, Ipp32s* pSrcDst, int len,
|
|
int scaleFactor, IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus,ippsLogAdd_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pSrcDst, int len,
|
|
int scaleFactor, IppHintAlgorithm hint))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogSub_*
|
|
// Purpose: Logarithmically subtracts two vectors in place .
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pDst Pointer to the input and output vectors [len].
|
|
// len The number of elements in the input and output vectors.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsNoOperation Indicates an error when pDst[i] > pSrc[i]is more than 0.
|
|
*/
|
|
IPPAPI(IppStatus,ippsLogSub_32f,(const Ipp32f* pSrc, Ipp32f* pSrcDst, int len))
|
|
|
|
IPPAPI(IppStatus,ippsLogSub_64f,(const Ipp64f* pSrc, Ipp64f* pSrcDst, int len))
|
|
|
|
IPPAPI(IppStatus,ippsLogSub_32s_Sfs,(const Ipp32s* pSrc, Ipp32s* pSrcDst, int len,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus,ippsLogSub_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pSrcDst, int len,
|
|
int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMahDistSingle_*
|
|
// Purpose: Calculates the Mahalanobis distance
|
|
// for a single observation vector.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pMean Pointer to the mean vector [len].
|
|
// pVar Pointer to the variance vector [len].
|
|
// len The number of elements in the input, mean,
|
|
// and variance vectors.
|
|
// pResult Pointer to the result value.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar, or
|
|
// pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsMahDistSingle_32f, (const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int len,
|
|
Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistSingle_64f, (const Ipp64f* pSrc,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int len,
|
|
Ipp64f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistSingle_32f64f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int len, Ipp64f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistSingle_16s32f,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int len, Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistSingle_16s32s_Sfs,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int len, Ipp32s* pResult,
|
|
int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMahDist_*_*
|
|
// Purpose: Calculates the Mahalanobis distances
|
|
// for multiple observation vectors.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// step The row step in pSrc.
|
|
// pMean Pointer to the mean vector [width].
|
|
// pVar Pointer to the variance vector [width].
|
|
// width The length of the input matrix row, mean,
|
|
// and variance vectors.
|
|
// pDst Pointer to the result value [height].
|
|
// height The number of rows in the input matrix and the length of
|
|
// the result vector pDst.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pDst,o rmSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when width or heightis less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsMahDist_32f_D2, (const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width, Ipp32f* pDst,
|
|
int height))
|
|
|
|
IPPAPI(IppStatus, ippsMahDist_64f_D2, (const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width, Ipp64f* pDst,
|
|
int height))
|
|
|
|
IPPAPI(IppStatus, ippsMahDist_32f_D2L, (const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width, Ipp32f* pDst,
|
|
int height))
|
|
|
|
IPPAPI(IppStatus, ippsMahDist_64f_D2L, (const Ipp64f** mSrc,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width, Ipp64f* pDst,
|
|
int height))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMahDistMultiMix_*_*
|
|
// Purpose: Calculates the Mahalanobis distances
|
|
// for multiple means and variances
|
|
// Parameters:
|
|
// pMean Pointer to the mean vector [height*step].
|
|
// pVar Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// step Row step in pSrc.
|
|
// pSrc Pointer to the input vector [width].
|
|
// width Length of the input matrix row and pSrc vector.
|
|
// pDst Pointer to the result vector [height].
|
|
// height Number of rows in input matrices and length of result
|
|
// vector pDst.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// mMean, mVar, or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsMahDistMultiMix_32f_D2, (const Ipp32f* pMean,
|
|
const Ipp32f* pVar, int step, const Ipp32f* pSrc, int width,
|
|
Ipp32f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistMultiMix_64f_D2, (const Ipp64f* pMean,
|
|
const Ipp64f* pVar, int step, const Ipp64f* pSrc, int width,
|
|
Ipp64f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistMultiMix_32f_D2L, (const Ipp32f** mMean,
|
|
const Ipp32f** mVar, const Ipp32f* pSrc, int width, Ipp32f* pDst,
|
|
int height))
|
|
|
|
IPPAPI(IppStatus, ippsMahDistMultiMix_64f_D2L, (const Ipp64f** mMean,
|
|
const Ipp64f** mVar, const Ipp64f* pSrc, int width, Ipp64f* pDst,
|
|
int height))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussSingle_*
|
|
// Purpose: Calculates the observation probability for a
|
|
// single Gaussian with an observation vector.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pMean Pointer to the mean vector [len].
|
|
// pVar Pointer to the variance vector [len].
|
|
// pBlockVar Pointer to the block diagonal variance matrix.
|
|
// len Number of elements in the input, mean, and variance
|
|
// vectors.
|
|
// pResult Pointer to the result value.
|
|
// val Gaussian constant.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar, or
|
|
// pResult or pBlockVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_32f, (const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int len,
|
|
Ipp32f* pResult, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_64f, (const Ipp64f* pSrc,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int len,
|
|
Ipp64f* pResult, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_32f64f, (const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int len,
|
|
Ipp64f* pResult, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_Scaled_16s32f, (const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* dst,
|
|
Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_16s32s_Sfs, (const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* dst,
|
|
Ipp32s val, int scaleFactor))
|
|
|
|
|
|
/*
|
|
//Case 2: Operation for the diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_DirectVar_32f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int len, Ipp32f* pResult,
|
|
Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_DirectVar_64f,(const Ipp64f* pSrc,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int len, Ipp64f* pResult,
|
|
Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_DirectVar_32f64f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int len, Ipp64f* pResult,
|
|
Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_DirectVarScaled_16s32f,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int len, Ipp32f* pResult,
|
|
Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_DirectVar_16s32s_Sfs,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int len, Ipp32s* pResult,
|
|
Ipp32s val, int scaleFactor))
|
|
|
|
|
|
/*
|
|
//Case 3: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVar_32f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, int len, Ipp32f* pResult, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVar_64f,(const Ipp64f* pSrc,
|
|
const Ipp64f* pMean, int len, Ipp64f* pResult, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVar_32f64f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, int len, Ipp64f* pResult, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVarScaled_16s32f,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int len, Ipp32f* pResult, Ipp32f va,
|
|
int scaleFactorl))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVar_16s32s_Sfs,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int len, Ipp32s* pResult, Ipp32s val,
|
|
int scaleFactor))
|
|
|
|
|
|
/*
|
|
//Case 4: Operation for the block diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_BlockDVar_32f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean,const IppsBlockDMatrix_32f* pVar, int len,
|
|
Ipp32f* pResult, Ipp32f val))
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_BlockDVar_64f,(const Ipp64f* pSrc,
|
|
const Ipp64f* pMean, const IppsBlockDMatrix_64f * pVar, int len,
|
|
Ipp64f* pResult, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_BlockDVar_32f64f,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, const IppsBlockDMatrix_32f * pVar, int len,
|
|
Ipp64f* pResult, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_BlockDVarScaled_16s32f,(const Ipp16s* pSrc,
|
|
const Ipp16s* pSrcMean,const IppsBlockDMatrix_16s* pSrcVar, int srcLen,Ipp32f* pResult,
|
|
Ipp32f val,int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_BlockDVar_16s32s_Sfs,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const IppsBlockDMatrix_16s * pVar, int len,
|
|
Ipp32s* pResult, Ipp32s val, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGauss_*
|
|
// Purpose: Calculates the observation probability for a single
|
|
// Gaussian with multiple observation vectors.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// step The row step in pSrc.
|
|
// pMean Pointer to the mean vector [width].
|
|
// pVar Pointer to the variance vector [width].
|
|
// width Length of the mean and variance vectors.
|
|
// pDst Pointer to the result value [height].
|
|
// pSrcDst Pointer to the input and output vector [height].
|
|
// height The number of rows in the input matrix and the length of
|
|
// the result vector pDst.
|
|
// val Gaussian constant.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pDst,or mSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGauss_16s32s_D2Sfs, (const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* pDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_16s32s_D2LSfs, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* pDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_32f_D2, (const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width, Ipp32f* pDst,
|
|
int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_64f_D2, (const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width, Ipp64f* pDst,
|
|
int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_32f_D2L, (const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width,
|
|
Ipp32f* pDst, int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_64f_D2L, (const Ipp64f** mSrc,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width,
|
|
Ipp64f* pDst, int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_Scaled_16s32f_D2, (const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_Scaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVar_16s32s_D2Sfs,(const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32s* pDst, int height,
|
|
Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVarScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32f* pDst, int height,
|
|
Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVar_32f_D2,(const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pMean, int width, Ipp32f* pDst, int height,
|
|
Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVar_64f_D2,(const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pMean, int width, Ipp64f* pDst, int height,
|
|
Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVar_16s32s_D2LSfs,(const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32s* pDst, int height, Ipp32s val,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVarScaled_16s32f_D2L,(const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32f* pDst, int height, Ipp32f val,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVar_32f_D2L,(const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, int width, Ipp32f* pDst, int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVar_64f_D2L,(const Ipp64f** mSrc,
|
|
const Ipp64f* pMean, int width, Ipp64f* pDst, int height, Ipp64f val))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMultiMix_*
|
|
// Purpose: Calculates the observation probability for
|
|
// multiple Gaussian mixture components.
|
|
//
|
|
// Parameters:
|
|
// pMean Pointer to the mean vector [height*step].
|
|
// pVar Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// pSrcDst Pointer to the input additive values and
|
|
// the result vector [height].
|
|
// step The row step in pMean.
|
|
// pSrc Pointer to the input vector [width].
|
|
// height The number of rows in input matrices and the length of
|
|
// the result vector pSrcDst.
|
|
// width The length of the input matrices row and the vector pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst, mMean, or mVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_16s32s_D2Sfs, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
Ipp32s* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_16s32s_D2LSfs, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, Ipp32s* pSrcDst,
|
|
int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_Scaled_16s32f_D2, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_Scaled_16s32f_D2L, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, Ipp32f* pSrcDst,
|
|
int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_32f_D2, (const Ipp32f* pMean,
|
|
const Ipp32f* pVar, int step, const Ipp32f* pSrc, int width,
|
|
Ipp32f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_64f_D2, (const Ipp64f* pMean,
|
|
const Ipp64f* pVar, int step, const Ipp64f* pSrc, int width,
|
|
Ipp64f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_32f_D2L, (const Ipp32f** mMean,
|
|
const Ipp32f** mVar, const Ipp32f* pSrc, int width, Ipp32f* pSrcDst,
|
|
int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_64f_D2L, (const Ipp64f** mMean,
|
|
const Ipp64f** mVar, const Ipp64f* pSrc, int width, Ipp64f* pSrcDst,
|
|
int height))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMax_*_D2
|
|
// Purpose: Computes maximum value of a vector dst and
|
|
// logarithms of the Gaussian probability distribution function.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// step The row step in pSrc.
|
|
// pMean Pointer to the mean vector [width].
|
|
// pVar Pointer to the variance vector [width].
|
|
// width The length of the input matrix row, mean,
|
|
// and variance vectors.
|
|
// pSrcDst Pointer to the input and output vector [height].
|
|
// height The number of rows in the input matrix and the length of
|
|
// the result vector pSrcDst.
|
|
// val The value to add to each distance.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst, mSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMax_32f_D2, (const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width,
|
|
Ipp32f* pSrcDst, int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_32f_D2L, (const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_64f_D2, (const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width, Ipp64f* pSrcDst,
|
|
int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_64f_D2L, (const Ipp64f** mSrc,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width, Ipp64f* pSrcDst,
|
|
int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_16s32s_D2Sfs, (const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
Ipp32s* pSrcDst, int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_16s32s_D2LSfs, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* pSrcDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_Scaled_16s32f_D2, (const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
Ipp32f* pSrcDst, int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_Scaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVar_32f_D2, (const Ipp32f* pSrc,
|
|
int step, const Ipp32f* pMean, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVar_32f_D2L, (const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, int width, Ipp32f* pSrcDst, int height,
|
|
Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVar_64f_D2, (const Ipp64f* pSrc,
|
|
int step, const Ipp64f* pMean, int width, Ipp64f* pSrcDst,
|
|
int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVar_64f_D2L, (const Ipp64f** mSrc,
|
|
const Ipp64f* pMean, int width, Ipp64f* pSrcDst, int height,
|
|
Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVar_16s32s_D2Sfs, (const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32s* pSrcDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVar_16s32s_D2LSfs, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32s* pSrcDst, int height,
|
|
Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVarScaled_16s32f_D2, (const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVarScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32f* pSrcDst, int height,
|
|
Ipp32f val, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMaxMultiMix_*_*
|
|
// Purpose: Computes the maximum of the Gaussian probability
|
|
// distribution function.
|
|
// Parameters:
|
|
// pMean Pointer to the mean vector [height*step].
|
|
// pVar Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// pVal Pointer to the input vector of Max values [height].
|
|
// pSrcDst Pointer to the input and output vector [height].
|
|
// step Row step in pMean and pVar.
|
|
// pSrc Pointer to theinput vector [width].
|
|
// height Number of rows in input matrices and the length of
|
|
// the result vector pSrcDst.
|
|
// width Length of the input matrices row and the vector pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst, mMean, mVar or pVal pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_32f_D2, (const Ipp32f* pMean,
|
|
const Ipp32f* pVar, int step, const Ipp32f* pSrc, int width,
|
|
const Ipp32f* pVal, Ipp32f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_32f_D2L, (const Ipp32f** mMean,
|
|
const Ipp32f** mVar, const Ipp32f* pSrc, int width, const Ipp32f* pVal,
|
|
Ipp32f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_64f_D2, (const Ipp64f* pMean,
|
|
const Ipp64f* pVar, int step, const Ipp64f* pSrc, int width,
|
|
const Ipp64f* pVal, Ipp64f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_64f_D2L, (const Ipp64f** mMean,
|
|
const Ipp64f** mVar, const Ipp64f* pSrc, int width, const Ipp64f* pVal,
|
|
Ipp64f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_Scaled_16s32f_D2, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
const Ipp32f* pVal, Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_Scaled_16s32f_D2L, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, const Ipp32f* pVal,
|
|
Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_16s32s_D2Sfs, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
const Ipp32s* pVal, Ipp32s* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_16s32s_D2LSfs, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, const Ipp32s* pVal,
|
|
Ipp32s* pSrcDst, int height, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussAdd_32f_D2
|
|
// Purpose: Calculates the likelihood probability for multiple
|
|
// observation vectors.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [width*height]
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// step Row step in pSrc.
|
|
// pMean Pointer to the mean vector [width]
|
|
// pVar Pointer to the variance vector [width]
|
|
// width Length of the mean, and variance vectors.
|
|
// pSrcDst Pointer to input vector and output vector [height]
|
|
// height Length of the input and output vector pSrcDst
|
|
// val Value to add to each distance.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst or mSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when width or height
|
|
// is less than or equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
*/
|
|
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_32f_D2, (const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_32f_D2L, (const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_64f_D2,(const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pMean, const Ipp64f* pVar, int width,
|
|
Ipp64f* pSrcDst, int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_64f_D2L, (const Ipp64f** mSrc, const Ipp64f* pMean,
|
|
const Ipp64f* pVar, int width, Ipp64f* pSrcDst, int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_Scaled_16s32f_D2,(const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
Ipp32f* pSrcDst, int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_Scaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVarScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVarScaled_16s32f_D2L,(const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32f* pSrcDst, int height, Ipp32f val,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVar_32f_D2,(const Ipp32f* pSrc,
|
|
int step, const Ipp32f* pMean, int width, Ipp32f* pSrcDst, int height,
|
|
Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVar_32f_D2L,(const Ipp32f** mSrc,
|
|
const Ipp32f* pMean, int width, Ipp32f* pSrcDst, int height, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVar_64f_D2,(const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pMean, int width, Ipp64f* pSrcDst, int height, Ipp64f val))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVar_64f_D2L,(const Ipp64f** mSrc,
|
|
const Ipp64f* pMean, int width, Ipp64f* pSrcDst, int height, Ipp64f val))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussAddMultiMix_*_*
|
|
// Purpose: Calculates the likelihood probability for multiple
|
|
// Gaussian mixture components.
|
|
//
|
|
// Parameters:
|
|
// pMean Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// pVar Pointer to the variance vector [height*step].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// pVal Pointer to the input vector of additive values [height].
|
|
// pSrcDst Pointer to the input and output vector [height].
|
|
// step The row step in pMean.
|
|
// pSrc Pointer to the input vector [width].
|
|
// height The number of rows in input matrices and the length of
|
|
// the result vector pSrcDst.
|
|
// width The length of the input matrices row and the vector pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst, mMean, mVar or pVal pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_Scaled_16s32f_D2, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
const Ipp32f* pVal, Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_Scaled_16s32f_D2L, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, const Ipp32f* pVal,
|
|
Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_32f_D2, (const Ipp32f* pMean,
|
|
const Ipp32f* pVar, int step, const Ipp32f* pSrc, int width,
|
|
const Ipp32f* pVal, Ipp32f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_32f_D2L, (const Ipp32f** mMean,
|
|
const Ipp32f** mVar, const Ipp32f* pSrc, int width, const Ipp32f* pVal,
|
|
Ipp32f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_64f_D2, (const Ipp64f* pMean,
|
|
const Ipp64f* pVar, int step, const Ipp64f* pSrc, int width,
|
|
const Ipp64f* pVal, Ipp64f* pSrcDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_64f_D2L, (const Ipp64f** mMean,
|
|
const Ipp64f** mVar, const Ipp64f* pSrc, int width, const Ipp64f* pVal,
|
|
Ipp64f* pSrcDst, int height))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Model Estimation
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMeanColumn_*
|
|
// Purpose: Computes the mean values vector of column
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// height The number rows in the input matrix.
|
|
// step The row step in pSrc.
|
|
// pDstMean Pointer to the output mean vector [width].
|
|
// width The number of columns in the input matrix and the length
|
|
// of the output mean vector pDstMean.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, mSrc, or pDstMean
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsMeanColumn_16s_D2,(const Ipp16s* pSrc, int height,
|
|
int step, Ipp16s* pDstMean, int width))
|
|
|
|
IPPAPI(IppStatus, ippsMeanColumn_16s_D2L,(const Ipp16s** mSrc, int height,
|
|
Ipp16s* pDstMean, int width))
|
|
|
|
|
|
IPPAPI(IppStatus, ippsMeanColumn_32f_D2,(const Ipp32f* pSrc, int height,
|
|
int step, Ipp32f* pDstMean, int width))
|
|
|
|
IPPAPI(IppStatus, ippsMeanColumn_32f_D2L,(const Ipp32f** mSrc, int height,
|
|
Ipp32f* pDstMean, int width))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVarColumn_*
|
|
// Purpose: Computes the variance values vector of column elements.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// height The number of rows in the input matrix.
|
|
// step The row step in pSrc.
|
|
// pSrcMean Pointer to the input mean vector [width].
|
|
// pDstVar Pointer to the output variance vector of length [width].
|
|
// width Number of columns in the input matrix and the length of
|
|
// the input mean vector pSrcMean and output variance
|
|
// vector pDstVar.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrc, pSrcMean, pDstVar, or
|
|
// pSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when srcHight or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVarColumn_16s_D2Sfs,(const Ipp16s* pSrc, int height,
|
|
int step, Ipp16s* pSrcMean, Ipp16s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVarColumn_16s_D2LSfs,(const Ipp16s** mSrc, int height,
|
|
Ipp16s* pSrcMean, Ipp16s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVarColumn_32f_D2,(const Ipp32f* pSrc, int height,
|
|
int step, Ipp32f* pSrcMean, Ipp32f* pDstVar, int width))
|
|
|
|
IPPAPI(IppStatus, ippsVarColumn_32f_D2L,(const Ipp32f** mSrc, int height,
|
|
Ipp32f* pSrcMean, Ipp32f* pDstVar, int width))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMeanVarColumn_*
|
|
// Purpose: Computes the mean and variance values vector of
|
|
// column elements.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// height The number of rows in the input matrix.
|
|
// step The row step in pSrc.
|
|
// pDstMean Pointer to the output mean vector [width].
|
|
// pDstVar Pointer to the output variance vector [width].
|
|
// width The number of columns in the input matrix and the length
|
|
// of the output mean vector pDstMean and
|
|
// variance vector pDstVar.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, mSrc, pDstMean, or
|
|
// pDstVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_16s_D2Sfs,(const Ipp16s* pSrc, int height,
|
|
int step, Ipp16s* pDstMean, Ipp16s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_16s_D2LSfs,(const Ipp16s** mSrc, int height,
|
|
Ipp16s* pDstMean, Ipp16s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_16s16s32s_D2,(const Ipp16s* pSrc, int height,
|
|
int step, Ipp16s* pDstMean, Ipp32s* pDstVar, int width))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_16s16s32s_D2L,(const Ipp16s** mSrc, int height,
|
|
Ipp16s* pDstMean, Ipp32s* pDstVar, int width))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_16s32s_D2Sfs,(const Ipp16s* pSrc, int height,
|
|
int step, Ipp32s* pDstMean, Ipp32s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_16s32s_D2LSfs,(const Ipp16s** mSrc, int height,
|
|
Ipp32s* pDstMean, Ipp32s* pDstVar, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_32f_D2,(const Ipp32f* pSrc, int height,
|
|
int step, Ipp32f* pDstMean, Ipp32f* pDstVar, int width))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarColumn_32f_D2L,(const Ipp32f** mSrc, int height,
|
|
Ipp32f* pDstMean, Ipp32f* pDstVar, int width))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNormalizeColumn_*_*
|
|
// Purpose: Normalizes the matrix rows with the help of mean
|
|
// and variance vectors.
|
|
// Parameters:
|
|
// pMean Pointer to the mean vector [width].
|
|
// pVar Pointer to the variance vector [width].
|
|
// pSrcDst Pointer to the input and output vector [height*step].
|
|
// mSrcDst Pointer to the input/output matrix [height][width]
|
|
// width The number of elements in the mean
|
|
// and variance vectors.
|
|
// step The row step in pSrcDst.
|
|
// height The number of rows in the input and output matrix
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pMean, pVar, or pSrcDst
|
|
// or mSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsNormalizeColumn_32f_D2,(Ipp32f* pSrcDst, int step,
|
|
int height, const Ipp32f* pMean, const Ipp32f* pVar, int width))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeColumn_32f_D2L,(Ipp32f** mSrcDst, int height,
|
|
const Ipp32f* pMean, const Ipp32f* pVar, int width))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeColumn_16s_D2Sfs,(Ipp16s* pSrcDst, int step,
|
|
int height, const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeColumn_16s_D2LSfs,(Ipp16s** mSrcDst, int height,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNormalizeInRange_*
|
|
//
|
|
// Purpose: Normalizes and scales input vector elements.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input array [len].
|
|
// pSrcDst Pointer to the input and output array
|
|
// (for the in-place operation) [len].
|
|
// pDst Pointer to the output array [len].
|
|
// len Number of elements in the input and output array.
|
|
// lowCut Lower cutoff value.
|
|
// highCut High cutoff value.
|
|
// range Upper bound of output data value (lower bound is 0).
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when 0<=lowCut<highCut<=1 condition
|
|
// is not true or range is less than 0.
|
|
// ippStsInvZero Indicates a warning when Xmin = Xmax. All elements of
|
|
// the output vector are set to 0.
|
|
*/
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_16s8u, (const Ipp16s* pSrc, Ipp8u* pDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp8u range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_16s, (const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp16s range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_16s_I, (Ipp16s* pSrcDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp16s range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_32f8u, (const Ipp32f* pSrc, Ipp8u* pDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp8u range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_32f16s, (const Ipp32f* pSrc, Ipp16s* pDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp16s range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_32f, (const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp32f range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRange_32f_I, (Ipp32f* pSrcDst,
|
|
int len, Ipp32f lowCut, Ipp32f highCut, Ipp32f range))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNormalizeInRangeMinMax_*
|
|
//
|
|
// Purpose: Normalizes and scales input vector elements.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input array [len].
|
|
// pSrcDst Pointer to the input and output array
|
|
// (for the in-place operation) [len].
|
|
// pDst Pointer to the output array [len].
|
|
// len Number of elements in the input and output array.
|
|
// lowCut Lower cutoff value.
|
|
// highCut High cutoff value.
|
|
// range Upper bound of output data value (lower bound is 0).
|
|
// valMin Minimum of input data.
|
|
// valMax Maximum of input data.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when 0<=lowCut<highCut<=1 condition
|
|
// is not true or range is less than 0 or valMin is greater
|
|
// than valMax.
|
|
// ippStsInvZero Indicates a warning when valMin=valMax. All elements of
|
|
// the output vector are set to 0.
|
|
*/
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_16s8u, (const Ipp16s* pSrc, Ipp8u* pDst,
|
|
int len, Ipp16s valMin, Ipp16s valMax,
|
|
Ipp32f lowCut, Ipp32f highCut, Ipp8u range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_16s, (const Ipp16s* pSrc, Ipp16s* pDst,
|
|
int len, Ipp16s valMin, Ipp16s valMax,
|
|
Ipp32f lowCut, Ipp32f highCut, Ipp16s range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_16s_I, (Ipp16s* pSrcDst,
|
|
int len, Ipp16s valMin, Ipp16s valMax, Ipp32f
|
|
lowCut, Ipp32f highCut, Ipp16s range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_32f8u, (const Ipp32f* pSrc, Ipp8u* pDst,
|
|
int len, Ipp32f valMin, Ipp32f valMax,
|
|
Ipp32f lowCut, Ipp32f highCut, Ipp8u range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_32f16s, (const Ipp32f* pSrc, Ipp16s* pDst,
|
|
int len, Ipp32f valMin, Ipp32f valMax,
|
|
Ipp32f lowCut, Ipp32f highCut, Ipp16s range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_32f, (const Ipp32f* pSrc, Ipp32f* pDst,
|
|
int len, Ipp32f valMin, Ipp32f valMax,
|
|
Ipp32f lowCut, Ipp32f highCut, Ipp32f range))
|
|
|
|
IPPAPI(IppStatus, ippsNormalizeInRangeMinMax_32f_I, (Ipp32f* pSrcDst,
|
|
int len, Ipp32f valMin, Ipp32f valMax,
|
|
Ipp32f lowCut, Ipp32f highCut, Ipp32f range))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMeanVarAcc_*
|
|
// Purpose: Computes mean and variance accumulators.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pSrcMean Pointer to the mean vector [len].
|
|
// pDstMeanAcc Pointer to the mean accumulated vector [len].
|
|
// pDstVarAcc Pointer to the variance accumulated vector [len].
|
|
// len The number of elements in the input, mean,
|
|
// and variance vectors.
|
|
// val The value of the multiplyed mean and variance vectors
|
|
// before accumulated.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pSrcMean, pDstMeanAcc,
|
|
// or pDstVarAcc pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsMeanVarAcc_32f, (Ipp32f const* pSrc,
|
|
Ipp32f const* pSrcMean, Ipp32f* pDstMeanAcc, Ipp32f* pDstVarAcc,
|
|
int len, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsMeanVarAcc_64f, (Ipp64f const* pSrc,
|
|
Ipp64f const* pSrcMean, Ipp64f* pDstMeanAcc, Ipp64f* pDstVarAcc,
|
|
int len, Ipp64f val))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsGaussianDist_32f
|
|
// Purpose: Computes distance between Gaussians.
|
|
// Parameters:
|
|
// pSrcMean1 Pointer to the mean vector of the first Gaussian [len]
|
|
// pSrcVar1 Pointer to the variance vector of the
|
|
// first Gaussian [len].
|
|
// pSrcMean2 Pointer to the mean vector of the second
|
|
// Gaussian [len].
|
|
// pSrcVar2 Pointer to the variance vector of the second
|
|
// Gaussian [len].
|
|
// len The number of elements in the mean and variance vectors.
|
|
// pResult Pointer to the distance value.
|
|
// wgt1 The first Gaussian weight.
|
|
// det1 The first Gaussian determinant.
|
|
// wgt2 The second Gaussian weight.
|
|
// det2 The second Gaussian determinant.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcMean1, pSrcMean2,
|
|
// pSrcVar1, pSrcVar2, or pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsGaussianDist_32f,(const Ipp32f* pSrcMean1,
|
|
const Ipp32f* pSrcVar1, const Ipp32f* pSrcMean2, const Ipp32f* pSrcVar2,
|
|
int len, Ipp32f* pResult, Ipp32f wgt1, Ipp32f det1, Ipp32f wgt2,
|
|
Ipp32f det2))
|
|
|
|
IPPAPI(IppStatus, ippsGaussianDist_64f,(const Ipp64f* pSrcMean1,
|
|
const Ipp64f* pSrcVar1, const Ipp64f* pSrcMean2, const Ipp64f* pSrcVar2,
|
|
int len, Ipp64f* pResult, Ipp64f wgt1, Ipp64f det1, Ipp64f wgt2,
|
|
Ipp64f det2))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsGaussianSplit_32f
|
|
// Purpose: Splits simple Gaussian probability distribution functions
|
|
//
|
|
// Parameters:
|
|
// pSrcMean1 Pointer to the input and the first output mean
|
|
// vector [len].
|
|
// pSrcVar1 Pointer to the input and the first variance vector [len].
|
|
// pSrcMean2 Pointer to the second output mean vector [len].
|
|
// pSrcVar2 Pointer to the input and the second variance vector [len].
|
|
// len The number of elements in the mean and variance vectors.
|
|
// val The variance perturbation value.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcMean1, pSrcMean2,
|
|
// pSrcVar1, or pSrcVar2 pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsGaussianSplit_32f,(Ipp32f* pSrcMean1, Ipp32f* pSrcVar1,
|
|
Ipp32f* pSrcMean2, Ipp32f* pSrcVar2, int len, Ipp32f val))
|
|
|
|
IPPAPI(IppStatus, ippsGaussianSplit_64f,(Ipp64f* pSrcMean1, Ipp64f* pSrcVar1,
|
|
Ipp64f* pSrcMean2, Ipp64f* pSrcVar2, int len, Ipp64f val))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsGaussianMerge_32f
|
|
// Purpose: Merges two simple Gaussian probability
|
|
// distribution functions.
|
|
// Parameters:
|
|
// pSrcMean1 Pointer to the mean vector of the first Gaussian [len].
|
|
// pSrcVar1 Pointer to the variance vector of the first
|
|
// Gaussian [len].
|
|
// pSrcMean2 Pointer to the mean vector of the second Gaussian [len].
|
|
// pSrcVar2 Pointer to the variance vector of the second
|
|
// Gaussian [len].
|
|
// pDstMean Pointer to the mean vector of the merged Gaussian [len].
|
|
// pDstVar Pointer to the variance vector of the merged
|
|
// Gaussian [len].
|
|
// len The number of elements in the mean and variance vectors.
|
|
// pDstDet Pointer to the determinant of the merged Gaussian.
|
|
// wgt1 The first Gaussian weight.
|
|
// wgt2 The second Gaussian weight.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcMean1, pSrcMean2,
|
|
// pSrcVar1, pSrcVar2, pDstMean, pDstVar, or pDstDet
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsGaussianMerge_32f,(const Ipp32f* pSrcMean1,
|
|
const Ipp32f* pSrcVar1, const Ipp32f* pSrcMean2, const Ipp32f* pSrcVar2,
|
|
Ipp32f* pDstMean, Ipp32f* pDstVar, int len, Ipp32f* pDstDet, Ipp32f wgt1,
|
|
Ipp32f wgt2))
|
|
|
|
IPPAPI(IppStatus, ippsGaussianMerge_64f,(const Ipp64f* pSrcMean1,
|
|
const Ipp64f* pSrcVar1, const Ipp64f* pSrcMean2, const Ipp64f* pSrcVar2,
|
|
Ipp64f* pDstMean, Ipp64f* pDstVar, int len, Ipp64f* pDstDet, Ipp64f wgt1,
|
|
Ipp64f wgt2))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsEntropy_*
|
|
//
|
|
// Purpose: Calculate exponent of minus squared argument.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pResult Pointer to the destination enropy value.
|
|
// len Length of the input vector.
|
|
// srcShiftVal
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsLnNegArg Indicates a warning for input vector elements less than 0.
|
|
// Operation execution is aborted. The destination
|
|
// value NaN and for integer operations is 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsEntropy_32f, (const Ipp32f* pSrc, int len, Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsEntropy_16s32s_Sfs, (const Ipp16s* pSrc, int srcShiftVal,
|
|
int len, Ipp32s* pResult, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSinC_*
|
|
//
|
|
// Purpose: Calculate sine divided by argument.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input array [len].
|
|
// pSrcDst Pointer to the input and destination vector [len].
|
|
// pDst Pointer to the output array [len].
|
|
// len Number of elements in the input vector.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pSrcDst or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSinC_32f, (const Ipp32f* pSrc, Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsSinC_32f64f, (const Ipp32f* pSrc, Ipp64f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsSinC_64f, (const Ipp64f* pSrc, Ipp64f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsSinC_32f_I, (Ipp32f* pSrcDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsSinC_64f_I, (Ipp64f* pSrcDst, int len))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsExpNegSqr_*
|
|
//
|
|
// Purpose: Calculate exponent of minus squared argument.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input array [len].
|
|
// pSrcDst Pointer to the input and destination vector [len].
|
|
// pDst Pointer to the destination vector [len].
|
|
// len Length of the input and output vectors.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pSrcDst or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
// File: psexpns.c
|
|
*/
|
|
IPPAPI(IppStatus, ippsExpNegSqr_32f, (const Ipp32f* pSrc, Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsExpNegSqr_32f64f,(const Ipp32f* pSrc, Ipp64f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsExpNegSqr_64f, (const Ipp64f* pSrc, Ipp64f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsExpNegSqr_32f_I, (Ipp32f* pSrcDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsExpNegSqr_64f_I, (Ipp64f* pSrcDst, int len))
|
|
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: IppStatus ippsBhatDistSLog_*
|
|
// Purpose: Calculates the Bhattacharia distance between two Gaussians.
|
|
//
|
|
// Parameters:
|
|
// pSrcMean1 Pointer to the first mean vector [len].
|
|
// pSrcVar1 Pointer to the first variance vector [len].
|
|
// pSrcMean2 Pointer to the second mean vector [len].
|
|
// pSrcVar2 Pointer to the second variance vector [len].
|
|
// pResult Pointer to the result value.
|
|
// len Length of the input mean and variance vectors.
|
|
// sumLog1 Sum of the first Gaussian variance in the logarithmic
|
|
// representation.
|
|
// sumLog2 Sum of the second Gaussian variance in the logarithmic
|
|
// representation.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcMean1, pSrcVar1,
|
|
// pSrcMean2, pSrcVar2 or pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
// ippStsLnZeroArg Indicates a warning that a zero value was detected in
|
|
// the input vector. The execution is not aborted.
|
|
// The result value is set to -Inf if there is no negative
|
|
// element in the vector.
|
|
// ippStsLnNegArg Indicates a warning that negative values were detected
|
|
// in the input vector. The execution is not aborted.
|
|
// The result value is set to NaN.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsBhatDist_32f,(const Ipp32f* pSrcMean1,
|
|
const Ipp32f* pSrcVar1, const Ipp32f* pSrcMean2, const Ipp32f* pSrcVar2,
|
|
int len, Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsBhatDist_32f64f,(const Ipp32f* pSrcMean1,
|
|
const Ipp32f* pSrcVar1, const Ipp32f* pSrcMean2, const Ipp32f* pSrcVar2,
|
|
int len, Ipp64f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsBhatDistSLog_32f,(const Ipp32f* pSrcMean1,
|
|
const Ipp32f* pSrcVar1, const Ipp32f* pSrcMean2, const Ipp32f* pSrcVar2,
|
|
int len, Ipp32f* pResult, Ipp32f sumLog1, Ipp32f sumLog2))
|
|
|
|
IPPAPI(IppStatus, ippsBhatDistSLog_32f64f,(const Ipp32f* pSrcMean1,
|
|
const Ipp32f* pSrcVar1, const Ipp32f* pSrcMean2, const Ipp32f* pSrcVar2,
|
|
int len, Ipp64f* pResult, Ipp32f sumLog1, Ipp32f sumLog2))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsUpdateMean_*
|
|
// Purpose: Update the mean vector in the embedded EM
|
|
// training algorithm.
|
|
// Parameters:
|
|
// pMeanAcc Pointer to the mean accumulator [len].
|
|
// pMean Pointer to the mean vector [len].
|
|
// len The legth of the mean vector [len].
|
|
// meanOcc The occupation sum of the Gaussian mixture.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pMean or pMeanAcc
|
|
// pointer is null.
|
|
// ippStsZeroOcc Indicates an error when meanOcc is equal to 0
|
|
// ippStsNegOcc Indicates an error when meanOcc is less than 0
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsUpdateMean_32f, (const Ipp32f* pMeanAcc, Ipp32f* pMean,
|
|
int len, Ipp32f meanOcc))
|
|
|
|
IPPAPI(IppStatus, ippsUpdateMean_64f, (const Ipp64f* pMeanAcc, Ipp64f* pMean,
|
|
int len, Ipp64f meanOcc))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsUpdateVar_*
|
|
// Purpose: Updates the variance vector in the EM training
|
|
// algorithm.
|
|
// Parameters:
|
|
// pMeanAcc Pointer to the mean accumulator [len].
|
|
// pVarAcc Pointer to the variance accumulator [len].
|
|
// pVarFloor Pointer to the variance floor vector [len].
|
|
// pVar Pointer to the variance vector [len].
|
|
// len The legth of the mean and variance vectors [len].
|
|
// meanOcc The occupation sum of the Gaussian mixture.
|
|
// varOcc The square occupation sum of the variance mixture.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the or pMeanAcc or pVarAcc or pVar
|
|
// or pVarFloor pointer is null.
|
|
// ippStsZeroOcc Indicates an error when meanOcc or varOcc is equal to 0
|
|
// ippStsNegOcc Indicates an error when meanOcc and varOcc are less than 0
|
|
// ippStsResFloor Indicates a warning when all variances are floored.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsUpdateVar_32f, (const Ipp32f* pMeanAcc,
|
|
const Ipp32f* pVarAcc, const Ipp32f* pVarFloor, Ipp32f* pVar, int len,
|
|
Ipp32f meanOcc, Ipp32f varOcc))
|
|
IPPAPI(IppStatus, ippsUpdateVar_64f, (const Ipp64f* pMeanAcc,
|
|
const Ipp64f* pVarAcc, const Ipp64f* pVarFloor, Ipp64f* pVar, int len,
|
|
Ipp64f meanOcc, Ipp64f varOcc))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsUpdateWeight_*
|
|
// Purpose: Updates the weight values of Gaussian mixtures
|
|
// in the EM training algorithm.
|
|
// Parameters:
|
|
// pWgtAccm Pointer to the weight accumulator [len].
|
|
// pWgt Pointer to the weight vector [len].
|
|
// len Number of mixtures in the HMM state.
|
|
// pWgtSum Pointer to the output sum of weight values.
|
|
// wgtOcc The nominator of the weight update equation.
|
|
// wgtThresh The threshold for the weight values.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the or pWgtAcc or pWgt or pWgtSum
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
// ippStsZeroOcc Indicates an error when wgtOcc is equal to 0
|
|
// ippStsNegOcc Indicates an error when wgtOcc is less than 0
|
|
// ippStsResFloor Indicates a warning when all weights are floored.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsUpdateWeight_32f, (const Ipp32f* pWgtAcc, Ipp32f* pWgt,
|
|
int len, Ipp32f* pWgtSum, Ipp32f wgtOcc, Ipp32f wgtThresh))
|
|
|
|
IPPAPI(IppStatus, ippsUpdateWeight_64f, (const Ipp64f* pWgtAcc, Ipp64f* pWgt,
|
|
int len, Ipp64f* pWgtSum, Ipp64f wgtOcc, Ipp64f wgtThresh))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsUpdateGConst_*
|
|
// Purpose: Updates the fixed constant in the Gaussian output
|
|
// probability density function.
|
|
// Parameters:
|
|
// pVar Pointer to the variance vector [len].
|
|
// len Dimension of the variance vector.
|
|
// pDet Pointer to the result value.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the or pVar or pDet pointer
|
|
// is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
// ippStsLnZeroArg Indicates a warning for zero-valued input vector elements.
|
|
// Operation execution is not aborted. The result value is
|
|
// set to -Inf if there are no negative elements in the vector.
|
|
// ippStsLnNegArg Indicates a warning for negative input vector elements.
|
|
// Operation execution is not aborted. The result value is NaN.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsUpdateGConst_32f, (const Ipp32f* pVar, int len, Ipp32f* pDet))
|
|
|
|
IPPAPI(IppStatus, ippsUpdateGConst_64f, (const Ipp64f* pVar, int len, Ipp64f* pDet))
|
|
|
|
IPPAPI(IppStatus, ippsUpdateGConst_DirectVar_32f, (const Ipp32f* pVar, int len,
|
|
Ipp32f* pDet))
|
|
|
|
IPPAPI(IppStatus, ippsUpdateGConst_DirectVar_64f, (const Ipp64f* pVar, int len,
|
|
Ipp64f* pDet))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsOutProbPreCalc_*
|
|
// Purpose: Pre-calculates the part of Gaussian mixture output
|
|
// probability that is irrelevant to observation vectors.
|
|
// Parameters:
|
|
// pWeight Pointer to the Gaussian mixture weight vector [len].
|
|
// pGConst Pointer to the constant vector calculated from
|
|
// ippsUpdateGConst [len].
|
|
// pVal Pointer to the resulting vector [len].
|
|
// len Number of mixtures in the HMM state.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the or pWeight or pGConst or pVal
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsOutProbPreCalc_32f, (const Ipp32f* pWeight,
|
|
const Ipp32f* pGConst, Ipp32f* pVal, int len))
|
|
|
|
IPPAPI(IppStatus, ippsOutProbPreCalc_64f, (const Ipp64f* pWeight,
|
|
const Ipp64f* pGConst, Ipp64f* pVal, int len))
|
|
|
|
IPPAPI(IppStatus, ippsOutProbPreCalc_32f_I, (const Ipp32f* pWeight,
|
|
Ipp32f* pGConst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsOutProbPreCalc_64f_I, (const Ipp64f* pWeight,
|
|
Ipp64f* pGConst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsOutProbPreCalc_32s, (const Ipp32s* pWeight,
|
|
const Ipp32s* pGConst, Ipp32s* pVal, int len))
|
|
|
|
IPPAPI(IppStatus, ippsOutProbPreCalc_32s_I, (const Ipp32s* pWeight,
|
|
Ipp32s* pGConst, int len))
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDcsClustLAccumulate_*
|
|
// Purpose: Update the accumulators for calculating state-cluster
|
|
// likelihood in the desition-tree clustering algorithm.
|
|
// Parameters:
|
|
// pMean Pointer to the mean vector of the HMM state in the
|
|
// cluster [len]
|
|
// pVar Pointer to the variance vector of the HMM state in the
|
|
// cluster [len]
|
|
// pDstSum Pointer to the sum part of the accumulator [len]
|
|
// pDstSqr Pointer to the sqr part of the accumulator [len]
|
|
// len Length of the mean and variance vectors.
|
|
// occ Occupation count of the HMM state.
|
|
// Return:
|
|
// ippStsNoErr Idicates no error
|
|
// ippStsNullPtrErr Idicates an error when the pMean, pVar, pDstSum or
|
|
// pDstSqr pointer is null
|
|
// ippStsSizeErr Idicates an error when len is less than or equal to 0
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsDcsClustLAccumulate_32f, (const Ipp32f* pMean,
|
|
const Ipp32f* pVar, Ipp32f* pDstSum, Ipp32f* pDstSqr, int len, Ipp32f occ))
|
|
|
|
IPPAPI(IppStatus, ippsDcsClustLAccumulate_64f, (const Ipp64f* pMean,
|
|
const Ipp64f* pVar, Ipp64f* pDstSum, Ipp64f* pDstSqr, int len, Ipp64f occ))
|
|
|
|
IPPAPI(IppStatus, ippsDcsClustLAccumulate_DirectVar_32f, (const Ipp32f* pMean,
|
|
const Ipp32f* pVar, Ipp32f* pDstSum, Ipp32f* pDstSqr, int len, Ipp32f occ))
|
|
|
|
IPPAPI(IppStatus, ippsDcsClustLAccumulate_DirectVar_64f, (const Ipp64f* pMean,
|
|
const Ipp64f* pVar, Ipp64f* pDstSum, Ipp64f* pDstSqr, int len, Ipp64f occ))
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDcsClustLCompute_*
|
|
// Purpose: Calculate the likelihood of an HMM state cluster in the
|
|
// decision-tree state-clustering algorithm.
|
|
// Parameters:
|
|
// pSrcSum Pointer to the sum part of the accumulator [len]
|
|
// pSrcSqr Pointer to the sqr part of the accumulator [len]
|
|
// len Length of the mean and variance vectors.
|
|
// pDst Pointer to the resulting likelihood value
|
|
// occ Ocupation sum of the HMM state cluster
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Idicates no error
|
|
// ippStsNullPtrErr Idicates an error when the pSrcSum, pSrcSqr,
|
|
// pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0 or
|
|
// occ is less than or equal to 0.
|
|
// ippStsZeroOcc Indicates an error when occ is equal to 0
|
|
// ippStsNegOcc Indicates an error when occ is less than 0
|
|
// ippStsLnZeroArg Indicates a warning for zero-valued input vector elements.
|
|
// Operation execution is not aborted. The result value is
|
|
// set to -Inf if there are no negative elements in the
|
|
// vector.
|
|
// ippStsLnNegArg Indicates a warning for negative input vector elements.
|
|
// Operation execution is not aborted. The result value
|
|
// is set to NaN.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsDcsClustLCompute_32f64f, (const Ipp32f* pSrcSum,
|
|
const Ipp32f* pSrcSqr, int len, Ipp64f* pDst, Ipp32f occ))
|
|
|
|
IPPAPI(IppStatus, ippsDcsClustLCompute_64f, (const Ipp64f* pSrcSum,
|
|
const Ipp64f* pSrcSqr, int len, Ipp64f* pDst, Ipp64f occ))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Model Adaptation
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsAddMulColumn_64f_D2L
|
|
// Purpose: Adds a weighted matrix column to another column.
|
|
//
|
|
// Parameters:
|
|
// mSrcDst Pointer to the source and destination
|
|
// matrix [height][width].
|
|
// width The number of columns in the matrix mSrcDst.
|
|
// height The number of rows in the matrix mSrcDst.
|
|
// col1 The first number of the column.
|
|
// col2 The second number of the column.
|
|
// row1 The first number of the row.
|
|
// val The multiplier factor.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when when height, width
|
|
// is less than or equal to 0;
|
|
// or col1 or col2 is greater than or equal to width;
|
|
// or row1 is greater than or equal to height;
|
|
// or col1 or col2 or row1 is less than 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsAddMulColumn_64f_D2L, (Ipp64f** mSrcDst, int width,
|
|
int height, int col1, int col2, int row1, const Ipp64f val))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsAddMulRow_64f
|
|
// Purpose: Multiplies sourceh vector elements by a value
|
|
// and places them in the destination vector.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector [len]
|
|
// pDst Pointer to the result vector [len]
|
|
// len Length of source vector
|
|
// val The multiplying coefficient
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNoErr Indicates an error when the pSrc or pDst is null
|
|
// ippStsSizeErr Indicates an error when the len is less or equal 0
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsAddMulRow_64f, (const Ipp64f *pSrc, Ipp64f *pDst,
|
|
int len, const Ipp64f val))
|
|
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsQRTransColumn_64f_D2L
|
|
// Purpose: Calculates QR transformation.
|
|
//
|
|
// Parameters:
|
|
// mSrcDst Pointer to the source and destination
|
|
// matrix [height][width].
|
|
// width The number of columns in the matrix mSrcDst.
|
|
// height The number of rows in the matrix mSrcDst.
|
|
// col1 The first number of the column.
|
|
// col2 The second number of the column.
|
|
// val1 The first multiplier factor.
|
|
// val2 The second multiplier factor.
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, width
|
|
// is less than or equal to 0;
|
|
// or col1 or col2 is greater than or equal to width.
|
|
// or col1 or col2 is less than 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsQRTransColumn_64f_D2L, (Ipp64f** mSrcDst, int width,
|
|
int height, int col1, int col2, const Ipp64f val1, const Ipp64f val2))
|
|
|
|
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsDotProdColumn_64f_D2L
|
|
// Purpose: Calculates the dot product of two matrix columns.
|
|
//
|
|
// Parameters:
|
|
// mSrc Pointer to the source matrix [height][width].
|
|
// width The number of columns in the matrix mSrc.
|
|
// height The number of rows in the matrix mSrc.
|
|
// pSum Pointer to the value of the computed sum.
|
|
// col1 The first number of the column.
|
|
// col2 The second number of the column.
|
|
// row1 The first number of the row.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrcor pSum pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, width
|
|
// is less than or equal to 0;
|
|
// or row1 is greater than or equal to height;
|
|
// or col1 is greater than or equal to width;
|
|
// or row1 or col1 is less than 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsDotProdColumn_64f_D2L, (const Ipp64f** mSrc, int width,
|
|
int height, Ipp64f* pSum, int col1, int col2, int row1))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMulColumn_64f_D2L
|
|
// Purpose: Multiplies a matrix column by a value.
|
|
//
|
|
// Parameters:
|
|
// mSrcDst Pointer to the source and destination
|
|
// matrix [height][width].
|
|
// width The number of columns in the matrix mSrcDst.
|
|
// height The number of rows in the matrix mSrcDst.
|
|
// col1 The first number of the column.
|
|
// row1 The first number of the row.
|
|
// val The multiplier factor.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, width
|
|
// is less than or equal to 0;
|
|
// or row1 is greater than or equal to height;
|
|
// or col1 is greater than or equal to width;
|
|
// or row1 or col1 is less than 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsMulColumn_64f_D2L, (Ipp64f** mSrcDst, int width,
|
|
int height, int col1, int row1, const Ipp64f val))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumColumnAbs_64f_D2L
|
|
// Purpose: Sums absolute values of column elements.
|
|
//
|
|
// Parameters:
|
|
// mSrc Pointer to the source matrix [height][width].
|
|
// width The number of columns in the matrix mSrc.
|
|
// height The number of rows in the matrix mSrc.
|
|
// pSum Pointer to the value of the computed sum.
|
|
// col1 The first number of the column.
|
|
// row1 The first number of the row.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrc or pSum pointer is null.
|
|
// ippStsSizeErr Indicates an error when width, height
|
|
// is less than or equal to 0;
|
|
// or row1 is greater than or equal to height;
|
|
// or col1 is greater than or equal to width;
|
|
// or row1 or col1 is less than 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSumColumnAbs_64f_D2L, (const Ipp64f** mSrc, int width,
|
|
int height, Ipp64f* pSum, int col1, int row1))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumColumnSqr_64f_D2L
|
|
// Purpose: Multiplies matrix column elements by a value and
|
|
// sums their squares.
|
|
//
|
|
// Parameters:
|
|
// mSrcDst Pointer to the source matrix [height][width].
|
|
// width The number of columns in the matrix mSrcDst.
|
|
// height The number of rows in the matrix mSrcDst.
|
|
// pSum Pointer to the value of the computed sum.
|
|
// col1 The first number of the column.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mSrcDst or pSum
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when width, height
|
|
// is less than or equal to 0;
|
|
// or row1 is greater than or equal to height;
|
|
// or col1 is greater than or equal to width.
|
|
// or row1 or col1 is less than 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSumColumnSqr_64f_D2L, (Ipp64f** mSrcDst, int width,
|
|
int height, Ipp64f* pSum, int col1, int row1, const Ipp64f val))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumRowAbs_64f
|
|
// Purpose: Sums absolute values of vector elements.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the source vector [len].
|
|
// pSum Pointer to the value of the computed sum.
|
|
// len The number of elements in the source vector pSrc.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pSum pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSumRowAbs_64f, (const Ipp64f *pSrc, int len, Ipp64f *pSum))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSumRowSqr_64f
|
|
// Purpose: Multiplies vector elements by a value and sums
|
|
// their squares.
|
|
//
|
|
// Parameters:
|
|
// pSrcDst Pointer to the source vector [len].
|
|
// len The number of elements in the source vector pSrcDst.
|
|
// pSum Pointer to the value of the computed sum.
|
|
// val The multiplier factor.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcDst or pSum
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when lenis less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsSumRowSqr_64f, (Ipp64f *pSrcDst,
|
|
int len, Ipp64f *pSum, const Ipp64f val))
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSVD__*, ippsSVDSort__*
|
|
// Purpose: Performs Single Value Decomposition on a matrix.
|
|
//
|
|
// Parameters:
|
|
// pSrcA Pointer to the input vector A [height*step].
|
|
// pDstU Ppointer to the output vector U [height*step].
|
|
// pSrcDstA Pointer to the input matrix A and output
|
|
// matrix U [height*step].
|
|
// pDstV Pointer to the output vector V [width*step].
|
|
// mSrcA Pointer to the input matrix A [height][width].
|
|
// mDstU Pointer to the output matrix U [height][width].
|
|
// mSrcDstA Pointer to the input matrix A and output
|
|
// matrix U [height][width].
|
|
// pDstW Pointer to the output vector W [width].
|
|
// mDstV Pointer to the output matrix V [width][width].
|
|
// height Number of rows in the input matrix.
|
|
// width Number of columns in the input matrix.
|
|
// step Row step in pSrcA, pSrcDstA, and pDstV.
|
|
// nIter Number of iteration for diagonalization.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrcA, pSrcDstA, pDstV, mSrcA,
|
|
// mDstU, mSrcDstA, pDstW or mDstV pointer is null.
|
|
// ippStsSizeErr Indicates an error when heigh, width, step or nIter is less
|
|
// than or equal to 0 or width is greater than step;
|
|
// ippStsSVDCnvg Indicates an error when SVD algorithm was not converged for
|
|
// nIter iterations.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsSVD_64f_D2,(const Ipp64f* pSrcA, Ipp64f* pDstU, int height,
|
|
Ipp64f* pDstW, Ipp64f* pDstV, int width, int step, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVD_64f_D2_I,(Ipp64f* pSrcDstA, int height, Ipp64f* pDstW,
|
|
Ipp64f* pDstV, int width, int step, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVD_64f_D2L,(const Ipp64f** mSrcA, Ipp64f** mDstU, int height,
|
|
Ipp64f* pDstW, Ipp64f** mDstV, int width, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVD_64f_D2L_I,(Ipp64f** mSrcDstA, int height, Ipp64f* pDstW,
|
|
Ipp64f** mDstV, int width, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVDSort_64f_D2,(const Ipp64f* pSrcA, Ipp64f* pDstU, int height,
|
|
Ipp64f* pDstW, Ipp64f* pDstV, int width, int step, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVDSort_64f_D2_I,(Ipp64f* pSrcDstA, int height, Ipp64f* pDstW,
|
|
Ipp64f* pDstV, int width, int step, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVDSort_64f_D2L,(const Ipp64f** mSrcA, Ipp64f** mDstU, int height,
|
|
Ipp64f* pDstW, Ipp64f** mDstV, int width, int nIter))
|
|
|
|
IPPAPI(IppStatus, ippsSVDSort_64f_D2L_I,(Ipp64f** mSrcDstA, int height, Ipp64f* pDstW,
|
|
Ipp64f** mDstV, int width, int nIter))
|
|
|
|
|
|
/*///////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsWeightedSum_*
|
|
// Purpose: Calculates the weighted sums of two input vector elements.
|
|
// Parameters:
|
|
// pSrc1 Pointer to the first input vector [len].
|
|
// pSrc2 Pointer to the second input vector [len].
|
|
// pDst Pointer to the output vector [len]
|
|
// len The length of the input an output vectors.
|
|
// weight1 The first weight value.
|
|
// weight2 The second weight value.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc1, pSrc2 or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
// ippStsDivByZero Indicates a warning for zero-valued divisor vector
|
|
// element. Operation execution is not aborted. The value of
|
|
// the destination vector element in the floating-point operations:
|
|
// NaN For zero-valued dividend vector element.
|
|
// +Inf For positive dividend vector element.
|
|
// -Inf For negative dividend vector element.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsWeightedSum_16s, (const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, Ipp16s* pDst, int len, Ipp32f weight1,
|
|
Ipp32f weight2))
|
|
|
|
IPPAPI(IppStatus, ippsWeightedSum_32f, (const Ipp32f* pSrc1,
|
|
const Ipp32f* pSrc2, Ipp32f* pDst, int len, Ipp32f weight1,
|
|
Ipp32f weight2))
|
|
|
|
IPPAPI(IppStatus, ippsWeightedSum_64f, (const Ipp64f* pSrc1,
|
|
const Ipp64f* pSrc2, Ipp64f* pDst, int len, Ipp64f weight1,
|
|
Ipp64f weight2))
|
|
|
|
IPPAPI(IppStatus, ippsWeightedSumHalf_32f, (const Ipp32f* pSrc1,
|
|
const Ipp32f* pSrc2, Ipp32f* pDst, int len, Ipp32f weight1,
|
|
Ipp32f weight2))
|
|
|
|
IPPAPI(IppStatus, ippsWeightedSumHalf_64f, (const Ipp64f* pSrc1,
|
|
const Ipp64f* pSrc2, Ipp64f* pDst, int len, Ipp64f weight1,
|
|
Ipp64f weight2))
|
|
|
|
|
|
IPPAPI(IppStatus, ippsWeightedSumHalf_16s, (const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, Ipp16s* pDst, int len, Ipp32f weight1,
|
|
Ipp32f weight2))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Vector Quantization
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFormVector_*
|
|
// Purpose: Composes a vector from four element chunks.
|
|
// Parameters:
|
|
// pInd Pointer to the input vector of codebook indexes [nStream].
|
|
// mSrc Pointer to the vector of pointers to source lookup
|
|
// tables [nStream].
|
|
// pHeights Pointer to the vector of codebook lengths [nStream].
|
|
// pWidths Pointer to the vector of codebook entry lengths [nStream].
|
|
// pSteps Pointer to the vector of codebook row pSteps [nStream].
|
|
// nStream The number of codebooks.
|
|
// pDst Pointer to the output vector [len].
|
|
// len The length of the output vector.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the the pInd, mSrc, pHeights,
|
|
// pWidths, pSteps, pDst or mSrc[k].
|
|
// ippStsSizeErr Indicates an error when len , nStream, pHeights[k],
|
|
// pWidths[k] or pSteps[k] is less than or equal to 0 .
|
|
*/
|
|
IPPAPI(IppStatus, ippsFormVector_4i_8u16s, (const Ipp8u* pInd,
|
|
const Ipp16s** mSrc, const Ipp32s* pHeights, Ipp16s* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_4i_16s16s, (const Ipp16s* pInd,
|
|
const Ipp16s** mSrc, const Ipp32s* pHeights, Ipp16s* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_4i_8u32f, (const Ipp8u* pInd,
|
|
const Ipp32f** mSrc, const Ipp32s* pHeights, Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_4i_16s32f, (const Ipp16s* pInd,
|
|
const Ipp32f** mSrc, const Ipp32s* pHeights, Ipp32f* pDst, int len))
|
|
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_2i_8u16s, (const Ipp8u* pInd,
|
|
const Ipp16s** mSrc, const Ipp32s* pHeights, Ipp16s* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_2i_16s16s, (const Ipp16s* pInd,
|
|
const Ipp16s** mSrc, const Ipp32s* pHeights, Ipp16s* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_2i_8u32f, (const Ipp8u* pInd,
|
|
const Ipp32f** mSrc, const Ipp32s* pHeights, Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_2i_16s32f, (const Ipp16s* pInd,
|
|
const Ipp32f** mSrc, const Ipp32s* pHeights, Ipp32f* pDst, int len))
|
|
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_8u16s, (const Ipp8u* pInd,
|
|
const Ipp16s** mSrc, const Ipp32s* pHeights, const Ipp32s* pWidths,
|
|
const Ipp32s* pSteps, int nStream, Ipp16s* pDst))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_16s16s, (const Ipp16s* pInd,
|
|
const Ipp16s** mSrc, const Ipp32s* pHeights, const Ipp32s* pWidths,
|
|
const Ipp32s* pSteps, int nStream, Ipp16s* pDst))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_8u32f, (const Ipp8u* pInd,
|
|
const Ipp32f** mSrc, const Ipp32s* pHeights, const Ipp32s* pWidths,
|
|
const Ipp32s* pSteps, int nStream, Ipp32f * pDst))
|
|
|
|
IPPAPI(IppStatus, ippsFormVector_16s32f, (const Ipp16s* pInd,
|
|
const Ipp32f** mSrc, const Ipp32s* pHeights, const Ipp32s* pWidths,
|
|
const Ipp32s* pSteps, int nStream, Ipp32f * pDst))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCdbkInitAlloc_L2_*
|
|
// Purpose: Initializes the codebook structure.
|
|
//
|
|
// Parameters:
|
|
// pCdbk Pointer to the codebook structure to be created.
|
|
// pSrc Pointer to the source vector [height*step].
|
|
// width Length of input vectors.
|
|
// step Row step in pSrc.
|
|
// height Number of rows in pSrc.
|
|
// cdbkSize Required number of codevectors.
|
|
// hint One of the following values:
|
|
// IPP_CDBK_FULL The source data are treated as a codebook,
|
|
// height should be greater or equal to
|
|
// nCluster. The nearest codebook entry is
|
|
// found by a full search.
|
|
// IPP_CDBK_KMEANS_LONG LBG algorithm with splitting of the
|
|
// most extensional cluster is used for
|
|
// the codebook building. The nearest
|
|
// codebook entry is located through
|
|
// a logarithmical search.
|
|
// IPP_CDBK_KMEANS_NUM LBG algorithm with splitting of
|
|
// the most numerous clusters is used for
|
|
// the codebook building. The nearest
|
|
// codebook entry is located through
|
|
// a logarithmical search.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when width, step, or cdbkSize
|
|
// is less than or equal to 0;
|
|
// or cdbkSizeis greater than height;
|
|
// or width is greater than step;
|
|
// or cdbkSize is greater than 16383;
|
|
// or hintis equal to IPP_CDBK_FULL and cdbkSizeis not equal
|
|
// to height.
|
|
// ippStsCdbkFlagErr
|
|
// Indicates an error when the hint value is incorrect.
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsCdbkInitAlloc_L2_16s,(IppsCdbkState_16s** pCdbk,
|
|
const Ipp16s* pSrc, int width, int step, int height, int nCluster,
|
|
Ipp_Cdbk_Hint hint))
|
|
|
|
IPPAPI(IppStatus, ippsCdbkInitAlloc_L2_32f,(IppsCdbkState_32f** pCdbk,
|
|
const Ipp32f* pSrc, int width, int step, int height, int nCluster,
|
|
Ipp_Cdbk_Hint hint))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCdbkInitAlloc_WgtL2_*
|
|
// Purpose: Initializes the structure that contains the codebook
|
|
// and additional information to be used for fast search.
|
|
//
|
|
// Parameters:
|
|
// pCdbk Pointer to the codebook structure to be created.
|
|
// pSrc Pointer to the source vector [height*step].
|
|
// pWgt Pointer to the weights vector [width].
|
|
// width Length of input vectors.
|
|
// step Row step in pSrc.
|
|
// height Number of rows in pSrc.
|
|
// cdbkSize Required number of codevectors.
|
|
// hint One of the following values:
|
|
// IPP_CDBK_FULL The source data are treated as a codebook, height should
|
|
// be greater or equal to nCluster. The nearest codebook
|
|
// entry is found by a full search.
|
|
//
|
|
// IPP_CDBK_LBG_LONG
|
|
// LBG algorithm with splitting of the most extensious
|
|
// cluster is used for the codebook building. The nearest
|
|
// codebook entry is found by a logarithmical search.
|
|
//
|
|
// IPP_CDBK_LBG_NUM LBG algorithm with splitting of the most numerous
|
|
// clusters is used for the codebook building. The nearest
|
|
// codebook entry is found by a logarithmical search
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when width, step, height or cdbkSize
|
|
// is less than or equal to 0 or width is greater than step
|
|
// or cdbkSize is greater than 16383;
|
|
// ippStsCdbkFlagErr
|
|
// Indicates an error when the hint value is incorrect.
|
|
// ippStsMemAllocErr Indicates an error when no memory allocated.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsCdbkInitAlloc_WgtL2_32f,(IppsCdbkState_32f** pCdbk, const Ipp32f* pSrc,
|
|
const Ipp32f* pWgt, int width, int step, int height, int cdbkSize, Ipp_Cdbk_Hint hint))
|
|
|
|
IPPAPI(IppStatus, ippsCdbkInitAlloc_WgtL2_16s,(IppsCdbkState_16s** pCdbk, const Ipp16s* pSrc,
|
|
const Ipp16s* pWgt, int width, int step, int height, int cdbkSize, Ipp_Cdbk_Hint hint))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCdbkFree_*
|
|
// Purpose: Destroys the codebook structure a
|
|
//
|
|
// Parameters:
|
|
// pCdbk Pointer to the codebook structure.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pCdbk pointer is null.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsCdbkFree_16s,(IppsCdbkState_16s* pCdbk))
|
|
|
|
IPPAPI(IppStatus, ippsCdbkFree_32f,(IppsCdbkState_32f* pCdbk))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsGetCdbkSize_*
|
|
// Purpose: Retrieves the number of codevectors in the codebook.
|
|
//
|
|
// Parameters:
|
|
// pCdbk Pointer to the codebook structure.
|
|
// pNum Pointer to the result number of codevectors.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pCdbk or pNum pointer is null.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsGetCdbkSize_16s,(const IppsCdbkState_16s* pCdbk, int* pNum))
|
|
|
|
IPPAPI(IppStatus, ippsGetCdbkSize_32f,(const IppsCdbkState_32f* pCdbk, int* pNum))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsGetCodebook_*
|
|
// Purpose: Retrieves the number of codevectors in the codebook pCdbk.
|
|
//
|
|
// Parameters:
|
|
// pCdbk Pointer to the codebook structure.
|
|
// pDst Pointer to the destination vector for codevectors
|
|
// [pNum[0]* step].
|
|
// step Row step in the destination vector pDst.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pDst or pNum pointer is null.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsGetCodebook_16s,(const IppsCdbkState_16s* pCdbk,
|
|
Ipp16s* pDst, int step))
|
|
|
|
IPPAPI(IppStatus, ippsGetCodebook_32f,(const IppsCdbkState_32f* pCdbk,
|
|
Ipp32f* pDst, int step))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVQ_*
|
|
// Purpose: Quantizes the input vectors given a codebook.
|
|
//
|
|
// Parameters:
|
|
// pCdbk Pointer to the codebook structure.
|
|
// pSrc Pointer to the source vector [height*step].
|
|
// step Row step in pSrc.
|
|
// height Number of rows in pSrc.
|
|
// pIndx Pointer to the destination vector of closiest codevector
|
|
// numbers [height].
|
|
// pDist Pointer to the destination vector of distance to for
|
|
// closiest codevector [height].
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pCdbk, pSrc, pIndx or pDist
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when step is less than or equal to 0 or
|
|
// is step is less than width.
|
|
// ippStsSizeErr Indicates an error when width, step, height is less than
|
|
// or equal to 0 or width is greater than step;
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVQ_16s,(const Ipp16s* pSrc, int step, Ipp32s* pIndx,
|
|
int height, const IppsCdbkState_16s* pCdbk))
|
|
|
|
IPPAPI(IppStatus, ippsVQ_32f,(const Ipp32f* pSrc, int step, Ipp32s* pIndx,
|
|
int height, const IppsCdbkState_32f* pCdbk))
|
|
|
|
IPPAPI(IppStatus, ippsVQDist_16s32s_Sfs,(const Ipp16s* pSrc, int step,
|
|
Ipp32s* pIndx, Ipp32s* pDist, int height, const IppsCdbkState_16s* pCdbk,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVQDist_32f,(const Ipp32f* pSrc, int step, Ipp32s* pIndx,
|
|
Ipp32f* pDist, int height, const IppsCdbkState_32f* pCdbk))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSplitVQ_*
|
|
// Purpose: Quantizes a multiple-stream vector given the codebooks.
|
|
//
|
|
// Parameters:
|
|
// pCdbks Pointer to the vector of pointers to codebook
|
|
// structure [nStream].
|
|
// pSrc Pointer to the source vector [height*srcStep].
|
|
// pDst Pointer to the destination vector [height*dstStep].
|
|
// srcStep Row step in pSrc.
|
|
// dstStep Row step in pDst.
|
|
// dstBitStep Row step in pDst in bits
|
|
// height Number of rows in pSrc.
|
|
// nStream Number of chunks in input vectors.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pCdbk, pCdbk[k], pSrc or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when srcStep, dstStep, height or
|
|
// nStream is less than or equal to 0 or chunk length sum
|
|
// is greater than srcStep or nStream is greater than
|
|
// dstStep for functions with 16s or 8u output or number of
|
|
// bits to represent output indexes sequence is greater than
|
|
// dstStep for functions with 1u output or codebook size is
|
|
// greater than 256 for functions with 8u output.
|
|
//
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsSplitVQ_16s16s,(const Ipp16s* pSrc, int srcStep, Ipp16s* pDst,
|
|
int dstStep, int height,const IppsCdbkState_16s** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsSplitVQ_16s8u,(const Ipp16s* pSrc, int srcStep, Ipp8u* pDst,
|
|
int dstStep, int height,const IppsCdbkState_16s** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsSplitVQ_16s1u,(const Ipp16s* pSrc, int srcStep, Ipp8u* pDst,
|
|
int dstBitStep, int height,const IppsCdbkState_16s** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsSplitVQ_32f16s,(const Ipp32f* pSrc, int srcStep, Ipp16s* pDst,
|
|
int dstStep, int height,const IppsCdbkState_32f** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsSplitVQ_32f8u,(const Ipp32f* pSrc, int srcStep, Ipp8u* pDst,
|
|
int dstStep, int height,const IppsCdbkState_32f** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsSplitVQ_32f1u,(const Ipp32f* pSrc, int srcStep, Ipp8u* pDst,
|
|
int dstBitStep, int height,const IppsCdbkState_32f** pCdbks, int nStream))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFormVectorVQ_*
|
|
// Purpose: Constructs multiple-stream vectors from codebooks,
|
|
// given indexes.
|
|
//
|
|
// Parameters:
|
|
// pCdbks Pointer to the vector of pointers to codebook
|
|
// structure [nStream].
|
|
// pSrc Pointer to the source vector [height*srcStep].
|
|
// pDst Pointer to the destination vector [height*dstStep].
|
|
// srcStep Row step in pSrc.
|
|
// dstStep Row step in pDst.
|
|
// srcBitStep Row step in pSrc in bits
|
|
// height Number of rows in pSrc.
|
|
// nStream Number of chunks in input vectors.
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pCdbk, pCdbk[k], pSrc or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when srcStep, dstStep, height or
|
|
// nStream is less than or equal to 0 or codevector length
|
|
// sum is greater than dstStep or nStream is greater than
|
|
// srcStep for functions with 16s or 8u output or number of bits
|
|
// to represent output indexes sequence is greater than srcStep
|
|
// for functions with 1u output.
|
|
// Notes:
|
|
*/
|
|
IPPAPI(IppStatus, ippsFormVectorVQ_16s16s,(const Ipp16s* pSrc, int srcStep, Ipp16s* pDst,
|
|
int dstStep, int height, const IppsCdbkState_16s** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsFormVectorVQ_8u16s,(const Ipp8u* pSrc, int srcStep, Ipp16s* pDst,
|
|
int dstStep, int height, const IppsCdbkState_16s** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsFormVectorVQ_1u16s,(const Ipp8u* pSrc, int srcBitStep, Ipp16s* pDst,
|
|
int dstStep, int height, const IppsCdbkState_16s** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsFormVectorVQ_16s32f,(const Ipp16s* pSrc, int srcStep, Ipp32f* pDst,
|
|
int dstStep, int height, const IppsCdbkState_32f** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsFormVectorVQ_8u32f,(const Ipp8u* pSrc, int srcStep, Ipp32f* pDst,
|
|
int dstStep, int height, const IppsCdbkState_32f** pCdbks, int nStream))
|
|
|
|
IPPAPI(IppStatus, ippsFormVectorVQ_1u32f,(const Ipp8u* pSrc, int srcBitStep, Ipp32f* pDst,
|
|
int dstStep, int height, const IppsCdbkState_32f** pCdbks, int nStream))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: IppStatus ippsCdbkInit_L2_*
|
|
//
|
|
// Description: Initializes the structure that contains the codebook
|
|
//
|
|
//
|
|
// Input Arguments: pCdbk Pointer to the codebook structure to be initialized.
|
|
// pSrc Pointer to the source vector [height*step].
|
|
// width Length of input vectors.
|
|
// step Row step in pSrc.
|
|
// height Number of rows in pSrc.
|
|
// nCluster Required number of codevectors.
|
|
// hint One of the following values:
|
|
// IPP_CDBK_FULL The source data are treated as a
|
|
// codebook, height should be greater or equal to
|
|
// nCluster. The nearest codebook entry is found by
|
|
// a full search.
|
|
// IPP_CDBK_LBG_LONG Not supported
|
|
// IPP_CDBK_LBG_NUM Not supported
|
|
//
|
|
//
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsSizeErr - Bad Arguments.
|
|
// ippStsCdbkFlagErr - Hint not supported
|
|
//
|
|
// Notes: The primitive does not support tree-based codebook
|
|
*/
|
|
IPPAPI(IppStatus, ippsCdbkInit_L2_16s,(IppsCdbkState_16s* pCdbk,
|
|
const Ipp16s* pSrc,
|
|
int width,
|
|
int step,
|
|
int height,
|
|
int nCluster,
|
|
Ipp_Cdbk_Hint hint))
|
|
|
|
IPPAPI(IppStatus, ippsCdbkInit_L2_32f,(IppsCdbkState_32f* pCdbk,
|
|
const Ipp32f* pSrc,
|
|
int width,
|
|
int step,
|
|
int height,
|
|
int nCluster,
|
|
Ipp_Cdbk_Hint hint))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: IppStatus ippsCdbkGetSize_*
|
|
//
|
|
// Description: Computes the size in bytes required for the codebook table
|
|
//
|
|
//
|
|
// Input Arguments: width Length of input vectors.
|
|
// step Row step in pSrc.
|
|
// nCluster Required number of codevectors.
|
|
// hint One of the following values:
|
|
// IPP_CDBK_FULL The source data are treated as a
|
|
// codebook, height should be greater or equal to
|
|
// nCluster. The nearest codebook entry is found by
|
|
// a full search.
|
|
// IPP_CDBK_LBG_LONG Not supported
|
|
// IPP_CDBK_LBG_NUM Not supported
|
|
//
|
|
//
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsNullPtrErr - Indicates an error when pSize pointer is null.
|
|
// ippStsSizeErr - Indicates an error when width, step, height, or cdbkSize is less than
|
|
// or equal to 0; or width is greater than step; or cdbkSize is greater than 16383; or height is not equal to cdbkSize.
|
|
// ippStsCdbkFlagErr - Indicates an error when the hint value is incorrect or not supported.
|
|
//
|
|
//
|
|
// Notes:
|
|
*/
|
|
IPPAPI(IppStatus, ippsCdbkGetSize_16s,(int width,
|
|
int step,
|
|
int height,
|
|
int nCluster,
|
|
Ipp_Cdbk_Hint hint,
|
|
int* pSize))
|
|
|
|
IPPAPI(IppStatus, ippsCdbkGetSize_32f,(int width,
|
|
int step,
|
|
int height,
|
|
int nCluster,
|
|
Ipp_Cdbk_Hint hint,
|
|
int* pSize))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// TTS Arithmetic
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
|
|
/*/////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsReflectionToAbsTilt_* / ippsReflectionToTilt_*
|
|
// Purpose: Calculates tilt for rise/fall/connection parameters.
|
|
//
|
|
// Parameters:
|
|
// pSrc1 Pointer to the first input vector [len].
|
|
// pSrc2 Pointer to the second input vector [len].
|
|
// pDst Pointer to the destination vector [len].
|
|
// len Length of the input and output vectors.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc1, pSrc2 or pDst
|
|
// pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsDivByZero Indicates a warning for zero-valued divisor vector
|
|
// element. Operation execution is not aborted. The value of
|
|
// the destination vector element in the floating-point
|
|
// operations:
|
|
// NaN For zero-valued dividend vector element.
|
|
// +Inf For positive dividend vector element.
|
|
// -Inf For negative dividend vector
|
|
// The value of the destination vector element in the
|
|
// integer operations:
|
|
// IPP_MAX_16S For positive dividend vector element.
|
|
// IPP_MIN_16S For negative dividend vector
|
|
// Notes:
|
|
// The function ippsReflectionToAbsTilt converts rise and fall
|
|
// coefficients to absolute tilt.
|
|
// The function ippsReflectionToTilt converts rise and fall
|
|
// coefficients to tilt.
|
|
*/
|
|
IPPAPI(IppStatus, ippsReflectionToAbsTilt_16s_Sfs, (const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, Ipp16s* pDst, int len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToAbsTilt_32f, (const Ipp32f* pSrc1,
|
|
const Ipp32f* pSrc2, Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToTilt_16s_Sfs, (const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, Ipp16s* pDst, int len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsReflectionToTilt_32f, (const Ipp32f* pSrc1,
|
|
const Ipp32f* pSrc2, Ipp32f* pDst, int len))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussSingle_*
|
|
// Purpose: Calculates the observation probability for a
|
|
// single Gaussian with an observation vector.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// pMean Pointer to the mean vector [len].
|
|
// pVar Pointer to the variance vector [len].
|
|
// pBlockVar Pointer to the block diagonal variance matrix.
|
|
// len Number of elements in the input, mean, and variance
|
|
// vectors.
|
|
// pResult Pointer to the result value.
|
|
// val Gaussian constant.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar, or
|
|
// pResult or pBlockVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_Low_16s32s_Sfs,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int len, Ipp32s* pResult,
|
|
Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_LowScaled_16s32f,(const Ipp16s* pSrc, const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int len, Ipp32f* pResult, Ipp32f val, int scaleFactor))
|
|
|
|
/*
|
|
//Case 3: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVarLow_16s32s_Sfs,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int len, Ipp32s* pResult, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussSingle_IdVarLowScaled_16s32f,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int len, Ipp32f* pResult, Ipp32f val, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGauss_*
|
|
// Purpose: Calculates the observation probability for a single
|
|
// Gaussian with multiple observation vectors.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][ width].
|
|
// step The row step in pSrc.
|
|
// pMean Pointer to the mean vector [width].
|
|
// pVar Pointer to the variance vector [width].
|
|
// width Length of the mean and variance vectors.
|
|
// pDst Pointer to the result value [height].
|
|
// pSrcDst Pointer to the input and output vector [height].
|
|
// height The number of rows in the input matrix and the length of
|
|
// the result vector pDst.
|
|
// val Gaussian constant.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pDst,or mSrc pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGauss_Low_16s32s_D2Sfs, (const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* pDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_Low_16s32s_D2LSfs, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* pDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_LowScaled_16s32f_D2, (const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_LowScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVarLow_16s32s_D2Sfs,(const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32s* pDst, int height,
|
|
Ipp32s val,int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVarLowScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32f* pDst, int height,
|
|
Ipp32f val,int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVarLow_16s32s_D2LSfs,(const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32s* pDst, int height, Ipp32s val,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGauss_IdVarLowScaled_16s32f_D2L,(const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32f* pDst, int height, Ipp32f val,
|
|
int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMultiMix_*
|
|
// Purpose: Calculates the observation probability for
|
|
// multiple Gaussian mixture components.
|
|
//
|
|
// Parameters:
|
|
// pMean Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// pSrcDst Pointer to the input additive values and
|
|
// the result vector [height].
|
|
// step The row step in pMean.
|
|
// pSrc Pointer to the input vector [width].
|
|
// height The number of rows in input matrices and the length of
|
|
// the result vector pSrcDst.
|
|
// width The length of the input matrices row and the vector pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst, mMean, or mVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when heightor width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_Low_16s32s_D2Sfs, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
Ipp32s* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_Low_16s32s_D2LSfs, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, Ipp32s* pSrcDst,
|
|
int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_LowScaled_16s32f_D2, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMultiMix_LowScaled_16s32f_D2L, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, Ipp32f* pSrcDst,
|
|
int height, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMax_*_D2
|
|
// Purpose: Computes maximum value of a vector dst and
|
|
// logarithms of the Gaussian probability distribution function.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// step The row step in pSrc.
|
|
// pMean Pointer to the mean vector [width].
|
|
// pVar Pointer to the variance vector [width].
|
|
// width The length of the input matrix row, mean,
|
|
// and variance vectors.
|
|
// pSrcDst Pointer to the input and output vector [height].
|
|
// height The number of rows in the input matrix and the length of
|
|
// the result vector pDst.
|
|
// val The value to add to each distance.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMax_Low_16s32s_D2Sfs, (const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
Ipp32s* pSrcDst, int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_Low_16s32s_D2LSfs, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32s* pDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_LowScaled_16s32f_D2, (const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
Ipp32f* pSrcDst, int height, Ipp32f val, int scaleFacto))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_LowScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pDst,
|
|
int height, Ipp32f val, int scaleFacto))
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVarLow_16s32s_D2Sfs, (const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32s* pSrcDst,
|
|
int height, Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVarLow_16s32s_D2LSfs, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32s* pSrcDst, int height,
|
|
Ipp32s val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVarLowScaled_16s32f_D2, (const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMax_IdVarLowScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32f* pSrcDst, int height,
|
|
Ipp32f val, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMaxMultiMix_*_*
|
|
// Purpose: Computes the maximum of the Gaussian probability
|
|
// distribution function.
|
|
// Parameters:
|
|
// pMean Pointer to the mean vector of length [height*step].
|
|
// pVar Pointer to the variance vector of length [height*step].
|
|
// mMean Pointer to the mean matrix of size [height][width].
|
|
// mVar Pointer to the mean matrix of size [height][width].
|
|
// pVal Pointer to the input vector of Maxitive values [height].
|
|
// pSrcDst Pointer to the input and output vector of length [height].
|
|
// step Row step in pMean and pVar.
|
|
// pSrc Pointer to theinput vector of length[width].
|
|
// height Number of rows in input matrices and the length of
|
|
// the result vector pSrcDst.
|
|
// width Length of the input matrices row and the vector pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst or mMean or mVar or pVal pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_LowScaled_16s32f_D2, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc,int width,
|
|
const Ipp32f* pVal, Ipp32f* pSrcDst,int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_LowScaled_16s32f_D2L, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, const Ipp32f* pVal,
|
|
Ipp32f* pSrcDst,int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_Low_16s32s_D2Sfs, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
const Ipp32s* pVal, Ipp32s* pSrcDst,int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMaxMultiMix_Low_16s32s_D2LSfs, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, const Ipp32s* pVal,
|
|
Ipp32s* pSrcDst,int height, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussAdd_32f_D2
|
|
// Purpose: Calculates the likelihood probability for multiple
|
|
// observation vectors.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the first input vector of length [width*height]
|
|
// step Row step in pSrc.
|
|
// pMean Pointer to the mean vector of length [width]
|
|
// pVar Pointer to the variance vector of length [width]
|
|
// width Length of the mean, and variance vectors.
|
|
// pSrcDst Pointer to input vector and output vector [height]
|
|
// height Length of the input and output vector pSrcDst
|
|
// val Value to add to each distance.
|
|
//
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean,pVar,
|
|
// pSrcDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when width or height
|
|
// is less than or equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
*/
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_LowScaled_16s32f_D2,(const Ipp16s* pSrc, int step,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width,
|
|
Ipp32f* pSrcDst, int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_LowScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVarLowScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
int step, const Ipp16s* pMean, int width, Ipp32f* pSrcDst,
|
|
int height, Ipp32f val, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAdd_IdVarLowScaled_16s32f_D2L,(const Ipp16s** mSrc,
|
|
const Ipp16s* pMean, int width, Ipp32f* pSrcDst, int height, Ipp32f val,
|
|
int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussAddMultiMix_*_*
|
|
// Purpose: Calculates the likelihood probability for multiple
|
|
// Gaussian mixture components.
|
|
//
|
|
// Parameters:
|
|
// pMean Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// pVal Pointer to the input vector of additive values [height].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// pSrcDst Pointer to the input and output vector of length [height].
|
|
// step The row step in pMean.
|
|
// pSrc Pointer to the input vector [width].
|
|
// height The number of rows in input matrices and the length of
|
|
// the result vector pSrcDst.
|
|
// width The length of the input matrices row and the vector pSrc.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMean, pVar,
|
|
// pSrcDst, mMean, or mVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when heightor width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_LowScaled_16s32f_D2, (const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int step, const Ipp16s* pSrc, int width,
|
|
const Ipp32f* pVal, Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussAddMultiMix_LowScaled_16s32f_D2L, (const Ipp16s** mMean,
|
|
const Ipp16s** mVar, const Ipp16s* pSrc, int width, const Ipp32f* pVal,
|
|
Ipp32f* pSrcDst, int height, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: LogGaussMixture_*
|
|
// Purpose: Calculates the likelihood probability for the Gaussian mixture
|
|
//
|
|
// Parameters:
|
|
// pMean Pointer to the variance vector [height*step].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// pVar Pointer to the variance vector [height*step].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// pVal Pointer to the weight constant vector [height]..
|
|
// pSrc Pointer to the input vector [width].
|
|
// pResult Pointer to the output mixture value.
|
|
// step The row step in pMean and pVar.
|
|
// height Number of Gaussian mixture components.
|
|
// width Length of the mean and variance matrices rows and pSrc vector.
|
|
// scaleFactor
|
|
//
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the mMean, mVar, pMean, pVar, pVal or
|
|
// pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when height, step or width is less than or
|
|
// equal to 0.
|
|
// ippStsStrideErr Indicates an error when width > step.
|
|
//
|
|
*/
|
|
/*
|
|
//Case 1: Operation for the inverse diagonal covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_Scaled_16s32f_D2,(const Ipp16s* pSrc, const Ipp16s* pMean,
|
|
const Ipp16s* pVar, int height, int step, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_Scaled_16s32f_D2L,(const Ipp16s* pSrc, const Ipp16s** mMean,
|
|
const Ipp16s** mVar, int height, int width, const Ipp32f* pVal, Ipp32f* pResult,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_LowScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int height, int step, int width,
|
|
const Ipp32f* pVal, Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_LowScaled_16s32f_D2L,(const Ipp16s* pSrc,
|
|
const Ipp16s** mMean, const Ipp16s** mVar, int height, int width,
|
|
const Ipp32f* pVal, Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_32f_D2,(const Ipp32f* pSrc, const Ipp32f* pMean,
|
|
const Ipp32f* pVar, int height, int step, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_32f_D2L,(const Ipp32f* pSrc, const Ipp32f** mMean,
|
|
const Ipp32f** mVar, int height, int width, const Ipp32f* pVal, Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_64f_D2,(const Ipp64f* pSrc, const Ipp64f* pMean,
|
|
const Ipp64f* pVar, int height, int step, int width, const Ipp64f* pVal,
|
|
Ipp64f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_64f_D2L,(const Ipp64f* pSrc, const Ipp64f** mMean,
|
|
const Ipp64f** mVar, int height, int width, const Ipp64f* pVal, Ipp64f* pResult))
|
|
|
|
/*
|
|
//Case 2: Operation for the identity covariance matrix
|
|
*/
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVarScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int height, int step, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVarScaled_16s32f_D2L,(const Ipp16s* pSrc,
|
|
const Ipp16s** mMean, int height, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVarLowScaled_16s32f_D2,(const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int height, int step, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVarLowScaled_16s32f_D2L,(const Ipp16s* pSrc,
|
|
const Ipp16s** mMean, int height, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVar_32f_D2,(const Ipp32f* pSrc,
|
|
const Ipp32f* pMean, int height, int step, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVar_32f_D2L,(const Ipp32f* pSrc,
|
|
const Ipp32f** mMean, int height, int width, const Ipp32f* pVal,
|
|
Ipp32f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVar_64f_D2,(const Ipp64f* pSrc,
|
|
const Ipp64f* pMean, int height, int step, int width, const Ipp64f* pVal,
|
|
Ipp64f* pResult))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_IdVar_64f_D2L,(const Ipp64f* pSrc,
|
|
const Ipp64f** mMean, int height, int width, const Ipp64f* pVal,
|
|
Ipp64f* pResult))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogSum_*
|
|
// Purpose: Logarithmically sums vector elements.
|
|
// Parameters:
|
|
// pSrc The first input vector [len].
|
|
// pResult Pointer to the result value.
|
|
// len The number of elements in the input and output vectors.
|
|
// hint Recommends to use a specific code for the
|
|
// Logarithmically Sums.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus,ippsLogSum_64f,(const Ipp64f* pSrc, Ipp64f* pResult, int len,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus,ippsLogSum_32f,(const Ipp32f* pSrc, Ipp32f* pResult, int len,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus,ippsLogSum_32s_Sfs,(const Ipp32s* pSrc, Ipp32s* pResult, int len,
|
|
int scaleFactor, IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus,ippsLogSum_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pResult, int len,
|
|
int scaleFactor, IppHintAlgorithm hint))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsWeightedMeanColumn_*_*
|
|
// Purpose: Computes the weighted mean values for the column elements.
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, mSrc, pWgt, or pDstMean pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than or equal to 0.
|
|
// IppStsStrideErr Indicates an error when step is less than width.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// pWgt Pointer to the weights vector [height].
|
|
// height Number of rows in the input matrix.
|
|
// step Row step in the input vector (measured in pSrc elements).
|
|
// pDstMean Pointer to the output mean vector [width].
|
|
// width Number of columns in the input matrix, and also the length of the output mean vector pDstMean.
|
|
// Notes:
|
|
*/
|
|
|
|
|
|
IPPAPI(IppStatus, ippsWeightedMeanColumn_32f_D2,(const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pWgt, int height, Ipp32f* pDstMean, int width))
|
|
IPPAPI(IppStatus, ippsWeightedMeanColumn_32f_D2L,(const Ipp32f** mSrc,
|
|
const Ipp32f* pWgt, int height, Ipp32f* pDstMean, int width))
|
|
IPPAPI(IppStatus, ippsWeightedMeanColumn_64f_D2,(const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pWgt, int height, Ipp64f* pDstMean, int width))
|
|
IPPAPI(IppStatus, ippsWeightedMeanColumn_64f_D2L,(const Ipp64f** mSrc,
|
|
const Ipp64f* pWgt, int height, Ipp64f* pDstMean, int width))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsWeightedVarColumn_*_*
|
|
// Purpose: Computes the weighted variances values for the column elements.
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, mSrc, pWgt, pSrcMean,
|
|
// or pDstVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when step is less than width.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// pWgt Pointer to the weights vector [height].
|
|
// height Number of rows in the input matrix.
|
|
// step Row step in the input vector (measured in pSrc elements).
|
|
// pSrcMean Pointer to the input mean vector [width].
|
|
// pDstVar Pointer to the output variance vector [width].
|
|
// width Number of columns in the input matrix, and also the length
|
|
// of the input mean vector pSrcMean and the output variance vector pDstVar.
|
|
*/
|
|
|
|
|
|
IPPAPI(IppStatus, ippsWeightedVarColumn_32f_D2,(const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pWgt, int height, const Ipp32f* pSrcMean,
|
|
Ipp32f* pDstVar, int width))
|
|
IPPAPI(IppStatus, ippsWeightedVarColumn_32f_D2L,(const Ipp32f** mSrc,
|
|
const Ipp32f* pWgt, int height, const Ipp32f* pSrcMean,
|
|
Ipp32f* pDstVar, int width))
|
|
IPPAPI(IppStatus, ippsWeightedVarColumn_64f_D2,(const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pWgt, int height, const Ipp64f* pSrcMean,
|
|
Ipp64f* pDstVar, int width))
|
|
IPPAPI(IppStatus, ippsWeightedVarColumn_64f_D2L,(const Ipp64f** mSrc,
|
|
const Ipp64f* pWgt, int height, const Ipp64f* pSrcMean,
|
|
Ipp64f* pDstVar,int width))
|
|
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsWeightedMeanVarColumn_*_*
|
|
// Purpose: Computes the weighted mean variances values for the column elements.
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, mSrc, pWgt, pDstMean,
|
|
// or pDstVar pointer is null.
|
|
// ippStsSizeErr Indicates an error when height or width is less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when step is less than width.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [height*step].
|
|
// mSrc Pointer to the input matrix [height][width].
|
|
// pWgt Pointer to the weights vector [height].
|
|
// height Number of rows in the input matrix.
|
|
// step Row step in the input vector (measured in pSrc elements).
|
|
// pDstMean Pointer to the output mean vector [width].
|
|
// pDstVar Pointer to the output variance vector [width].
|
|
// width Number of columns in the input matrix, and also the length of the output mean vector pSrcMean and the output variance vector pDstVar.
|
|
*/
|
|
|
|
|
|
IPPAPI(IppStatus, ippsWeightedMeanVarColumn_32f_D2,(const Ipp32f* pSrc, int step,
|
|
const Ipp32f* pWgt, int height, Ipp32f* pDstMean, Ipp32f* pDstVar, int width))
|
|
IPPAPI(IppStatus, ippsWeightedMeanVarColumn_32f_D2L,(const Ipp32f** mSrc,
|
|
const Ipp32f* pWgt, int height, Ipp32f* pDstMean, Ipp32f* pDstVar, int width))
|
|
IPPAPI(IppStatus, ippsWeightedMeanVarColumn_64f_D2,(const Ipp64f* pSrc, int step,
|
|
const Ipp64f* pWgt, int height, Ipp64f* pDstMean, Ipp64f* pDstVar, int width))
|
|
IPPAPI(IppStatus, ippsWeightedMeanVarColumn_64f_D2L,(const Ipp64f** mSrc,
|
|
const Ipp64f* pWgt, int height, Ipp64f* pDstMean, Ipp64f* pDstVar, int width))
|
|
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCrossCorrCoeffDecim
|
|
// Purpose: Calculate vector of cross correlation coefficients with decimation.
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc1, pSrc2, or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when val is less than 0.
|
|
// Parameters:
|
|
// pSrc1 Pointer to the first input vector [maxLen].
|
|
// pSrc2 Pointer to the second input vector [maxLen].
|
|
// pDst Pointer to the output vector [(maxLen-minLen+dec-1)/dec].
|
|
// maxLen Maximal length of cross correlation.
|
|
// minLen Minimal length of cross correlation.
|
|
// dec Decimation step.
|
|
*/
|
|
IPPAPI(IppStatus, ippsCrossCorrCoeffDecim_16s32f,(const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, int maxLen, int minLen, Ipp32f* pDst, int dec))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCrossCorrCoeff
|
|
// Purpose: Calculate cross correlation coefficient.
|
|
// Context:
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc1, pSrc2, or pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when val is less than 0.
|
|
// Parameters:
|
|
// pSrc1 Pointer to the first input vector [len].
|
|
// pSrc2 Pointer to the second input vector [len].
|
|
// len Length of the input vectors.
|
|
// pResult Pointer to the result cross correlation coefficient value.
|
|
// val First vector length value.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsCrossCorrCoeff_16s32f,(const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, int len, Ipp32f* pResult))
|
|
IPPAPI(IppStatus, ippsCrossCorrCoeffPartial_16s32f,(const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, int len, Ipp32f val, Ipp32f* pResult))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsCrossCorrCoeffInterpolation
|
|
// Purpose: Calculate cross correlation coefficient.
|
|
// Context:
|
|
// Returns:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc1, pSrc2, pBeta or pResult pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsStrideErr Indicates an error when srcStep or dstStep is less than width.
|
|
// Parameters:
|
|
// pSrc1 Pointer to the first input vector [len].
|
|
// pSrc2 Pointer to the second input vector [len+1].
|
|
// len Length of the input vectors.
|
|
// pResult Pointer to the result cross correlation coefficient value.
|
|
// pBeta Pointer to the result value of fractional part of the pitch period.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsCrossCorrCoeffInterpolation_16s32f,(const Ipp16s* pSrc1,
|
|
const Ipp16s* pSrc2, int len, Ipp32f* pBeta, Ipp32f* pResult))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsBuildSignTable_8u1u
|
|
// Purpose: Fills sign table for Gaussian mixture calculation.
|
|
//
|
|
// Parameters:
|
|
// pIndx Pointer to the cluster indexes vector ([frames*num] or sum of pNum elements).
|
|
// num Number of clusters for each input vector.
|
|
// mShortlist Pointer to the shortlist matrix [clust*width] (in bytes).
|
|
// clust Number of rows in shortlist vector (equal to the codebook size).
|
|
// width Row length in shortlist matrix in bytes.
|
|
// shift First element displacement in shortlist vector rows (in bits).
|
|
// pSign Pointer to the output vector of Gaussian calculation
|
|
// signs [frames*(comps+7)/8] (in bytes).
|
|
// frames Number of input vectors (rows in pSign vector).
|
|
// comps Number of Gaussian mixture components (bit columns in pSign vector).
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pIndx, pSign, mShortlist or pNum is NULL.
|
|
// ippStsSizeErr Indicates an error when clust, width, frames, comps, num or one
|
|
// of pNum vector elements is less than or equal to 0 or when
|
|
// shift is less than 0.
|
|
// ippStsStrideErr Indicates an error when width is less than (shift+height+7)/8.
|
|
// ippStsBadArgErr Indicates an error when one of pIndx vector elements is
|
|
// less than 0 or greater than or equal to clust.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsBuildSignTable_8u1u, (const Ipp32s* pIndx, int num, const Ipp8u** mShortlist,
|
|
int clust, int width, int shift, Ipp8u* pSign, int frames, int comps))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsBuildSignTable_Var_8u1u
|
|
// Purpose: Fills sign table for Gaussian mixture calculation.
|
|
//
|
|
// Parameters:
|
|
// pIndx Pointer to the cluster indexes vector ([frames*num] or sum of pNum elements).
|
|
// pNum Number of clusters vector [frames].
|
|
// mShortlist Pointer to the shortlist matrix [clust*width] (in bytes).
|
|
// clust Number of rows in shortlist vector (equal to the codebook size).
|
|
// width Row length in shortlist matrix in bytes.
|
|
// shift First element displacement in shortlist vector rows (in bits).
|
|
// pSign Pointer to the output vector of Gaussian calculation
|
|
// signs [frames*(comps+7)/8] (in bytes).
|
|
// frames Number of input vectors (rows in pSign vector).
|
|
// comps Number of Gaussian mixture components (bit columns in pSign vector).
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pIndx, pSign, mShortlist or pNum is NULL.
|
|
// ippStsSizeErr Indicates an error when clust, width, frames, comps, num or one
|
|
// of pNum vector elements is less than or equal to 0 or when
|
|
// shift is less than 0.
|
|
// ippStsStrideErr Indicates an error when width is less than (shift+height+7)/8.
|
|
// ippStsBadArgErr Indicates an error when one of pIndx vector elements is
|
|
// less than 0 or greater than or equal to clust.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsBuildSignTable_Var_8u1u, (const Ipp32s* pIndx, const int* pNum,
|
|
const Ipp8u** mShortlist, int clust, int width, int shift, Ipp8u* pSign,
|
|
int frames, int comps))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMixture_Select*_*_D2
|
|
// Purpose: Calculates the likelihood probability for the Gaussian
|
|
// mixture using Gaussian selection.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector
|
|
// pMean Pointer to the mean vector
|
|
// pVar Pointer to the variance vector
|
|
// step Row step in mean, variance and input vectors (in pMean elements)
|
|
// width Length of the mean, variance and input matrix rows
|
|
// pVal Pointer to the vector of weight constants
|
|
// pSign Pointer to the vector of Gaussian calculation
|
|
// signs [frames*(height+7)/8] (in bytes).
|
|
// height Number of Gaussian mixture components
|
|
// pResult Pointer to the vector of output mixture values
|
|
// frames Number of input vectors; also the length of pSign row
|
|
// none Result value if no Gaussian is calculated
|
|
// scaleFactor Scaling factor for intermediate sums.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pMean, pVar, pSign, pVal
|
|
// or pResult is NULL.
|
|
// ippStsSizeErr Indicates an error when width, height or frames less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when step is less than width.
|
|
// ippStsSizeErr Indicates an error when width, height, frames less than
|
|
// or equal to 0
|
|
// ippStsStrideErr Indicates an error when step is less than width .
|
|
// ippStsNoGaussian Indicates a warning when no Gaussian is calculated for
|
|
// one of input vectors.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_Select_32f_D2, (const Ipp32f* pSrc, const Ipp32f* pMean,
|
|
const Ipp32f* pVar,/* const Ipp32f* Det,*/ int step, int width, const Ipp32f* pVal,
|
|
const Ipp8u* pSign, int height, Ipp32f* pResult, int frames, Ipp32f none))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_SelectScaled_16s32f_D2, (const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, const Ipp16s* pVar, int step, int width, const Ipp32f* pVal,
|
|
const Ipp8u* pSign, int height, Ipp32f* pResult, int frames, Ipp32f none, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMixture_Select*_*_D2L
|
|
// Purpose: Calculates the likelihood probability for the Gaussian
|
|
// mixture using Gaussian selection.
|
|
//
|
|
// Parameters:
|
|
// mSrc Pointer to the input matrix [frames][width].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// mVar Pointer to the variance matrix [height][width].
|
|
// width Length of the mean, variance and input matrix rows
|
|
// pVal Pointer to the vector of weight constants
|
|
// pSign Pointer to the vector of Gaussian calculation
|
|
// signs [frames*(height+7)/8] (in bytes).
|
|
// height Number of Gaussian mixture components
|
|
// pResult Pointer to the vector of output mixture values
|
|
// frames Number of input vectors; also the length of pSign row
|
|
// none Result value if no Gaussian is calculated
|
|
// scaleFactor Scaling factor for intermediate sums.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when mSrc, mMean, mVar, pSign, pVal
|
|
// or pResult is NULL.
|
|
// ippStsSizeErr Indicates an error when width, height or frames less than
|
|
// or equal to 0.
|
|
// ippStsSizeErr Indicates an error when width, height, frames less than
|
|
// or equal to 0
|
|
// ippStsNoGaussian Indicates a warning when no Gaussian is calculated for
|
|
// one of input vectors.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_Select_32f_D2L,(const Ipp32f** mSrc, const Ipp32f** mMean,
|
|
const Ipp32f** mVar, int width, const Ipp32f* pVal, const Ipp8u* pSign, int height,
|
|
Ipp32f* pResult, int frames, Ipp32f none))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_SelectScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s** mMean, const Ipp16s** mVar, int width, const Ipp32f* pVal,
|
|
const Ipp8u* pSign, int height, Ipp32f* pResult, int frames, Ipp32f none, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMixture_SelectIdVar*_*_D2
|
|
// Purpose: Calculates the likelihood probability for the Gaussian
|
|
// mixture using Gaussian selection.
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector
|
|
// pMean Pointer to the mean vector
|
|
// step Row step in mean, variance and input vectors (in pMean elements)
|
|
// width Length of the mean, variance and input matrix rows
|
|
// pVal Pointer to the vector of weight constants
|
|
// pSign Pointer to the vector of Gaussian calculation
|
|
// signs [frames*(height+7)/8] (in bytes).
|
|
// height Number of Gaussian mixture components
|
|
// pResult Pointer to the vector of output mixture values
|
|
// frames Number of input vectors; also the length of pSign row
|
|
// none Result value if no Gaussian is calculated
|
|
// scaleFactor Scaling factor for intermediate sums.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pMean, pSign, pVal
|
|
// or pResult is NULL.
|
|
// ippStsSizeErr Indicates an error when width, height or frames less than
|
|
// or equal to 0.
|
|
// ippStsStrideErr Indicates an error when step is less than width.
|
|
// ippStsSizeErr Indicates an error when width, height, frames less than
|
|
// or equal to 0
|
|
// ippStsStrideErr Indicates an error when step is less than width .
|
|
// ippStsNoGaussian Indicates a warning when no Gaussian is calculated for
|
|
// one of input vectors.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_SelectIdVar_32f_D2, (const Ipp32f* pSrc, const Ipp32f* pMean,
|
|
int step, int width, const Ipp32f* pVal, const Ipp8u* pSign, int height, Ipp32f* pResult,
|
|
int frames, Ipp32f none))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_SelectIdVarScaled_16s32f_D2, (const Ipp16s* pSrc,
|
|
const Ipp16s* pMean, int step, int width, const Ipp32f* pVal, const Ipp8u* pSign, int height,
|
|
Ipp32f* pResult, int frames, Ipp32f none, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLogGaussMixture_SelectIdVar*_*_D2L
|
|
// Purpose: Calculates the likelihood probability for the Gaussian
|
|
// mixture using Gaussian selection.
|
|
//
|
|
// Parameters:
|
|
// mSrc Pointer to the input matrix [frames][width].
|
|
// mMean Pointer to the mean matrix [height][width].
|
|
// width Length of the mean, variance and input matrix rows
|
|
// pVal Pointer to the vector of weight constants
|
|
// pSign Pointer to the vector of Gaussian calculation
|
|
// signs [frames*(height+7)/8] (in bytes).
|
|
// height Number of Gaussian mixture components
|
|
// pResult Pointer to the vector of output mixture values
|
|
// frames Number of input vectors; also the length of pSign row
|
|
// none Result value if no Gaussian is calculated
|
|
// scaleFactor Scaling factor for intermediate sums.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when mSrc, mMean, pSign, pVal
|
|
// or pResult is NULL.
|
|
// ippStsSizeErr Indicates an error when width, height or frames less than
|
|
// or equal to 0.
|
|
// ippStsSizeErr Indicates an error when width, height, frames less than
|
|
// or equal to 0
|
|
// ippStsNoGaussian Indicates a warning when no Gaussian is calculated for
|
|
// one of input vectors.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_SelectIdVar_32f_D2L, (const Ipp32f** mSrc,
|
|
const Ipp32f** mMean, int width, const Ipp32f* pVal, const Ipp8u* pSign, int height,
|
|
Ipp32f* pResult, int frames, Ipp32f none))
|
|
|
|
IPPAPI(IppStatus, ippsLogGaussMixture_SelectIdVarScaled_16s32f_D2L, (const Ipp16s** mSrc,
|
|
const Ipp16s** mMean, int width, const Ipp32f* pVal, const Ipp8u* pSign, int height,
|
|
Ipp32f* pResult, int frames, Ipp32f none, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVQSingle_Thresh_*
|
|
// Purpose: Quantizes the input vector given a codebook getting
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector
|
|
// pIndx Pointer to the destination indexes vector
|
|
// pCdbk Pointer to the codebook structure
|
|
// val Relative threshold value
|
|
// pNum Pointer to the number of clusters within threshold [1]
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pIndx, pCdbk or pNum is NULL
|
|
// ippStsBadArgErr Indicates an error when val is less than 1
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVQSingle_Thresh_32f,(const Ipp32f *pSrc, Ipp32s *pIndx, const IppsCdbkState_32f* pCdbk, Ipp32f val, int *pNum))
|
|
|
|
IPPAPI(IppStatus, ippsVQSingle_Thresh_16s,(const Ipp16s *pSrc, Ipp32s *pIndx, const IppsCdbkState_16s* pCdbk, Ipp32f val, int *pNum))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVQDistSingle_Thresh_*
|
|
// Purpose: Quantizes the input vector given a codebook getting
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector
|
|
// pIndx Pointer to the destination indexes vector
|
|
// pDist Pointer to the destination distances vector
|
|
// pCdbk Pointer to the codebook structure
|
|
// val Relative threshold value
|
|
// pNum Pointer to the number of clusters within threshold [1]
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pIndx, pDist, pCdbk or pNum is NULL
|
|
// ippStsBadArgErr Indicates an error when val is less than 1
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVQDistSingle_Thresh_32f,(const Ipp32f *pSrc, Ipp32s *pIndx, Ipp32f *pDist, const IppsCdbkState_32f* pCdbk, Ipp32f val, int *pNum))
|
|
|
|
IPPAPI(IppStatus, ippsVQDistSingle_Thresh_16s32s_Sfs,(const Ipp16s *pSrc, Ipp32s *pIndx, Ipp32s *pDist, const IppsCdbkState_16s* pCdbk, Ipp32f val, int *pNum, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVQSingle_Sort_*
|
|
// Purpose: Quantizes the input vector given a codebook getting
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector
|
|
// pIndx Pointer to the destination indexes vector
|
|
// pCdbk Pointer to the codebook structure
|
|
// num Number of closest clusters to search for each input vector
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pIndx, pCdbk is NULL
|
|
// ippStsSizeErr Indicates an error when num less than or equal to 0 or
|
|
// is greater than the codebook size.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVQSingle_Sort_32f,(const Ipp32f *pSrc, Ipp32s *pIndx, const IppsCdbkState_32f* pCdbk, int num))
|
|
|
|
IPPAPI(IppStatus, ippsVQSingle_Sort_16s,(const Ipp16s *pSrc, Ipp32s *pIndx, const IppsCdbkState_16s* pCdbk, int num))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVQDistSingle_Sort_*
|
|
// Purpose: Quantizes the input vector given a codebook getting
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector
|
|
// pIndx Pointer to the destination indexes vector
|
|
// pDist Pointer to the destination distances vector
|
|
// pCdbk Pointer to the codebook structure
|
|
// num Number of closest clusters to search for each input vector
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pSrc, pIndx, pDist, pCdbk is NULL
|
|
// ippStsSizeErr Indicates an error when num less than or equal to 0 or
|
|
// is greater than the codebook size.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVQDistSingle_Sort_32f,(const Ipp32f *pSrc, Ipp32s *pIndx, Ipp32f *pDist, const IppsCdbkState_32f* pCdbk, int num))
|
|
|
|
IPPAPI(IppStatus, ippsVQDistSingle_Sort_16s32s_Sfs,(const Ipp16s *pSrc, Ipp32s *pIndx, Ipp32s *pDist, const IppsCdbkState_16s* pCdbk, int num, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFillShortlist_Row_1u
|
|
// Purpose: Fills row-wise shortlist table for Gaussian selection.
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pIndx Pointer to the cluster indexes vector ([num*clust])
|
|
// num Number of Gaussian for each codebook cluster
|
|
// pShortlist Pointer to the shortlist matrix [clust][Listlen] (size in bytes)
|
|
// clust Number of rows in shortlist vector and rows in pIndx
|
|
// Listlen Number of elements in shortlist vector
|
|
// shift First element displacement in shortlist vector rows (in bits)
|
|
// height Number of Gaussian mixture components
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pIndx or pShortlist NULL
|
|
// ippStsSizeErr Indicates an error when clust, height, Listlen, num vector elements
|
|
// is less than or equal to 0 or when shift is less than 0
|
|
// ippStsStrideErr Indicates an error when Listlen is less than (shift+height+7)/8.
|
|
// ippStsBadArgErr Indicates an error when one of pIndx vector elements is less than
|
|
// 0 or greater than or equal to height.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFillShortlist_Row_1u,(const Ipp32s* pIndx, int height, int num, Ipp8u** pShortlist, int clust, int Listlen, int shift))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFillShortlist_RowVar_1u
|
|
// Purpose: Fills row-wise shortlist table for Gaussian selection.
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pIndx Pointer to the cluster indexes vector ([sum of pNum's])
|
|
// pNum Number of clusters vector [clust].
|
|
// pShortlist Pointer to the shortlist matrix [clust][Listlen] (size in bytes)
|
|
// clust Number of rows in shortlist vector and rows in pIndx
|
|
// Listlen Number of elements in shortlist vector
|
|
// shift First element displacement in shortlist vector rows (in bits)
|
|
// height Number of Gaussian mixture components
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pIndx or pShortlist NULL
|
|
// ippStsSizeErr Indicates an error when clust, height, Listlen, or any pNum elements
|
|
// is less than or equal to 0 or when shift is less than 0.
|
|
// ippStsStrideErr Indicates an error when Listlen is less than (shift+height+7)/8.
|
|
// ippStsBadArgErr Indicates an error when one of pIndx vector elements is less than
|
|
// 0 or greater than or equal to height.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFillShortlist_RowVar_1u,(const Ipp32s* pIndx, int *pNum, int height, Ipp8u** pShortlist, int clust, int Listlen, int shift))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFillShortlist_Column_1u
|
|
// Purpose: Fills column-wise shortlist table for Gaussian selection.
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pIndx Pointer to the cluster indexes vector ([num*height])
|
|
// num Number of Gaussian for each codebook cluster
|
|
// pShortlist Pointer to the shortlist matrix [clust][Listlen] (size in bytes)
|
|
// clust Number of rows in shortlist vector
|
|
// Listlen Number of elements in shortlist vector
|
|
// shift First element displacement in shortlist vector rows (in bits)
|
|
// height Number of Gaussian mixture components (and rows in pIndx)
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pIndx or pShortlist NULL
|
|
// ippStsSizeErr Indicates an error when clust, height, Listlen, num vector elements
|
|
// is less than or equal to 0 or when shift is less than 0
|
|
// ippStsStrideErr Indicates an error when Listlen is less than (shift+height+7)/8.
|
|
// ippStsBadArgErr Indicates an error when one of pIndx vector elements is less than
|
|
// 0 or greater than or equal to clust.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFillShortlist_Column_1u,(const Ipp32s* pIndx, int num, Ipp8u** pShortlist, int clust, int Listlen, int shift, int height))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFillShortlist_ColumnVar_1u
|
|
// Purpose: Fills column-wise shortlist table for Gaussian selection.
|
|
// several closest clusters
|
|
//
|
|
// Parameters:
|
|
// pIndx Pointer to the cluster indexes vector ([sum of pNum's])
|
|
// pNum Number of clusters vector [height].
|
|
// pShortlist Pointer to the shortlist matrix [clust][Listlen] (size in bytes)
|
|
// clust Number of rows in shortlist vector
|
|
// Listlen Number of elements in shortlist vector
|
|
// shift First element displacement in shortlist vector rows (in bits)
|
|
// height Number of Gaussian mixture components (and rows in pIndx)
|
|
// Return:
|
|
// ippStsNoErr Indicates no error
|
|
// ippStsNullPtrErr Indicates an error when pIndx or pShortlist NULL
|
|
// ippStsSizeErr Indicates an error when clust, height, Listlen, any pNum elements
|
|
// is less than or equal to 0 or when shift is less than 0.
|
|
// ippStsStrideErr Indicates an error when Listlen is less than (shift+height+7)/8.
|
|
// ippStsBadArgErr Indicates an error when one of pIndx vector elements is less than
|
|
// 0 or greater than or equal to clust.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsFillShortlist_ColumnVar_1u,(const Ipp32s* pIndx, int *pNum, Ipp8u** pShortlist, int clust, int ListLen, int shift, int height))
|
|
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsTabsCalculation_Aurora
|
|
// Purpose: Calculates filter coefficients for residual filter
|
|
//
|
|
//
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector [10]
|
|
// pDst Pointer to the output vector [17]
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsTabsCalculation_Aurora_32f,(const Ipp32f *pSrc,Ipp32f *pDst))
|
|
|
|
IPPAPI(IppStatus, ippsTabsCalculation_Aurora_16s,(const Ipp16s *pSrc,Ipp16s *pDst))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResidualFilter_Aurora
|
|
// Purpose: Calculates denoised waveform signal
|
|
// Arguments:
|
|
// pTabs Pointer to the input vector [17]
|
|
// pSrc Pointer to the input vector [96]
|
|
// pDst Pointer to the output vector [80]
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst or pTabs pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsResidualFilter_Aurora_32f,(const Ipp32f* pSrc, Ipp32f* pDst, const Ipp32f* pTabs))
|
|
|
|
IPPAPI(IppStatus, ippsResidualFilter_Aurora_16s_Sfs,(const Ipp16s* pSrc, Ipp16s* pDst, const Ipp16s* pTabs, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsWaveProcessing_Aurora
|
|
// Purpose: Processes waveform data after noise reduction
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector [200]
|
|
// pDst Pointer to the output vector [200]
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsWaveProcessing_Aurora_32f,(const Ipp32f *pSrc,Ipp32f *pDst))
|
|
|
|
IPPAPI(IppStatus, ippsWaveProcessing_Aurora_16s,(const Ipp16s *pSrc,Ipp16s *pDst))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsSmoothedPowerSpectrumAurora
|
|
// Purpose: Calculates smoothed magnitude of FFT output
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector [len]
|
|
// pDst Pointer to the output vector [len/4+1]
|
|
// len The length of input and output vectors
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0, or len is not multiple of 4
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsSmoothedPowerSpectrumAurora_32f,(Ipp32f *pSrc, Ipp32f *pDst,Ipp32s len))
|
|
|
|
IPPAPI(IppStatus, ippsSmoothedPowerSpectrumAurora_32s_Sfs,(Ipp32s *pSrc, Ipp32s *pDst,Ipp32s len,
|
|
int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsSmoothedPowerSpectrumAurora_32s64s_Sfs,(Ipp32s *pSrc, Ipp64s *pDst,
|
|
Ipp32s len, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsSmoothedPowerSpectrumAurora_16s,(Ipp16s *pSrc, Ipp16s *pDst,Ipp32s len))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsLowHighFilter_Aurora
|
|
// Purpose: Calculates low band and high band filters
|
|
// Arguments:
|
|
// pTabs Pointer to the input vector [tapsLen]
|
|
// tapsLen The filter taps number (even)
|
|
// pSrc Pointer to the input vector [len+tapsLen-1]
|
|
// pDstLow Pointer to the output vector [len/2]
|
|
// pDstHigh Pointer to the output vector [len/2]
|
|
// len The input samples number (even)
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc or pTabs or pDstLow or pDstHigh pointer is null.
|
|
// ippStsSizeErr Indicates an error when len or tapsLen is less than or equal to 0
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsLowHighFilter_Aurora_32f,(const Ipp32f* pSrc,
|
|
Ipp32f* pDstLow, Ipp32f* pDstHigh, Ipp32s len, const Ipp32f* pTabs, Ipp32s tapsLen))
|
|
|
|
IPPAPI(IppStatus, ippsLowHighFilter_Aurora_16s_Sfs,(const Ipp16s* pSrc,
|
|
Ipp16s* pDstLow, Ipp16s* pDstHigh, Ipp32s len, const Ipp16s* pTabs, Ipp32s tapsLen, int scaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNoiseSpectrumUpdate_Aurora
|
|
// Purpose: Updates noise spectrum
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector of mean [len]
|
|
// pSrcNoise Pointer to the input vector of noiseless signal spectrum [len]
|
|
// pDst Pointer to the output vector [len]
|
|
// len The length of input and output vectors
|
|
// ScaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pSrcNoise, pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsNoiseSpectrumUpdate_Aurora_32f,(const Ipp32f* pSrc, const Ipp32f* pSrcNoise,
|
|
Ipp32f *pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsNoiseSpectrumUpdate_Aurora_16s_Sfs,(const Ipp16s* pSrc, const Ipp16s* pSrcNoise,
|
|
Ipp16s *pDst, int len, int ScaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsNoiseSpectrumUpdate_Aurora_32s_Sfs,(const Ipp32s* pSrc, const Ipp32s* pSrcNoise,
|
|
Ipp32s *pDst, int len, int ScaleFactor))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsWienerFilterDesign_Aurora
|
|
// Purpose: Calculates improved transfer function of adaptive Wiener filter
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector of square roots of power spectral density mean [len]
|
|
// pNoise Pointer to the input vector of square roots of noise spectrum estimate [len]
|
|
// pDen Pointer to the input vector of square roots of previous noiseless signal spectrum [len]
|
|
// pDst Pointer to the output vector [len]
|
|
// len The length of input and output vectors
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pNoise, pDen, pDst pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsWienerFilterDesign_Aurora_32f,(const Ipp32f* pSrc, const Ipp32f* pNoise,
|
|
const Ipp32f* pDen, Ipp32f* pDst, int len))
|
|
|
|
IPPAPI(IppStatus, ippsWienerFilterDesign_Aurora_16s,(const Ipp16s* pSrc, const Ipp16s* pNoise,
|
|
const Ipp16s* pDen, Ipp16s* pDst, int len))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsBlindEqualization_Aurora
|
|
// Purpose: Equalizes the cepstral coefficients
|
|
// Arguments:
|
|
// pRefs Pointer to the input vector of reference cepstrum [len]
|
|
// pCeps Pointer to the input and output vector of cepstrum [len]
|
|
// pBias Pointer to the input and output vector of bias [len]
|
|
// len The length of input and output vectors
|
|
// val The log energy value
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pRefs, pCeps, pBias pointer is null.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsBlindEqualization_Aurora_32f,(const Ipp32f* pRefs, Ipp32f* pCeps, Ipp32f* pBias,
|
|
int len, Ipp32f val))
|
|
IPPAPI(IppStatus, ippsBlindEqualization_Aurora_16s,(const Ipp16s* pRefsQ6, Ipp16s* pCeps,
|
|
Ipp16s* pBias, int len, Ipp32s valQ6))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsHighBandCoding_Aurora
|
|
// Purpose: Codes and decodes high frequency band energy values
|
|
// Arguments:
|
|
// pSrcHFB Pointer to the input high frequency band energy vector [3].
|
|
// pInSWP Pointer to the input signal smoothed power spectrum vector [65].
|
|
// pDSWP Pointer to the denoised signal power spectrum vector [129].
|
|
// pDstHFB Pointer to the output coded high frequency band log energy vector [3].
|
|
// scaleFactor Refer to "Integer Scaling" in Chapter 2.
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pRefs, pCeps, pBias pointer is null.
|
|
// ippBadArg Indicates an error when a non-positive or NaN argument of logarithm is detected
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsHighBandCoding_Aurora_32f,(const Ipp32f* pSrcHFB,
|
|
const Ipp32f* pInSWP, const Ipp32f* pDSWP, Ipp32f* pDstHFB))
|
|
IPPAPI(IppStatus, ippsHighBandCoding_Aurora_32s_Sfs,(const Ipp32s* pSrcHFB,
|
|
const Ipp32s* pInSWP, const Ipp32s* pDSWP, Ipp32s* pDstHFB, int scaleFactor))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsMatVecMul
|
|
// Purpose: Multiplies matrix by vector
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector [width].
|
|
// pMatr Pointer to the input matrix [height*step].
|
|
// mMatr Pointer to the input matrix [height][width].
|
|
// step Row step in pMatr vector (in pMatr elements).
|
|
// width Length of the input vector and input matrix rows
|
|
// height Number of rows in the input matrix and the length of the result vector.
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMatr, mMatr pointer is null.
|
|
// ippStsSizeErr Indicates an error when width or height is less than or equal to 0
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_16s_D2Sfs,(const Ipp16s* pMatr, int step, const Ipp16s* pSrc, int width,
|
|
Ipp16s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_16s32s_D2Sfs,(const Ipp16s* pMatr, int step, const Ipp16s* pSrc, int width,
|
|
Ipp32s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_32s_D2Sfs,(const Ipp32s* pMatr, int step, const Ipp32s* pSrc, int width,
|
|
Ipp32s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_32f_D2,(const Ipp32f* pMatr, int step, const Ipp32f* pSrc, int width,
|
|
Ipp32f* pDst, int height))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_16s_D2LSfs,(const Ipp16s** mMatr, const Ipp16s* pSrc, int width,
|
|
Ipp16s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_16s32s_D2LSfs,(const Ipp16s** mMatr, const Ipp16s* pSrc, int width,
|
|
Ipp32s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_32s_D2LSfs,(const Ipp32s** mMatr, const Ipp32s* pSrc, int width,
|
|
Ipp32s* pDst, int height, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsMatVecMul_32f_D2L,(const Ipp32f** mMatr, const Ipp32f* pSrc, int width,
|
|
Ipp32f* pDst, int height))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVecMatMul
|
|
// Purpose: Multiplies vector by matrix
|
|
// Arguments:
|
|
// pSrc Pointer to the input vector [height].
|
|
// pMatr Pointer to the input matrix [height*step].
|
|
// mMatr Pointer to the input matrix [height][width].
|
|
// step Row step in pMatr vector (in pMatr elements).
|
|
// width Length of the input vector and input matrix rows
|
|
// height Number of rows in the input matrix and the length of the result vector.
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSrc, pMatr, mMatr pointer is null.
|
|
// ippStsSizeErr Indicates an error when width or height is less than or equal to 0
|
|
*/
|
|
IPPAPI(IppStatus, ippsVecMatMul_16s_D2Sfs,(const Ipp16s* pSrc, const Ipp16s* pMatr, int step, int height,
|
|
Ipp16s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_16s32s_D2Sfs,(const Ipp16s* pSrc, const Ipp16s* pMatr, int step, int height,
|
|
Ipp32s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_32s_D2Sfs,(const Ipp32s* pSrc, const Ipp32s* pMatr, int step, int height,
|
|
Ipp32s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_32f_D2,(const Ipp32f* pSrc, const Ipp32f* pMatr, int step, int height,
|
|
Ipp32f* pDst, int width))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_16s_D2LSfs,(const Ipp16s* pSrc, const Ipp16s** mMatr, int height,
|
|
Ipp16s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_16s32s_D2LSfs,(const Ipp16s* pSrc, const Ipp16s** mMatr, int height,
|
|
Ipp32s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_32s_D2LSfs,(const Ipp32s* pSrc, const Ipp32s** mMatr, int height,
|
|
Ipp32s* pDst, int width, int scaleFactor))
|
|
|
|
IPPAPI(IppStatus, ippsVecMatMul_32f_D2L,(const Ipp32f* pSrc, const Ipp32f** mMatr, int height,
|
|
Ipp32f* pDst, int width))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVADGetBufSize_Aurora
|
|
// Purpose: Queries the memory size for VAD decision
|
|
// Arguments:
|
|
// pSize Pointer to the output value of the memory size needed for VAD decision
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSize pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVADGetBufSize_Aurora_32f,(Ipp32s* pSize))
|
|
IPPAPI(IppStatus, ippsVADGetBufSize_Aurora_16s,(Ipp32s* pSize))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVADInit_Aurora
|
|
// Purpose: Initializes VAD decision process
|
|
// Arguments:
|
|
// pVADmem Pointer to the VAD decision memory
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pVADmem pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVADInit_Aurora_32f,(Ipp8u* pVADmem))
|
|
IPPAPI(IppStatus, ippsVADInit_Aurora_16s,(Ipp8u* pVADmem))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVADDecision_Aurora
|
|
// Purpose: Takes VAD decision for the input data
|
|
// Arguments:
|
|
// pCoeff Pointer to the input vector of Mel-warped Wiener filter coefficients [25].
|
|
// pTrans Pointer to the input vector of Wiener filter transfer function [64].
|
|
// nbSpeechFrame Speech frame hangover counter
|
|
// res VAD decision (1 for if voice detected, 0 otherwise).
|
|
// pVADmem Pointer to the VAD decision memory
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pVADmem pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVADDecision_Aurora_32f,(const Ipp32f* pCoeff, const Ipp32f* pTrans,
|
|
int nbSpeechFrame, IppVADDecision_Aurora *pRes, Ipp8u* pVADmem))
|
|
IPPAPI(IppStatus, ippsVADDecision_Aurora_16s,(const Ipp16s* pCoeff, const Ipp16s* pTrans,
|
|
int nbSpeechFrame, IppVADDecision_Aurora *pRes, Ipp8u* pVADmem))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsVADFlush_Aurora
|
|
// Purpose: Takes VAD decision for the input data
|
|
// Arguments:
|
|
// pRes VAD decision (1 for if voice detected, 0 otherwise).
|
|
// pVADmem Pointer to the VAD decision memory
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pVADmem, pRes pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsVADFlush_Aurora_32f,(IppVADDecision_Aurora *pRes, Ipp8u* pVADmem))
|
|
IPPAPI(IppStatus, ippsVADFlush_Aurora_16s,(IppVADDecision_Aurora *pRes, Ipp8u* pVADmem))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphaseFree
|
|
// Purpose: Free structure for data resampling
|
|
// Arguments:
|
|
// pSpec The pointer to the resampling state structure
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when the pSpec pointer is null.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFree_16s,(IppsResamplingPolyphase_16s* pSpec))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFree_32f,(IppsResamplingPolyphase_32f* pSpec))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedFree_16s,(IppsResamplingPolyphaseFixed_16s* pSpec))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedFree_32f,(IppsResamplingPolyphaseFixed_32f* pSpec))
|
|
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphaseInitAlloc
|
|
// Purpose: Initialize structure for data resampling
|
|
// Arguments:
|
|
// pSpec The pointer to the resampling state structure
|
|
// window The size of the ideal lowpass filter window.
|
|
// nStep The discretization step for filter coefficients
|
|
// rollf The roll-off frequency of the filter.
|
|
// alpha The parameter of the Kaiser window.
|
|
// width Length of the input vector and input matrix rows
|
|
// inRate The input rate for resampling with fixed factor.
|
|
// outRate The output rate for resampling with fixed factor.
|
|
// len The filter length for resampling with fixed factor.
|
|
// pSpec The pointer to the resampling state structure to be created.
|
|
// hint Suggests using specific code. The values for the hint argument are described in "Flag and Hint Arguments"
|
|
//
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSpec is NULL.
|
|
// ippStsSizeErr Indicates an error when inRate, outRate, nStep or len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when rollf is less than or equal to 0 or is greater than 1 or if alpha is less than 1 or if window is less than 2/nStep.
|
|
// ippStsMemAllocErr Indicates a memory allocation error.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseInitAlloc_16s,(IppsResamplingPolyphase_16s** pState, Ipp32f window,
|
|
int nStep, Ipp32f rollf, Ipp32f alpha,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseInitAlloc_32f,(IppsResamplingPolyphase_32f** pState, Ipp32f window,
|
|
int nStep, Ipp32f rollf, Ipp32f alpha,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedInitAlloc_16s,(IppsResamplingPolyphaseFixed_16s** pState, int inRate,
|
|
int outRate, int len, Ipp32f rollf, Ipp32f alpha,
|
|
IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedInitAlloc_32f,(IppsResamplingPolyphaseFixed_32f** pState, int inRate,
|
|
int outRate, int len, Ipp32f rollf, Ipp32f alpha,
|
|
IppHintAlgorithm hint))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphase
|
|
// Purpose: Resample input data
|
|
// Arguments:
|
|
// pSpec The pointer to the resampling state structure.
|
|
// pSrc The pointer to the input vector.
|
|
// pDst The pointer to the output vector.
|
|
// len The number of input vector elements to resample.
|
|
// norm The norming factor for output samples.
|
|
// factor The resampling factor.
|
|
// pTime The pointer to the start time of resampling (in input vector elements).
|
|
// pOutlen The number of calculated output vector elements
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSpec, pSrc, pDst, pTime or pOutlen is NULL.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0.
|
|
// ippStsBadArgErr Indicates an error when factor is less than or equal to.
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphase_16s,(const IppsResamplingPolyphase_16s *pState, const Ipp16s *pSrc, int len,
|
|
Ipp16s *pDst, Ipp64f factor, Ipp32f norm, Ipp64f *pTime,
|
|
int *pOutlen))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphase_32f,(const IppsResamplingPolyphase_32f *pState, const Ipp32f *pSrc, int len,
|
|
Ipp32f *pDst, Ipp64f factor, Ipp32f norm, Ipp64f *pTime,
|
|
int *pOutlen))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixed_16s,(const IppsResamplingPolyphaseFixed_16s *pState,
|
|
const Ipp16s *pSrc, int len, Ipp16s *pDst,
|
|
Ipp32f norm, Ipp64f *pTime, int *pOutlen))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixed_32f,(const IppsResamplingPolyphaseFixed_32f *pState,
|
|
const Ipp32f *pSrc, int len, Ipp32f *pDst,
|
|
Ipp32f norm, Ipp64f *pTime, int *pOutlen))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphaseFixedGetSize
|
|
// Purpose: Determines the size required for the ResamplePolyphaseFixed_*
|
|
// Arguments:
|
|
// inRate The input rate for resampling with fixed factor.
|
|
// outRate The output rate for resampling with fixed factor.
|
|
// len The filter length for resampling with fixed factor.
|
|
// pSize Required size in bytes
|
|
// pLen Filter len
|
|
// pHeight Number of filter
|
|
// hint Suggests using specific code. The values for the hint argument are described in "Flag and Hint Arguments"
|
|
//
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSize, pLen or pHeight are NULL.
|
|
// ippStsSizeErr Indicates an error when inRate, outRate or len is less than or equal to 0.
|
|
*/
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedGetSize_16s,(int inRate, int outRate, int
|
|
len, int* pSize, int* pLen, int* pHeight, IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedGetSize_32f,(int inRate, int outRate, int
|
|
len, int* pSize, int* pLen, int* pHeight, IppHintAlgorithm hint))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphaseFixedInit
|
|
// Purpose: Initializes ResamplePolyphaseFixed_* structures
|
|
// Arguments:
|
|
// pSpec The pointer to the resampling state structure to be created.
|
|
// inRate The input rate for resampling with fixed factor.
|
|
// outRate The output rate for resampling with fixed factor.
|
|
// len The filter length for resampling with fixed factor.
|
|
// hint Suggests using specific code. The values for the hint argument are described in "Flag and Hint Arguments"
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSpec is NULL.
|
|
// ippStsSizeErr Indicates an error when inRate, outRate or len is less than or equal to 0.
|
|
//
|
|
*/
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedInit_16s,(IppsResamplingPolyphaseFixed_16s* pSpec,
|
|
int inRate, int outRate, int len, IppHintAlgorithm hint))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseFixedInit_32f,(IppsResamplingPolyphaseFixed_32f* pSpec,
|
|
int inRate, int outRate, int len, IppHintAlgorithm hint))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphaseSetFixedFilter
|
|
// Purpose: Set filter coefficient
|
|
// Arguments:
|
|
// pSpec The pointer to the resampling state structure to be created.
|
|
// pSrc Input vector of filter coefficients [height][step]
|
|
// step Lenght of filter
|
|
// height Number of filter
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSpec or pSrc are NULL.
|
|
// ippStsSizeErr Indicates an error when step or height is less than or equal to 0.
|
|
*/
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseSetFixedFilter_16s,(IppsResamplingPolyphaseFixed_16s* pSpec,
|
|
const Ipp16s* pSrc, int step, int height))
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseSetFixedFilter_32f,(IppsResamplingPolyphaseFixed_32f* pSpec,
|
|
const Ipp32f* pSrc, int step, int height))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsResamplePolyphaseGetFixedFilter
|
|
// Purpose: Get filter coefficient
|
|
// Arguments:
|
|
// pSpec The pointer to the resampling state structure to be created.
|
|
// pDst Input vector of filter coefficients [height][step]
|
|
// step Lenght of filter
|
|
// height Number of filter
|
|
// Return Value
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSpec or pSrc are NULL.
|
|
// ippStsSizeErr Indicates an error when step or height is less than or equal to 0.
|
|
*/
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseGetFixedFilter_16s,(IppsResamplingPolyphaseFixed_16s* pSpec,
|
|
Ipp16s* pDst, int step, int height))
|
|
|
|
|
|
IPPAPI(IppStatus, ippsResamplePolyphaseGetFixedFilter_32f,(IppsResamplingPolyphaseFixed_32f* pSpec,
|
|
Ipp32f* pDst, int step, int height))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Definitions for Audio Toolkit functions
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
#if !defined( _OWN_BLDPCS )
|
|
|
|
struct MCRAState;
|
|
typedef struct MCRAState IppMCRAState;
|
|
struct MCRAState32f;
|
|
typedef struct MCRAState32f IppMCRAState32f;
|
|
|
|
#endif /* _OWN_BLDPCS */
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Definitions of Audio Toolkit functions
|
|
///////////////////////////////////////////////////////////////////////////// */
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFilterUpdateEMNS
|
|
// Purpose: Calculates the Ephraim-Malah noise suppression filter coefficients
|
|
//
|
|
// H(k) = (0.5 * sqrt(pi * W(k) * Rp(k)) * M(W(k)*Rp(k))) / Rp(k)
|
|
// where,
|
|
// k : frequency bin index
|
|
// W : Wiener filter coefficients
|
|
// Rp : posterior SNR
|
|
// M(T) : exp(-T/2) * [(1+T)*I0(T/2) + T*I1(T/2)]
|
|
// where,
|
|
// I0, I1 : are modified Bessel functions of order 0 and 1 respectively
|
|
// In here, for better performance in fix-point implement, Original Ephraim-Malah
|
|
// filter weights formula have been reformed as fellow:
|
|
// H(k) = W(k) * M'(W(k)*Rp(k)))
|
|
// M'(T) = 0.5 * sqrt(pi/T) * exp(-T/2) * [(1+T)*I0(T/2) + T*I1(T/2)]
|
|
// By the new Ephraim-Malah filter weights formula, the division operation has been
|
|
// removed.
|
|
// M'(T) have been fix-point realized by (T is thetaQ22 in code):
|
|
// 1) Use table look-up for small value (T< 2^(-15)) to achieve high precision
|
|
// 2) Set exponential increasing band ( From 2^i to 2^(i+1) ) to keep near same
|
|
// precision in each band. Total 24 bands used in code.
|
|
// 3) Use dynamic Q value for parameter P1 and P2 to keep high precision. P1, P2
|
|
// and P0 are used in the formula of two-order polynomial approximations:
|
|
// f(x) = P0 + P1 * x + P2 * x^2
|
|
// The value of P0, P1 & P2 have been recorded in table P0_2_32SQ22, P1_2_32SQ5i
|
|
// and P2_2_32SQi4. The Q value of P1 is (i+5), The Q value of P2 is (i-4),
|
|
// i is the index of band (i from 0 to 23). The representation of P0 is fixed
|
|
// at Q22 for all segments
|
|
// Arguments:
|
|
// pSrcWienerCoefsQ31 - pointer to a real-valued vector containing the Q31 format
|
|
// Wiener filter coefficients.
|
|
// pSrcPostSNR - pointer to a real-valued vector containing an estimate of
|
|
// the a posteriori signal to noise ratio.
|
|
// len - number of elements contained in input and output vectors.
|
|
// pDstFilterCoefsQ31 - pointer to a real-valued vector containing the Q31 format
|
|
// filter coefficients.
|
|
//
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsNullPtrErr - pSrcWienerCoefsQ31, pSrcPostSNRQ15 or pDstFilterCoefsQ31 is null.
|
|
// ippStsLengthErr - len is out of range.
|
|
//
|
|
// Notes:
|
|
*/
|
|
IPPAPI(IppStatus, ippsFilterUpdateEMNS_32s,(const Ipp32s *pSrcWienerCoefsQ31,
|
|
const Ipp32s *pSrcPostSNRQ15, Ipp32s *pDstFilterCoefsQ31, int len))
|
|
IPPAPI(IppStatus, ippsFilterUpdateEMNS_32f,(const Ipp32f *pSrcWienerCoefs,
|
|
const Ipp32f *pSrcPostSNR, Ipp32f *pDstFilterCoefs, int len))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFilterUpdateWiener
|
|
// Purpose: Calculates Wiener filter coefficients.
|
|
// W(k) = 1 / (1 + 1/R(k))
|
|
//
|
|
// with a piecewise uniform quantization table. The table is
|
|
// designed such that finer quantization steps are taken for
|
|
// smaller values where the function is more sensitive and large
|
|
// steps are taken for large values where the function is fairly
|
|
// flat. The table is divided into segments defined by
|
|
//
|
|
// 0 <= r < 2^WienerSegmentBitOffset[1]
|
|
// 2^WienerSegmentBitOffset[1] <= r < 2^WienerSegmentBitOffset[2]
|
|
// 2^WienerSegmentBitOffset[2] <= r < 2^WienerSegmentBitOffset[3]
|
|
// 2^WienerSegmentBitOffset[3] <= r
|
|
//
|
|
// where r represents an entry of the input vector. The number
|
|
// of table entries in segment i of the table is
|
|
//
|
|
// 2^(WienerSegmentBitOffset[i+1] - WienerSegmentBitOffset[i]).
|
|
//
|
|
// Therefore, if an input pSrcPriorSNRQ15[k] falls into segment i
|
|
// of the table then the index into the table segment is simply
|
|
//
|
|
// pSrcPriorSNRQ15[k] / 2^WienerSegmentBitOffset[i]
|
|
//
|
|
// A segment offset (e.g., TABLESEG0) is provided for each segment
|
|
// of the table. It may be added to the above result to find the
|
|
// offset from the beginning of the table. Within a segment, the
|
|
// table entries were created by uniform quantization. Since the
|
|
// function is flat for large values, it it represented by a
|
|
// constant in the final segment.
|
|
// Input Arguments: pSrcPriorSNRQ15 - pointer to the a priori SNR vector
|
|
// in Q15 (x/32768) format.
|
|
// len - number of elements contained in input vector.
|
|
//
|
|
// Output Arguments: pDstFilterCoefsQ31 - pointer to the output vector
|
|
// in Q31 format.
|
|
//
|
|
// Returns:
|
|
// IppStsNoErr - No Error
|
|
// IppStsBadArgErr - Bad Arguments
|
|
//
|
|
// Notes: none
|
|
//
|
|
*/
|
|
IPPAPI( IppStatus, ippsFilterUpdateWiener_32s,(const Ipp32s *pSrcPriorSNRQ15,
|
|
Ipp32s *pDstFilterCoefsQ31, int len))
|
|
|
|
IPPAPI( IppStatus, ippsFilterUpdateWiener_32f,(const Ipp32f *pSrcPriorSNR,
|
|
Ipp32f *pDstFilterCoefs, int len) )
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsGetSizeMCRA
|
|
// Purpose: Returns the size of memory for noise PSD estimator
|
|
//
|
|
// Arguments:
|
|
// nFFTSize - number of elements contained in the input FFT.
|
|
// pDstSize - pointer to the state structure.
|
|
//
|
|
// Returns:
|
|
// IppStsNoErr - No Error
|
|
// IppStsBadArgErr - Bad Arguments
|
|
//
|
|
// Notes: none
|
|
//
|
|
*/
|
|
IPPAPI( IppStatus, ippsGetSizeMCRA_32s,(int nFFTSize, int *pDstSize) )
|
|
|
|
IPPAPI( IppStatus, ippsGetSizeMCRA_32f,(int nFFTSize, int *pDstSize) )
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsInitMCRA
|
|
// Purpose: Initializes the noise PSD estimator
|
|
// See page 14 of "Noise Estimation by Minima
|
|
// Controlled Recursive Averaging for Robust Speech Enhancement"
|
|
// by I. Cohen and B. Berdugo, IEEE Signal Proc. Letters, Vol. 9,
|
|
// No. 1, Jan. 2002, pp. 12-15. Since the authors only established
|
|
// parameters for a sample rate Fs of 16000 Hz and a block update of
|
|
// 8 msec (M == 64 samples), it was necessary to derive equations
|
|
// to support arbitrary sample rate and block update. These
|
|
// equations are given in the comments below.
|
|
// Arguments:
|
|
// nSamplesPerSec - input sample rate.
|
|
// nFFTSize - number of elements contained in the input FFT.
|
|
// pDst - pointer to the state structure.
|
|
// Returns:
|
|
// IppStsNoErr - No Error
|
|
// IppStsBadArgErr - Bad Arguments
|
|
//
|
|
// Notes: This function must be kept in synch with the definition of the
|
|
// IppMCRAState. Memory pointers are assigned according to the order
|
|
// in the structure.
|
|
//
|
|
*/
|
|
IPPAPI( IppStatus, ippsInitMCRA_32s,(int nSamplesPerSec, int nFFTSize,
|
|
IppMCRAState *pDst) )
|
|
|
|
IPPAPI( IppStatus, ippsInitMCRA_32f,(int nSamplesPerSec, int nFFTSize,
|
|
IppMCRAState32f *pDst) )
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsAltInitMCRA
|
|
// Purpose: Initializes alternative noise PSD estimator
|
|
//
|
|
// Arguments:
|
|
// nSamplesPerSec - input sample rate.
|
|
// nFFTSize - number of elements contained in the input FFT.
|
|
// nUpdateSamples - number of new samples per frame
|
|
// pDst - pointer to the state structure.
|
|
//
|
|
// Returns:
|
|
// IppStsNoErr - No Error
|
|
// IppStsBadArgErr - Bad Arguments
|
|
//
|
|
// Notes: This function is a candidate to replace ippsInitMCRA_32s. It provides
|
|
// an added degree of flexibility so that the state can be initialized
|
|
// properly when zero padding is used to support frame sizes that are
|
|
// less than nFFTSize/2.
|
|
// This function must be kept in synch with the definition of the
|
|
// IppMCRAState. Memory pointers are assigned according to the order
|
|
// in the structure.
|
|
//
|
|
*/
|
|
|
|
IPPAPI( IppStatus, ippsAltInitMCRA_32s,(int nSamplesPerSec,
|
|
int nFFTSize,
|
|
int nUpdateSamples,
|
|
IppMCRAState *pDst) )
|
|
|
|
IPPAPI( IppStatus, ippsAltInitMCRA_32f,(int nSamplesPerSec,
|
|
int nFFTSize,
|
|
int nUpdateSamples,
|
|
IppMCRAState32f *pDst) )
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsUpdateNoisePSDMCRA
|
|
// Purpose: Estimates the noise power spectral density
|
|
// using the "Minima Controlled Recursive Averaging" method. See
|
|
// "Noise Estimation by Minima Controlled Recursive Averaging for
|
|
// Robust Speech Enhancement" by I. Cohen and B. Berdugo, IEEE
|
|
// Signal Proc. Letters, Vol. 9, No. 1, Jan. 2002, pp. 12-15. To
|
|
// relate this source code to the paper, the following table may
|
|
// be helpful:
|
|
//
|
|
// Paper Eqn Source Code
|
|
// ===== === ===========
|
|
// |Y(k,l)|^2 4 pSrcNoisySpeech[k]
|
|
// lambdahat_d(k,l) 4 pSrcDstNoisePSD[k] (input)
|
|
// lambdahat_d(k,l+1) 4 pSrcDstNoisePSD[k] (output)
|
|
// alpha_d 4 pSrcDstState->alphaDQ31
|
|
// alphatilde_d(k,l) 4 alphaTildeDQ31
|
|
// S(k,l-1) 7 pSrcDstState->pS[k] (input)
|
|
// S(k,l) 7 pSrcDstState->pS[k] (output)
|
|
// alpha_s 7 pSrcDstState->alphaSQ31
|
|
// S_min(k,l-1) 8 pSrcDstState->pSmin[k] (input)
|
|
// S_min(k,l) 8 pSrcDstState->pSmin[k] (output)
|
|
// S_tmp(k,l-1) 9 pSrcDstState->pStmp[k] (input)
|
|
// S_tmp(k,l) 9 pSrcDstState->pStmp[k] (output)
|
|
// phatprime(k,l-1) 14 pSrcDstState->pPprimeQ31[k] (input)
|
|
// phatprime(k,l) 14 pSrcDstState->pPprimeQ31[k] (output)
|
|
// alpha_p 14 pSrcDstState->alphaPQ31
|
|
//
|
|
// Arguments:
|
|
// pSrcNoisySpeech - pointer to the magnitude squared of the FFT of the noisy speech.
|
|
// pSrcDstState - state structure.
|
|
// pSrcDstNoisePSD - pointer to the input noise PSD vector.
|
|
//
|
|
// pSrcDstState - updated state structure.
|
|
// pSrcDstNoisePSD - pointer to the output noise PSD vector.
|
|
//
|
|
// Returns:
|
|
// IppStsNoErr - No Error
|
|
// IppStsBadArgErr - Bad Arguments
|
|
//
|
|
// Notes: For reasonable signal levels, the pSrcNoisySpeech and pSrcDstNoisePSD
|
|
// values will need to be scaled by 2^31 during the mag-squaring
|
|
// procedure.
|
|
//
|
|
*/
|
|
IPPAPI( IppStatus, ippsUpdateNoisePSDMCRA_32s_I, (const Ipp32s *pSrcNoisySpeech,
|
|
IppMCRAState *pSrcDstState, Ipp32s *pSrcDstNoisePSD))
|
|
|
|
IPPAPI( IppStatus, ippsUpdateNoisePSDMCRA_32f_I, (const Ipp32f *pSrcNoisySpeech,
|
|
IppMCRAState32f *pSrcDstState, Ipp32f *pSrcDstNoisePSD) )
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsFindPeaks
|
|
// Purpose: Identifies the peaks in the input vector,
|
|
// places a one in the output vector at the locations of the peaks
|
|
// and places a zero elsewhere. A peak is defined as a point pSrc[i]
|
|
// such that - pSrc[i-L] < pSrc[i-L+1] <...< pSrc[i] > pSrc[i+1] > ...> pSrc[i+L]
|
|
// where L is the size of the search.
|
|
// If movingAvgSize (M) is greater than 0, the input vector is smoothed
|
|
// before peaks are selected -
|
|
// pSrc[i] = (1/(2M+1)) {pSrc[i-M] + pSrc[i-M+1] + ... + pSrc[i] + pSrc[i+1]+
|
|
// ...+ pSrc[i+M] }
|
|
// Arguments:
|
|
// pSrc - pointer to the input vector
|
|
// len - number of elements contained in the input and output vectors
|
|
// searchSize - number of elements on either side to consider when peak picking
|
|
// movingAvgSize - width of the moving average window applied before peak picking
|
|
// pDstPeaks - pointer to the output vector
|
|
//
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsBadArgErr - Bad Arguments.
|
|
// ippStsSizeErr - Error: search window greater than the internal
|
|
// buffer that holds smoothed values
|
|
//
|
|
// Notes: Search the input vector. Calculate each number of the successive ascending elements
|
|
// and the successive descending elements. If both the number of successive ascending
|
|
// elements and the number of successive descending elements are greater than searchSize,
|
|
// then, one peak was found.
|
|
*/
|
|
IPPAPI(IppStatus, ippsFindPeaks_32s8u,(const Ipp32s *pSrc, Ipp8u *pDstPeaks,
|
|
int len, int searchSize, int movingAvgSize))
|
|
|
|
IPPAPI(IppStatus, ippsFindPeaks_32f8u,(const Ipp32f *pSrc, Ipp8u *pDstPeaks,
|
|
int len, int searchSize, int movingAvgSize))
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsPeriodicityLSPE
|
|
// Purpose: Estimates the periodicity and period of the input frame.
|
|
// The core algorithm used is the least-squares periodicity estimator as
|
|
// described in Section 4.1 of the paper:
|
|
// R.Tucker,"Voice activity etection using a periodicity measure",
|
|
// IEEE Proceedings-I Vol. 139, No. 4, August 1992
|
|
//
|
|
// The approach is to compute the normalized periodicity measure (R1) for
|
|
// all values of possible pitch periods in samples (Pmin <= P0 <= Pmax). The
|
|
// maximum value of R1 obtained is the estimated periodicity of the input frame
|
|
// and the corresponding period (P0) is the pitch period in samples of the input frame.
|
|
//
|
|
// The correspondence of the notation used in the paper to that used in
|
|
// this function is as follows:
|
|
// Paper Equation Source code
|
|
// ----- -------- -----------
|
|
// s 3, 4, 5 pSrc
|
|
// Pmin 2 minPeriod
|
|
// Pmax 2 maxPeriod
|
|
// P0 3, 4, 5 p
|
|
// I0 3, 5 i0
|
|
// I1 3, 4 i1
|
|
// R1 3 periodicityQ15
|
|
// K0 4, 5 n
|
|
//
|
|
// Arguments:
|
|
// pSrc - pointer to the input vector containing non-negative entries
|
|
// (assumed input is energy values for time-domain signal.
|
|
// len - number of elements contained in the input vector
|
|
// maxPeriod - maximum pitch period (in samples) to search
|
|
// minPeriod - minimum pitch period (in samples) to search
|
|
//
|
|
// periodicityQ15 - normalized sum of the largest harmonic sampling
|
|
// period - period in sample that provided the maximum-energy harmonic
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsBadArgErr - Bad Arguments.
|
|
//
|
|
// Notes: none
|
|
*/
|
|
IPPAPI(IppStatus, ippsPeriodicityLSPE_16s,(const Ipp16s *pSrc, int len,
|
|
Ipp16s *periodicityQ15, int *period, int maxPeriod, int minPeriod))
|
|
|
|
IPPAPI(IppStatus, ippsPeriodicityLSPE_32f,(const Ipp32f *pSrc, int len,
|
|
Ipp32f *periodicity, int *period, int maxPeriod, int minPeriod))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsPeriodicity
|
|
// Purpose: Computes the periodicity of the input vector. In typical
|
|
// applications, the input vector is the magnitude-squared of the discrete Fourier
|
|
// transform of speech. The periodicity is defined as the periodic sampling of the
|
|
// input vector that preserves the most energy.
|
|
//
|
|
// The period is defined as P such that
|
|
// P = argmax_(p) sum_n[ x(b + np) ]/N
|
|
// where Pmin<=p<=Pmax, 0<b<p, N<=MAX_HARMONICS, 0<n<N
|
|
// N is the smaller of the number of harmonics in the input vector
|
|
// for a particular period (p) or MAX_HARMONICS
|
|
//
|
|
// Using the N,P values obtained above, the periodicity is calculated as:
|
|
// periodicity = sum_n[x(k+nP)] / sum_n2[x(n2)], 0<n<N, 0<n2<len
|
|
//
|
|
//
|
|
// Arguments:
|
|
// pSrc - pointer to the input vector containing non-negative entries
|
|
// for, e.g. magnitude spectrum values
|
|
// len - number of elements contained in the input vector
|
|
// maxPeriod - maximum period to search
|
|
// minPeriod - minimum period of search
|
|
//
|
|
// periodicityQ15 - normalized sum of the largest harmonic sampling
|
|
// period - period in sample that provided the maximum-energy harmonics
|
|
//
|
|
// Returns: ippStsNoErr - No Error.
|
|
// ippStsBadArgErr - Bad Arguments.
|
|
//
|
|
// Notes: none
|
|
*/
|
|
IPPAPI(IppStatus, ippsPeriodicity_32s16s, (const Ipp32s *pSrc, int len,
|
|
Ipp16s *periodicityQ15, int *period, int maxPeriod, int minPeriod))
|
|
|
|
IPPAPI(IppStatus, ippsPeriodicity_32f, (const Ipp32f *pSrc, int len,
|
|
Ipp32f *periodicity, int *period, int maxPeriod, int minPeriod))
|
|
|
|
|
|
/* /////////////////////////////////////////////////////////////////////////////
|
|
// Name: ippsNthMaxElement_*
|
|
// Purpose: Functions ippsNthMaxElement find N-th maximal element of
|
|
// the input vector pSrc.
|
|
// Parameters:
|
|
// pSrc Pointer to the input vector [len].
|
|
// len Number of elements in the input vector pSrc.
|
|
// N Rank of element to find.
|
|
// pRes Pointer to the value of N-th maximal element.
|
|
// Return:
|
|
// ippStsNoErr Indicates no error.
|
|
// ippStsNullPtrErr Indicates an error when pSrc or pRes is NULL.
|
|
// ippStsSizeErr Indicates an error when len is less than or equal to 0 or.
|
|
// ippStsBadArgErr Indicates an error when N is less then 0 or is greater than or equal to len.
|
|
// Notes:
|
|
*/
|
|
|
|
IPPAPI(IppStatus, ippsNthMaxElement_32s,(const Ipp32s* pSrc, int len, int N, Ipp32s* pRes))
|
|
IPPAPI(IppStatus, ippsNthMaxElement_32f,(const Ipp32f* pSrc, int len, int N, Ipp32f* pRes))
|
|
IPPAPI(IppStatus, ippsNthMaxElement_64f,(const Ipp64f* pSrc, int len, int N, Ipp64f* pRes))
|
|
|
|
|
|
|
|
|
|
|
|
/*======== End of declaration of functions ===================================*/
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#if defined (_IPP_STDCALL_CDECL)
|
|
#undef _IPP_STDCALL_CDECL
|
|
#define __stdcall __cdecl
|
|
#endif
|
|
|
|
#endif /* __IPPSR_H__ */
|
|
/* ////////////////////////// End of file "ippsr.h" ///////////////////////// */
|