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

Last change on this file since 4059 was 4058, checked in by ansari, 13 years ago

MAJ fichier modifs.tex suite ajout classes PrimeNumbers,QNumber,Units,PhysQty - Reza 16/04/2012

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