ScoreWarpMain.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 "TrainTools.h"
00057 #include "ScoreWarp.h"
00058 
00059 int main (int argc, char *argv[])
00060 {
00061   using namespace std;
00062   using namespace alize;
00063 
00064   try
00065   {
00066     Config config;
00067     CmdLine cmdLine (argc, argv);
00068     if (cmdLine.displayHelpRequired ()) // --help
00069       {
00070         cout << "ScoreWarp.exe" << endl;
00071         cout <<  " "  << endl;   
00072       }
00073     else if (cmdLine.displayVersionRequired ()) // --version
00074       cout << "Version 0.0" << endl;
00075     else
00076       {
00077         cmdLine.copyIntoConfig (config);
00078         if (config.getParamCount() == 0)
00079                 {cerr << "Error: Type ScoreWarp --help to get usage" << endl;exit(1);} 
00080         if (config.existsParam("debug")) debug=true;
00081         if (config.existsParam("verbose")) verbose=true;
00082         if (config.existsParam("generateGauss")){
00083           unsigned long nbBin=50;
00084           if (config.existsParam("nbBinGauss")) nbBin=config.getParam("nbBinGauss").toLong();
00085           unsigned long nbSample=1000000;
00086           if (config.existsParam("nbSample")) nbSample=config.getParam("nbSample").toLong();
00087           double mean=0;
00088           if (config.existsParam("mean")) mean=config.getParam("mean").toDouble();
00089           double cov=1;
00090           if (config.existsParam("cov")) cov=config.getParam("cov").toDouble();
00091           String outputFile="foo";
00092           if (config.existsParam("outputFilename")) outputFile=config.getParam("outputFilename");
00093           Histo gaussH=makeGausHisto(nbSample,mean, cov,nbBin);
00094           gaussH.saveGnuplot(outputFile+".gnuplot");
00095           gaussH.save(outputFile+".histo");
00096           }
00097         if (config.existsParam("testWarp")){
00098           String outputFile="foo.out";
00099           if (config.existsParam("outputFilename")) outputFile=config.getParam("outputFilename");
00100           ofstream ofile(outputFile.c_str(),ios::out);
00101           String fileDestH="destH";
00102           if (config.existsParam("filenameDestH")) fileDestH=config.getParam("filenameDestH");
00103           String fileRawH="rawH";
00104           if (config.existsParam("filenameRawH")) fileRawH=config.getParam("filenameRawH");
00105           unsigned long nbSample=1000000;
00106           if (config.existsParam("nbSample")) nbSample=config.getParam("nbSample").toLong();
00107           double mean=0;
00108           if (config.existsParam("mean")) mean=config.getParam("mean").toDouble();
00109           double cov=1;
00110           if (config.existsParam("cov")) cov=config.getParam("cov").toDouble();
00111           double nonObserved=0.1;
00112           if (config.existsParam("nonObserved")) nonObserved=config.getParam("nonObserved").toDouble();
00113           double area=0.5;
00114           if (config.existsParam("refArea")) area=config.getParam("refArea").toDouble();          
00115           Histo gaussH;
00116           Histo gaussR;
00117           gaussH.load(fileDestH+".histo");
00118           gaussR.load(fileRawH+".histo");
00119           boxMullerGeneratorInit();
00120           for (unsigned long i=0;i<nbSample;i++){
00121             double val=boxMullerGenerator(mean, cov);
00122             ofile << val <<" "<<scoreWarping(val,gaussR ,gaussH,nonObserved,area)<<endl;
00123           }
00124         }
00125         if (config.existsParam("normalizeHisto")){
00126           String outputFile="foo";
00127           if (config.existsParam("outputFilename")) outputFile=config.getParam("outputFilename");
00128           ofstream ofile(outputFile.c_str(),ios::out);
00129           String fileInputH="";
00130           if (config.existsParam("filenameInputH")) fileInputH=config.getParam("filenameInputH");  
00131           Histo inputH;
00132           inputH.load(fileInputH+".histo");   
00133           double area=0;
00134           for (unsigned long i=0;i<inputH.size();i++) area+=areaHisto(inputH,i);
00135           if (debug) cout <<"normalizeHisto, area["<<area<<"]"<<endl;
00136           inputH.div(area); 
00137           inputH.save(outputFile+".histo"); 
00138           inputH.saveGnuplot(outputFile+".gnuplot");
00139         }
00140         if (config.existsParam("testWarpLinear")){
00141           String outputFile="foo.out";
00142           if (config.existsParam("outputFilename")) outputFile=config.getParam("outputFilename");
00143           ofstream ofile(outputFile.c_str(),ios::out);
00144           String fileDestH="destH";
00145           if (config.existsParam("filenameDestH")) fileDestH=config.getParam("filenameDestH");
00146           String fileRawH="rawH";
00147           if (config.existsParam("filenameRawH")) fileRawH=config.getParam("filenameRawH");
00148           unsigned long nbSample=1000000;
00149           if (config.existsParam("nbSample")) nbSample=config.getParam("nbSample").toLong();
00150           double min=-10; 
00151           if (config.existsParam("min")) min=config.getParam("min").toDouble();
00152           double max=10;
00153           if (config.existsParam("max")) max=config.getParam("max").toDouble();
00154           double nonObserved=0.1;
00155           if (config.existsParam("nonObserved")) nonObserved=config.getParam("nonObserved").toDouble();
00156           double area=0.5;
00157           if (config.existsParam("refArea")) area=config.getParam("refArea").toDouble();
00158           Histo gaussH; 
00159           Histo gaussR; 
00160           gaussH.load(fileDestH+".histo");
00161           gaussR.load(fileRawH+".histo");
00162           for (unsigned long i=0;i<nbSample;i++){
00163             double val=min+(i*((max-min)/(double)nbSample)); 
00164             ofile << val <<" "<<scoreWarping(val,gaussR ,gaussH,nonObserved,area)<<endl;
00165           }
00166         }
00167       }
00168   }
00169   catch (alize::Exception & e)
00170   {
00171     cout << e.toString () << endl;
00172   }
00173 
00174   return 0;
00175 }