← Back to team overview

kaliveda-dev team mailing list archive

[Bug 1071230] Re: Erreur de lecture des functions d'identifications avec KVTGID::ReadFromAsciiFile(...)

 

Bon, raté pour ma jolie mise en page, merci launchpad!

Dans KVTGID.cpp (voir
http://indra.in2p3.fr/KaliVedaDoc/1.8.6/src/KVTGID.cxx.html#541),
remplacer la ligne 541:

const Char_t* GetValue(KVString &l, char c)
par
KVString GetValue(KVString &l, char c)

et la ligne 578:

 LTGfit->SetValidRuns( GetValue(line, '=') );
par
LTGfit->SetValidRuns( KVNumberList(GetValue(line, '=').Data()) );

devrait améliorer les choses. je vais tester sur ma branche.


** Branch linked: lp:kaliveda

** Branch linked: lp:kaliveda/e494s-dev

-- 
You received this bug notification because you are a member of KaliVeda
Development Team, which is subscribed to KaliVeda.
https://bugs.launchpad.net/bugs/1071230

Title:
  Erreur de lecture des functions d'identifications avec
  KVTGID::ReadFromAsciiFile(...)

Status in KaliVeda data analysis framework:
  New

Bug description:
  KVROOT:
  /afs/in2p3.fr/throng/indra/.kvroot-1.8.6_gcc-4.1.2_x86_64_root-5.33.01

  La lecture des fonctions d'identifications (KVTGID) ne se fait pas correctement avec la fonction membre 
  KVTGID::ReadFromAsciiFile(...). Le programme suivant montre le problème que j'ai rencontré:

  ######### File: test.cpp  ######################

  #include "Riostream.h"
  #include "KVTGID.h"
  #include "KVNumberList.h"
  #include "KVIDTelescope.h"

  void testIOofKVTGID(){

  	//////////////////////////////////
  	//  Building a KVTGID object  //
  	//////////////////////////////////
  	
  	TString f1name  = "test_write.dat";
  	TString f2name = "test_read.dat";

  	KVTGID *tgid = KVTGID::MakeTGID("my_tgid",1,1,0,1);
  	KVNumberList runlist("69-666");
  	tgid->SetValidRuns(runlist);
  	KVIDTelescope *tel = new KVIDTelescope();
  	tel->SetName("MyIDtel");
  	tgid->AddIDTelescope(tel);
  	tgid->SetVarX("my_X");
  	tgid->SetVarY("my_Y");
  	tgid->SetIDmin(2);
  	tgid->SetIDmax(20);
  	Double_t par[] = {1,2,3,4,5,6,7,8,9,10};
  	tgid->SetLTGParameters(par);

  	/////////////////////////////////////////////////////////
  	// Checking the method KVTGID::WriteToAscciFile //
  	/////////////////////////////////////////////////////////
  	
  	ofstream ofile1(f1name.Data());
  	tgid->WriteToAsciiFile(ofile1);
  	ofile1.close();

  	////////////////////////////////////////////////////////////
  	// Checking the method KVTGID::ReadFromAsciiFile  //
  	////////////////////////////////////////////////////////////
  	
     	ifstream ifile1 ( f1name.Data() );
     	ofstream ofile2 ( f2name.Data() );

          TString s;

     	while ( ifile1.good() ) {
        	//read a line
        	s.ReadLine ( ifile1 );
        	if ( s.BeginsWith ( "++" ) ) {
           	//New fit
           	//Get name of class by stripping off the '+' at the start of the line
           	s.Remove ( 0, s.Index("::")+2 );

  			// Make new identification function
  			KVTGID *fit = NULL;

  			// Read one fit in ifile1
           	        fit = KVTGID::ReadFromAsciiFile(s.Data(),ifile1);

  			// Write this read fit in ofile2
  			fit->WriteToAsciiFile(ofile2);
        	}
     	}

     	ifile1.close();
     	ofile2.close();
  }

  #########################################################

  Le programme construit une fonction d'identification 'tgid' et écrit ses paramétres dans le fichier ascii "test_write.dat".
  Ensuite ce fichier est lu par la méthode KVTGID::WriteFromAsciiFile(...) et la fonction chargée et de nouveau écrite dans un second fichier ascii "test_read.dat".

  Les fichiers de sortie obtenus sont:

  
  ## File: test_write.dat ########       ## File: test_read.dat #########

  ++KVTGID::my_tgid                      ++KVTGID::my_tgid
  Type=1                                 Type=1
  LightEnergyDependence=1                LightEnergyDependence=0
  ZorA=0                                 ZorA=0
  Functional=KVTGIDFunctions::fede       Functional=KVTGIDFunctions::fede
  Runs=69-666                            Runs=
  IDTelescopes=/MyIDtel/                 IDTelescopes=Ɇ}ÿ
  <VARX> my_X                            <VARX> my_X
  <VARY> my_Y                            <VARY> my_Y
  ZMIN=2  ZMAX=20                        ZMIN=2  ZMAX=20
  Lambda= 1.0000000000000e+00            Lambda= 0.0000000000000e+00
  Alpha= 2.0000000000000e+00             Alpha= 0.0000000000000e+00
  Beta= 3.0000000000000e+00              Beta= 0.0000000000000e+00
  Mu= 4.0000000000000e+00                Mu= 0.0000000000000e+00
  Nu= 5.0000000000000e+00                Nu= 0.0000000000000e+00
  Xi= 6.0000000000000e+00                Xi= 0.0000000000000e+00
  G= 7.0000000000000e+00                 G= 0.0000000000000e+00
  Pdx= 8.0000000000000e+00               Pdx= 0.0000000000000e+00
  Pdy= 9.0000000000000e+00               Pdy= 0.0000000000000e+00
  Eta= 1.0000000000000e+01               !
  !
  ######################################################################


  (j'ai essayé de mettre les deux fichiers cote à cote, j'espère que
  launchpad gardera la mise en page)

  On voit que l'écriture fonctionne correctement mais lorsque le fichier ascii est relu il y a quelques problèmes,
  les deux fichiers devraient être identiques.

To manage notifications about this bug go to:
https://bugs.launchpad.net/kaliveda/+bug/1071230/+subscriptions


References