FeatureMultipleFileReader.h

Go to the documentation of this file.
00001 /*
00002         This file is part of ALIZE which is an open-source tool for 
00003         speaker recognition.
00004 
00005     ALIZE is free software: you can redistribute it and/or modify
00006     it under the terms of the GNU Lesser General Public License as 
00007     published by the Free Software Foundation, either version 3 of 
00008     the License, or any later version.
00009 
00010     ALIZE is distributed in the hope that it will be useful,
00011     but WITHOUT ANY WARRANTY; without even the implied warranty of
00012     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013     GNU Lesser General Public License for more details.
00014 
00015     You should have received a copy of the GNU Lesser General Public 
00016     License along with ALIZE.
00017     If not, see <http://www.gnu.org/licenses/>.
00018         
00019         ALIZE is a development project initiated by the ELISA consortium
00020         [alize.univ-avignon.fr/] and funded by the French Research 
00021         Ministry in the framework of the TECHNOLANGUE program 
00022         [www.technolangue.net]
00023 
00024         The ALIZE project team wants to highlight the limits of voice
00025         authentication in a forensic context.
00026         The "Person  Authentification by Voice: A Need of Caution" paper 
00027         proposes a good overview of this point (cf. "Person  
00028         Authentification by Voice: A Need of Caution", Bonastre J.F., 
00029         Bimbot F., Boe L.J., Campbell J.P., Douglas D.A., Magrin-
00030         chagnolleau I., Eurospeech 2003, Genova].
00031         The conclusion of the paper of the paper is proposed bellow:
00032         [Currently, it is not possible to completely determine whether the 
00033         similarity between two recordings is due to the speaker or to other 
00034         factors, especially when: (a) the speaker does not cooperate, (b) there 
00035         is no control over recording equipment, (c) recording conditions are not 
00036         known, (d) one does not know whether the voice was disguised and, to a 
00037         lesser extent, (e) the linguistic content of the message is not 
00038         controlled. Caution and judgment must be exercised when applying speaker 
00039         recognition techniques, whether human or automatic, to account for these 
00040         uncontrolled factors. Under more constrained or calibrated situations, 
00041         or as an aid for investigative purposes, judicious application of these 
00042         techniques may be suitable, provided they are not considered as infallible.
00043         At the present time, there is no scientific process that enables one to 
00044         uniquely characterize a person=92s voice or to identify with absolute 
00045         certainty an individual from his or her voice.]
00046         Contact Jean-Francois Bonastre for more information about the licence or
00047         the use of ALIZE
00048 
00049         Copyright (C) 2003-2010
00050         Laboratoire d'informatique d'Avignon [lia.univ-avignon.fr]
00051         ALIZE admin [alize@univ-avignon.fr]
00052         Jean-Francois Bonastre [jean-francois.bonastre@univ-avignon.fr]
00053 */
00054 
00055 #if !defined(ALIZE_FeatureMultipleFileReader_h)
00056 #define ALIZE_FeatureMultipleFileReader_h
00057 
00058 #if defined(_WIN32)
00059 #if defined(ALIZE_EXPORTS)
00060 #define ALIZE_API __declspec(dllexport)
00061 #else
00062 #define ALIZE_API __declspec(dllimport)
00063 #endif
00064 #else
00065 #define ALIZE_API
00066 #endif
00067 
00068 #include "FeatureFileReaderAbstract.h"
00069 #include "XLine.h"
00070 #include "FeatureFileList.h"
00071 #include "FeatureFileReader.h"
00072 #include "RealVector.h"
00073 
00074 namespace alize
00075 {
00076   class Feature;
00077   class LabelServer;
00078   class Config;
00079 
00088   class ALIZE_API FeatureMultipleFileReader : public FeatureFileReaderAbstract
00089   {
00090     friend class TestFeatureMultipleFileReader;
00091 
00092   public :
00093 
00105     explicit FeatureMultipleFileReader(const XLine& l,
00106                  const Config&, LabelServer* ls = NULL,
00107                  BigEndian be = BIGENDIAN_AUTO, BufferUsage b = BUFFER_AUTO,
00108                  unsigned long bufferSize = 0,
00109                  HistoricUsage = ALL_FEATURES, unsigned long historicSize = 0);
00110 
00120     static FeatureMultipleFileReader& create(const XLine& l,
00121          const Config& c, LabelServer* ls = NULL, BigEndian = BIGENDIAN_AUTO,
00122          BufferUsage = BUFFER_AUTO, unsigned long bufferSize = 0,
00123          HistoricUsage = ALL_FEATURES, unsigned long historicSize = 0);
00124     
00125     virtual ~FeatureMultipleFileReader();
00126 
00127     virtual bool readFeature(Feature& f, unsigned long step = 1);
00128 
00129     virtual bool writeFeature(const Feature& f, unsigned long step = 1);
00130 
00137     virtual unsigned long getFeatureCount();
00138 
00146     virtual unsigned long getVectSize();
00147 
00155     virtual const FeatureFlags& getFeatureFlags();
00156 
00164     virtual real_t getSampleRate();
00165 
00166 
00169     virtual void close();
00170 
00174     virtual unsigned long getSourceCount();
00175 
00180     virtual unsigned long getFeatureCountOfASource(unsigned long srcIdx);
00181 
00186     virtual unsigned long getFeatureCountOfASource(const FileName& f);
00187 
00192     virtual unsigned long getFirstFeatureIndexOfASource(unsigned long srcIdx);
00193 
00198     virtual unsigned long getFirstFeatureIndexOfASource(const FileName& f);
00199 
00204     virtual const String& getNameOfASource(unsigned long srcIdx);
00205 
00206     virtual String getClassName() const;
00207     virtual String toString() const;
00208 
00209 
00210   private :
00211 
00212     unsigned long         _fileCounter;
00213     const FeatureFileList _fileList;
00214     BigEndian             _bigEndian;
00215     unsigned long         _fileCount;
00216     ULongVector           _readerStack;
00217     ULongVector           _memStack;
00218     FeatureFileReader**   _readerPtrVect;
00219     FloatVector**         _bufferPtrVect;
00220     unsigned long         _memUsed;
00221     bool                  _featuresAreWritableDefined;
00222     unsigned long         _lastFeatureIndex;
00223 
00224 
00225     FeatureFileReader** createReaderPtrVect();
00226     FloatVector**       createBufferPtrVect();
00227     FeatureFileReader&  getReader(unsigned long idx);
00228     bool                rw(bool, Feature&, unsigned long);
00229     bool                featureWantedIsInHistoric(unsigned long n) const;
00230 
00231     bool operator==(const FeatureMultipleFileReader&)
00232                           const; 
00233     bool operator!=(const FeatureMultipleFileReader&)
00234                           const; 
00235     const FeatureMultipleFileReader& operator=(
00236             const FeatureMultipleFileReader&); 
00237     FeatureMultipleFileReader(
00238             const FeatureMultipleFileReader&); 
00239   };
00240 
00241 } // end namespace alize
00242 
00243 #endif // !defined(ALIZE_FeatureMultipleFileReader_h)
00244