SegCluster.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_SegCluster_h)
00056 #define ALIZE_SegCluster_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 "SegAbstract.h"
00069 #include "RefVector.h"
00070 
00071 namespace alize
00072 {
00081   class ALIZE_API SegCluster : public SegAbstract
00082   {
00083     friend class TestSegCluster;
00084     friend class TestSegServer;
00085 
00086   public :
00087 
00088     virtual ~SegCluster();
00089 
00090     //<FRANCAIS>
00097     virtual unsigned long begin() const;
00098 
00099     //<FRANCAIS>
00106     virtual unsigned long length() const;
00107 
00111     void add(SegAbstract& s);
00112 
00117     void add(SegAbstract& s, unsigned long pos);
00118 
00124     Seg& addCopy(const Seg& s);
00125 
00132     Seg& addCopy(const Seg& s, unsigned long pos);
00133 
00142     Seg& addNewSeg(unsigned long b = 0, unsigned long l = 0,
00143              unsigned long lc = 0, const String& s = "",
00144              const String& sn = "");
00145 
00149     void remove(SegAbstract& s);
00150 
00154     SegAbstract& remove(unsigned long idx);
00155 
00158     void removeAll();
00159 
00166     SegAbstract& get(unsigned long i) const;
00167 
00168     // <FRANCAIS>
00188     bool getFeatureLabelCode(unsigned long n, unsigned long& lc,
00189                  bool& isFirst, bool& isLast) const;
00190 
00200     bool getFeatureLabelCode(unsigned long n, unsigned long& lc) const;
00201 
00207     unsigned long getCount() const;
00208  
00214     virtual Seg* getSeg() const;
00215 
00219     unsigned long getId() const;
00220 
00224     virtual void rewind() const;
00225 
00226     virtual String getClassName() const;
00227     virtual String toString() const;
00228 
00229     // internal usage
00230 
00231     SegCluster& duplicate(const K&, SegServer&) const;
00232     void setId(const K&, unsigned long id);
00233     static SegCluster& create(const K&, SegServer& ss,
00234                   unsigned long lc = 0, const String& s = "",
00235                   const String& sn = "");
00236     virtual void getExtremeBoundaries(const K&, unsigned long& b,
00237                  unsigned long& e, bool& isDefined) const;
00238 
00239   private :
00240 
00241     RefVector<SegAbstract> _vect;
00242     unsigned long          _id;
00243 
00244     // for function getSeg()
00245     mutable SegAbstract*   _pCurrentSubSeg;
00246 
00247     // for functions getFeatureLabelCode(...)
00248     mutable Seg*           _pCurrentSeg;
00249           mutable Seg*           _pStartSeg;
00250     mutable unsigned long  _b;
00251     mutable unsigned long  _e;
00252     mutable unsigned long  _lc;
00253 
00254     explicit SegCluster(SegServer& ss, unsigned long lc = 0,
00255                 const String& s= "", const String& sn = "");
00256     SegCluster(const SegCluster&); /* not implemented */
00257     const SegCluster& operator=(const SegCluster& c); /* not implemented */
00258     bool operator==(const SegCluster& c) const; /* not implemented */
00259     bool operator!=(const SegCluster& c) const; /* not implemented */
00260   };   
00261 
00262 } // end namespace alize
00263 
00264 #endif // !defined(ALIZE_SegCluster_h)