ComputeTestMain.cpp

Go to the documentation of this file.
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 #include "liatools.h"
00057 #include "ComputeTest.h"
00058 
00059 int main(int argc, char* argv[]) {
00060         using namespace std;
00061         using namespace alize;
00062 
00063                 ConfigChecker cc;
00064                 cc.addStringParam("config", false, true, "default config filename");
00065                 cc.addStringParam("ndxFilename",true,true, "NDX file listing all verification tests to achieve: first column: test File, all others: models");  
00066                 cc.addStringParam("outputFilename",true,true, "output scores in this file: 'gender - test model - scores'");    
00067                 cc.addStringParam("inputWorldFilename",true,true,"model repsresenting the H0 hypothesis to get the LLR");
00068                 cc.addStringParam("labelSelectedFrames",true,true,"the segments with this label are used for training the worldmodel");         
00069                 cc.addStringParam("computeLLKWithTopDistribs",true,true, "PARTIAL/COMPLETE: will compute LLK with topdistribs. COMPLETE: add world LLK to client LLK, PARTIAL: just keeps the topDistrib LLK");
00070                 cc.addIntegerParam("topDistribsCount ",false,true,"Number of distrib to approximate complete LLK");
00071                 cc.addStringParam("gender",true,true, "M/F: will output the gender in score file");     
00072                 cc.addStringParam("fileLLR",false,true, "will output a score for the entire file (default true)");
00073                 cc.addStringParam("segmentLLR",false,true, "will output a score for each speech segment (default false)");
00074                 cc.addStringParam("windowLLR",false,true, "windowLLR: will output a score for each set of windowLLRSize frames. windowLLRDec gives the shift of the window (default false)");
00075                 cc.addIntegerParam("windowLLRSize",false,true, "if windowLLR is set, gives the size of the window (default 30)");
00076                 cc.addIntegerParam("windowLLRDec",false,true, "if windowLLR is set, gives the shift of the window (default windowLLRSize)");
00077                 cc.addBooleanParam("byLabelModel",false,true, "if the parameter is present, we work with a model by client and by  cluster (default false)");
00078                 cc.addBooleanParam("histoMode",false,true, "if the parameter is present, entropy of LR distrib is used as score (default false)");
00079                 cc.addStringParam("channelCompensation",true,true,"if set to [ NAP | FA | JFA | LFA | 'empty'], launch the corresponding channel compensation (default not set)");
00080 
00081         try {
00082                 CmdLine cmdLine(argc, argv);
00083                 if (cmdLine.displayHelpRequired()){
00084                 cout << "************************************" << endl;
00085                 cout << "********** ComputeTest.exe **********" << endl;
00086                 cout << "************************************" << endl;
00087                 cout << endl;
00088                 cout << "LLR computation for an NDX (NIST format) File" << endl;
00089                 cout << "" << endl;
00090                 cout << cc.getParamList()<<endl;
00091                 return 0;  
00092                 }
00093                 if (cmdLine.displayVersionRequired()){cout <<"ComputeTest - for computing the LLR using nixt style ndx files"<<endl;} 
00094                 Config tmp;
00095                 cmdLine.copyIntoConfig(tmp);
00096                 Config config;
00097                 if (tmp.existsParam("config")) config.load(tmp.getParam("config"));
00098                 cmdLine.copyIntoConfig(config);
00099                 cc.check(config);
00100                 debug=config.getParam_debug();
00101                 if (config.existsParam("verbose"))verbose=config.getParam("verbose").toBool();else verbose=false;
00102                 if (verbose) verboseLevel=1;else verboseLevel=0;
00103                 if (config.existsParam("verboseLevel"))verboseLevel=config.getParam("verboseLevel").toLong();
00104                 if (verboseLevel>0) verbose=true;
00105                 if (config.existsParam("byLabelModel"))        // if the parameter is present, we work with a model by client and by  cluster 
00106                 ComputeTestByLabel(config);
00107                 if (config.existsParam("histoMode"))        // if the parameter is present, entropy of LR distrib is used as score
00108                 ComputeTestHisto(config);
00109                 
00110                 if (config.getParam("channelCompensation")=="JFA"){ 
00111                         if(config.getParam("Scoring") == "FrameByFrame")        
00112                                 ComputeTestJFA(config);
00113                         else if(config.getParam("Scoring") == "DotProduct")             
00114                                 ComputeTestDotProduct(config);
00115                 }
00116                 else if (config.getParam("channelCompensation")=="LFA")         
00117                         ComputeTestLFA(config);
00118                 else if (config.getParam("channelCompensation")=="FA")          
00119                         ComputeTestFA(config);
00120                 else if(config.getParam("channelCompensation")=="NAP")
00121                         ComputeTestNAP(config);
00122                 else
00123                         ComputeTest(config);
00124         }
00125 catch (alize::Exception& e) {cout << e.toString() << endl << cc.getParamList()<< endl;}
00126 return 0;
00127 }