00001 /* 00002 This file is part of LIA_RAL which is a set of software based on ALIZE 00003 toolkit for speaker recognition. ALIZE toolkit is required to use LIA_RAL. 00004 00005 LIA_RAL project is a development project was initiated by the computer 00006 science laboratory of Avignon / France (Laboratoire Informatique d'Avignon - 00007 LIA) [http://lia.univ-avignon.fr <http://lia.univ-avignon.fr/>]. Then it 00008 was supported by two national projects of the French Research Ministry: 00009 - TECHNOLANGUE program [http://www.technolangue.net] 00010 - MISTRAL program [http://mistral.univ-avignon.fr] 00011 00012 LIA_RAL is free software: you can redistribute it and/or modify 00013 it under the terms of the GNU Lesser General Public License as 00014 published by the Free Software Foundation, either version 3 of 00015 the License, or any later version. 00016 00017 LIA_RAL is distributed in the hope that it will be useful, 00018 but WITHOUT ANY WARRANTY; without even the implied warranty of 00019 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00020 GNU Lesser General Public License for more details. 00021 00022 You should have received a copy of the GNU Lesser General Public 00023 License along with LIA_RAL. 00024 If not, see [http://www.gnu.org/licenses/]. 00025 00026 The LIA team as well as the LIA_RAL project team wants to highlight the 00027 limits of voice authentication in a forensic context. 00028 The "Person Authentification by Voice: A Need of Caution" paper 00029 proposes a good overview of this point (cf. "Person 00030 Authentification by Voice: A Need of Caution", Bonastre J.F., 00031 Bimbot F., Boe L.J., Campbell J.P., Douglas D.A., Magrin- 00032 chagnolleau I., Eurospeech 2003, Genova]. 00033 The conclusion of the paper of the paper is proposed bellow: 00034 [Currently, it is not possible to completely determine whether the 00035 similarity between two recordings is due to the speaker or to other 00036 factors, especially when: (a) the speaker does not cooperate, (b) there 00037 is no control over recording equipment, (c) recording conditions are not 00038 known, (d) one does not know whether the voice was disguised and, to a 00039 lesser extent, (e) the linguistic content of the message is not 00040 controlled. Caution and judgment must be exercised when applying speaker 00041 recognition techniques, whether human or automatic, to account for these 00042 uncontrolled factors. Under more constrained or calibrated situations, 00043 or as an aid for investigative purposes, judicious application of these 00044 techniques may be suitable, provided they are not considered as infallible. 00045 At the present time, there is no scientific process that enables one to 00046 uniquely characterize a persones voice or to identify with absolute 00047 certainty an individual from his or her voice.] 00048 00049 Copyright (C) 2004-2010 00050 Laboratoire d'informatique d'Avignon [http://lia.univ-avignon.fr] 00051 LIA_RAL admin [alize@univ-avignon.fr] 00052 Jean-Francois Bonastre [jean-francois.bonastre@univ-avignon.fr] 00053 */ 00054 00055 #include <iostream> 00056 00057 #include "SequenceExtractor.h" 00058 00059 00060 int main(int argc, char* argv[]) 00061 { 00062 try 00063 { 00064 // String inputTreeFilename=config.getParam("decoderFilename"); // The complete filename for the decoder tree 00065 // String outputFilename=config.getParam("outputFilename"); // The complete output filename 00066 // String inputFilename=config.getParam("inputFilename"); // The complete input filename 00067 00068 ConfigChecker cc; 00069 cc.addStringParam("config", false, true, "default config filename"); 00070 cc.addStringParam("decoderFilename",true,true,"filename of the decoder tree"); 00071 cc.addStringParam("inputFilename",true,true,"filename of the input symbol stream"); 00072 cc.addStringParam("outputFilename",true,true,"filename of the output symbol file"); 00073 cc.addStringParam("labelFilename",false,true,"if segment processing is needed, name of the label file"); 00074 cc.addStringParam("labelSelectedFrames",false,true,"if segment processsing is needed, label of the selected segments"); 00075 cc.addFloatParam("frameLength",false,true,"If segment processing is required, it gives the length in s of an input symbol"); 00076 cc.addBooleanParam("overlapMode",false,true,"if set to true (default=false), find overlap sequences. i.e decode one sequance by input symbol"); 00077 cc.addStringParam("ngramOutputFilename",false,true,"If set, computes the ngram on the output seq and save it in this file"); 00078 cc.addIntegerParam("ngramOutputOrder",false,true,"If output ngram is needed, gives the max order of the ngram"); 00079 CmdLine cmdLine(argc, argv); 00080 if (cmdLine.displayHelpRequired()) 00081 { 00082 cout <<"SequenceDecoder.exe"<<endl<<"This program uses in input a decoder tree and an input stream" 00083 <<endl<<"It decodes the input stream and outputs the finded sequences"<<endl<<cc.getParamList()<<endl; 00084 cout <<"HelpRequired"<<endl; 00085 return 0; 00086 } 00087 if (cmdLine.displayVersionRequired()) 00088 { 00089 cout <<"Version Beta "<<endl; 00090 } 00091 Config tmp; 00092 cmdLine.copyIntoConfig(tmp); 00093 Config config; 00094 if (tmp.existsParam("config")) config.load(tmp.getParam("config")); 00095 cmdLine.copyIntoConfig(config); 00096 cc.check(config); 00097 00098 00099 debug=config.getParam_debug(); 00100 if (config.existsParam("verbose")) verbose=config.getParam("verbose").toBool(); 00101 else verbose=false; 00102 sequenceDecoder(config); 00103 00104 00105 } 00106 catch (alize::Exception& e) 00107 { 00108 cout << e.toString() << endl; 00109 } 00110 00111 return 0; 00112 }
1.7.2