EMIPLIB

miphrirlisten.h

Go to the documentation of this file.
00001 /*
00002     
00003   This file is a part of EMIPLIB, the EDM Media over IP Library.
00004   
00005   Copyright (C) 2006-2011  Hasselt University - Expertise Centre for
00006                       Digital Media (EDM) (http://www.edm.uhasselt.be)
00007 
00008   This library is free software; you can redistribute it and/or
00009   modify it under the terms of the GNU Lesser General Public
00010   License as published by the Free Software Foundation; either
00011   version 2.1 of the License, or (at your option) any later version.
00012 
00013   This library is distributed in the hope that it will be useful,
00014   but WITHOUT ANY WARRANTY; without even the implied warranty of
00015   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00016   Lesser General Public License for more details.
00017 
00018   You should have received a copy of the GNU Lesser General Public
00019   License along with this library; if not, write to the Free Software
00020   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  
00021   USA
00022 
00023 */
00024 
00029 #ifndef MIPHRIRLISTEN_H
00030 
00031 #define MIPHRIRLISTEN_H
00032 
00033 #include "mipconfig.h"
00034 #include "miphrirbase.h"
00035 #include <cmath>
00036 #include <list>
00037 
00038 class MIPRawFloatAudioMessage;
00039 
00045 class EMIPLIB_IMPORTEXPORT MIPHRIRListen : public MIPHRIRBase
00046 {
00047 public:
00048         MIPHRIRListen();
00049         ~MIPHRIRListen();
00050 
00066         bool init(const std::string &baseDirectory, int maxFilterLength = 48, 
00067                   bool allowAmbientSound = true, bool useDistance = true);
00068 
00070         bool destroy();
00071 
00078         bool selectHRIRSet(int subjectNumber, bool compensated = true);
00079 
00081         int getSamplingRate() const                                                             { return m_sampingRate; }
00082 
00084         bool getSubjectNumbers(std::list<int> &subjectNumbers, bool compensated = true);
00085         
00086         bool push(const MIPComponentChain &chain, int64_t iteration, MIPMessage *pMsg);
00087         bool pull(const MIPComponentChain &chain, int64_t iteration, MIPMessage **pMsg);
00088 private:
00089         void clearMessages();
00090         void clearHRIRSets();
00091         bool searchDirectory(const std::string &path, bool reportOpenError = false);
00092         bool processFile(const std::string &baseDir, const std::string &fileName);
00093         
00094         bool m_init;
00095         bool m_ambient;
00096         bool m_useDistance;
00097         int m_sampingRate;
00098         int m_maxFilterLength;
00099         
00100         std::list<HRIRInfo *> m_rawHRIRSets;
00101         std::list<HRIRInfo *> m_compensatedHRIRSets;
00102         
00103         HRIRInfo *m_pCurHRIRSet;
00104 
00105         int64_t m_prevIteration;
00106         std::list<MIPRawFloatAudioMessage *> m_messages;
00107         std::list<MIPRawFloatAudioMessage *>::const_iterator m_msgIt;
00108 };
00109 
00110 #endif // MIPHRIRLISTEN_H
00111