/usr/include/sipxtapi/mp/MpVadBase.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 | //
// Copyright (C) 2008 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// Copyright (C) 2008 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// $$
///////////////////////////////////////////////////////////////////////////////
// Author: Sergey Kostanbaev <Sergey DOT Kostanbaev AT sipez DOT com>
#ifndef _MpVadBase_h_
#define _MpVadBase_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include <utl/UtlDefs.h>
#include <os/OsStatus.h>
#include <utl/UtlString.h>
#include "mp/MpTypes.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
/**
* Base class for all VAD algorithms.
*
* To create concrete class you could directly instantiate it or use
* MpVadBase::createVad() static method for greater flexibility.
*
* @nosubgrouping
*/
class MpVadBase
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
/* ============================ CREATORS ================================== */
///@name Creators
//@{
/// Initialize VAD with given sample rate
virtual OsStatus init(int samplesPerSec) = 0;
/**<
* Should be called before any other class methods.
*/
/// Factory method for VAD algorithms creation.
static MpVadBase *createVad(const UtlString &name = "");
/**<
* @param[in] name - name of VAD algorithm to use. Use empty string
* to get default algorithm.
*
* @returns Method never returns NULL. If appropriate VAD algorithm is
* not found, default one is returned.
*/
/// Destructor
virtual ~MpVadBase() {};
//@}
/* ============================ MANIPULATORS ============================== */
///@name Manipulators
//@{
/// Detect speech presence
virtual MpSpeechType processFrame(uint32_t packetTimeStamp,
const MpAudioSample* pBuf,
unsigned inSamplesNum,
const MpSpeechParams &speechParams,
UtlBoolean calcEnergyOnly = FALSE) = 0;
/**<
* @param[in] packetTimeStamp - RTP timestamp of packet.
* @param[in] pBuf - buffer with input data.
* @param[in] inSamplesNum - number of samples of actual data, passed to
* this function.
* @param[in] speechParams - various parameters of speech.
* @param[in] calcEnergyOnly - if TRUE, VAD should calculate energy only.
* @returns Method returns MP_SPEECH_ACTIVE or MP_SPEECH_SILENT mainly,
* but if algorithm doesn't handle some situations return value
* may be MP_SPEECH_UNKNOWN
*/
/// Set algorithm parameter
virtual OsStatus setParam(const char* paramName, void* value) = 0;
/**<
* @param[in] paramName - name of parameter
* @param[in] value - value, can be any type, before call cast it to void*
* @returns Method returns OS_SUCCESS if parameter has been set,
* otherwise OS_FAILED
*/
/// Set algorithm to be used by default.
static void setDefaultAlgorithm(const UtlString& name);
/**<
* Initially default algorithm is defined at compile time. Using this
* function you can change default algorithm at run-time or switch back to
* compile-time default.
*
* @param[in] name - name of algorithm to use by default. Reverts to
* compile-time default if empty.
*/
/// Prepare to process other unrelated audio stream.
virtual void reset() = 0;
/**<
* Only initialized algorithm can be reseted. Calling reset() should
* bring algorithm to the original state as it was right after init().
* So init() should NOT be called after reset().
*/
//@}
/* ============================ ACCESSORS ================================= */
///@name Accessors
//@{
/// Return weighted energy of current frame
virtual int getEnergy() const = 0;
//@}
/* ============================ INQUIRY =================================== */
///@name Inquiry
//@{
//@}
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
static UtlString smDefaultAlgorithm; ///< Name of algorithm to be used by default.
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
};
#endif // _MpVadBase_h_
|