/usr/include/sipxtapi/mp/MprNullAec.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 | //
// Copyright (C) 2007 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// Copyright (C) 2007 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// $$
///////////////////////////////////////////////////////////////////////////////
// Author: Dan Petrie <dpetrie AT SIPez DOT com>
#ifndef _MprNullAec_h_
#define _MprNullAec_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "mp/MpAudioResource.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class MprAudioFrameBuffer;
/**
* @brief The MprNullAec resource a no-op AEC implementation intended to be
* a base calls for real AEC implementations..
*
* This resource passes buffers from input 0 straight through to output 0.
*
* Typically AEC looks at the output to the speaker and subtracts that signal
* in some form from the input from the mic to remove the echo. So generically
* AEC has two inputs (mic and speaker) and one output (mic - echo). If this was
* done in a single resource this would create a loop in the process order of
* the resources (a resource must get all its inputs to generate its outputs).
*
* To avoid this loop, AEC is broken into two resources. The MprAudioFrameBuffer
* which simply stores references to the last MpBufs that went through it and
* makes it availabe via an accessor. AEC uses the MprAudioFrameBuffer to get
* the speaker output. So the real AEC resource then has only one input (mic) and
* one output (mic - echo). It gets the speaker output indirectly from the
* MprAudioFrameBuffer.
*/
class MprNullAec : public MpAudioResource
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
/* ============================ CREATORS ================================== */
///@name Creators
//@{
/// Constructor
MprNullAec(const UtlString& rName,
MprAudioFrameBuffer& MprAudioFrameBuffer);
/// Destructor
virtual
~MprNullAec();
//@}
/* ============================ MANIPULATORS ============================== */
///@name Manipulators
//@{
//@}
/* ============================ ACCESSORS ================================= */
///@name Accessors
//@{
//@}
/* ============================ INQUIRY =================================== */
///@name Inquiry
//@{
//@}
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
MprAudioFrameBuffer* mpOutputBufferResource;
virtual UtlBoolean doProcessFrame(MpBufPtr inBufs[],
MpBufPtr outBufs[],
int inBufsSize,
int outBufsSize,
UtlBoolean isEnabled,
int samplesPerFrame,
int samplesPerSecond);
/// Copy constructor (not implemented for this class)
MprNullAec(const MprNullAec& rMprNullAec);
/// Assignment operator (not implemented for this class)
MprNullAec& operator=(const MprNullAec& rhs);
};
/* ============================ INLINE METHODS ============================ */
#endif // _MprNullAec_h_
|