source: Sophya/trunk/SophyaLib/Manual/modifs.tex@ 4064

Last change on this file since 4064 was 4060, checked in by ansari, 13 years ago

MAJ fichier modifs.tex - correction PI/ucckprot.h et BitVector, cmv+reza 16/04/2012

File size: 75.2 KB
Line 
1\documentclass[twoside,11pt,A4]{article}
2% \documentclass[twoside,11pt,A4]{report}
3\usepackage[french]{babel}
4
5% \usepackage[T1]{fontenc}
6\usepackage[applemac]{inputenc}
7\usepackage{palatino}
8% \usepackage{times}
9% package pour ecrire DRAFT en fond de page
10% \usepackage[light,all,draft]{draftcopy}
11
12% \usepackage{epsfig}
13\usepackage{graphicx}
14\usepackage{amsmath}
15\usepackage{amssymb}
16
17\setlength{\textwidth}{16cm}
18\setlength{\textheight}{22 cm}
19\setlength{\topmargin}{-5mm}
20\setlength{\oddsidemargin}{0.cm}
21\setlength{\evensidemargin}{0.cm}
22\setlength{\unitlength}{1mm}
23
24\newcommand{\tcls}[1] {#1$<$T$>$}
25\newcommand{\tclsc}[2] {#1$<$#2$>$}
26
27\newcommand{\rond}{$\bullet \ $}
28\newcommand{\etoile}{$\star \ $}
29\newcommand{\cercle}{$\circ \ $}
30\newcommand{\carre}{$\Box \ $}
31
32%%%% Pour le decoupage en sections
33% \newcommand{\groupe}[1]{\chapter{#1}}
34% \newcommand{\titre}[1]{\section{#1}}
35% \newcommand{\soustitre}[1]{\subsection{#1}}
36%%%
37\newcommand{\groupe}[1]{\section{#1}}
38\newcommand{\titre}[1]{\subsection{#1}}
39\newcommand{\soustitre}[1]{\subsubsection{#1}}
40%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
41%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
42\begin{document}
43\begin{titlepage}
44\begin{center}
45{\Large \bf SOPHYA Change Log \\[1mm]
46 Liste des modifications de SOPHYA } \\[5mm]
47{\large Septembre 2003 - Septembre 2011 } \\[25mm]
48Liste des tags et dates : \\[5mm]
49{\large
50\begin{tabular}{lcl}
51V = 0.727 & \hspace{10mm} & Octobre 1999 \\
52V = 0.8 & \hspace{10mm} & F\'evrier 2000 \\
53V = 1.1 & \hspace{10mm} & F\'evrier 2001 \\
54V = 1.2 & \hspace{10mm} & Juillet 2001 \\
55V = 1.3 & \hspace{10mm} & Novembre 2001 \\
56V = 1.5 & \hspace{10mm} & D\'ecembre 2002 \\
57V = 1.7 & \hspace{10mm} & Septembre 2003 \\
58V = 1.9 & \hspace{10mm} & Juin 2005 - SANS tag CVS \\
59V = 1.9xx & \hspace{10mm} & 09/2005 ... 09/2006 \\
60V = 2.0 & \hspace{10mm} & Septembre 2006 - tag CVS \\
61V = 2.046 & \hspace{10mm} & Ao\^{u}t 2007 - NO tag \\
62V = 2.1 & \hspace{10mm} & Novembre 2007 - tag CVS \\
63V = 2.1xx & \hspace{10mm} & 12/ 2007 - \ldots \\
64V = 2.125 & \hspace{10mm} & Sept-Oct 2008 - NO tag \\
65V = 2.140 & \hspace{10mm} & Sept-Oct 2009 - NO tag \\
66V = 2.150 & \hspace{10mm} & Mars 2010 - NO tag \\
67V = 2.2 & \hspace{10mm} & Septembre 2010 - tag CVS \\
68V = 2.2xxx & \hspace{10mm} & Sep 2010 \ldots \\
69V = 2.211 & \hspace{10mm} & Novembre 2011 - NO tag \\
70V = 2.222 & \hspace{10mm} & Avril 2012 - NO tag \\
71
72\end{tabular}
73} \\[8mm]
74%%%%%%
75\begin{tabular}{ll}
76R. Ansari & ansari@lal.in2p3.fr \\
77C. Magneville & cmv@hep.saclay.cea.fr
78\end{tabular}
79\\[5mm]
80\today
81\end{center}
82\end{titlepage}
83
84\newpage
85\tableofcontents
86\newpage
87
88%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
89%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
90\groupe{De V2.2 (Sep 2010) ˆ V2.3 \ldots }
91\titre{BaseTools}
92\begin{itemize}
93\item[\rond] Avril 2012: Ajout des fichiers pqnumber.h .cc , sunitpcst.h , cc avec les classes
94 {\bf PrimeNumbers , QNumber , Units , PhysQty } et le programme test correspondant
95Tests/tpqunits.cc.
96
97\begin{verbatim}
98---Fichiers pqnumber.h .cc
99+ classe PrimeNumbers (nombres premiers)
100+ classe QNumber (nombres rationnels)
101 // Create rational numbers from integers
102 QNumber q1(3,4), q2(5,6), q3(6,8);
103 // Operations and comparsion
104 QNumber q4 = q1+q2;
105 QNumber qq(3*7*17*5,(-5)*7*11*2);
106 cout << " qq= " << qq << " qq.Simplify() = " << qq.Simplify() << endl;
107
108---Fichiers sunitpcst.h .cc
109+ classe Units ( avec dŽfinition d'une partie des unitŽs de base)
110+ classe PhysQty (avec dŽfinition des 4 ou 5 constantes de base)
111
112 cout << " units::watt() : " << Units::watt() << endl;
113 cout << " k_Boltzmann: " << PhysQty::k() << endl;
114\end{verbatim}
115
116\item[\rond] Septembre 2011: Ajout de 2 g\'en\'erateurs al\'eatoires. \\
117TinyMT[32/64]RandGen: utilisant le code Tiny Mersenne Twister (TinyMT)
118http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html.
119Ajout de la methode de tirage par Ziggurat pour la generation de v.a. gaussiennes.
120\end{itemize}
121
122\titre{TArray}
123\begin{itemize}
124\item[\rond] Mars 2012: Ajout de classe de vecteur de bits ( {\bf BitVector} ).
125\item[\rond] Novembre 2011: Correction bug au niveau de la gestion mŽmoire pour les constrcuteur de
126copie de TArray/TMatrix/TVector lorsqu'un argument de type BaseArray est passŽ. (bug identifiŽ par JEC)
127lors de l'utilisation de la commande {\tt vecplot} dans piapp. Ces constructeurs par copie ont maintenant
128un argument optionnel permettant de construire des tableaux compactŽs en mŽmoire (packed).
129\begin{verbatim}
130TArray(const BaseArray& a, bool pack=true);
131TMatrix(const BaseArray& a, bool pack=true);
132TVector(const BaseArray& a, bool pack=true);
133\end{verbatim}
134Le code de TArray/TMatrix/TVector a ŽtŽ modifiŽ aussi pour permettre la crŽation par le constructeur de
135copie d'objets non allouŽs, utile en particulier pour uiliser des objets comme
136\begin{verbatim}
137std::vector< TArray<int_4> >
138std::map< std::string, TMatrix<r_4> >
139\end{verbatim}
140\item[\rond] Octobre 2011: Print ds {\tt TArray$<$T$>$::ReadASCII() } soumis au print level global de BaseArray
141(demande JEC)
142\end{itemize}
143
144\titre{FitsIOServer}
145\begin{itemize}
146\item[\rond] Octobre 2011: FitsABTColRd + FitsABTWriter:
147Suppression du code de lecture bufferis\'ee (cfistio le fait aussi bien sans complication de code - test\'e!).
148Ajout lecture/\'ecriture des bintables dont les \'el\'ements sont des vecteurs de nombres.
149Ajout lecture/\'ecriture de bintable de complexes et de cha\^{i}nes de caract\`eres.
150\end{itemize}
151
152\titre{SysTools}
153\begin{itemize}
154\item[\rond] Septembre 2011: Corrections dans commander.cc des bugs de {\bf forinfile} et dans la gestion des
155boucles imbriquŽes (bugs trouvŽs par JEC en Mai 2011). DiffŽrentiation instruction break et breakall, pour
156sortir de la boucle courante ou de toutes les boucles. Reste ˆ modifier la gestion des instructions {\bf if}
157pour des tests multiples avec et/ou.
158\end{itemize}
159
160\titre{BaseTools}
161\begin{itemize}
162\item[\rond] Avril 2012: correction de protection de limites de tracŽ dans ucckprot.h
163\end{itemize}
164
165%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
166%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
167\groupe{De V2.1 (Dec2007) ˆ V2.2 (Sep2010) }
168\titre{Global}
169\begin{itemize}
170\item[\rond] Fev 2009 : Changement de {\tt char *} en {\tt const char *} dans le code pour
171Žviter les message {\it deprecated} du compilateur lors de l'utilisation de cha”ne de caractre constante.
172\end{itemize}
173
174\titre{BuildMgr}
175\begin{itemize}
176\item[\rond] Juillet/Aout 2010 : Ajout des options et arguments suivants au script configure
177\begin{verbatim}
178 -arch32 de compilation en 32 bits pour linux
179 -followlink pour suivi des liens symboliques lors des recherches
180 de fichiers par find. Pas de suivi des liens par defaut
181 -epip pour chemin de librairies et include file PI (Motif ...)
182 -wgrdl activation compil et link piapp avec GNU-readline
183\end{verbatim}
184 {\tt -arch32} de compilation en 32 bits pour linux
185\item[\rond] Mars 2010 : Ajout de l'option {\tt -ldble128} dans le script configure pour la gestion conditionnelle
186du flag compilation {\bf SO\_LDBLE128 } dans machdefs.h. Ce flag active la dŽclaration des nombres en
187virgule flottant ˆ 128 bits ({\tt r\_16}).
188\end{itemize}
189
190\titre{BaseTools}
191\begin{itemize}
192\item[\rond] Mars 2010 : Prise en charge de float 128 bits ({\tt r\_16}) et
193{\tt complex$<$ r\_16 $>$} dans les NDataBlock et PPersist.
194Compilation conditionnelle contr™lŽe par le flag {\bf SO\_LDBLE128 }
195\item[\rond] Avril 2009 : Introduction de la classe RandomGeneratorInterface, DR48RandGen, ThSDR48RandGen
196 et FMTRandGen - La classe ThSDR48RandGen RandomGenerator
197\item[\rond] Mars 2009 : Les exceptions sophya (PExceptions ...) hŽritent de de std::exception (methode what())
198\item[\rond] Oct 2008 : Suppression des flags {\tt OS\_xxx (OS\_MACOSX OS\_LINUX OS\_AIX ...) }
199de machdefs\_mkmf.h et ajout constructeur MuTyV(uint\_4, uint\_8)
200\end{itemize}
201
202\titre{TArray}
203\begin{itemize}
204\item[\rond] Juillet 2010 : Introduction des classes de matrices carrŽes spŽciales (SSQM : Special Square Matrix).
205Suppression de la classe {\bf TriangularMatrix$<$T$>$} et du fichier {\tt triangmtx.h }.
206Voir ci-dessous pour plus d'information.
207
208\item[\rond] Mars 2010 : Prise en charge de float 128 bits ({\tt r\_16}) et
209{\tt complex$<$ r\_16 $>$} dans les TArray, TMatrix et TVector.
210 Compilation conditionnelle contr™lŽe par le flag {\bf SO\_LDBLE128 }
211
212\item[\rond] Fev 2009 : Correction du bug de SetTemp() intempestive provoquant sur-Žcriture de
213tableaux lors d'opŽration avec des SubArray.
214\item[\rond] Jan 2008 : Correction bug de protection dans TArray::Resize() \\
215(lors de resize avec ndim=BASEARRAY\_MAXNDIMS = 5)
216\end{itemize}
217
218\soustitre{SSQM: Special Square Matrix}
219Classes de matrices carrees speciales avec la hiŽrarchie dŽcrite ci-dessous. Ces classes ont ŽtŽ dŽveloppŽes au
220printemps 2009 et introduites dans SOPHYA ˆ l'ŽtŽ 2010.
221\begin{verbatim}
222AnyDataObj -- SpecialSquareMatrix<T> -- DiagonalMatrix<T>
223 -- LowerTriangularMatrix<T>
224 -- SymmetricMatrix<T>
225+ classe gestionnaire PPF FIO_SpecialSquareMatrix<T>
226\end{verbatim}
227
228Fichiers ajoutŽs dans TArray/ : \\
229{\tt spesqmtx.h spesqmtx\_tsnl.h diagmtx.h trngmtx.h symmtx.h fiospsqmtx.h} \\
230{\tt spesqmtx.cc fiospsqmtx.cc } \\
231Fichier {\tt triangmtx.h } a ŽtŽ supprimŽ (classe {\bf TriangularMatrix$<$T$>$ }
232remplacŽe par {\bf LowerTriangularMatrix$<$T$>$} . \\
233Programme test {\tt tssqmx.cc} ajoutŽ dans le module Tests/.
234Pour vŽrifier le code, faire : \\
235{\tt csh> tssqmx d ( tssqmx t , s ) } \\[1mm]
236Pour ajouter d'autres classes de matrices carrŽes:
237\begin{enumerate}
238\item DŽclarer si besoin le type ds enum SpSqMtxType (fichier spesqmtx.h)
239\item Recopier diagmtx.h en mtxnouvcarre.h (enfin, le nouveau nom de fichier/classe)
240\item changer le nom de la classe ds mtxnouvcarre.h
241\item Repasser ˆ travers les mŽthodes et constructeurs en particulier SetSize() et les
242accs aux ŽlŽments
243\item Modifier ou simplement supprimer les mŽthodes (et opŽrateurs) de multiplication de matrices
244\item Dans le fichier fiospsqmtx.cc, prŽvoir le dynamic\_cast / new $<$MatriceCarre$>$ dans :
245\hspace{5mm} FIO\_SpecialSquareMatrix(const SpecialSquareMatrix$<$T$>$ \& obj) \\
246\hspace{5mm} FIO\_SpecialSquareMatrix$<$T$>$::ReadSelf(PInPersist\& is)
247\end{enumerate}
248
249
250\titre{SkyMap/Samba}
251\begin{itemize}
252\item[\rond] Juillet 2010 : Adaptation ˆ la nouvelle classe {\bf LowerTriangularMatrix$<$T$>$}
253\item[\rond] Sep 2008 : Nettoyage cosmetique ds lambdaBuilder.h .cc - {\bf A FAIRE :} rendre
254LambdaLMBuilder thread-safe.
255\item[\rond] Aout 2008 {\bf (Samba)}: Nettoyage cosmetique ds alm.h .cc, utilisation de la
256classe RandomGenerator par la classe Alm$<$T$>$. Possibilite de specifier un objet
257RandomGenerator au constructeur de la classe SphericalTransformServer. Adaptation
258programme PrgMap/cl2map.cc.
259\item[\rond] Aout 2008 {\bf (SkyMap)} : modifs/correction ds la classe SphereECP$<$T$>$.
260Ajout m\'ethode \\
261{\tt SphereECP<T>::ExtractPartial() } \hspace{5mm} et correction calcul phi ds \\
262{\tt SphereECP<T>::PixThetaPhi() } et modif programme Tests/tsphereecp.cc
263\end{itemize}
264
265\titre{NTools}
266\begin{itemize}
267\item[rond] Aout 2010 : Ajout de la classe d'interpolation lineaire {\bf SLinInterp1D} et programme
268test Tests/tstinterp.cc
269\item[\rond] Oct 2008 : Instanciation explicite des classes
270\tcls{Image} et \tcls{ArrayFitter} pour T=uint\_4, uint\_8
271\end{itemize}
272
273\titre{SysTools}
274\begin{itemize}
275\item[\rond] Dec 2009: Introduction des classes {\bf ParallelTaskInterface, ParallelTaskFunction}
276et {\bf ParalExThread, ParallelExecutor} afin de faciliter l'Žcriture de code avec exŽcution de
277fonctions en parallle dans des threads. \\
278Voir les fichier {\tt SysTools/parlex.h .cc} et {\tt Tests/tparlex.cc}.
279\item[\rond] Fev 2009 : AmŽlioration conversion double->string pour Žviter la perte de
280prŽcision lors des Žvaluations avec les variables de l'interprŽteur (commander.cc).
281\item[\rond] Fev 2009 : AmŽlioration de la classe {\bf Timer}, prŽcision time-elapsed
282par utilisation de \\
283{\tt gettimeofday(...)} au lieu de {\tt time()}, \\
284amŽlioration calcul temps cpu pour jobs tres long (lorsque TCPU dŽpasse le maximum $2^{32}$.
285\end{itemize}
286
287\titre{FitsIOServer}
288\begin{itemize}
289\item[\rond] Avril 2008 : Ajout m\'ethodes de lecture/Žcriture tableaux avec offset: \\
290{\tt FitsArrayHandler::ReadAtOffset() , WriteAtOffset() } \\
291$\longrightarrow$ PossibilitŽ de lecture/Žcriture de tableaux par morceaux
292de HDU IMAGE
293\item[\rond] Jan 2008 : Ajout {\tt FitsInOutFile::SetBScaleBZero(...)} et type LONGLONG
294pour HDU\_Image. Enregistrement conditionnel handler TArray$<$int\_8$>$.
295\end{itemize}
296
297\titre{PI/piapp}
298{\bf IMPORTANT }\\
299{\bf A1} Reste a faire : debug / prise en charge des images avec tables de couleurs de plus de
300256 entrees dans fichier postscript. \\
301{\bf A2} Utiliser la classe PICMapDrawer dans le widget PICMapView et ajouter la possibilitŽ d'afficher une table
302de couleur dans PIScDrawWdg.
303\begin{itemize}
304\item[\rond] Introduction de la classe classe {\bf PICMapDrawer} et ajout de la possibilitŽ d'afficher
305la table de couleur dans la fentre principale PIImage. L'attribut graphique {\tt showcmap} contr™le
306l'affichage de la table. \\
307{\tt showcmap , showcmap=no , showcmap=top , \\
308showcmap=no/top/right/bottom/left/horiz/vert }
309\item[\rond] Dec 2009: Ajout des options d'affichage : \\
310{\tt cdreal cdimag cdphase cdmod (=defaut) cdmod2 } \\
311pour les tableaux 2D en mode image ou surface. Fichiers modifiŽs:
312nomtarradapter.cc , nomtmatvecadapter.cc , pitvmaad.cc , pitvmaad.h.
313\item[\rond] Ajout de gestionnaire d'Žvenements VisibilityChange ds pixtbase.cc pour gŽrer les
314problmes de fentre PIBaseWdg non rafra”chie - suppression de {\tt XFlush()/usleep() }mis
315dans piwindowx.cc en Aout 2007
316\item[\rond] Jan 2009 {\bf PI , PIext} Extension de la logique AutoFontSize (choix automatique de
317la taille de fonte comme fraction de la taille du widget a tous les PIDrawer. Valeur globale par defaut
318en variable et mŽthode statique de PIDrawer (=0.04). Changement possible par variable d'environnement
319{\bf PIDEFAFSZFRAC} et la commande piapp {\bf setdefafsz }.
320\item[\rond] Nov 2008 {\bf PIext} Ajout commande {\bf pirgbdisp} - Lecture et affichage d'image RGB
321(objet PIPixRGBArray)
322\item[\rond] Nov 2008 {\bf PI} Optimisation classe LUT, introduction typeExp
323\item[\rond] Oct 2008 {\bf PIext} : Instanciation explicite et enregistrement des adaptateurs NObjMgrAdapter pour TArray, et TMatrix/TVector $<$T$>$ pour T=uint\_4, uint\_8
324\item[\rond] Sep-Nov 2008 {\bf PI} : Modifs importantes pour permettre la visalisation des images
325ou photos couleurs (RGB) ds piapp :
326\begin{enumerate}
327\item Introduction des classes auxiliaires PIPixColIdx , PIPixRGB , PIPixRGBArray
328(nouveau fichier pipixutils.cc .h) pour support de tables de couleurs avec $>$ 256 couleurs.
329\item Ajout de tables de couleurs RGB (RGB216CM , RGB512CM, RGB4096CM, RGB32768CM)
330pour representation d'images/photos couleurs RGB
331\item Extension et modification de la classe P2DArrayAdapter, introduction de la methode
332P2DArrayAdapter::MeanVal()
333\item Modif de la classe LUT pour introduction typeRGB et methode LUT::ApplyRGB()
334\end{enumerate}
335\item[\rond] Avril 2008 {\bf (PI)}: Ajout d\'ecodage options sens des axes X,Y ˆ PiScDrawWdg. \\
336{\tt revax = axerl } (kAxeDirRtoL) \hspace{5mm} {\tt axelr} (kAxeDirLtoR) \\
337{\tt revay = axeud} (kAxeDirUpDown) \hspace{5mm} {\tt axedu} ((kAxeDirDownUp)
338\item[\rond] Fevrier 2008 {\bf (PI)}: Nouvelle m\'ethode de calcul de limite de LUT\\
339On garde les $frackeep$ valeurs centrales des pixels, cad on vire les $(1-frackeep)/2$
340valeurs les plus petites et les $(1-frackeep)/2$ valeurs les plus grandes.
341\begin{verbatim}
342 autolut=hisrng,frackeep,min,max
343\end{verbatim}
344\item[\rond] Janvier 2008 {\bf (ProgPI)} Ajout de l'option {\tt -nobsz} ˆ la commande {\bf readfits}
345et ajout de la commande de lecture array from fits : {\bf rdfitsarr}
346\end{itemize}
347
348\groupe{De V2.0 (Sep2006) ˆ V2.1 (Nov2007) }
349\titre{BuildMgr}
350\begin{itemize}
351\item[\rond] Nov 2007 : configure detecte Linux 64 bits {(\tt -> /usr/X11R6/lib64)}
352et correction bug lors de l'execution de sed pour la creation de sophyamake.inc
353{\tt AIX, -X 64 }.
354\item[\rond] Oct 2007 : Ajout flag {\tt -alsofftwfloat} au script pour compilation/link
355methodes float (r\_4) de FFTWServer.
356\item[\rond] Avril 2007 : AmŽlioration du script configure, qui prend en charge
357la gestion des diffŽrents flags de compilation (mis dans fichier machdefs.h gŽnŽrŽ
358ou dans sophyamake.inc (pour les flags du compilateur) - Nettoyage du fichier
359BaseTools/machdefs\_mkmf.h et des fichiers osname\_compilo.inc
360\begin{verbatim}
361csh> cd BuildMgr/
362csh> ./configure -h
363configure [-sbase SOPHYABASE] [-scxx SOPHYACXX] [-incln]
364 [-minc mymake.inc] [-compopt 'cc/cxxOptions']
365 [-arch64] [-sasz64] [-nofpic] [-nothsafe] [-boundcheck] [-sodebug]
366 [-extp dir1 -extp dir2 ...] [-extip dir1 -extip dir2 ... ]
367 [-extlp dir1 -extlp dir2 ... ]
368 [-noextlib] [-noext fits] [-noext fftw]
369 [-noext lapack] [-noext astro]
370 [-noPI] [-slballinone]
371 [-usefftw2 -uselapack2]
372 (See SOPHYA manual/web pages for a detailed description
373 of configure options)
374\end{verbatim}
375\end{itemize}
376
377%%%%%%
378\titre{BaseTools}
379\begin{itemize}
380\item[\rond] Novembre 2007 : Ajout de la classe de gŽnŽrateur alŽatoire
381thread-safe {\bf RandomGenerator } - fichiers {\tt stsrand.h .cc} -
382Ajout du programme {\tt Tests/tmtrnd,3.cc }.\\
383Correction , protection I/O PPF pour NDataBlock de taille nulle.
384\item[\rond] Aout 2007 : Passage numŽro de version SOPHYA V=2.135
385ˆ V=2.046 - Les numŽros V=A.B sont dŽsormais rŽservŽs aux versions
386avec un tag cvs.
387\item[\rond] Avril 2007 : {\bf ThreadSafe } \hspace{5mm}
388Les opŽrations de partage de rŽfŽrence rendues thread-safe pour les classes
389{\bf NDataBlock$<$T$>$ , SegDataBlock$<$T$>$, SwSegDataBlock$<$T$>$}
390\begin{itemize}
391\item Ajout de la classe {\bf ThSafeOp} avec les mŽthodes {\tt lock() , unlock() } utilisant
392un mutex.
393\item Ces mŽthodes peuvent tre rendues transparentes (sans effet) en activant le flag \\
394{\tt SO\_NOTHSAFE} (option -nothsafe de configure)
395\item Cette protection / synchronisation semble tre efficace en ce qui concerne les
396constructeurs de copie et l'extraction de sous-tableaux pour TArray, TMatrix,TVector.
397(programme de vŽrification Tests/zthr.cc - option sync ).
398\item En ce qui concerne les classes SegDataBlock , SwSegDataBlock, l'efficacitŽ
399de la protection n'a pas ŽtŽ testŽe. Les opŽrations d'Žcriture sur les DataTable
400devront aussi tre protŽgŽes pour l'utilisation multi-thread.
401\end{itemize}
402\item[\rond] Avril 2007 : Nettoyage du fichier machdefs\_mkmf.h, suppression des flags
403de compilation optionnelle MacOS 8.x 9.x / compilo CodeWarrior
404\item[\rond] Fev 2007 : Ajout methode NDataBlock::RenewObjId() , et Dealloc() (alias de Delete())
405et correction bug ds SwSegDataBlock::GetCstSegment()
406\end{itemize}
407
408%%%%%%
409\titre{TArray}
410\begin{itemize}
411\item[\rond] Oct 07 : MŽthode TArray::SumX2() renommŽe en SumSq(), Norm2() appelle SumSq() sauf pour les tableaux complexes, o on calcule une norme rŽelle positive (Sum[el x conj(el)).
412\item[\rond] Avr 07 : Constructeur de copie et extraction de sous-tableaux rendus thread-safe
413(voir ci-dessus)
414\item[\rond] Jan 07 : Ajout classes/methodes de cast de contenu - sans conversion (fichier arrctcast.h)
415\item[\rond] Fev 07 : Ajout methode TArray::RenewObjId() (reecriture PPF), et ZeroSize()
416(deallocation tableau / le rendre vierge=sans taille)
417\end{itemize}
418
419%%%%%%
420\titre{HiStats}
421
422\begin{itemize}
423\item[\rond] Novembre 2007 : Les methodes de remplissage de NTuple {\tt Fill() }
424et de DataTable, SwPPFDataTable {\tt AddRow() }, ainsi que
425{\tt BaseDataTable::GetRow() } rendues thread-safe. \\
426Activation avec la methode {\tt SetThreadSafe(bool fg=true) }
427pour chaque NTuple ou DataTable / SwPPFDataTable. Ajout du programme Tests/tmtdt.cc.
428\item[\rond] Janvier 2007 : Remaniement de la classe HistoErr: elle n'h\'erite plus
429de Histo et devient stand-alone avec des TVector comme support des donne\'ees. \\
430Introduction de la classe Histo2DErr qui fait la meme chose que HistoErr
431mais \`a $2$ dimensions. \\
432Modifs des adaptateurs: NOMAdapter\_Histo ne contient plus HistoErr,
433et NOMAdapter\_HistoErr, NOMAdapter\_Histo2DErr sont cr\'ees dans PIext.
434
435\end{itemize}
436
437%%%%%%
438\titre{SkyMap}
439
440\begin{itemize}
441\item[\rond] Aou 2007 : Correction de signe dans {\tt LocalMap::PixToSphereC()} suite message de
442S. Plaszczynski du 12/07/07
443\item[\rond] Fev 2007 : Ajout methode RenewObjId() (reecriture PPF) pour les cartes spheriques
444et localmap
445\end{itemize}
446
447%%%%%%
448\titre{SysTools}
449
450\begin{itemize}
451\item[\rond] Jul 2007 : Ajout d'acces au temps CPU et elapsed ds la classe Timer - et
452ajout test specifique dans Tests/tcmd.cc {\tt (tcmd timer)}. \\
453{\tt Timer::TotalElapsedTime() , PartialElapsedTime() , TotalCPUTime() , PartialCPUTime() }
454\end{itemize}
455
456%%%%%%
457\titre{FitsIOServer}
458
459\begin{itemize}
460\item[\rond] Nov 2007 : propagation des modifs BaseDataTable-Thread-safe dans
461SwFitsDataTable. Mais les SwFitsDataTable NE sont toujours pas thread-safe.
462\item[\rond] Jan/Fev 2007 : Passage a la version LONGLONG ( fits\_xxxll ) permettant
463la gestion de tailles $ > 2^{32} $
464\end{itemize}
465
466\titre{IFFTW}
467
468\begin{itemize}
469\item[\rond] Nov 2007 : Correction resize tableau de sortie {\tt FFT(complexe -> reel)} multi-dim.
470\item[\rond] Oct 2007 : Ajout version float (r\_4) des methodes {\tt FFTForward} et {\tt FFTBackward}
471a la classe FFTWServer. (compilation sous condition et flag -alsofftwfloat du script configure)
472\end{itemize}
473
474%%%%%%
475\titre{PI/piapp}
476\begin{itemize}
477%%%
478\item[\rond] Novembre 2007 {\bf PIext/ProgPI}: \\
479- Ajout commande de trace d'ellipse d'erreur {\tt errorellipse} \\
480- Axes en degres (0..360, -90..90) pour la projection molleweide et adaptation de la commande {\tt mollgrid}. Suppression de mollgridsph. \\
481- Ajout fonctions tetphi2mollX/Y() et longlat2mollX/Y() ds les fichiers d'expressi
482on ntuple generes par piapp pour trace sur projection de type molleweide. \\
483- Ajout flag [-s] a openppf . openfits/savefits comme alias de readfits/writefits.
484- Verification arret thread Reveil avant destruction de l'objet.
485\item[\rond] Octobre 2007 {\bf (PI/PIext)}: Ajout methodes de redirection stdout/stderr vers un objet PIConsole,
486a travers un fichier disque (fichiers PI/piapplx.h .cc) avec possibilite de recopie sur stdout/stderr
487original (terminal) - en plus d'affichage sur PIConsole. \\
488+ Adaptation au niveau de PIext/pistdimgapp.h .cc et ProgPI/piapp.cc \\
489+ la redirection passe par les fichiers PIATmp\_xxx/sout.log /serr.log \\
490+ le flag (s)piapp -doublered permet la redirection avec recopie sur terminal
491%%%
492\item[\rond] Octobre 2007 {\bf (PIext)}: Correction/protection au niveau de gestion des locks de mutex
493(classes NamedObjMgr , PIStdImgApp) pour eviter les blocages de l'application sous certaines
494conditions ( lors de l'affichage de la fenetre de gestion d'objets et lecture PPF). \\
495Modification des classes NamedObjMgr . ObjMgrWind, la methode
496{ \tt UpdateObjMgrWindow() } de NamedObjMgr en particulier. \\
497Ajout de la classe {\bf SOpExObj} (ds piacmd.h piacmd.cc) pour executer
498- de maniere asynchrone -
499les commandes display,print \ldots sur les objets, initiees au niveau
500de la boucle d'evenements (fenetre ObjMgrWind).
501\item[\rond] Octobre 2007 {\bf (PIext)}: Ajout attributs graphiques \\
502{\tt samew=WdgName } specification de widget cible pour trace en superposition \\
503{\tt wname=Nom } Pour specifier un nom de widget (= nom d'objet par defaut) \\
504{\tt inset=fx1,fx2,fy1,fy2 } pour specifier la position du drawer en inset (medaillon)
505\item[\rond] Octobre 2007 {\bf (PIGcont/PIext)}: Codage mŽthode PIContourDrawer::GetOptionsHelpInfo() pour le traceur de contour. \\
506Ajout accs aux attributs {\tt min max minmax sumsq norm2 } aux niveau des adaptateurs
507des objets de type TArray, TMatrix, TVector ({\tt \$\{arrName.sumsq\} \$\{arrName.min\} } \ldots).
508\item[\rond] Aout 2007 {\bf (PI)}: Nouvelles mŽthodes de calcul de limite de LUT
509dans PIImage (AutoLut) et ajout du dŽcodage de l'option {\tt autolut=alt[,ns[,minp,maxp]]}.
510Si {\tt minp,maxp} spŽcifiŽs, seuls les pixels entre {\tt minp <= pixval <= maxp}
511sont utilisŽs pour le calcul des limites.
512\begin{verbatim}
513 autolut=minmax,frac Fraction de la dynamique totale
514 autolut=meansig,ns min=mean-ns*sigma , max=mean+ns*sigma
515 autolut=histail,ns Queue de l'histo des pixels
516 autolut=hispeak,ns Pic de l'histo des pixels
517\end{verbatim}
518%
519\item[\rond] Aout 2007 {\bf (PI)}: Contournement d'un problme d'Žvenements X expose
520perdu - apparu avec des versions rŽcentes du serveur XFree ou le serveur X sur Linux
521ou une combinaison des deux. RŽsultat, contenu non affichŽ lors d'une crŽation de fentre
522suivi d'un ajout de PIBaseWidget (sauf PIImage) et plantage lors du click dans la fentre.
523Correction: Ajout de {\tt XFlush() + usleep(5000)} (5 $\mu$s).
524\item[\rond] Juin 2007 {\bf (PI/PIext)}: Ajout des mŽthodes
525{\tt PIGraphicAtt::ColNameToColor() , ColIndexToColor()} et possibilitŽ d'utiliser le contenu
526d'une colonne d'une table comme nom de couleur ou numŽro de couleur pour le tracŽ
527des markers par PINTuple {\tt PINTuple::SelectColorByName() , SelectColorByIndex()}.
528Ajout des commandes {\bf nt2dcn} et {\bf nt2dci} et {\bf plot2dc} ds piapp.
529\item[\rond] Avril 2007 {\bf (PI)}: La source des problmes sur MacOS/PowerPC (G4/G5)
530et AIX (architecture Power) a finalement ŽtŽ identifiŽ et corrigŽ/
531Parmi ces problmes: des pull-down menus mal placŽs (MenuBar), ou encore des
532dysfonctionnement de boutons dans les fentres de dialogues. \\
533Source et correction: \hspace{5mm} {\tt XtMoveWidget / XtResizeWidget} remplacŽ par \\
534\hspace*{10mm} {\tt XtMakeGeometryRequest}
535\item[\rond] Avril 2007 {\bf (PIext/piapp)}:
536\begin{itemize}
537\item Ajout de la classe {\bf NOMAdapter\_DVList}
538pour la prise en charge des objets DVList.
539Accs aux variables par {\tt \$\{dvlName.varName\} }
540\item Accs ˆ l'objet DVList attachŽ aux TArray, TMatrix, DataTable et NTuple par \\
541\hspace*{5mm} {\tt \$\{objName.info.varName\} }
542\item L'adaptateur de DataTable permet aussi d'accŽder aux lignes de la table par \\
543\hspace*{5mm} {\tt \$\{tableName.row.num\} }
544\item Prise en charge de la classe {\tt Image<T>} par l'adaptateur des matrices
545{\tt NOMAdapter\_TMatrix<T> } au lieu de l'adaptateur spŽcifique
546{\tt NOMAdapter\_Image<T> }
547\end{itemize}
548\item[ \rond] Janvier 2007 {\bf (PIext)}: modification des trac\'es des histogrammes PIHisto.
549La classe PIHisto prend en entr\'ee un wrapper P1DHistoWrapper.
550Les wrappers HistoWrapper et HistoErrWrapper sont cr\'ees.
551Ainsi les HistoErr peuvent \^etre dessin\'es sous forme d'histogrammes.
552Mise en place des options graphiques permettant de dessiner les
553valeurs (``val''), erreurs (``err'') et le nombre d'entr\'ees par bin (``nb'')
554pour les HistoErr. Idem pour les versions $2$ dimensions.
555\end{itemize}
556
557%%%%%%%%
558\titre{Documentation (Manual/) }
559\begin{itemize}
560\item[\rond] Jan 2007 : Ajout fichier de mesure de performances comparees entre
561differentes processeur / OS / compilateur {\tt perfmachine.txt }
562\end{itemize}
563
564
565%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
566%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
567\groupe{De V1.7 (Sep2003) ˆ V2.0 (Sep2006) }
568\titre{BuildMgr}
569\begin{itemize}
570\item[\rond] Juin 2006 : Ajout targets cleanobj prgall tests prgutil
571\item[\rond] Avril 2006 : suppression de libextsophya.so pour fabriquer libPI.so
572(PIext rendu independant de FitsIOServer)
573\item[\rond] Dec 2005/Jan 2006 : Portage sur AIX - xlC
574\item[\rond] Dec 2005 : check Compil avec icc , compil avec gcc-4
575\item[\rond] Avril-Mai 2005 : Introduction de la nouvelle version de
576scripts de gestion du code - avec un script principal configure. \\
577Variable d'environnement {\bf SOPHYABASE } - \\
578Pour les makefiles, l'ensemble des dŽfinitions se trouve dans : \\
579SOPHYABASE/include/sophyamake.ic \\
580\end{itemize}
581
582%%%%%%
583\titre{BaseTools}
584
585\soustitre{Modifs}
586
587\begin{itemize}
588\item[\rond] Jun/Jul 2006 : Amelioration gestion initialiseur modules \\
589- Ajout methodes statique {\tt RegisterModule(const char* name, double version)
590ListModules(ostream\& os) } a la classe de base SophyaInitiator. \\
591- Enregistrement des modules avec leur nom et un numero de version par module,
592independante du numero de version SOPHYA \\
593- le programme scanppf peut donner la liste des modules enregistrees et leur numero
594de version.
595\item[\rond] Octobre-Novembre 2005 : \\
5961/ Correction bug TimeStamp::ToDays() + petites amelioration \\
5972/ Prise en compte du type TimeStamp dans MuTyV (sous forme de double en interne) \\
5983/ Adaptation DVList a modifs MuTyV (typ TimeStamp) et R/W PPersist \\
5994/ Gestion format YYYY-MM-DDThh:mm:ss par TimeStamp \\
6005/ Gestionnaire PPersist pour TimeStamp
601%
602\item[\rond] Septembre 2004 - {\bf Namespace SOPHYA } \\
603Suppression de {\tt using namespace SOPHYA ; } ds machdefs.h -
604Ajout fichier {\tt \#include "sopnamsp.h"} dans les .cc de SOPHYA,
605ainsi que lors de la gŽnŽration automatique du code (runxx, c++exec)
606\end{itemize}
607
608\soustitre{PPF}
609\begin{itemize}
610\item[\rond] Avril 2005 - Ajout de wrapper de lecture/ecriture PPF pour les vecteurs de
611la librairie standard (classe PPFWrapperSTLVector$<$T$>$ ) fichier ppfwrapstlv.h
612\item[\rond] Ajout de la classes utilitaire PPF\_TPointer\_IO$<$T$>$
613(fichiers ppftpointer.h .cc)
614\item[\rond] Amelioration de l'impression ds AnalyseTags (ppfbinstream.cc)
615\item[\rond] scanppf.cc revision 1.8 (2005/04/05)
616modification programme scanppf: ajout option -lh -lho pour lister les classes PP
617ersist handler
618\item[\rond] DŽcembre 2003 (9/12/2003) Fin de l'ensemble des modifs pour les
619PPF V3 \\
620- Ecriture nombre complexes r4, r8 avec tag spŽcifique. \\
621Tag de positionnement sous forme de \\
622\centerline{\tt <tag (1 byte)><FilePosition (8 byte, long int)> } \\
623- Ecriture PosTagTable \\
624- Ecriture Statistiques en fin de fichier \\
625- Voir BaseTools/ppfbinstream.h: \\
626\centerline{\tt GotoPositionTag(int\_8 pos) , }
627\centerline{\tt GetPosTagTable(...) }
628\centerline{\tt int\_8 WritePositionTag() PutPosTagTable(...) }
629- Ajout programme de test Tests/ppftswap.cc
630\item[\rond] DŽcembre 2003 - Ajout ppfbinstream.h .cc \\
631Classes PPFBinaryIOStream , PPFBinaryInputStream , PPFBinaryOutputStream
632\item[\rond] Novembre 2003 (21/11/2003) - Ajout rawstream.h .cc \\
633Classes RawInOutStream , RawInFileStream , RawOutFileStream
634
635\end{itemize}
636
637
638\soustitre{Nouvelles classes}
639\begin{itemize}
640\item[\rond] Ajout de la classe {\bf TimeStamp} pour la manipulation de date et heure -
641calcul de duree. - Ajout du prog. test Tests/ttimestamp.cc (Mars 2005)
642\item[\rond] { \bf Segmented Data Block :} \\
643Mars-Avril 2005: Introduction des classes similaires aux NDataBlock, mais permettant
644de gerer des blocs de donnees segementes, pour tout type de donnees, de structures
645et de classes (template pour tout type T).
646\begin{enumerate}
647\item Ajout de la classe {\tt SegDataBlock<T>} (et l'interface { \tt SegDBInterface<T>} )
648pour la gestion de blocs de donnees segmentes (segdatablock.h) et son
649gestionnaire PPF {\tt FIO\_SegDataBlock<T>} (fichier fiosegdb.h )
650\item Ajout de la classe {\tt SwSegDataBlock<T>} (Data bloc segmente avec gestion
651de swap) et la classe swapper PPF {\tt PPFDataSwapper<T>} (fichiers
652ppfswapper.h et swsegdb.h)
653\item Ajout programme de test Tests/tstsegdb.cc
654\end{enumerate}
655\end{itemize}
656
657%%%%%
658\titre{TArray}
659%%
660Il s'agit essentiellement des ameliorations en terme de performances et
661de correction d'erreur.
662
663\begin{itemize}
664\item[\rond] Avril 2006 \\
665- Instanciation explicite des tableaux , matrices et vecteurs en types \\
666{\tt int\_2 uint\_2 uint\_4 uint\_8 } \\
667- Optimisation du code (ds tarray.cc) des operations sur tableaux \\
668{\tt (TArray::Add/Mul/Sub/DivCst TArray::Add/Mul/Sub/DivElt ) } \\
669a travers le choix entre Share() ou Allocation si le tableau resultat est non alloue.
670D'apres les tests de performances (TCPU), {\bf (tjet , spar)}, il ne semble pas y
671avoir de cas de pertes, et on a en general des gains de l'ordre de 20\% dans la plupart
672des cas de tests, et un ou deux cas avec des gains de 50-80\%. \\
673- Declaration de l'operateur / entre tableaux (DivElt) et l'operateur \& \& pour la
674multiplication element par element (MulElt)
675\item[\rond] Janvier, FŽvrier 2006 \\
676- AmŽlioration des fonctionalitŽs de la classe {\bf Range} et des mŽthodes d'extraction
677de sous-tableaux (+ correction bugs et amŽlioration documentation) \\
678- Ajout de la methode BaseArray::ValueAtPositionDB() pour corriger un gros bug au
679niveau de la conversion de type (r\_4 r\_8 ...) des tableaux \\
680- Compil avec g++ 4 : ajouts fichiers declarations privees tmatrix\_tsnl.h tvector\_tsnl.h
681
682\item[\rond] Juillet 2004 \\
683- Optimisation de la multiplication matricielle (CMV) - Extrait du
684message (from CMV) du 30 Juillet 2004: \\
685\begin{verbatim}
686- on definit un flag d'optimisation
687 Contrairement a ce qu'on avait dit, je n'ai pas ajoute
688 un argument a Multiply car on ne peut pas jouer
689 avec qiand on utilise l'operateur * surcharge.
690 Or au vu des performance il'ma parut interessant que l'utilisateur
691 meme lambda puisse choisir le niveau d'optimisation
692 --> donc j'ai ajoute une methode statis dans BaseArray::
693 void BaseArray::SetMatProdOpt(uint_2);
694 uint_2 BaseArray::GetMatProdOpt();
695
696- Je n'ai refait les test de rapidite que sur OSF:
697
6981./ pour les matrices 1000x1000 (grosses)
699 on arrive effectivement au meme temps pour les 4 cas
700 si on copie dans le cas lent (FxC)
701 ---EndMultiply FxC CPUTime: Total= 93.1296 (Partial= 69.3806) Sec.
702 devient
703 ---EndMultiply FxC CPUTime: Total= 34.9653 (Partial= 11.1829) Sec.
704 exactement comme les copains:
705 La copie prend de la place mais ne prend absolument
706 pas de temps pour les grosses matrices
707
7082./ pour les matrices 10x10 (1000000 multiplications par cas)
709 on a bien ce que l'on attend a savoir que
710 la copie faites 100000 fois finie par nous faire perdre du temps
711 ---EndMultiply FxC CPUTime: Total= 37.4152 (Partial= 12.4662) Sec.
712 devient
713 ---EndMultiply FxC CPUTime: Total= 53.9978 (Partial= 28.8322) Sec.
714 dans ce cas on perd un gros facteur 2 a cause de la copie
715 mais rien de surprenant la dedans.
716
717-----------------------------------------------------------------------
718- ensuite j'ai implemente une prise de decision au niveau de
719l'optimisation pour les petites matrices:
720le test est simple mais me semble OK:
721je calcule sza taille du NDataBlock de A
722 szb B
723si ((sza+szb)*sizeof(T) < 100000 ) pas d'optimisation
724IDEE: on pifometre que raisonnablement il y a 100 koctets
725 de disponible pour les matrices A et B dans le cache processeur
726 et que dans ce cas elles sont copiees toutes les 2 dans le cache
727 par l'optimiseur du compilo qui est tres malin et surtout qui
728 veux absolument nous faire plaisir......
729
730-----------------------------------------------------------------
731===> Les resultats sont dans le fichier toto.calc en attached
732.. En tete tu as l'explication des flags d'optimisation
733...Avec les 2 sections:
734 GROSSE MATRICE
735 et
736 PETITE MATRICE
737\end{verbatim}
738
739\item[\rond] Juillet 2004 : Optimisation operations diverses, en particulier \\
7401) Remplacement des methodes Add/Sub/Mul/DivElt(a) par
741 Add/Sub/Mul/DivElt(TArray a, TArray res) \\
7422) Operateurs += -= A+B A-B TArray et TMatrix/TVecteur modifies en consequence
743\item[\rond] Extrait de {\tt cvs log tarray.cc }
744{\small \begin{verbatim}
745----------------------------
746revision 1.38
747date: 2004/07/30 13:31:39; author: ansari; state: Exp; lines: +28 -24
748Diverses petites optimisations ds les methodes operations/affectations de TArray - Reza 30 Juillet 2004
749----------------------------
750----------------------------
751revision 1.36
752date: 2004/07/27 11:44:23; author: ansari; state: Exp; lines: +4 -1
753Corrections bug apres modifs methods Add/Sub/Mul/DivCst(x,res) - Reza 27 Juillet 2004
754----------------------------
755revision 1.35
756date: 2004/07/26 17:30:40; author: ansari; state: Exp; lines: +187 -108
757Remplacement methodes Add/Mul/Sub/Div(T x) par AddCst/MulCst/SubCst/DivCst(T x, TArray<T> res) ds TArray - Reza 26 Juillet 2004
758----------------------------
759\end{verbatim} }
760
761\item[\rond] Extrait de {\tt cvs log tarray.cc }
762{\small \begin{verbatim}
763----------------------------
764revision 1.27
765date: 2004/07/30 10:24:12; author: cmv; state: Exp; lines: +97 -32
766- Intro decision auto d'optimisation produit de matrices
767- Possibilite a l'utilisateur pour choisir l'optimisation
768- cas FxC optimise par copie
769 cmv 30/07/04
770----------------------------
771revision 1.26
772date: 2004/07/29 12:31:16; author: ansari; state: Exp; lines: +7 -5
7731/ Remplacement des methodes Add/Sub/Mul/DivElt(a) par
774 Add/Sub/Mul/DivElt(TArray a, TArray res)
7752/ Operateurs += -= A+B A-B TArray et TMatrix/TVecteur modifies en consequence
7763/ Ajout methode TArray::ScalarProduct()
7774/ Methode TArray::SetT renomme en SetCst() SetT garde en alias
7785/ Ajout parametre bool fzero (mise a zero) ajoute ds constructeur et
779 ReSize() de TMatrix et TVecteur.
780 Reza 29/07/2004
781----------------------------
782revision 1.25
783date: 2004/07/29 08:40:49; author: cmv; state: Exp; lines: +148 -1
784Optimisation produit de matrice a la sauce cmv 29/07/04
785----------------------------
786\end{verbatim} }
787
788\end{itemize}
789
790
791%%%%%%%%
792\titre{HiStats}
793%%%%%
794\soustitre{Classe Histo,HProf,HistoErr,Histo2D }
795\noindent
796- Aout 2006 : refonte profonde des allocations memoire et delete de
797 Histo,HProf,HistoErr,Histo2D pour faciliter la gestion des IO FITS. \\
798- Sept 2004 : Ajout classe HistoErr.
799C'est un Histo qui garde le nombre d'entr\'ees dans chaque bin) \\
800\soustitre{NTuple}
801la classe NTuple peut maintenant avoir des colonnes float ou double.
802Il y a maintenant deux methodes Fill(r\_4 *) et Fill(r\_8 *)
803Les noms ne sont plus limites a 8 caracteres.
804
805
806\soustitre{ Les DataTable (SuperNTuple) }
807
808{\bf Octobre-Novembre 2005 } \\
809\begin{itemize}
810\item[\rond] Ajout classe {\bf DataTableRow} pour manipulation d'une ligne de la table.
811Ajout/maj methode BaseDataTable::EmptyRow() AddRow() GetRow()
812\item[\rond] Gestion des types {\tt complex<r\_4> , complex<r\_8> , TimeStamp } par
813BaseDataTable, DataTable et SwPPFDataTable
814\item[\rond] Codage methode Print() (Dump ascii) et NTFrAscii (decodage fichier
815text) dans BaseDataTable.
816\item[\rond] Codage mŽthode BaseDataTable::GetColumnD() pour recuperer
817une colonne de la table en {\tt TVector<r\_8>} - NON TESTE
818\end{itemize}
819
820\begin{verbatim}
821BaseDataTable
822 -------- DataTable
823 -------- SwPPFDataTable
824\end{verbatim}
825
826\noindent {\bf BaseDataTable} : Classe de base, avec qques methodes virtuelles
827pures, implementent la presque totalite des fonctionalites, en particulier
828celles de l'interface NTupleInterface.
829
830\noindent {\bf DataTable} : Implementation concrete de BaseDataTable avec donnees en
831memoire \\
832(utilise SegDataBlock$<$T$>$ pour stocker les colonnes)
833
834\noindent {\bf SwPPFDataTable} : Implementation concrete de BaseDataTable avec donnees
835en swap sur stream PPF (POutPersist)- \\
836Utilise (SwSegDataBlock$<$T$>$ avec
837un data-swapper PPF (classe PPFDataSwapper$<$T$>$ )
838
839DataTable et SwPPFDataTable respecte +/- les conventions SOPHYA ,
840constructeur de copie avec partage ou copie de donnees, operateur =
841Datatable : partage et copie , = : fait une copie
842SwPPFDataTable : C'est toujours partage (presque par definition)
843Autre point, compte tenu de la structure des streams PPF ,
844les SwPPFDataTable fonctionne en ecriture OU en lecture, mais
845pas les deux a la fois.
846
847Classe de gestion de persistence commune : \\
848{\bf ObjFileIO$<$BaseDataTable$>$ }
849
850Lit et ecrit les DataTable et SwPPFDataTable
851Actuellement, on ne peut les relires que dans le meme type,
852cad on ne peut relire avec un SwPPFDataTable un objet
853ecrit comme DataTable - mais cette possibilite pourra
854peut-etre codee ulterieurement (d'ou l'interet en particulier
855d'un gestionnaire commun ObjFileIO$<$BaseDataTable$>$
856
857(les operateurs habituel $<<$ et $>>$ sur PIn/OutPersist sont definies)
858
859
860Les merges et copie sont prevues,
861on doit en principe pouvoir ecrire par exemple:
862\begin{verbatim}
863SwPPFDataTable swdt;
864PInPersist pis("swdt.ppf");
865pis >> swdt;
866DataTable dt;
867dt = swdt; // Pour tout charger en memoire
868\end{verbatim}
869
870{\it On pourra aussi ajouter des methodes d'acces aux variables
871membres pour enrichier l'interface. }
872
873
874{\bf DataTable cote PIAPP :} \\
875Cote piapp, les DataTable et SwPPFDataTable sont pris en charge par
876{\tt NOMAdapter\_DataTable} (qui prend en charge tous les 'BaseDataTable' )
877Il faudrait peut-etre rajouter deux commandes : \\
878newdt ou newdatatable
879newdt ncol col1 [col2 .... ] \\
880avec possibilite de specifier coli sous fome de X:colname ou X = D,F,S,I,L ...
881et puis dtfromascii ...
882
883Voir Tests/tnt.cc pour exemple d'utilisation :
884\begin{verbatim}
885DataTable dt(64);
886dt.AddIntegerColumn("line");
887dt.AddDoubleColumn("x");
888dt.AddFloatColumn("f_sin");
889MuTyV rec[10];
890for(int k = 0; k<1000; k++) {
891 rec[0] = k;
892 double x = M_PI*k/100.;
893 double fx = sin(x)*cos(x);
894 rec[1] = x;
895 rec[2] = sin(x);
896}
897 POutPersist po("dtable.ppf");
898 po << dt;
899\end{verbatim}
900
901Pour SwPPFDataTable, il faut juste creer un stream PPF avant, qui doit rester
902ouvert tant que le SwPPFDataTable est actif: \\
903\begin{verbatim}
904 POutPersist po("swdtable.ppf");
905 SwPPFDataTable dt(po, 64);
906\end{verbatim}
907
908
909
910\titre{SkyMap}
911%%%
912\begin{itemize}
913\item[\rond] Juin 2006: Prise en charge du rangement mŽmoire {\bf NESTED} dans
914les SphereHEALPix , + I/O PPF et FITS
915\item[\rond] Juin 2006: Nettoyage et amŽliorations diverses dans les classes
916Vector3d, UnitVector, LongLat \ldots et les cartes sphŽriques, en particulier :
917\begin{enumerate}
918\item Nettoyage/uniformation mŽthodes {\tt Print()} des cartes, et
919 ajout de la mŽthode {\tt Show()} dans PixelMap
920 \item Ajout mŽthodes {\tt HasSymThetaSlice() , GetSymThetaSliceIndex() }
921 dans les cartes sphŽriques (SphericalMap)
922 \item Ajout methode {\tt ResolToSizeIndex() SizeIndexToResol() }
923 ds SphereThetaPhi , SphereHEALPix et SphereECP
924 \item Petites optimisations dans {\tt GetThetaSlice()} + methode {\tt GetThetaSliceDataPtr() }
925 \end{enumerate}
926\item[\rond] Juin 2006: Introduction de la classe {\bf Angle} - pour conversion d'angle.
927\begin{verbatim}
928 // Example to convert 0.035 radians to arcsec
929 double vr = 0.035;
930 cout << "Angle rad= " << vr << " ->arcsec= " << Angle(vr).ToArcSec() << endl;
931 // Example to convert 2.3 arcmin to radian - we use the conversion operator
932 double vam = 2.3;
933 cout << "Angle arcmin= " << vam << " ->rad= "
934 << (double)Angle(vam, Angle::ArcMin) << endl;
935\end{verbatim}
936%
937
938
939\item[\rond] {\bf SphereECP} - Septembre 2004 \\
940Extrait du message du 7 Septembre 2004
941\begin{verbatim}
942 J'ai mis dans la base (module SkyMap) le code de la classe
943SphereECP<T> (pixelisation avec projection cylindrique) - carte partielle et complete,
944+ gestionnaire PPersist + modifs adaptateur NomSkyMapAdaptor (PIext/ spiapp)
945
946Programme test (avec appel a transforme en Alm) ds Test/tsphereecp.cc
947Attention, mettre le parametere de pixelisation a -1 lors de l'appel a Generate pour eviter
948le Resize de la sphereECP
949ylmserver.GenerateFromCl(map, -1, clin, 0.);
950
951Dans piapp, c'est visualise par defaut en projection Molleweide
952On peut ajouter dans les options d'affichage :
953ecparray : affichage direct du tableau TArray des pixels (X:Phi, Y:Theta)
954Si option ecparray, on peut preciser en plus
955 - ecpscaledeg: echelle des axes en degres au lieu de pixels
956 - ecpscalerad: echelle des axes en radians au lieu de pixels
957Exemple:
958Cmd> disp mapecp 'ecparray ecpscaledeg zoomx2 stdaxes'
959\end{verbatim}
960
961\item[\rond] Bug non corrigŽ ds classe Circle
962\begin{verbatim}
963From: Laurence Perotto <perotto@cdf.in2p3.fr>
964Date: Mon Jan 5, 2004 4:59:12 PM Europe/Paris
965To: Reza Ansari <ansari@lal.in2p3.fr>, Christophe Magneville <cmv@hep.saclay.cea.fr>
966Subject: un bug dans sophya...
967
968 Bonjour et bonne annee a tous les deux...
969
970 Je viens de trouver un ptit bug dans la fonction TanOnCircle de la classe Circle: Il
971s'agit d'un melange entre les coordonnees (beta, lambda) de Benoit et les (theta, phi)
972utilises dans Sophya. Lors du passage de l'un a l'autre, une transfo sin->cos a ete
973oubliee...
974 Voila...
975 Bonne journee.
976
977 Laurence.
978\end{verbatim}
979\end{itemize}
980
981\titre{Samba }
982
983\begin{itemize}
984\item[\rond] {\bf Juin 2006:} correction bug de calcul $a_{lm} \rightarrow$ SphereHEALPix
985(zones polar cap): le problme venant du choix de taille lors du calcul de la transformŽ
986de Fourier complex $\rightarrow$ rŽel (n/2 - 1 ou n/2 -2) .
987Correction dans {\tt RfourierSynthesisFromB } et utilisation de cette mŽthode
988pour tout type de carte.
989On gagne un peu encore en temps de calcul - sur asc (OSF1-cxx) , avec
990SphereThetaPhi(m=400), $l_{max} = 511$ \\[2mm]
991\begin{tabular}{|l|c|c|}
992\hline
993OpŽration & TCPU Avant & TCPU Aprs OPT \\
994\hline
995map $\rightarrow a_{lm}$ & 10 s & 3.6 s. \\
996$a_{lm} \rightarrow$ map & 26 & 10.5 s. \\
997\hline
998\end{tabular} \\[1mm]
999%
1000\item[\rond] {\bf Mai 2006:} Optimisation calcul transformŽ en harmoniques sphŽriques
1001{\bf SphericalTransformServer}. \\
1002Au lieu de calculer un tableau de $\lambda_{lm}$ dans LambdaLMBuilder
1003et utiliser ensuite ce tableau, on calcule les sommes nŽcessaires au vol,
1004dans des mŽthodes spŽcifiques de la classe LambdaLMBuilder qui
1005sont utilisŽes dans SphericalTransformServer (pour les transformŽs
1006scalaire/tempŽrature) - PAS fait pour la polarisation pour le moment.
1007On peut encore gagner un facteur 2 en utilisant la symŽtrie
1008en $\theta <> \pi-\theta$. \\
1009Extrait de cvs log :
1010\begin{verbatim}
1011revision 1.8
1012date: 2006/06/01 11:34:50; author: ansari; state: Exp; lines: +147 -12
10131/ passage en sa_size_t (au lieu de int) dans Alm<T> et Bm<T>
10142/ Ajout des methodes optimisees (statiques) pour calcul transforme Ylm
1015ds LambdaLMBuilder et utilisation ds SphericalTransformServer
1016 Reza , 1/06/2006
1017\end{verbatim}
1018
1019\item[\rond] {\bf Fin 2004} : Tests et vŽrifications des polynomes de Legendre.
1020La classe LambdaLMBuilder donne les bons r\'esultats mais calcule les Plm
1021pour tous les $l,m$.
1022Introduction d'une routine (C-like) ``HarmSph\_array\_teta'' qui calcule
1023les Plm pour $m$ fix\'e et $l\in [0,l_{max}]$ comme ce qui est fait
1024dans la GSL... (la routine GSL ne marche pas corectement).
1025\end{itemize}
1026
1027%%%%%%%%%%%
1028\titre{SysTools}
1029{\bf Mai-Juin 2006 } classe ZThread - petites modifs/amŽliorations liŽes
1030ˆ la gestion des signaux et mŽthodes kill
1031
1032\soustitre{Classe SOPHYA::Commander (module SysTools) }
1033Mai-Juin 2006:
1034Debug (?) de gestion/controle des threads dans la classe Commander -
1035Extrait de cvs log :
1036\begin{verbatim}
1037date: 2006/05/29 17:27:35; author: ansari; state: Exp; lines: +62 -11
1038Ajout gestionnaire signal ds ZThread et correction/adaptation gestion des thread
1039s (killthr) dans Commander - Reza 29 mai 2006
1040----------------------------
1041revision 1.7
1042date: 2006/04/26 15:22:09; author: ansari; state: Exp; lines: +13 -0
1043ajout methode ZThread::kill() pour envoi de signal a un thread + remplacement Ca
1044ncelThread par StopThread (par kill/SIGUSR1) dans Commander (commander.cc) + ame
1045----------------------------
1046revision 1.22
1047date: 2006/05/31 12:30:13; author: ansari; state: Exp; lines: +20 -11
1048correction gestion & pour ThrExec ds Commander - Reza 31/05/2006
1049----------------------------
1050revision 1.21
1051date: 2006/05/29 17:27:35; author: ansari; state: Exp; lines: +37 -16
1052Ajout gestionnaire signal ds ZThread et correction/adaptation gestion des thread
1053s (killthr) dans Commander - Reza 29 mai 2006
1054----------------------------
1055revision 1.20
1056date: 2006/04/26 15:22:08; author: ansari; state: Exp; lines: +55 -15
1057ajout methode ZThread::kill() pour envoi de signal a un thread + remplacement Ca
1058ncelThread par StopThread (par kill/SIGUSR1) dans Commander (commander.cc) + ame
1059lioration documentation , Reza 26/4/2006
1060
1061\end{verbatim}
1062
1063Mars-Avril 2004 :
1064Classe d'interprŽteur de ligne de commande inspire de C-Shell,
1065destine a etre incluee dans des applications C/C++. \\
1066( Programme test Test/tcmd.cc ) \\
1067Avril 2005 : Introduction de la possibilite d'execution de commandes
1068en multithreads \\
1069Avril 2005 : Controle strict sur les noms de variables, limites
1070aux caracteres alphanumeriques + underscore - Adaptation
1071de l'algorithme de substitution en consequence.
1072
1073{\bf Mini guide de l'interpreteur - Message du 19 Mars 2004 } \
1074
1075\begin{itemize}
1076
1077\item[\rond] {\bf Gestion des variables } \\
1078 - Les variables sont non typees toutes traitees comme des chaines
1079de caracteres.
1080 - Acces aux variables d'environnement -
1081 - Un niveau variable d'environnement application est aussi prevu
1082 - Toutes les variables de l'interpreteur sont traitees comme des vecteurs.
1083extensibles automatiquement (difference avec le C-Shell)
1084
1085\item[\rond] {\bf Creation / initialisation de variables } \\
1086\begin{verbatim}
1087Cmd> set sv StringValue
1088# Suppression d'une variable : unset ou clearvar
1089Cmd> unset sv
1090
1091# Initialisation de type vecteur - Espace avant/apres ')' et avant ')' obligatoire
1092Cmd> set vecv ( mot1 mot2 mot3 mot4 mot5 )
1093#Calcul numerique : expression de type C - Espace avant/apres '=' obligatoire
1094Cmd> a = 2+3*sqrt(4)
1095# Le signe egal peut etre utilise pour attribuer une chaine de caracteres
1096Cmd> a = 'Bonjour Madame'
1097# Un element de tableau peut etre specifie avant le signe egal
1098Cmd> vecv[2] = 'coucou'
1099# Ou bien
1100Cmd> i = 3
1101Cmd> vecv[i] = 'Ooohhh'
1102\end{verbatim}
1103
1104A droite du signe egal (membre de droite), les variables doivent etre
1105adressees a l'aide du signe \$.
1106
1107Une chaine peut etre cassee en mots a l'aide de la commande var2words
1108\begin{verbatim}
1109Cmd> var2words varname wordvarname [separateur]
1110\end{verbatim}
1111
1112\item[\rond] {\bf Acces aux variables } \\
1113L'acces aux variables s'effectue par le signe \$ {\tt \$varname} .
1114Les {\tt \$xxx} sont remplaces par le contenu de la variable xxx.
1115Cette substitution ne s'effectue pas entre simple quotes {\tt ' ... \$xxx '},
1116mais se fait entre double quotes {\tt " ... \$xxx ... "} . Les formes
1117{\tt \${vname} } ou {\tt \$(vname)} peuvent etre utilisees.
1118
1119\begin{verbatim}
1120Cmd> x = 'Hello'
1121Cmd> echo $x
1122# Taille d'une variable de type vecteur $#vname
1123Cmd> set vx ( 111 2222 3333 444444 )
1124Cmd> echo $#vx
1125# Acces aux elements de tableau
1126Cmd> echo $vx[0] $vx[1]
1127# ou bien indexe par une variable
1128Cmd> i = 2
1129Cmd> echo $vx[i]
1130# Une syntaxe particuliere: $[vname] retourne le contenu de
1131# la variable dont le nom est ds vname
1132Cmd> zzz = 'Commander'
1133Cmd> xxx = 'zzz'
1134Cmd> echo '$[xxx]= ' $[xxx]
1135$[xxx]= Commander
1136\end{verbatim}
1137
1138Variables d'environnement: L'acces aux variables d'environnement
1139se fait simplement par{\tt \$varenvname}. Attention, les variables locales
1140de l'interpreteur sont prioritaires.
1141
1142\item[\rond] {\bf Variables particulieres: } \\
1143{\tt \$retval} ou {\tt \$retstr} : chaine specifee sur la derniere commande return
1144{\tt \$status} : code de retour de la derniere commande executee.
1145(variable existe et est rempli - mais il faudra se donner une regle
1146plus claire ...)
1147Arguments des fichiers .pic appeles par la commande exec
1148{\tt \$\# } : nombre d'arguments, a part \$0
1149{\tt \$0} nom du fichier ou du script
1150{\tt \$1 \$2 \$3} .... les arguments (pour les scripts et les .pic (exec))
1151
1152
1153\item[\rond] {\bf Structures de controle } \\
1154\begin{verbatim}
1155foreach f ( w1 w2 w3 ... )
1156 ...
1157 echo $f
1158end
1159\end{verbatim}
1160
1161Espace avant/apres '(' et avant ')' obligatoire.
1162
1163\begin{verbatim}
1164foreach v vecname
1165 ...
1166 echo $v
1167end
1168\end{verbatim}
1169
1170Boucle de type integer:
1171\begin{verbatim}
1172for i startInt:endInt[:stepInt]
1173 ....
1174 echo $i
1175end
1176\end{verbatim}
1177
1178Boucle de type float
1179\begin{verbatim}
1180for f startFloat:endFloat[:stepFloat]
1181 ....
1182 echo $f
1183end
1184\end{verbatim}
1185
1186Boucle sur les lignes d'un fichier:
1187\begin{verbatim}
1188forinfile line FileName
1189 ...
1190 echo $line
1191end
1192\end{verbatim}
1193
1194Instruction {\tt break} pour casser une boucle
1195
1196\item[\rond] {\bf Les tests }
1197\begin{verbatim}
1198if ( test ) then
1199endif
1200
1201if ( test ) then
1202 ....
1203else
1204 ....
1205endif
1206\end{verbatim}
1207
1208Espace avant/apres '(' et avant ')' obligatoire.
1209
1210test de type {\tt a == b} OU {\tt a != b} OU {\tt a < b} OU {\tt a > b}
1211OU {\tt a <= b} OU {\tt a >= b}
1212les espaces avant l'operateur de comparaison sont obligatoires.
1213{\tt ==} et {\tt !=} effectue une comparaison de chaines de caracteres.
1214{\tt < , > , <= , >=}une comparaison apres conversion en valeur flottante.
1215
1216\item[\rond] {\bf Definition de script } \\
1217\begin{verbatim}
1218defscript scriptname [description ]
1219 ....
1220endscript
1221\end{verbatim}
1222
1223L'appel a un script se fait simplement a l'aide
1224du nom de script (contrairement aux fichiers
1225de commande qui sont executes a l'aide de la
1226commande {\tt exec} )
1227\begin{verbatim}
1228Cmd> scriptname arg1 arg2 arg3 ....
1229\end{verbatim}
1230
1231L'instruction {\tt return} provoque l'arret (et le retour) d'execution d'un
1232script ou d'un fichier de commandes.
1233Commandes {\bf listscript }et {\bf clearscript scriptname}
1234 permettet d'avoir la liste des scripts
1235 definis / supprimer la definition d'un script
1236
1237\item[\rond] {\bf Autres commandes}
1238\begin{itemize}
1239\item Instruction {\bf echo } pour ecrire sur cout/stdout
1240\item Instruction {\bf echo2file} pour ecrire a la fin d'un fichier
1241\item Instruction {\bf sleep nsec} (attente de nsec seconds )
1242\item Instructions {\bf timingon , timingoff , traceon , traceoff } \\
1243%
1244\item Commande {\bf exec commandfilename [arg1 arg2 ... ] }
1245\item Commandes {\bf help et help keyword/commandname }
1246\item Commandes {\bf listvars , listcommands }
1247\item Defintion et liste d'alias : {\bf alias aliasname 'string ' } et {\bf listalias}
1248\end{itemize}
1249
1250\item[\rond] {\bf Threads d'execution de commandes (Avril 2005)} \\
1251Possibilite de lancer des commandes (autre que les commandes
1252 de l'interpreteur lui-meme) en thread separe (il suffit de mettre un \&
1253 a la fin de la commande) \\
1254 Commandes des gestion des threads : \\
1255 {\bf thrlist ; cleanthrlist ; cancelthr ThId ; waitthr } \\
1256 Attention, la possibilite de lancer des commandes en threads separes ne fonctionne que
1257pour des commandes "thread-safe".
1258La plupart de nos commandes de piapp sont \\
1259 - soit trop rapide, \\
1260 - soit non "thread-safe" \\
1261
1262 \item[\rond] controle d'execution : \\
1263Possibilite d'arreter l'execution de l'interpreteur (dans une boucle
1264 ou dans dans un fichier .pic ...
1265 Utiliser la commande {\bf stop} ou {\tt <Cntrl C>} dans PIConsole
1266
1267\end{itemize}
1268
1269\soustitre{Classes CExpressionEvaluator et RPNExpressionEvaluator }
1270\begin{itemize}
1271\item[\rond] Ajout des classes RPNExpressionEvaluator et CExpressionEvaluator
1272d'Žvaluation d'expressions numŽriques en notation polonaise inverse
1273et avec la syntaxe C . Utilise dans la classe Commander.
1274\item[\rond] Programme test Test/tcmd.cc
1275\item[\rond] extrait de {\tt cvs log cexpre.cc }
1276{\small \begin{verbatim}
1277----------------------------
1278revision 1.3
1279date: 2004/03/18 18:15:19; author: ansari; state: Exp; lines: +10 -6
1280Suite (presque finie) des modifications de l'interpreteur - gestion des variables en particulier - Reste au moins un bug ds CExpressionEvaluator - Reza 18/03/2004
1281----------------------------
1282revision 1.2
1283date: 2004/03/16 08:47:48; author: ansari; state: Exp; lines: +5 -6
1284suppression variables inutilisees ds cexpr.cc - Reza 16 Mars 2004
1285----------------------------
1286revision 1.1
1287date: 2004/03/15 22:19:43; author: ansari; state: Exp;
1288Ajout fichiers des classes RPNExpressionEvaluator et CExpressionEvaluator (expression arithmetiques) et MAJ du fichier Makefile et objlist.list - Reza 15 Mars 2003
1289\end{verbatim} }
1290
1291\item[\rond] Extrait du message du 3 Mars 2004
1292\begin{verbatim}
1293Le code est base sur une hierarchie de classe d'expression :
1294 Expr -------- NumberExp
1295 --------- BinExp ------ AddExp
1296 ------ MulExp
1297 ------ SubExp
1298 ------ DivExp
1299 --------- FuncExp
1300 --------- CExpressionEvaluator
1301
1302NumberExp : expression elementaire de nombre, sait actuellement traduire Pi et E
1303 tres facile d'ajouter d'autres constantes
1304BinExp: Classe d'operations binaires (deux operandes) a+b a-b a*b a/b
1305 avec gestion de niveau de priorite des operateurs
1306 On peut facilement ajouter d'autres operateurs binaires (par exemple
1307 puissance ^ a^b ) - et les priorites relatives seront gerees en principe.
1308FuncExp: classe d'expression fonctionnelle, avec n arguments f(x1,x2,...x3)
1309 actuellemenent, n=0 a n=3 arguments et quelques fonctions
1310 usuelles sont decodes ds cette classe (sin,cos,tan, asin, acos, atan, exp, log,
1311 atan2, pow ) - voir ds le code
1312
1313CExpressionEvaluator : C'est la classe de haut niveau a utiliser -
1314 la fonction de decodage de la chaine ASCII (qui utilise
1315 les fonctionalites des differentes classes est la dedans
1316 et ce n'est pas tres long.
1317(+ une classe d'exception specifique).
1318\end{verbatim}
1319
1320\end{itemize}
1321
1322
1323%%%%%%%%
1324\titre{FitsIOServer}
1325%%%
1326\begin{itemize}
1327\item[\rond] Aout 2006 : Ecriture/Lecture des classes Histo,HProf,HistoErr,Histo2D dans fichier FITS.
1328Les Histo2D et leurs projections 1D associ\'ees sont lus et \'ecrits
1329sur plusieurs HDU cons\'ecutifs.
1330\item[\rond] Juin 2006 : Ajout verification/correction noms de colonne lors de lecture FITS / DataTable,
1331et remplacement throw par un warning lors de lecture fits-healpix avec $nbcols > 1$ \\[1mm]
1332\item[\rond] { \large Sep 2005-Jan 2006 : Refondation totale du module }
1333\begin{itemize}
1334\item[\rond] Amelioration du programme PrgUtil/scanppf -
1335(scanfits -V1 -lh -rd -header filename)
1336\item[\rond] La classe FitsFile (et donc FitsInFile FitsOutFile) heritent de FitsInOutFile.
1337(Jan 2006)
1338\item[\rond] Fonctionalites classe {\bf FitsManager } etendues - en particulier ScanFile()
1339\item[\rond] Les FitsIOHandler (ancien) heritent de FitsHandlerInterface -
1340Tous les handlers sont pris en charge et enregistre par FitsManager (Jan 2006)
1341\item[\rond] Ajout classe d'initialisation du module {\bf FitsIOServerInitiator },
1342fichiers fiosinit.h .cc (Dec 2005)
1343\item[\rond] Classe { \bf SwFitsDataTable } (DataTable avec swap sur FITS) ajoute
1344 + classe FitsHandler<BaseDataTable> modifie pour prise
1345en charge de SwFitsDataTable (Dec 2005 - Jan 2006)
1346\item[\rond] Classes {\bf FITSDataSwapper$<$T$>$} modifies (Dec 2005)
1347\item[\rond] Prise en charge de types TSTRING et TCOMPLEX et TDBLCOMPLEX
1348lors de lecture/ecriture de colonnes FITS.
1349\item[\rond] Prise en charge de l'ensemble des types de colonnes pour le handler de Fits
1350de DataTable
1351\item[\rond] Classe {\bf FitsInOutFile } comme wrapper des fonctions de la librairie cfitsio +
1352classe d'exception spŽcifique {\bf FitsIOException} , et la classe des types FITS {\bf FitsTypes}.
1353\item[\rond] Classe template {\bf FitsBlockRW$<$T$>$} pour lecture/Žcriture (tableaux de donnŽes)
1354sur IMGHDU et Tables.
1355\item[\rond] Classes gestionnaires I/O Fits pour les objets {\bf FitsHandler$<$T$>$} et {\bf FitsManager}
1356\item[\rond] Classes gestionnaire pour les tableaux : {\bf FitsArrayHandler$<$T$>$}
1357\item[\rond] Classes gestionnaire pour les DataTable {\bf FitsHandler$<$BaseDataTable$>$}
1358\item[\rond] Mai 2005 : Classe {\bf FITSDataSwapper$<$T$>$} pour la gestion des
1359SwSegDataBlock sur fichiers FITS
1360\end{itemize}
1361\end{itemize}
1362
1363\titre{LinAlg}
1364Extension des fonctionalitŽs de la classe {\tt LapackServer<T>} :
1365(Juillet 2004 / cmv , FŽvrier 2005 / Reza)
1366\begin{itemize}
1367\item[\rond] Ajout lancement d'exception sur renvoi de code d'erreur par lapack
1368(desactivable par flag au niveau du constructeur de la classe serveur)
1369\item[\rond] Introduction de l'interface Lapack d'inversion des matrices symetriques (21/7/2004)
1370\item[\rond] Introduction de l'interface Lapack de recherche de valeurs et vecteurs propres
1371 (cas general, symetrique et hermitique) (21/7/2004)
1372\item[\rond] Introduction d'un fonction d'interface pour le calculateur de workspace
1373 (ilaenv\_) (21/7/2004)
1374\item[\rond] Ajout prog test Tests/tsttminv.cc + Commentaires sur les diverses methodes et sur les matrices FORTRAN (21/7/2004)
1375\item[\rond] Ajout SVD decomp by Divide and Conquer SVD\_DC (23/7/2004)
1376\item[\rond] Ajout Least Square with SVD DC
1377\item[\rond] Ajout methode calcul de la matrice inverse par Lapack en utilisant la
1378resolution de systemes (07/02/2005)
1379\end{itemize}
1380
1381\titre{IFFTW}
1382\noindent
1383- Juillet 2007 : Passage a FFTW 3 \\
1384- Nov 2005 : Correction du bug dans le cas de FFT-1D Backward(complex -> reel)
1385in(1).imag() pouvait etre ecrase.
1386
1387\titre{PI,PIext,piapp}
1388\soustitre{PI: Classes modifiees - ameliorees}
1389\begin{itemize}
1390\item[\rond] {\bf PIImageNavigator } \\
1391Ajout de la classe {\tt PIImageNavigator } permettant de visualiser une image
1392avec ses propres widget zoom / global view et colormap. (Fevrier 2005) \\
1393Commande {\tt imagnav} ajoute ds piapp/baseexcute.cc . \\
1394\item[\rond] Avril 2005 - Amelioration de la classe {\bf PIConsole} \\
13951/Envoi Message PIMSG\_Cancel lors de {\tt <Cntl C>} \\
1396 2/ Correction positionnement curseur lors de rappel de commande,
1397 Si possible en fin de commande - mais toujours avec le
1398 debut de commande visible. \\
13993/ Correction (probable) du petit bug sur les derniers caracteres lors de copier/coller
1400 ds PIConsole
1401\item[\rond] Codage Options graphiques en text (string) pour PIGraphicAtt (Nov-Dec 2005)
1402\item[\rond] Corrections diverses trace d'axes etc ... (Dec 2005)
1403\item[\rond] PIext rendu indŽpendant de FITS (Avril 2006) - commandes spŽcifiques dans
1404ProgPI/fitsbtadapter.cc
1405\item[\rond] BUG A corriger, DrawOpaqueString ds PIGraphPS (sortie postscript)
1406\end{itemize}
1407%%%%
1408\soustitre{ Codage texte des options graphiques (11 Mars 2004)}
1409\begin{verbatim}
1410// Methode retournant un vecteur de string a partir des options
1411virtual int PIDrawer::OptionToString(vector<string> & opt) const
1412qui vient completer les deux methodes
1413virtual int PIDrawer:: DecodeOptionString(vector<string> & opt, bool ...) et
1414virtual void PIDrawer:: GetOptionsHelpInfo(string& info);
1415Ces methodes s'occupent de decoder les options graphiques (et l'aide
1416associe). La methode ajoutee permet de faire l'operation inverse, fabriquer
1417une serie de chaine de caracteres a partir des options graphiques.
1418Il y a aussi la methode
1419virtual int PIWdgGen::OptionToString(vector<string> & opt) const
1420que j'ai ajoute (rien a faire pour le moment) - ainsi que
1421int PIGraphicAtt::AttToStrings(vector<string> & att) const.
1422
1423Peux-tu remplir la methode PIGraphicAtt::AttToStrings(vector<string> & att) const.
1424L'implementation par defaut de PIDrawer::OptionToString(vector<string> & opt) const
1425appelle PIGraphicAtt::AttToStrings() - a laisser donc tel quel.
1426
1427par contre, pour les autres drawer (PIYfXDrawer, PIFuncDrawer, PIElDrawer,
1428PISurfaceDrawer, PIHisto, PIHisto2D, PINTuple ...) - lorsque
1429DecodeOptionString(vector<string> & opt, bool ...) est modifie,
1430rajouter la methode OptionToString(vector<string> & opt) et verifier le help.
1431Attention, il ne faut pas mettre l'argument opt a zero, mais ajouter des chaines
1432derriere (push_back()) afin de pouvoir cumuler les options de base + options
1433specifiques.
1434
1435Comment tester ?
1436Pour tester, tu peux utiliser la fenetre des options texte ou j'ai ajoute le bouton
1437[GetOption] . Tu peux acceder a cette fenetre a partir de la fenetre des options
1438graphiques <Alt>O , ou directement sur un objet de gestionnaire 2D - par
1439<Alt>T - <Shift>Button-1 permet de selectionner le drawer actif
1440\end{verbatim}
1441
1442\soustitre{ Trace des axes (11 Mars 2004)}
1443 Ajouter la possibilite de specifier l'origine (le point de croisement des axes)
1444lorsque les axes ne sont pas de type 'box' - classes PIAxes et PIElDrawer. FAIT
1445
1446\soustitre{ Selection graphique (souris) du drawer actif (11 Mars 2004)}
1447\begin{verbatim}
1448J'ai ajoute la methode PIDrawer::GetDistanceToPoint(double x, double y)
1449// Renvoie une distance au point x,y
1450// 0: au(x) point(s) le(s) plus proche(s) ... 1 au bord xmin/xmax , ymin/ymax
1451// La methode par defaut calcule la distance normalisee au point ((xmin+xmax)/2,
1452(ymin+ymax)/2)
1453 virtual double PIDrawer::GetDistanceToPoint(double x, double y);
1454
1455ainsi que ce qu'il faut ds PIBaseWdgGen et ds PIDrawer pour exploiter cette
1456methode + code permettant le test ds PIScDrawWdg.
1457(virtual void PIDrawer::WdgCoord2DrwCoord(int x, int y, double& xu ...
1458 virtual int PIBaseWdgGen:;FindNearestDrawerId(int x, int y) ...)
1459Tu as a t'aoccuper de la methode PIDrawer::GetDistanceToPoint(double x, double y)
1460qui doit etre redefinie si possible pour chaque drawer, afin de fournir une
1461distance raisonnable au point (x,y) en argument.
1462J'ai juste mis une implementation par defaut (ds PIDrawer) et une implementation
1463partielle pour PIElDrawer (qui trace les axes en particulier) - qu'il faut
1464completer.
1465
1466Comment tester ?
1467J'ai mis ce qu'il faut ds le gestionnaire 2D (PIScDrawWdg) -
1468<Shift>Button-1 choisit le drawer le plus proche (base sur la
1469valeur de retour de PIDrawer::GetDistanceToPoint(double x, double y)
1470comme drawer actif. Ce drawer est passe en 'highlight' pendant que
1471le bouton est appuye.
1472\end{verbatim}
1473
1474\soustitre{ Manipulation interactive des drawers (3 Juin 2004) }
1475La manipulation interactive des drawers (ˆ l'aide d'un menu) a
1476ŽtŽ finalisŽe pour les PIImage PIScDrawWdg PI3DWdg .
1477
1478\begin{verbatim}
1479 o <Alt>D affiche le menu avec les differentes option
1480 o Move/Resize: Affichage du rectangle + rectangle milieu
1481 (deplacement) + coin bas-droite (deplacement) -
1482 clicker ailleurs pour finir
1483 o Mouse Select : Le mouse select des drawers est gere
1484 maintenant par un PIEventHandler (comme pour Move/ReSize)
1485 Drawer actif affiche par le rectangle muni d'un petit coin
1486 (petit carre + rond dedans, en bas a droite).
1487 Click souris change eventuellement le drawer actif.
1488 On termine en clickant ds le petit [carre+rond]
1489\end{verbatim}
1490
1491\soustitre{ Traceur de bar-graph (classe PIBarGraph) (3 Juin 2004) }
1492Ajout du traceur de bar-graph (classe {\bf PIBarGraph}) ds module PI/
1493et commande {\tt bargraph} ds PIext/basexecut.cc .
1494La commande bargraph ne gere pas encore toutes les possibilites
1495de la classe PIBarGraph. \\
1496Exemple d'utilisation:
1497\begin{verbatim}
1498Cmd> bargraph ' ' -10. 15. 22. 8. 33. 7 -4.
1499Cmd> bargraph 'blue ' -10. 15. 22. 8. 33. 7 -4.
1500Cmd> bargraph 'blue horizontalbars' -10. 15. 22. 8. 33. 7 -4.
1501Cmd> bargraph 'blue horizontalbars barvaluelabel ' -10. 15. 22. 8. 33. 7 -4.
1502Cmd> bargraph 'blue verticalbars nofill barvaluelabel ' -10. 15. 22. 8. 33. 7 -4.
1503Cmd> bargraph 'font=times,bold,16 blue verticalbars nofill barvaluelabel ' \
1504 -10. 15. 2 2. 8. 33. 7 -4.
1505Cmd> bargraph 'font=times,bold,16 blue verticalbars fill barvaluelabel packfrac=0.8' \
1506 -10. 15. 22. 8. 33. 7 -4.
1507\end{verbatim}
1508
1509\soustitre{ Traceur de lignes de texte (classe PITextDrawer) (3 Juin 2004) }
1510
1511Ajout d'une classe de traceur de lignes de texte (classe {\bf PITextDrawer}) et commande
1512{\tt textdrawe}r ds PIext/basexecut.cc . Mais le traceur (et sa commande)
1513doivent etre completes. \\
1514Exemple d'utilisation:
1515\begin{verbatim}
1516# On affiche qque chose
1517Cmd> openppf demo.ppf
1518Cmd> disp h1d
1519Cmd> textdrawer 'frame line=solid,2 font=times,bold,16 red inset' \
1520 ' Christophe ' ' Reza Ansari' ' SOPHYA '
1521\end{verbatim}
1522
1523\soustitre{ Gestion de re-scale-ing des axes en 3D (3 Juin 2004) }
1524
1525Mise en place complete (?) de la gestion de re-scale-ing des axes en 3D
1526avec gestion des options graphiques (texte) - Il est possible en particulier d'imposer
1527les limites de la boites 3D.
1528cela a ete une grosse prise de tete de tout un apres-midi.
1529J'ai eu ensuite mal a la tete une partie de la soiree ! \\
1530Exemple d'utilisation:
1531
1532\begin{verbatim}
1533
1534# On ouvre le fichier demo.ppf
1535Cmd> openppf demo.ppf
1536Cmd> surf mtx1 'colbr32'
1537Cmd> surf mtx1 'colbr32 noautoscale'
1538Cmd> surf mtx1 'colbr32 lim3dbox=-10,60,-10,60,-3,15 autoscale3dbox'
1539# Affichage avec superposition
1540Cmd> nt3d nt32 x y z - - - - - 'marker=circle,7 red'
1541Cmd> nt3d nt32 x y z - - - - - 'same marker=cross,5 blue '
1542# Ou bien :
1543Cmd> nt3d nt32 x y z - - - - - 'marker=circle,7 red noautoscale'
1544Cmd> nt3d nt32 x y z - - - - - 'same marker=cross,5 blue '
1545
1546\end{verbatim}
1547\soustitre{piapp (PIext/ProgPI) }
1548\begin{itemize}
1549%%%%
1550\item[\rond] Juillet 2006 : Ameliorations et ajouts divers : \\
1551- Ajout commande {\bf plot3dw} ({\tt Services2NObjMgr::DisplayPoints3DW() }) \\
1552- Ajout possibilite d'acces aux caracteristiques des objets par {\tt \$\{objname.att\} } \\
1553{\tt (PIACmd::GetVarApp()) } et amelioration verification du nom des objets
1554(methode {\tt NamedObjMgr::CheckName()}) \\
1555- Operations sur objets: commande {\bf objaoper} ({\tt NObjMgrAdapter::PerformOperation()})
1556
1557\begin{verbatim}
1558# Extracting row / column from matrix
1559Cmd> objaoper matrixname row 23
1560Cmd> objaoper matrixname col 148
1561# Extracting plane from 3D array (slicexy slicexz sliceyz)
1562Cmd> objaoper arr3dname slicexy 14
1563\end{verbatim}
1564%%%%
1565\item[\rond] Avril 2006: Ajout possibilite de lecture des commandes sur le terminal (stdin)
1566et flag en argument de commande {\tt -small} \\
1567Extrait de cvs log :
1568\begin{verbatim}
1569revision 1.16
1570date: 2006/04/26 15:53:18; author: ansari; state: Exp; lines: +20 -11
15711/ Ajout classe de lecture sur stdin (terminal) avec thread separe pour
1572piapp - incluant la possibilite d'utilisation de la librairie GNU readline
1573(fichiers piacmdrdr.cc piacmdrdr.h + fichier makfile specifique makefile_wgrdl
1574 pour compil+link avec GNU readline)
15752/ MAJ Makefile et modif programme principal piapp.cc avec flag -small
1576et activation thread de lecture sur terminal
1577 Reza , 26/04/2006
1578
1579----------------------------
1580\end{verbatim}
1581
1582\item[\rond] Jan 2006 : commandes readfits writefits scanfits ont ete ajoutees
1583dans ProgPI/fitsbtadapter.cc en utilisant le nouveau FITS -
1584Le menu OpenFits de PIStdImgApp utilise desormais ces commandes
1585\item {\bf BUG } a corriger pour {\tt imagvav}:
1586La destruction de l'objet et/ou widget pascorrectement geres -
1587provoque des plantages lors de la sortie de l'application.
1588\end{itemize}
1589\soustitre{piapp multi-thread }
1590\begin{itemize}
1591\item[\rond] Avril 2005: PossibilitŽ d'execution de commandes en threads separes, en
1592ajoutant {\bf \&} en fin de ligne de commande.
1593\item[\rond] Janvier 2004: Le multithreading a ŽtŽ mis en oeuvre dans piapp .
1594
1595\item[\rond] Extrait de {\tt cvs log pistdimgapp.cc } :
1596\begin{verbatim}
1597revision 1.77
1598date: 2005/04/27 11:55:00; author: ansari; state: Exp; lines: +26 -10
15991/ Prise en charge de DataTable et SwPPFDataTable pour piapp (NObjMgrAdapter) :
1600nomhistadapter.cc et piiinit.cc
16012/ Lecture de tous les objets ds un fichier PPF par NamedObjMgr::ReadAll() pour
1602fichier PPF sans nametag.
16033/ Ajout bloc try/catch ds PIStdImgApp::Run() (boucle d'evenements)
1604 Reza , 27 Avril 2005
1605----------------------------
1606revision 1.76
1607date: 2005/04/19 09:13:49; author: ansari; state: Exp; lines: +3 -1
1608Ajout de l option nodisp ds les affichages des NamedObjMgr, prise en compte de
1609<Cntrl C> (Msg_Cancel) pour arreter l'execution de l'interpreteur ds PIStdImgApp
1610et remplacement commande breakexe par stop ds PIACmd - Reza 19/4/2005
1611----------------------------
1612revision 1.75
1613date: 2005/04/19 06:56:52; author: ansari; state: Exp; lines: +5 -4
1614Remis en marche la possibilite d'execution d'un .pic au lancement de piapp -
1615Reza 19/4/2005
1616----------------------------
1617revision 1.74
1618date: 2005/02/18 14:09:47; author: ansari; state: Exp; lines: +62 -37
1619Modifications pour l'utilisation viewer PIImageNavigator (ajout commande imagnav
1620) - Reza 18 Fev 2005
1621----------------------------
1622revision 1.73
1623date: 2004/11/19 17:41:07; author: ansari; state: Exp; lines: +26 -0
1624Ajout commandes addoval addfoval pour trace d'ellipse - Reza 19/11/2004
1625----------------------------
1626revision 1.71
1627date: 2004/09/07 07:10:18; author: ansari; state: Exp; lines: +35 -0
1628Ajout bloc try/catch ds piacmd.cc (thread execution commandes) et ds pistdimgapp.cc (
1629methode process, thread boucle d'evts) - Reza 07/09/2004
1630----------------------------
1631revision 1.70
1632date: 2004/01/06 18:44:56; author: ansari; state: Exp; lines: +11 -1
1633 Suite debugging gestion lock entre threads ds piapp - A l'air de
1634marcher sur OSF1 et Linux ... Reza 06/01/2004
1635----------------------------
1636revision 1.69
1637date: 2004/01/06 17:05:25; author: ansari; state: Exp; lines: +33 -7
1638Suite debug piapp multithread : on ne peut pas utiliser ZSync() ds un if (destructeur
1639 appele de suite) - Reza 06/01/2004
1640----------------------------
1641revision 1.68
1642date: 2004/01/04 19:02:43; author: ansari; state: Exp; lines: +43 -13
1643Suite des modifs pour piapp multi-threads
16441) Ajout Mutex de synchronisation ds ls classe NamedObjMgr
16452) Suite controle de gestion d'appel aux methodes de PIStdImgApp depuis
1646la classe elle-meme, a travers le NamedObjMgr
16473) Modification de la boucle d'evenements, avec un thread de reveil
1648periodique
1649 Reza, 4 Janvier 2004
1650\end{verbatim}
1651\item[\rond] Extrait de {\tt cvs log pistdimgapp.cc } :
1652\begin{verbatim}
1653----------------------------
1654revision 1.62
1655date: 2003/11/27 10:51:58; author: ansari; state: Exp; lines: +45 -20
1656Suite modification/adaptations a la classe PIACmd qui herite maintenent de SOPHYA::Co
1657mmander - Reza 27/11/2003
1658----------------------------
1659revision 1.61
1660date: 2003/11/26 23:01:55; author: ansari; state: Exp; lines: +20 -1755
1661Modification du code de PIACmd : La classe PIACmd herite maintenant de la classe Comm
1662ander (de SysTools) - Reza 26/11/2003
1663----------------------------
1664revision 1.60
1665date: 2003/07/21 21:13:10; author: cmv; state: Exp; lines: +3 -3
1666- introduction notion de numero de ligne dans expression ntuple
1667 modif prototype PlotExprFunc NTLoopExprFunc (add _nl _nstart _nend)
1668 modif int_4 -> int_8_exprf (long long) pour _nl (DecodeLoopParameters,
1669 PrepareNTExpressionCFile, LinkExprFunc,...)
1670- doc pour _nl _nstart _nend et arragement repartition RegisterHelp/RegisterCommand
1671 (rz + cmv 21/7/2003)
1672----------------------------
1673\end{verbatim}
1674\end{itemize}
1675
1676\titre{Documentation (Manual/) }
1677%%%%
1678Documentation des classes de SysTools. \\
1679Extrait message du 12 Aout 2004 : \\
1680\begin{verbatim}
1681---> Au sujet de la doc (Manual/)
1682 J'ai installe doxygen sur le Mac, version 1.3.8 -
1683 Il faut updater le fichier de config de depart (dox_sophya.conf)
1684 Pour ma part, j'ai du modifier mkmf (en version privee) -
1685 En effet, il n'y avait pas le program doxysearch - Je ne sais pas si c'est general
1686 ou specifique Mac.
1687
1688 J'ai aussi modifie certaines options de doxygen (en version privee)
1689 EXTRACT_LOCAL_CLASSES --> NO (au lieu de YES)
1690 DETAILS_AT_TOP ---> YES (au lieu de No)
1691 SORT_MEMBER_DOCS ---> NO (au lieu de YES)
1692
1693 Si on est d'accord, on peut modifier ces options ds le fichier dox_sophya.conf et
1694 utiliser la fonction update de doxygen (doxygen -u)
1695\end{verbatim}
1696
1697\titre{Mgr}
1698\begin{itemize}
1699\item Avril-Mai 2005 : Basculement vers la nouvelle version de scripts
1700de gestion du code (module {\bf BuildMgr/ } )
1701On n'a plus a se preoccuper des indications de cette section
1702
1703\item
1704Septembre 2003 (17/9/2003) : Changement DPCDEVREP, DPCBASEREP
1705en SOPHYADEVREP , SOPHYABASEREP , EROSCXX en SOPHYACXX
1706\end{itemize}
1707
1708
1709
1710\titre{Plan de modifs pour SOPHYA V 2.x PI/piapp V 4.x }
1711
1712{\bf Sep 2006} : La grande majorit\'e des modifs pr\'evues en 2003 ont \'et\'e
1713effectu\'ees. Reste \`a faire , si besoin :
1714\begin{itemize}
1715\item SophyaLib::TArray/
1716\begin{verbatim}
1717 - Ajouter une classe de base abstraite GenericMatrix<T>
1718 avec methode d'acces aux elements, nb de lignes, nb de colonnes,
1719 - Introduire les TinyMatrix (TinyMatrix<T, int L, int C>)
1720 avec passage de/vers TMatrix<T> (et TinyVector<T, int N>) ?
1721 - Introduire des matrices creuses simples SpareMatrix<T>
1722 - Introduire les DiagonalMatrix<T>
1723Remarque: Les TMatrix TinyMatrix et SparseMatrix heritent de GenericMatrix
1724\end{verbatim}
1725
1726\item PI/ piapp
1727\begin{verbatim}
1728o Ajouter un traceur de ApplePie (BarChart fait )
1729o Ajouter un traceur de Lego-Plot
1730o (?) Une fonction pour faire facilement une fenetre d'alerte ou d'info (?)
1731o Voir comment on pourrait "joindre" deux objets ayant l'interface NTupleInterface
1732 pour pouvoir plotter des objets, l'un vs l'autre
1733o (???) Introduire quelque chose du style
1734 AddDialogue("Cmd", "dialogue-description)
1735 qui pourrait fabriquer automatiquement une fenetre avec des champs a remplir
1736 pour les commandes usuelles (???)
1737\end{verbatim}
1738\end{itemize}
1739
1740
1741\end{document}
Note: See TracBrowser for help on using the repository browser.