[2632] | 1 | \documentclass[twoside,11pt,A4]{article}
|
---|
| 2 | \usepackage[french]{babel}
|
---|
| 3 |
|
---|
| 4 | % \usepackage[T1]{fontenc}
|
---|
| 5 | \usepackage[applemac]{inputenc}
|
---|
| 6 | \usepackage{palatino}
|
---|
| 7 | % \usepackage{times}
|
---|
| 8 | % package pour ecrire DRAFT en fond de page
|
---|
[2716] | 9 | % \usepackage[light,all,draft]{draftcopy}
|
---|
[2632] | 10 |
|
---|
| 11 | % \usepackage{epsfig}
|
---|
| 12 | \usepackage{graphicx}
|
---|
| 13 | \usepackage{amsmath}
|
---|
| 14 | \usepackage{amssymb}
|
---|
| 15 |
|
---|
| 16 | \setlength{\textwidth}{16cm}
|
---|
| 17 | \setlength{\textheight}{23 cm}
|
---|
| 18 | \setlength{\topmargin}{0.5cm}
|
---|
| 19 | \setlength{\oddsidemargin}{0.cm}
|
---|
| 20 | \setlength{\evensidemargin}{0.cm}
|
---|
| 21 | \setlength{\unitlength}{1mm}
|
---|
| 22 |
|
---|
| 23 | \newcommand{\rond}{$\bullet \ $}
|
---|
| 24 | \newcommand{\etoile}{$\star \ $}
|
---|
| 25 | \newcommand{\cercle}{$\circ \ $}
|
---|
| 26 | \newcommand{\carre}{$\Box \ $}
|
---|
| 27 |
|
---|
| 28 | \begin{document}
|
---|
| 29 | \begin{titlepage}
|
---|
| 30 | \begin{center}
|
---|
| 31 | {\Large \bf Liste de modifications de SOPHYA } \\[5mm]
|
---|
| 32 | { \large (fait ou faire ) } \\
|
---|
[2829] | 33 | {\large Janvier 2003 - Novembre 2005 } \\[25mm]
|
---|
[2632] | 34 | Liste des tags et dates : \\[5mm]
|
---|
| 35 | {\large
|
---|
| 36 | \begin{tabular}{lcl}
|
---|
| 37 | V = 0.727 & \hspace{10mm} & Octobre 1999 \\
|
---|
| 38 | V = 0.8 & \hspace{10mm} & Fvrier 2000 \\
|
---|
| 39 | V = 1.1 & \hspace{10mm} & Fvrier 2001 \\
|
---|
| 40 | V = 1.2 & \hspace{10mm} & Juillet 2001 \\
|
---|
| 41 | V = 1.3 & \hspace{10mm} & Novembre 2001 \\
|
---|
| 42 | V = 1.5 & \hspace{10mm} & Dcembre 2002 \\
|
---|
| 43 | V = 1.7 & \hspace{10mm} & Septembre 2003 \\
|
---|
[2829] | 44 | V = 1.9 & \hspace{10mm} & Juin 2005 - SANS tag CVS \\
|
---|
| 45 |
|
---|
[2632] | 46 | \end{tabular}
|
---|
| 47 | }
|
---|
| 48 | \end{center}
|
---|
| 49 | \end{titlepage}
|
---|
| 50 |
|
---|
| 51 | \newpage
|
---|
| 52 | \tableofcontents
|
---|
| 53 | \newpage
|
---|
| 54 |
|
---|
[2829] | 55 | \section{BuildMgr}
|
---|
| 56 | Avril-Mai 2005 : Introduction de la nouvelle version de
|
---|
| 57 | scripts de gestion du code - avec un script principal configure. \\
|
---|
| 58 | Variable d'environnement {\bf SOPHYABASE } - \\
|
---|
| 59 | Pour les makefiles, l'ensemble des dfinitions se trouve dans : \\
|
---|
| 60 | SOPHYABASE/include/sophyamake.ic \\
|
---|
[2632] | 61 |
|
---|
[2829] | 62 | \section{BaseTools}
|
---|
| 63 | \subsection{Modifs}
|
---|
[2632] | 64 |
|
---|
[2829] | 65 | \begin{itemize}
|
---|
[2835] | 66 | \item[\rond] Octobre-Novembre 2005 : \\
|
---|
[2829] | 67 | 1/ Correction bug TimeStamp::ToDays() + petites amelioration \\
|
---|
| 68 | 2/ Prise en compte du type TimeStamp dans MuTyV (sous forme de double en interne) \\
|
---|
| 69 | 3/ Adaptation DVList a modifs MuTyV (typ TimeStamp) et R/W PPersist \\
|
---|
[2835] | 70 | 4/ Gestion format YYYY-MM-DDThh:mm:ss par TimeStamp
|
---|
| 71 | 5/ Gestionnaire PPersist pour TimeStamp
|
---|
[2829] | 72 | %
|
---|
| 73 | \item[\rond] Septembre 2004 - {\bf Namespace SOPHYA } \\
|
---|
[2632] | 74 | Suppression de {\tt using namespace SOPHYA ; } ds machdefs.h -
|
---|
| 75 | Ajout fichier {\tt \#include "sopnamsp.h"} dans les .cc de SOPHYA,
|
---|
| 76 | ainsi que lors de la gnration automatique du code (runxx, c++exec)
|
---|
[2829] | 77 | \end{itemize}
|
---|
[2632] | 78 |
|
---|
| 79 | \subsection{PPF}
|
---|
| 80 | \begin{itemize}
|
---|
| 81 | \item[\rond] Novembre 2003 (21/11/2003) - Ajout rawstream.h .cc \\
|
---|
| 82 | Classes RawInOutStream , RawInFileStream , RawOutFileStream
|
---|
| 83 | \item[\rond] Dcembre 2003 - Ajout ppfbinstream.h .cc \\
|
---|
| 84 | Classes PPFBinaryIOStream , PPFBinaryInputStream , PPFBinaryOutputStream
|
---|
[2716] | 85 | \item[\rond] Dcembre 2003 (9/12/2003) Fin de l'ensemble des modifs pour les
|
---|
[2632] | 86 | PPF V3 \\
|
---|
| 87 | - Ecriture nombre complexes r4, r8 avec tag spcifique. \\
|
---|
| 88 | Tag de positionnement sous forme de \\
|
---|
| 89 | \centerline{\tt <tag (1 byte)><FilePosition (8 byte, long int)> } \\
|
---|
| 90 | - Ecriture PosTagTable \\
|
---|
| 91 | - Ecriture Statistiques en fin de fichier \\
|
---|
| 92 | - Voir BaseTools/ppfbinstream.h: \\
|
---|
| 93 | \centerline{\tt GotoPositionTag(int\_8 pos) , }
|
---|
| 94 | \centerline{\tt GetPosTagTable(...) }
|
---|
| 95 | \centerline{\tt int\_8 WritePositionTag() PutPosTagTable(...) }
|
---|
| 96 | - Ajout programme de test Tests/ppftswap.cc
|
---|
[2716] | 97 | \item[\rond] Avril 2005 - Ajout de wrapper de lecture/ecriture PPF pour les vecteurs de
|
---|
[2717] | 98 | la librairie standard (classe PPFWrapperSTLVector$<$T$>$ ) fichier ppfwrapstlv.h
|
---|
[2716] | 99 | \item[\rond] Ajout de la classes utilitaire PPF\_TPointer\_IO$<$T$>$
|
---|
| 100 | (fichiers ppftpointer.h .cc)
|
---|
| 101 | \item[\rond] Amelioration de l'impression ds AnalyseTags (ppfbinstream.cc)
|
---|
| 102 | \item[\rond] scanppf.cc revision 1.8 (2005/04/05)
|
---|
| 103 | modification programme scanppf: ajout option -lh -lho pour lister les classes PP
|
---|
| 104 | ersist handler
|
---|
| 105 |
|
---|
[2632] | 106 | \end{itemize}
|
---|
| 107 |
|
---|
[2716] | 108 |
|
---|
[2717] | 109 | \subsection{Nouvelles classes}
|
---|
| 110 | \begin{itemize}
|
---|
| 111 | \item[\rond] Ajout de la classe {\bf TimeStamp} pour la manipulation de date et heure -
|
---|
| 112 | calcul de duree. - Ajout du prog. test Tests/ttimestamp.cc (Mars 2003)
|
---|
| 113 | \item[\rond] { \bf Segmented Data Block :} \\
|
---|
[2716] | 114 | Mars-Avril 2005: Introduction des classes similaires aux NDataBlock, mais permettant
|
---|
| 115 | de gerer des blocs de donnees segementes, pour tout type de donnees, de structures
|
---|
[2717] | 116 | et de classes (template pour tout type T).
|
---|
| 117 | \begin{enumerate}
|
---|
| 118 | \item Ajout de la classe {\tt SegDataBlock<T>} (et l'interface { \tt SegDBInterface<T>} )
|
---|
[2716] | 119 | pour la gestion de blocs de donnees segmentes (segdatablock.h) et son
|
---|
[2717] | 120 | gestionnaire PPF {\tt FIO\_SegDataBlock<T>} (fichier fiosegdb.h )
|
---|
| 121 | \item Ajout de la classe {\tt SwSegDataBlock<T>} (Data bloc segmente avec gestion
|
---|
| 122 | de swap) et la classe swapper PPF {\tt PPFDataSwapper<T>} (fichiers
|
---|
[2716] | 123 | ppfswapper.h et swsegdb.h)
|
---|
[2717] | 124 | \item Ajout programme de test Tests/tstsegdb.cc
|
---|
| 125 | \end{enumerate}
|
---|
| 126 | \end{itemize}
|
---|
[2716] | 127 |
|
---|
| 128 |
|
---|
[2632] | 129 | \section{TArray}
|
---|
| 130 | \begin{itemize}
|
---|
| 131 | \item Optimisation de la multiplication matricielle (CMV) - Extrait du
|
---|
[2716] | 132 | message (from CMV) du 30 Juillet 2004: \\
|
---|
[2632] | 133 | \begin{verbatim}
|
---|
| 134 | - on definit un flag d'optimisation
|
---|
| 135 | Contrairement a ce qu'on avait dit, je n'ai pas ajoute
|
---|
| 136 | un argument a Multiply car on ne peut pas jouer
|
---|
| 137 | avec qiand on utilise l'operateur * surcharge.
|
---|
| 138 | Or au vu des performance il'ma parut interessant que l'utilisateur
|
---|
| 139 | meme lambda puisse choisir le niveau d'optimisation
|
---|
| 140 | --> donc j'ai ajoute une methode statis dans BaseArray::
|
---|
| 141 | void BaseArray::SetMatProdOpt(uint_2);
|
---|
| 142 | uint_2 BaseArray::GetMatProdOpt();
|
---|
| 143 |
|
---|
| 144 | - Je n'ai refait les test de rapidite que sur OSF:
|
---|
| 145 |
|
---|
| 146 | 1./ pour les matrices 1000x1000 (grosses)
|
---|
| 147 | on arrive effectivement au meme temps pour les 4 cas
|
---|
| 148 | si on copie dans le cas lent (FxC)
|
---|
| 149 | ---EndMultiply FxC CPUTime: Total= 93.1296 (Partial= 69.3806) Sec.
|
---|
| 150 | devient
|
---|
| 151 | ---EndMultiply FxC CPUTime: Total= 34.9653 (Partial= 11.1829) Sec.
|
---|
| 152 | exactement comme les copains:
|
---|
| 153 | La copie prend de la place mais ne prend absolument
|
---|
| 154 | pas de temps pour les grosses matrices
|
---|
| 155 |
|
---|
| 156 | 2./ pour les matrices 10x10 (1000000 multiplications par cas)
|
---|
| 157 | on a bien ce que l'on attend a savoir que
|
---|
| 158 | la copie faites 100000 fois finie par nous faire perdre du temps
|
---|
| 159 | ---EndMultiply FxC CPUTime: Total= 37.4152 (Partial= 12.4662) Sec.
|
---|
| 160 | devient
|
---|
| 161 | ---EndMultiply FxC CPUTime: Total= 53.9978 (Partial= 28.8322) Sec.
|
---|
| 162 | dans ce cas on perd un gros facteur 2 a cause de la copie
|
---|
| 163 | mais rien de surprenant la dedans.
|
---|
| 164 |
|
---|
| 165 | -----------------------------------------------------------------------
|
---|
| 166 | - ensuite j'ai implemente une prise de decision au niveau de
|
---|
| 167 | l'optimisation pour les petites matrices:
|
---|
| 168 | le test est simple mais me semble OK:
|
---|
| 169 | je calcule sza taille du NDataBlock de A
|
---|
| 170 | szb B
|
---|
| 171 | si ((sza+szb)*sizeof(T) < 100000 ) pas d'optimisation
|
---|
| 172 | IDEE: on pifometre que raisonnablement il y a 100 koctets
|
---|
| 173 | de disponible pour les matrices A et B dans le cache processeur
|
---|
| 174 | et que dans ce cas elles sont copiees toutes les 2 dans le cache
|
---|
| 175 | par l'optimiseur du compilo qui est tres malin et surtout qui
|
---|
| 176 | veux absolument nous faire plaisir......
|
---|
| 177 |
|
---|
| 178 | -----------------------------------------------------------------
|
---|
| 179 | ===> Les resultats sont dans le fichier toto.calc en attached
|
---|
| 180 | .. En tete tu as l'explication des flags d'optimisation
|
---|
| 181 | ...Avec les 2 sections:
|
---|
| 182 | GROSSE MATRICE
|
---|
| 183 | et
|
---|
| 184 | PETITE MATRICE
|
---|
| 185 | \end{verbatim}
|
---|
| 186 |
|
---|
| 187 | \item Optimisation operations diverses, en particulier \\
|
---|
| 188 | 1) Remplacement des methodes Add/Sub/Mul/DivElt(a) par
|
---|
| 189 | Add/Sub/Mul/DivElt(TArray a, TArray res) \\
|
---|
| 190 | 2) Operateurs += -= A+B A-B TArray et TMatrix/TVecteur modifies en consequence
|
---|
| 191 | \item Extrait de {\tt cvs log tarray.cc }
|
---|
| 192 | {\small \begin{verbatim}
|
---|
| 193 | ----------------------------
|
---|
| 194 | revision 1.38
|
---|
| 195 | date: 2004/07/30 13:31:39; author: ansari; state: Exp; lines: +28 -24
|
---|
| 196 | Diverses petites optimisations ds les methodes operations/affectations de TArray - Reza 30 Juillet 2004
|
---|
| 197 | ----------------------------
|
---|
| 198 | ----------------------------
|
---|
| 199 | revision 1.36
|
---|
| 200 | date: 2004/07/27 11:44:23; author: ansari; state: Exp; lines: +4 -1
|
---|
| 201 | Corrections bug apres modifs methods Add/Sub/Mul/DivCst(x,res) - Reza 27 Juillet 2004
|
---|
| 202 | ----------------------------
|
---|
| 203 | revision 1.35
|
---|
| 204 | date: 2004/07/26 17:30:40; author: ansari; state: Exp; lines: +187 -108
|
---|
| 205 | Remplacement methodes Add/Mul/Sub/Div(T x) par AddCst/MulCst/SubCst/DivCst(T x, TArray<T> res) ds TArray - Reza 26 Juillet 2004
|
---|
| 206 | ----------------------------
|
---|
| 207 | \end{verbatim} }
|
---|
| 208 |
|
---|
| 209 | \item Extrait de {\tt cvs log tarray.cc }
|
---|
| 210 | {\small \begin{verbatim}
|
---|
| 211 | ----------------------------
|
---|
| 212 | revision 1.27
|
---|
| 213 | date: 2004/07/30 10:24:12; author: cmv; state: Exp; lines: +97 -32
|
---|
| 214 | - Intro decision auto d'optimisation produit de matrices
|
---|
| 215 | - Possibilite a l'utilisateur pour choisir l'optimisation
|
---|
| 216 | - cas FxC optimise par copie
|
---|
| 217 | cmv 30/07/04
|
---|
| 218 | ----------------------------
|
---|
| 219 | revision 1.26
|
---|
| 220 | date: 2004/07/29 12:31:16; author: ansari; state: Exp; lines: +7 -5
|
---|
| 221 | 1/ Remplacement des methodes Add/Sub/Mul/DivElt(a) par
|
---|
| 222 | Add/Sub/Mul/DivElt(TArray a, TArray res)
|
---|
| 223 | 2/ Operateurs += -= A+B A-B TArray et TMatrix/TVecteur modifies en consequence
|
---|
| 224 | 3/ Ajout methode TArray::ScalarProduct()
|
---|
| 225 | 4/ Methode TArray::SetT renomme en SetCst() SetT garde en alias
|
---|
| 226 | 5/ Ajout parametre bool fzero (mise a zero) ajoute ds constructeur et
|
---|
| 227 | ReSize() de TMatrix et TVecteur.
|
---|
| 228 | Reza 29/07/2004
|
---|
| 229 | ----------------------------
|
---|
| 230 | revision 1.25
|
---|
| 231 | date: 2004/07/29 08:40:49; author: cmv; state: Exp; lines: +148 -1
|
---|
| 232 | Optimisation produit de matrice a la sauce cmv 29/07/04
|
---|
| 233 | ----------------------------
|
---|
| 234 | \end{verbatim} }
|
---|
| 235 |
|
---|
| 236 | \end{itemize}
|
---|
| 237 |
|
---|
| 238 | \section{HiStats}
|
---|
| 239 | \subsection{Classe HistoErr }
|
---|
| 240 | Ajout classe HistoErr (Septembre-Octobre 2004)
|
---|
| 241 |
|
---|
[2716] | 242 | \subsection{NTuple}
|
---|
| 243 | la classe NTuple peut maintenant avoir des colonnes float ou double.
|
---|
| 244 | Il y a maintenant deux methodes Fill(r\_4 *) et Fill(r\_8 *)
|
---|
| 245 | Les noms ne sont plus limites a 8 caracteres.
|
---|
| 246 |
|
---|
| 247 |
|
---|
| 248 | \subsection{ Les DataTable (SuperNTuple) }
|
---|
| 249 |
|
---|
[2835] | 250 | {\bf Octobre-Novembre 2005 } \\
|
---|
| 251 | \begin{itemize}
|
---|
[2854] | 252 | \item[\rond] Ajout classe {\bf DataTableRow} pour manipulation d'une ligne de la table.
|
---|
| 253 | Ajout/maj methode BaseDataTable::EmptyRow() AddRow() GetRow()
|
---|
[2835] | 254 | \item[\rond] Gestion des types {\tt complex<r\_4> , complex<r\_8> , TimeStamp } par
|
---|
| 255 | BaseDataTable, DataTable et SwPPFDataTable
|
---|
| 256 | \item[\rond] Codage methode Print() (Dump ascii) et NTFrAscii (decodage fichier
|
---|
| 257 | text) dans BaseDataTable.
|
---|
| 258 | \item[\rond] Codage mthode BaseDataTable::GetColumnD() pour recuperer
|
---|
| 259 | une colonne de la table en {\tt TVector<r\_8>} - NON TESTE
|
---|
| 260 | \end{itemize}
|
---|
| 261 |
|
---|
[2632] | 262 | \begin{verbatim}
|
---|
[2716] | 263 | BaseDataTable
|
---|
| 264 | -------- DataTable
|
---|
| 265 | -------- SwPPFDataTable
|
---|
| 266 | \end{verbatim}
|
---|
[2717] | 267 |
|
---|
| 268 | \noindent {\bf BaseDataTable} : Classe de base, avec qques methodes virtuelles
|
---|
[2716] | 269 | pures, implementent la presque totalite des fonctionalites, en particulier
|
---|
| 270 | celles de l'interface NTupleInterface.
|
---|
[2632] | 271 |
|
---|
[2717] | 272 | \noindent {\bf DataTable} : Implementation concrete de BaseDataTable avec donnees en
|
---|
| 273 | memoire \\
|
---|
| 274 | (utilise SegDataBlock$<$T$>$ pour stocker les colonnes)
|
---|
[2632] | 275 |
|
---|
[2717] | 276 | \noindent {\bf SwPPFDataTable} : Implementation concrete de BaseDataTable avec donnees
|
---|
| 277 | en swap sur stream PPF (POutPersist)- \\
|
---|
| 278 | Utilise (SwSegDataBlock$<$T$>$ avec
|
---|
| 279 | un data-swapper PPF (classe PPFDataSwapper$<$T$>$ )
|
---|
[2632] | 280 |
|
---|
[2716] | 281 | DataTable et SwPPFDataTable respecte +/- les conventions SOPHYA ,
|
---|
| 282 | constructeur de copie avec partage ou copie de donnees, operateur =
|
---|
| 283 | Datatable : partage et copie , = : fait une copie
|
---|
| 284 | SwPPFDataTable : C'est toujours partage (presque par definition)
|
---|
| 285 | Autre point, compte tenu de la structure des streams PPF ,
|
---|
| 286 | les SwPPFDataTable fonctionne en ecriture OU en lecture, mais
|
---|
| 287 | pas les deux a la fois.
|
---|
[2632] | 288 |
|
---|
[2716] | 289 | Classe de gestion de persistence commune : \\
|
---|
[2717] | 290 | {\bf ObjFileIO$<$BaseDataTable$>$ }
|
---|
[2632] | 291 |
|
---|
[2716] | 292 | Lit et ecrit les DataTable et SwPPFDataTable
|
---|
| 293 | Actuellement, on ne peut les relires que dans le meme type,
|
---|
| 294 | cad on ne peut relire avec un SwPPFDataTable un objet
|
---|
| 295 | ecrit comme DataTable - mais cette possibilite pourra
|
---|
| 296 | peut-etre codee ulterieurement (d'ou l'interet en particulier
|
---|
[2717] | 297 | d'un gestionnaire commun ObjFileIO$<$BaseDataTable$>$
|
---|
[2632] | 298 |
|
---|
[2716] | 299 | (les operateurs habituel $<<$ et $>>$ sur PIn/OutPersist sont definies)
|
---|
[2632] | 300 |
|
---|
[2717] | 301 | Actuellement, les colonnes peuvent etre de type \\
|
---|
| 302 | {\tt int\_4 , int\_8 , r\_4 , r\_8 , string } \\
|
---|
| 303 | On pourra ajouter apres les types suivants : \\
|
---|
| 304 | {\tt complex<r\_4> , complex<r\_8> , TimeStamp }
|
---|
[2716] | 305 |
|
---|
| 306 | Dans BaseDataTable, il reste a remplir la methode
|
---|
[2717] | 307 | {\tt BaseDataTable ::FillFromASCIIFile(string const \& fn) } \\
|
---|
| 308 | {\tt BaseDataTable :: Print(int num, int nmax=1) const }
|
---|
| 309 | (on peut utiliser { \tt LineToString(sa\_size\_t n) const }
|
---|
[2716] | 310 |
|
---|
| 311 | Par contre, les merges et copie sont prevues,
|
---|
| 312 | on doit en principe pouvoir ecrire par exemple:
|
---|
[2717] | 313 | \begin{verbatim}
|
---|
[2716] | 314 | SwPPFDataTable swdt;
|
---|
| 315 | PInPersist pis("swdt.ppf");
|
---|
| 316 | pis >> swdt;
|
---|
| 317 | DataTable dt;
|
---|
| 318 | dt = swdt; // Pour tout charger en memoire
|
---|
[2717] | 319 | \end{verbatim}
|
---|
[2716] | 320 |
|
---|
| 321 | On peut aussi ajouter des methodes d'acces aux variables membres pour enrichier l'interface.
|
---|
| 322 |
|
---|
[2717] | 323 | {\bf PLUS IMPORTANT : } \\
|
---|
| 324 | Il reste a ecrire la classe FITS\_BaseDataTable ou FITS\_DataTable
|
---|
| 325 | pour I/O sur fichiers FITS - j'ai regarde {\tt FITS\_XNTuple} qu'on pourra simplifier enormement
|
---|
[2716] | 326 | et que devrait etre assez rapide.
|
---|
[2717] | 327 | Il faut aussi faire une classe {\tt SwFITSDataTable}, en recopiant pas mal de chose ds la classe
|
---|
| 328 | {\tt SwPPFDataTable} - On pourrait peut-etre avoir une classe intermediaire qui regroupe
|
---|
| 329 | tout ce qui est commun a {\tt SwFITSDataTable et SwPPFDataTable} , mais a voir.
|
---|
| 330 | L'element cle sera le codage de {\tt FITSDataSwapper<T>} qui implemente
|
---|
| 331 | les deux methodes de {\tt DataSwapperInterface<T>} - le reste devrait etre du copier/coller
|
---|
[2716] | 332 | essentiellement.
|
---|
| 333 |
|
---|
[2717] | 334 | {\bf DataTable cote PIAPP :} \\
|
---|
[2716] | 335 | Cote piapp, les DataTable et SwPPFDataTable sont pris en charge par
|
---|
[2717] | 336 | {\tt NOMAdapter\_DataTable} (qui prend en charge tous les 'BaseDataTable' )
|
---|
| 337 | Il faudrait peut-etre rajouter deux commandes : \\
|
---|
[2716] | 338 | newdt ou newdatatable
|
---|
[2717] | 339 | newdt ncol col1 [col2 .... ] \\
|
---|
[2716] | 340 | avec possibilite de specifier coli sous fome de X:colname ou X = D,F,S,I,L ...
|
---|
| 341 | et puis dtfromascii ...
|
---|
| 342 |
|
---|
| 343 | Voir Tests/tnt.cc pour exemple d'utilisation :
|
---|
[2717] | 344 | \begin{verbatim}
|
---|
[2716] | 345 | DataTable dt(64);
|
---|
| 346 | dt.AddIntegerColumn("line");
|
---|
| 347 | dt.AddDoubleColumn("x");
|
---|
| 348 | dt.AddFloatColumn("f_sin");
|
---|
| 349 | MuTyV rec[10];
|
---|
| 350 | for(int k = 0; k<1000; k++) {
|
---|
| 351 | rec[0] = k;
|
---|
| 352 | double x = M_PI*k/100.;
|
---|
| 353 | double fx = sin(x)*cos(x);
|
---|
| 354 | rec[1] = x;
|
---|
| 355 | rec[2] = sin(x);
|
---|
| 356 | }
|
---|
| 357 | POutPersist po("dtable.ppf");
|
---|
| 358 | po << dt;
|
---|
[2717] | 359 | \end{verbatim}
|
---|
[2716] | 360 |
|
---|
| 361 | Pour SwPPFDataTable, il faut juste creer un stream PPF avant, qui doit rester
|
---|
[2717] | 362 | ouvert tant que le SwPPFDataTable est actif: \\
|
---|
| 363 | \begin{verbatim}
|
---|
[2716] | 364 | POutPersist po("swdtable.ppf");
|
---|
| 365 | SwPPFDataTable dt(po, 64);
|
---|
[2632] | 366 | \end{verbatim}
|
---|
| 367 |
|
---|
[2717] | 368 |
|
---|
[2632] | 369 | \section{SkyMap , Samba }
|
---|
| 370 | \subsection{Tests et vrifications des polynomes de Legendre}
|
---|
| 371 | --> CMV
|
---|
| 372 |
|
---|
| 373 | \subsection{SphereECP}
|
---|
| 374 | Extrait du message du 7 Septembre 2004
|
---|
| 375 | \begin{verbatim}
|
---|
| 376 | J'ai mis dans la base (module SkyMap) le code de la classe
|
---|
| 377 | SphereECP<T> (pixelisation avec projection cylindrique) - carte partielle et complete,
|
---|
| 378 | + gestionnaire PPersist + modifs adaptateur NomSkyMapAdaptor (PIext/ spiapp)
|
---|
| 379 |
|
---|
| 380 | Programme test (avec appel a transforme en Alm) ds Test/tsphereecp.cc
|
---|
| 381 | Attention, mettre le parametere de pixelisation a -1 lors de l'appel a Generate pour eviter
|
---|
| 382 | le Resize de la sphereECP
|
---|
| 383 | ylmserver.GenerateFromCl(map, -1, clin, 0.);
|
---|
| 384 |
|
---|
| 385 | Dans piapp, c'est visualise par defaut en projection Molleweide
|
---|
| 386 | On peut ajouter dans les options d'affichage :
|
---|
| 387 | ecparray : affichage direct du tableau TArray des pixels (X:Phi, Y:Theta)
|
---|
| 388 | Si option ecparray, on peut preciser en plus
|
---|
| 389 | - ecpscaledeg: echelle des axes en degres au lieu de pixels
|
---|
| 390 | - ecpscalerad: echelle des axes en radians au lieu de pixels
|
---|
| 391 | Exemple:
|
---|
| 392 | Cmd> disp mapecp 'ecparray ecpscaledeg zoomx2 stdaxes'
|
---|
| 393 | \end{verbatim}
|
---|
| 394 |
|
---|
| 395 | \subsection{Bug non corrig ds classe Circle}
|
---|
| 396 | \begin{verbatim}
|
---|
| 397 | From: Laurence Perotto <perotto@cdf.in2p3.fr>
|
---|
| 398 | Date: Mon Jan 5, 2004 4:59:12 PM Europe/Paris
|
---|
| 399 | To: Reza Ansari <ansari@lal.in2p3.fr>, Christophe Magneville <cmv@hep.saclay.cea.fr>
|
---|
| 400 | Subject: un bug dans sophya...
|
---|
| 401 |
|
---|
| 402 | Bonjour et bonne annee a tous les deux...
|
---|
| 403 |
|
---|
| 404 | Je viens de trouver un ptit bug dans la fonction TanOnCircle de la classe Circle: Il
|
---|
| 405 | s'agit d'un melange entre les coordonnees (beta, lambda) de Benoit et les (theta, phi)
|
---|
| 406 | utilises dans Sophya. Lors du passage de l'un a l'autre, une transfo sin->cos a ete
|
---|
| 407 | oubliee...
|
---|
| 408 | Voila...
|
---|
| 409 | Bonne journee.
|
---|
| 410 |
|
---|
| 411 | Laurence.
|
---|
| 412 | \end{verbatim}
|
---|
| 413 |
|
---|
| 414 | \section{SysTools}
|
---|
| 415 | \subsection{Classe SOPHYA::Commander (module SysTools) }
|
---|
| 416 |
|
---|
[2717] | 417 | Mars-Avril 2004 :
|
---|
[2632] | 418 | Classe d'interprteur de ligne de commande inspire de C-Shell,
|
---|
| 419 | destine a etre incluee dans des applications C/C++. \\
|
---|
[2717] | 420 | ( Programme test Test/tcmd.cc ) \\
|
---|
| 421 | Avril 2005 : Introduction de la possibilite d'execution de commandes
|
---|
| 422 | en multithreads \\
|
---|
| 423 | Avril 2005 : Controle strict sur les noms de variables, limites
|
---|
| 424 | aux caracteres alphanumeriques + underscore - Adaptation
|
---|
| 425 | de l'algorithme de substitution en consequence.
|
---|
[2632] | 426 |
|
---|
| 427 | {\bf Mini guide de l'interpreteur - Message du 19 Mars 2004 } \
|
---|
| 428 |
|
---|
| 429 | \begin{itemize}
|
---|
| 430 |
|
---|
| 431 | \item[\rond] {\bf Gestion des variables } \\
|
---|
| 432 | - Les variables sont non typees toutes traitees comme des chaines
|
---|
| 433 | de caracteres.
|
---|
| 434 | - Acces aux variables d'environnement -
|
---|
| 435 | - Un niveau variable d'environnement application est aussi prevu
|
---|
| 436 | - Toutes les variables de l'interpreteur sont traitees comme des vecteurs.
|
---|
| 437 | extensibles automatiquement (difference avec le C-Shell)
|
---|
| 438 |
|
---|
| 439 | \item[\rond] {\bf Creation / initialisation de variables } \\
|
---|
| 440 | \begin{verbatim}
|
---|
| 441 | Cmd> set sv StringValue
|
---|
| 442 | # Suppression d'une variable : unset ou clearvar
|
---|
| 443 | Cmd> unset sv
|
---|
| 444 |
|
---|
| 445 | # Initialisation de type vecteur - Espace avant/apres ')' et avant ')' obligatoire
|
---|
| 446 | Cmd> set vecv ( mot1 mot2 mot3 mot4 mot5 )
|
---|
| 447 | #Calcul numerique : expression de type C - Espace avant/apres '=' obligatoire
|
---|
| 448 | Cmd> a = 2+3*sqrt(4)
|
---|
| 449 | # Le signe egal peut etre utilise pour attribuer une chaine de caracteres
|
---|
| 450 | Cmd> a = 'Bonjour Madame'
|
---|
| 451 | # Un element de tableau peut etre specifie avant le signe egal
|
---|
| 452 | Cmd> vecv[2] = 'coucou'
|
---|
| 453 | # Ou bien
|
---|
| 454 | Cmd> i = 3
|
---|
| 455 | Cmd> vecv[i] = 'Ooohhh'
|
---|
| 456 | \end{verbatim}
|
---|
| 457 |
|
---|
| 458 | A droite du signe egal (membre de droite), les variables doivent etre
|
---|
| 459 | adressees a l'aide du signe \$.
|
---|
| 460 |
|
---|
| 461 | Une chaine peut etre cassee en mots a l'aide de la commande var2words
|
---|
| 462 | \begin{verbatim}
|
---|
| 463 | Cmd> var2words varname wordvarname [separateur]
|
---|
| 464 | \end{verbatim}
|
---|
| 465 |
|
---|
| 466 | \item[\rond] {\bf Acces aux variables } \\
|
---|
| 467 | L'acces aux variables s'effectue par le signe \$ {\tt \$varname} .
|
---|
| 468 | Les {\tt \$xxx} sont remplaces par le contenu de la variable xxx.
|
---|
| 469 | Cette substitution ne s'effectue pas entre simple quotes {\tt ' ... \$xxx '},
|
---|
| 470 | mais se fait entre double quotes {\tt " ... \$xxx ... "} . Les formes
|
---|
| 471 | {\tt \${vname} } ou {\tt \$(vname)} peuvent etre utilisees.
|
---|
| 472 |
|
---|
| 473 | \begin{verbatim}
|
---|
| 474 | Cmd> x = 'Hello'
|
---|
| 475 | Cmd> echo $x
|
---|
| 476 | # Taille d'une variable de type vecteur $#vname
|
---|
| 477 | Cmd> set vx ( 111 2222 3333 444444 )
|
---|
| 478 | Cmd> echo $#vx
|
---|
| 479 | # Acces aux elements de tableau
|
---|
| 480 | Cmd> echo $vx[0] $vx[1]
|
---|
| 481 | # ou bien indexe par une variable
|
---|
| 482 | Cmd> i = 2
|
---|
| 483 | Cmd> echo $vx[i]
|
---|
| 484 | # Une syntaxe particuliere: $[vname] retourne le contenu de
|
---|
| 485 | # la variable dont le nom est ds vname
|
---|
| 486 | Cmd> zzz = 'Commander'
|
---|
| 487 | Cmd> xxx = 'zzz'
|
---|
| 488 | Cmd> echo '$[xxx]= ' $[xxx]
|
---|
| 489 | $[xxx]= Commander
|
---|
| 490 | \end{verbatim}
|
---|
| 491 |
|
---|
| 492 | Variables d'environnement: L'acces aux variables d'environnement
|
---|
| 493 | se fait simplement par{\tt \$varenvname}. Attention, les variables locales
|
---|
| 494 | de l'interpreteur sont prioritaires.
|
---|
| 495 |
|
---|
| 496 | \item[\rond] {\bf Variables particulieres: } \\
|
---|
| 497 | {\tt \$retval} ou {\tt \$retstr} : chaine specifee sur la derniere commande return
|
---|
| 498 | {\tt \$status} : code de retour de la derniere commande executee.
|
---|
| 499 | (variable existe et est rempli - mais il faudra se donner une regle
|
---|
| 500 | plus claire ...)
|
---|
| 501 | Arguments des fichiers .pic appeles par la commande exec
|
---|
| 502 | {\tt \$\# } : nombre d'arguments, a part \$0
|
---|
| 503 | {\tt \$0} nom du fichier ou du script
|
---|
| 504 | {\tt \$1 \$2 \$3} .... les arguments (pour les scripts et les .pic (exec))
|
---|
| 505 |
|
---|
| 506 |
|
---|
| 507 | \item[\rond] {\bf Structures de controle } \\
|
---|
| 508 | \begin{verbatim}
|
---|
| 509 | foreach f ( w1 w2 w3 ... )
|
---|
| 510 | ...
|
---|
| 511 | echo $f
|
---|
| 512 | end
|
---|
| 513 | \end{verbatim}
|
---|
| 514 |
|
---|
| 515 | Espace avant/apres '(' et avant ')' obligatoire.
|
---|
| 516 |
|
---|
| 517 | \begin{verbatim}
|
---|
| 518 | foreach v vecname
|
---|
| 519 | ...
|
---|
| 520 | echo $v
|
---|
| 521 | end
|
---|
| 522 | \end{verbatim}
|
---|
| 523 |
|
---|
| 524 | Boucle de type integer:
|
---|
| 525 | \begin{verbatim}
|
---|
| 526 | for i startInt:endInt[:stepInt]
|
---|
| 527 | ....
|
---|
| 528 | echo $i
|
---|
| 529 | end
|
---|
| 530 | \end{verbatim}
|
---|
| 531 |
|
---|
| 532 | Boucle de type float
|
---|
| 533 | \begin{verbatim}
|
---|
| 534 | for f startFloat:endFloat[:stepFloat]
|
---|
| 535 | ....
|
---|
| 536 | echo $f
|
---|
| 537 | end
|
---|
| 538 | \end{verbatim}
|
---|
| 539 |
|
---|
| 540 | Boucle sur les lignes d'un fichier:
|
---|
| 541 | \begin{verbatim}
|
---|
| 542 | forinfile line FileName
|
---|
| 543 | ...
|
---|
| 544 | echo $line
|
---|
| 545 | end
|
---|
| 546 | \end{verbatim}
|
---|
| 547 |
|
---|
| 548 | Instruction {\tt break} pour casser une boucle
|
---|
| 549 |
|
---|
| 550 | \item[\rond] {\bf Les tests }
|
---|
| 551 | \begin{verbatim}
|
---|
| 552 | if ( test ) then
|
---|
| 553 | endif
|
---|
| 554 |
|
---|
| 555 | if ( test ) then
|
---|
| 556 | ....
|
---|
| 557 | else
|
---|
| 558 | ....
|
---|
| 559 | endif
|
---|
| 560 | \end{verbatim}
|
---|
| 561 |
|
---|
| 562 | Espace avant/apres '(' et avant ')' obligatoire.
|
---|
| 563 |
|
---|
| 564 | test de type {\tt a == b} OU {\tt a != b} OU {\tt a < b} OU {\tt a > b}
|
---|
| 565 | OU {\tt a <= b} OU {\tt a >= b}
|
---|
| 566 | les espaces avant l'operateur de comparaison sont obligatoires.
|
---|
| 567 | {\tt ==} et {\tt !=} effectue une comparaison de chaines de caracteres.
|
---|
| 568 | {\tt < , > , <= , >=}une comparaison apres conversion en valeur flottante.
|
---|
| 569 |
|
---|
| 570 | \item[\rond] {\bf Definition de script } \\
|
---|
| 571 | \begin{verbatim}
|
---|
| 572 | defscript scriptname [description ]
|
---|
| 573 | ....
|
---|
| 574 | endscript
|
---|
| 575 | \end{verbatim}
|
---|
| 576 |
|
---|
| 577 | L'appel a un script se fait simplement a l'aide
|
---|
| 578 | du nom de script (contrairement aux fichiers
|
---|
| 579 | de commande qui sont executes a l'aide de la
|
---|
| 580 | commande {\tt exec} )
|
---|
| 581 | \begin{verbatim}
|
---|
| 582 | Cmd> scriptname arg1 arg2 arg3 ....
|
---|
| 583 | \end{verbatim}
|
---|
| 584 |
|
---|
| 585 | L'instruction {\tt return} provoque l'arret (et le retour) d'execution d'un
|
---|
| 586 | script ou d'un fichier de commandes.
|
---|
| 587 | Commandes {\bf listscript }et {\bf clearscript scriptname}
|
---|
| 588 | permettet d'avoir la liste des scripts
|
---|
| 589 | definis / supprimer la definition d'un script
|
---|
| 590 |
|
---|
| 591 | \item[\rond] {\bf Autres commandes}
|
---|
| 592 | \begin{itemize}
|
---|
| 593 | \item Instruction {\bf echo } pour ecrire sur cout/stdout
|
---|
| 594 | \item Instruction {\bf echo2file} pour ecrire a la fin d'un fichier
|
---|
| 595 | \item Instruction {\bf sleep nsec} (attente de nsec seconds )
|
---|
| 596 | \item Instructions {\bf timingon , timingoff , traceon , traceoff } \\
|
---|
| 597 | %
|
---|
| 598 | \item Commande {\bf exec commandfilename [arg1 arg2 ... ] }
|
---|
| 599 | \item Commandes {\bf help et help keyword/commandname }
|
---|
| 600 | \item Commandes {\bf listvars , listcommands }
|
---|
| 601 | \item Defintion et liste d'alias : {\bf alias aliasname 'string ' } et {\bf listalias}
|
---|
| 602 | \end{itemize}
|
---|
[2717] | 603 |
|
---|
| 604 | \item[\rond] {\bf Threads d'execution de commandes (Avril 2005)} \\
|
---|
| 605 | Possibilite de lancer des commandes (autre que les commandes
|
---|
| 606 | de l'interpreteur lui-meme) en thread separe (il suffit de mettre un \&
|
---|
| 607 | a la fin de la commande) \\
|
---|
| 608 | Commandes des gestion des threads : \\
|
---|
| 609 | {\bf thrlist ; cleanthrlist ; cancelthr ThId ; waitthr } \\
|
---|
| 610 | Attention, la possibilite de lancer des commandes en threads separes ne fonctionne que
|
---|
| 611 | pour des commandes "thread-safe".
|
---|
| 612 | La plupart de nos commandes de piapp sont \\
|
---|
| 613 | - soit trop rapide, \\
|
---|
| 614 | - soit non "thread-safe" \\
|
---|
| 615 |
|
---|
| 616 | \item[\rond] controle d'execution : \\
|
---|
| 617 | Possibilite d'arreter l'execution de l'interpreteur (dans une boucle
|
---|
| 618 | ou dans dans un fichier .pic ...
|
---|
| 619 | Utiliser la commande {\bf stop} ou {\tt <Cntrl C>} dans PIConsole
|
---|
| 620 |
|
---|
[2632] | 621 | \end{itemize}
|
---|
| 622 |
|
---|
| 623 | \subsection{Classes CExpressionEvaluator et RPNExpressionEvaluator }
|
---|
| 624 | \begin{itemize}
|
---|
| 625 | \item[\rond] Ajout des classes RPNExpressionEvaluator et CExpressionEvaluator
|
---|
| 626 | d'valuation d'expressions numriques en notation polonaise inverse
|
---|
| 627 | et avec la syntaxe C . Utilise dans la classe Commander.
|
---|
| 628 | \item[\rond] Programme test Test/tcmd.cc
|
---|
| 629 | \item[\rond] extrait de {\tt cvs log cexpre.cc }
|
---|
| 630 | {\small \begin{verbatim}
|
---|
| 631 | ----------------------------
|
---|
| 632 | revision 1.3
|
---|
| 633 | date: 2004/03/18 18:15:19; author: ansari; state: Exp; lines: +10 -6
|
---|
| 634 | Suite (presque finie) des modifications de l'interpreteur - gestion des variables en particulier - Reste au moins un bug ds CExpressionEvaluator - Reza 18/03/2004
|
---|
| 635 | ----------------------------
|
---|
| 636 | revision 1.2
|
---|
| 637 | date: 2004/03/16 08:47:48; author: ansari; state: Exp; lines: +5 -6
|
---|
| 638 | suppression variables inutilisees ds cexpr.cc - Reza 16 Mars 2004
|
---|
| 639 | ----------------------------
|
---|
| 640 | revision 1.1
|
---|
| 641 | date: 2004/03/15 22:19:43; author: ansari; state: Exp;
|
---|
| 642 | Ajout fichiers des classes RPNExpressionEvaluator et CExpressionEvaluator (expression arithmetiques) et MAJ du fichier Makefile et objlist.list - Reza 15 Mars 2003
|
---|
| 643 | \end{verbatim} }
|
---|
| 644 |
|
---|
| 645 | \item[\rond] Extrait du message du 3 Mars 2004
|
---|
| 646 | \begin{verbatim}
|
---|
| 647 | Le code est base sur une hierarchie de classe d'expression :
|
---|
| 648 | Expr -------- NumberExp
|
---|
| 649 | --------- BinExp ------ AddExp
|
---|
| 650 | ------ MulExp
|
---|
| 651 | ------ SubExp
|
---|
| 652 | ------ DivExp
|
---|
| 653 | --------- FuncExp
|
---|
| 654 | --------- CExpressionEvaluator
|
---|
| 655 |
|
---|
| 656 | NumberExp : expression elementaire de nombre, sait actuellement traduire Pi et E
|
---|
| 657 | tres facile d'ajouter d'autres constantes
|
---|
| 658 | BinExp: Classe d'operations binaires (deux operandes) a+b a-b a*b a/b
|
---|
| 659 | avec gestion de niveau de priorite des operateurs
|
---|
| 660 | On peut facilement ajouter d'autres operateurs binaires (par exemple
|
---|
| 661 | puissance ^ a^b ) - et les priorites relatives seront gerees en principe.
|
---|
| 662 | FuncExp: classe d'expression fonctionnelle, avec n arguments f(x1,x2,...x3)
|
---|
| 663 | actuellemenent, n=0 a n=3 arguments et quelques fonctions
|
---|
| 664 | usuelles sont decodes ds cette classe (sin,cos,tan, asin, acos, atan, exp, log,
|
---|
| 665 | atan2, pow ) - voir ds le code
|
---|
| 666 |
|
---|
| 667 | CExpressionEvaluator : C'est la classe de haut niveau a utiliser -
|
---|
| 668 | la fonction de decodage de la chaine ASCII (qui utilise
|
---|
| 669 | les fonctionalites des differentes classes est la dedans
|
---|
| 670 | et ce n'est pas tres long.
|
---|
| 671 | (+ une classe d'exception specifique).
|
---|
| 672 | \end{verbatim}
|
---|
| 673 |
|
---|
| 674 | \end{itemize}
|
---|
| 675 |
|
---|
[2829] | 676 | \section{FitsIOServer}
|
---|
[2854] | 677 | Septembre-Novembre 2005 : Refondation totale du module - Les anciennes classes et gestionnaires
|
---|
[2829] | 678 | (FitsIOHandler , FitsFile , \ldots ) seront supprims.
|
---|
| 679 | \begin{itemize}
|
---|
[2854] | 680 | \item[\rond] Prise en charge de types TSTRING et TCOMPLEX et TDBLCOMPLEX
|
---|
| 681 | lors de lecture/ecriture de colonnes FITS.
|
---|
| 682 | \item[\rond] Prise en charge de l'ensemble des types de colonnes pour le handler de Fits
|
---|
| 683 | de DataTable
|
---|
[2829] | 684 | \item[\rond] Classe {\bf FitsInOutFile } comme wrapper des fonctions de la librairie cfitsio +
|
---|
| 685 | classe d'exception spcifique {\bf FitsIOException} , et la classe des types FITS {\bf FitsTypes}.
|
---|
| 686 | \item[\rond] Classe template {\bf FitsBlockRW$<$T$>$} pour lecture/criture (tableaux de donnes)
|
---|
| 687 | sur IMGHDU et Tables.
|
---|
| 688 | \item[\rond] Classes gestionnaires I/O Fits pour les objets {\bf FitsHandler$<$T$>$} et {\bf FitsManager}
|
---|
| 689 | \item[\rond] Classes gestionnaire pour les tableaux : {\bf FitsArrayHandler$<$T$>$}
|
---|
| 690 | \item[\rond] Classes gestionnaire pour les DataTable {\bf FitsHandler$<$BaseDataTable$>$}
|
---|
| 691 | \item[\rond] Mai 2005 : Classe {\bf FITSDataSwapper$<$T$>$} pour la gestion des
|
---|
| 692 | SwSegDataBlock sur fichiers FITS
|
---|
| 693 | \end{itemize}
|
---|
| 694 |
|
---|
[2717] | 695 | \section{LinAlg}
|
---|
| 696 | Extension des fonctionalits de la classe {\tt LapackServer<T>} :
|
---|
| 697 | (Juillet 2004 / cmv , Fvrier 2005 / Reza)
|
---|
| 698 | \begin{itemize}
|
---|
| 699 | \item[\rond] Introduction de l'interface Lapack d'inversion des matrices symetriques (21/7/2004)
|
---|
| 700 | \item[\rond] Introduction de l'interface Lapack de recherche de valeurs et vecteurs propres
|
---|
| 701 | (cas general, symetrique et hermitique) (21/7/2004)
|
---|
| 702 | \item[\rond] Introduction d'un fonction d'interface pour le calculateur de workspace
|
---|
| 703 | (ilaenv\_) (21/7/2004)
|
---|
| 704 | \item[\rond] Ajout prog test Tests/tsttminv.cc + Commentaires sur les diverses methodes et sur les matrices FORTRAN (21/7/2004)
|
---|
| 705 | \item[\rond] Ajout SVD decomp by Divide and Conquer SVD\_DC (23/7/2004)
|
---|
| 706 | \item[\rond] Ajout Least Square with SVD DC
|
---|
| 707 | \item[\rond] Ajout methode calcul de la matrice inverse par Lapack en utilisant la
|
---|
| 708 | resolution de systemes (07/02/2005)
|
---|
| 709 | \end{itemize}
|
---|
| 710 |
|
---|
[2854] | 711 | \section{IFFTW}
|
---|
| 712 | Correction du bug dans le cas de FFT-1D Backward(complex -> reel)
|
---|
| 713 | in(1).imag() pouvait etre ecrase.
|
---|
| 714 |
|
---|
[2632] | 715 | \section{PI,PIext,piapp}
|
---|
[2717] | 716 | \subsection{PI: Classes modifiees - ameliorees}
|
---|
| 717 | \begin{itemize}
|
---|
| 718 | \item[\rond] {\bf PIImageNavigator } \\
|
---|
| 719 | Ajout de la classe {\tt PIImageNavigator } permmettant de visualiser une image
|
---|
| 720 | avec ses propres widget zoom / global view et colormap. (Fevrier 2005) \\
|
---|
| 721 | Commande {\tt imagnav} ajoute ds piapp/baseexcute.cc . \\
|
---|
| 722 | \item[\rond] Avril 2005 - Amelioration de la classe {\bf PIConsole} \\
|
---|
| 723 | 1/Envoi Message PIMSG\_Cancel lors de {\tt <Cntl C>} \\
|
---|
| 724 | 2/ Correction positionnement curseur lors de rappel de commande,
|
---|
| 725 | Si possible en fin de commande - mais toujours avec le
|
---|
| 726 | debut de commande visible. \\
|
---|
| 727 | 3/ Correction (probable) du petit bug sur les derniers caracteres lors de copier/coller
|
---|
| 728 | ds PIConsole
|
---|
| 729 | \end{itemize}
|
---|
| 730 | %
|
---|
| 731 | %
|
---|
[2632] | 732 | \subsection{ Codage texte des options graphiques (11 Mars 2004)}
|
---|
| 733 | \begin{verbatim}
|
---|
| 734 | // Methode retournant un vecteur de string a partir des options
|
---|
| 735 | virtual int PIDrawer::OptionToString(vector<string> & opt) const
|
---|
| 736 | qui vient completer les deux methodes
|
---|
| 737 | virtual int PIDrawer:: DecodeOptionString(vector<string> & opt, bool ...) et
|
---|
| 738 | virtual void PIDrawer:: GetOptionsHelpInfo(string& info);
|
---|
| 739 | Ces methodes s'occupent de decoder les options graphiques (et l'aide
|
---|
| 740 | associe). La methode ajoutee permet de faire l'operation inverse, fabriquer
|
---|
| 741 | une serie de chaine de caracteres a partir des options graphiques.
|
---|
| 742 | Il y a aussi la methode
|
---|
| 743 | virtual int PIWdgGen::OptionToString(vector<string> & opt) const
|
---|
| 744 | que j'ai ajoute (rien a faire pour le moment) - ainsi que
|
---|
| 745 | int PIGraphicAtt::AttToStrings(vector<string> & att) const.
|
---|
| 746 |
|
---|
| 747 | Peux-tu remplir la methode PIGraphicAtt::AttToStrings(vector<string> & att) const.
|
---|
| 748 | L'implementation par defaut de PIDrawer::OptionToString(vector<string> & opt) const
|
---|
| 749 | appelle PIGraphicAtt::AttToStrings() - a laisser donc tel quel.
|
---|
| 750 |
|
---|
| 751 | par contre, pour les autres drawer (PIYfXDrawer, PIFuncDrawer, PIElDrawer,
|
---|
| 752 | PISurfaceDrawer, PIHisto, PIHisto2D, PINTuple ...) - lorsque
|
---|
| 753 | DecodeOptionString(vector<string> & opt, bool ...) est modifie,
|
---|
| 754 | rajouter la methode OptionToString(vector<string> & opt) et verifier le help.
|
---|
| 755 | Attention, il ne faut pas mettre l'argument opt a zero, mais ajouter des chaines
|
---|
| 756 | derriere (push_back()) afin de pouvoir cumuler les options de base + options
|
---|
| 757 | specifiques.
|
---|
| 758 |
|
---|
| 759 | Comment tester ?
|
---|
| 760 | Pour tester, tu peux utiliser la fenetre des options texte ou j'ai ajoute le bouton
|
---|
| 761 | [GetOption] . Tu peux acceder a cette fenetre a partir de la fenetre des options
|
---|
| 762 | graphiques <Alt>O , ou directement sur un objet de gestionnaire 2D - par
|
---|
| 763 | <Alt>T - <Shift>Button-1 permet de selectionner le drawer actif
|
---|
| 764 | \end{verbatim}
|
---|
| 765 |
|
---|
| 766 | \subsection{ Trace des axes (11 Mars 2004)}
|
---|
| 767 | Ajouter la possibilite de specifier l'origine (le point de croisement des axes)
|
---|
| 768 | lorsque les axes ne sont pas de type 'box' - classes PIAxes et PIElDrawer.
|
---|
| 769 |
|
---|
| 770 | \subsection{ Selection graphique (souris) du drawer actif (11 Mars 2004)}
|
---|
| 771 | \begin{verbatim}
|
---|
| 772 | J'ai ajoute la methode PIDrawer::GetDistanceToPoint(double x, double y)
|
---|
| 773 | // Renvoie une distance au point x,y
|
---|
| 774 | // 0: au(x) point(s) le(s) plus proche(s) ... 1 au bord xmin/xmax , ymin/ymax
|
---|
| 775 | // La methode par defaut calcule la distance normalisee au point ((xmin+xmax)/2,
|
---|
| 776 | (ymin+ymax)/2)
|
---|
| 777 | virtual double PIDrawer::GetDistanceToPoint(double x, double y);
|
---|
| 778 |
|
---|
| 779 | ainsi que ce qu'il faut ds PIBaseWdgGen et ds PIDrawer pour exploiter cette
|
---|
| 780 | methode + code permettant le test ds PIScDrawWdg.
|
---|
| 781 | (virtual void PIDrawer::WdgCoord2DrwCoord(int x, int y, double& xu ...
|
---|
| 782 | virtual int PIBaseWdgGen:;FindNearestDrawerId(int x, int y) ...)
|
---|
| 783 | Tu as a t'aoccuper de la methode PIDrawer::GetDistanceToPoint(double x, double y)
|
---|
| 784 | qui doit etre redefinie si possible pour chaque drawer, afin de fournir une
|
---|
| 785 | distance raisonnable au point (x,y) en argument.
|
---|
| 786 | J'ai juste mis une implementation par defaut (ds PIDrawer) et une implementation
|
---|
| 787 | partielle pour PIElDrawer (qui trace les axes en particulier) - qu'il faut
|
---|
| 788 | completer.
|
---|
| 789 |
|
---|
| 790 | Comment tester ?
|
---|
| 791 | J'ai mis ce qu'il faut ds le gestionnaire 2D (PIScDrawWdg) -
|
---|
| 792 | <Shift>Button-1 choisit le drawer le plus proche (base sur la
|
---|
| 793 | valeur de retour de PIDrawer::GetDistanceToPoint(double x, double y)
|
---|
| 794 | comme drawer actif. Ce drawer est passe en 'highlight' pendant que
|
---|
| 795 | le bouton est appuye.
|
---|
| 796 | \end{verbatim}
|
---|
| 797 |
|
---|
| 798 | \subsection{ Manipulation interactive des drawers (3 Juin 2004) }
|
---|
| 799 | La manipulation interactive des drawers ( l'aide d'un menu) a
|
---|
| 800 | t finalise pour les PIImage PIScDrawWdg PI3DWdg .
|
---|
| 801 |
|
---|
| 802 | \begin{verbatim}
|
---|
| 803 | o <Alt>D affiche le menu avec les differentes option
|
---|
| 804 | o Move/Resize: Affichage du rectangle + rectangle milieu
|
---|
| 805 | (deplacement) + coin bas-droite (deplacement) -
|
---|
| 806 | clicker ailleurs pour finir
|
---|
| 807 | o Mouse Select : Le mouse select des drawers est gere
|
---|
| 808 | maintenant par un PIEventHandler (comme pour Move/ReSize)
|
---|
| 809 | Drawer actif affiche par le rectangle muni d'un petit coin
|
---|
| 810 | (petit carre + rond dedans, en bas a droite).
|
---|
| 811 | Click souris change eventuellement le drawer actif.
|
---|
| 812 | On termine en clickant ds le petit [carre+rond]
|
---|
| 813 | \end{verbatim}
|
---|
| 814 |
|
---|
| 815 | \subsection{ Traceur de bar-graph (classe PIBarGraph) (3 Juin 2004) }
|
---|
| 816 | Ajout du traceur de bar-graph (classe {\bf PIBarGraph}) ds module PI/
|
---|
| 817 | et commande {\tt bargraph} ds PIext/basexecut.cc .
|
---|
| 818 | La commande bargraph ne gere pas encore toutes les possibilites
|
---|
| 819 | de la classe PIBarGraph. \\
|
---|
| 820 | Exemple d'utilisation:
|
---|
| 821 | \begin{verbatim}
|
---|
| 822 | Cmd> bargraph ' ' -10. 15. 22. 8. 33. 7 -4.
|
---|
| 823 | Cmd> bargraph 'blue ' -10. 15. 22. 8. 33. 7 -4.
|
---|
| 824 | Cmd> bargraph 'blue horizontalbars' -10. 15. 22. 8. 33. 7 -4.
|
---|
| 825 | Cmd> bargraph 'blue horizontalbars barvaluelabel ' -10. 15. 22. 8. 33. 7 -4.
|
---|
| 826 | Cmd> bargraph 'blue verticalbars nofill barvaluelabel ' -10. 15. 22. 8. 33. 7 -4.
|
---|
| 827 | Cmd> bargraph 'font=times,bold,16 blue verticalbars nofill barvaluelabel ' \
|
---|
| 828 | -10. 15. 2 2. 8. 33. 7 -4.
|
---|
| 829 | Cmd> bargraph 'font=times,bold,16 blue verticalbars fill barvaluelabel packfrac=0.8' \
|
---|
| 830 | -10. 15. 22. 8. 33. 7 -4.
|
---|
| 831 | \end{verbatim}
|
---|
| 832 |
|
---|
| 833 | \subsection{ Traceur de lignes de texte (classe PITextDrawer) (3 Juin 2004) }
|
---|
| 834 |
|
---|
| 835 | Ajout d'une classe de traceur de lignes de texte (classe {\bf PITextDrawer}) et commande
|
---|
| 836 | {\tt textdrawe}r ds PIext/basexecut.cc . Mais le traceur (et sa commande)
|
---|
| 837 | doivent etre completes. \\
|
---|
| 838 | Exemple d'utilisation:
|
---|
| 839 | \begin{verbatim}
|
---|
| 840 | # On affiche qque chose
|
---|
| 841 | Cmd> openppf demo.ppf
|
---|
| 842 | Cmd> disp h1d
|
---|
| 843 | Cmd> textdrawer 'frame line=solid,2 font=times,bold,16 red inset' \
|
---|
| 844 | ' Christophe ' ' Reza Ansari' ' SOPHYA '
|
---|
| 845 | \end{verbatim}
|
---|
| 846 |
|
---|
| 847 | \subsection{ Gestion de re-scale-ing des axes en 3D (3 Juin 2004) }
|
---|
| 848 |
|
---|
| 849 | Mise en place complete (?) de la gestion de re-scale-ing des axes en 3D
|
---|
| 850 | avec gestion des options graphiques (texte) - Il est possible en particulier d'imposer
|
---|
| 851 | les limites de la boites 3D.
|
---|
| 852 | cela a ete une grosse prise de tete de tout un apres-midi.
|
---|
| 853 | J'ai eu ensuite mal a la tete une partie de la soiree ! \\
|
---|
| 854 | Exemple d'utilisation:
|
---|
| 855 |
|
---|
| 856 | \begin{verbatim}
|
---|
| 857 |
|
---|
| 858 | # On ouvre le fichier demo.ppf
|
---|
| 859 | Cmd> openppf demo.ppf
|
---|
| 860 | Cmd> surf mtx1 'colbr32'
|
---|
| 861 | Cmd> surf mtx1 'colbr32 noautoscale'
|
---|
| 862 | Cmd> surf mtx1 'colbr32 lim3dbox=-10,60,-10,60,-3,15 autoscale3dbox'
|
---|
| 863 | # Affichage avec superposition
|
---|
| 864 | Cmd> nt3d nt32 x y z - - - - - 'marker=circle,7 red'
|
---|
| 865 | Cmd> nt3d nt32 x y z - - - - - 'same marker=cross,5 blue '
|
---|
| 866 | # Ou bien :
|
---|
| 867 | Cmd> nt3d nt32 x y z - - - - - 'marker=circle,7 red noautoscale'
|
---|
| 868 | Cmd> nt3d nt32 x y z - - - - - 'same marker=cross,5 blue '
|
---|
| 869 |
|
---|
| 870 | \end{verbatim}
|
---|
| 871 | \subsection{piapp}
|
---|
| 872 | \begin{itemize}
|
---|
| 873 | \item Le multithreading a t mis en oeuvre dans piapp (janvier 2004).
|
---|
[2717] | 874 | \item Possibilit d'execution de commandes en multithread (Avril 2005)
|
---|
| 875 | \item {\bf BUG } a corriger pour {\tt imagvav}:
|
---|
| 876 | La destruction de l'objet et/ou widget pascorrectement geres -
|
---|
| 877 | provoque des plantages lors de la sortie de l'application.
|
---|
| 878 |
|
---|
[2632] | 879 | \item Extrait de {\tt cvs log pistdimgapp.cc } :
|
---|
| 880 | \begin{verbatim}
|
---|
[2717] | 881 | revision 1.77
|
---|
| 882 | date: 2005/04/27 11:55:00; author: ansari; state: Exp; lines: +26 -10
|
---|
| 883 | 1/ Prise en charge de DataTable et SwPPFDataTable pour piapp (NObjMgrAdapter) :
|
---|
| 884 | nomhistadapter.cc et piiinit.cc
|
---|
| 885 | 2/ Lecture de tous les objets ds un fichier PPF par NamedObjMgr::ReadAll() pour
|
---|
| 886 | fichier PPF sans nametag.
|
---|
| 887 | 3/ Ajout bloc try/catch ds PIStdImgApp::Run() (boucle d'evenements)
|
---|
| 888 | Reza , 27 Avril 2005
|
---|
| 889 | ----------------------------
|
---|
| 890 | revision 1.76
|
---|
| 891 | date: 2005/04/19 09:13:49; author: ansari; state: Exp; lines: +3 -1
|
---|
| 892 | Ajout de l option nodisp ds les affichages des NamedObjMgr, prise en compte de
|
---|
| 893 | <Cntrl C> (Msg_Cancel) pour arreter l'execution de l'interpreteur ds PIStdImgApp
|
---|
| 894 | et remplacement commande breakexe par stop ds PIACmd - Reza 19/4/2005
|
---|
| 895 | ----------------------------
|
---|
| 896 | revision 1.75
|
---|
| 897 | date: 2005/04/19 06:56:52; author: ansari; state: Exp; lines: +5 -4
|
---|
| 898 | Remis en marche la possibilite d'execution d'un .pic au lancement de piapp -
|
---|
| 899 | Reza 19/4/2005
|
---|
| 900 | ----------------------------
|
---|
| 901 | revision 1.74
|
---|
| 902 | date: 2005/02/18 14:09:47; author: ansari; state: Exp; lines: +62 -37
|
---|
| 903 | Modifications pour l'utilisation viewer PIImageNavigator (ajout commande imagnav
|
---|
| 904 | ) - Reza 18 Fev 2005
|
---|
| 905 | ----------------------------
|
---|
| 906 | revision 1.73
|
---|
| 907 | date: 2004/11/19 17:41:07; author: ansari; state: Exp; lines: +26 -0
|
---|
| 908 | Ajout commandes addoval addfoval pour trace d'ellipse - Reza 19/11/2004
|
---|
| 909 | ----------------------------
|
---|
[2632] | 910 | revision 1.71
|
---|
| 911 | date: 2004/09/07 07:10:18; author: ansari; state: Exp; lines: +35 -0
|
---|
| 912 | Ajout bloc try/catch ds piacmd.cc (thread execution commandes) et ds pistdimgapp.cc (
|
---|
| 913 | methode process, thread boucle d'evts) - Reza 07/09/2004
|
---|
| 914 | ----------------------------
|
---|
| 915 | revision 1.70
|
---|
| 916 | date: 2004/01/06 18:44:56; author: ansari; state: Exp; lines: +11 -1
|
---|
| 917 | Suite debugging gestion lock entre threads ds piapp - A l'air de
|
---|
| 918 | marcher sur OSF1 et Linux ... Reza 06/01/2004
|
---|
| 919 | ----------------------------
|
---|
| 920 | revision 1.69
|
---|
| 921 | date: 2004/01/06 17:05:25; author: ansari; state: Exp; lines: +33 -7
|
---|
| 922 | Suite debug piapp multithread : on ne peut pas utiliser ZSync() ds un if (destructeur
|
---|
| 923 | appele de suite) - Reza 06/01/2004
|
---|
| 924 | ----------------------------
|
---|
| 925 | revision 1.68
|
---|
| 926 | date: 2004/01/04 19:02:43; author: ansari; state: Exp; lines: +43 -13
|
---|
| 927 | Suite des modifs pour piapp multi-threads
|
---|
| 928 | 1) Ajout Mutex de synchronisation ds ls classe NamedObjMgr
|
---|
| 929 | 2) Suite controle de gestion d'appel aux methodes de PIStdImgApp depuis
|
---|
| 930 | la classe elle-meme, a travers le NamedObjMgr
|
---|
| 931 | 3) Modification de la boucle d'evenements, avec un thread de reveil
|
---|
| 932 | periodique
|
---|
| 933 | Reza, 4 Janvier 2004
|
---|
| 934 | \end{verbatim}
|
---|
| 935 | \item Extrait de {\tt cvs log pistdimgapp.cc } :
|
---|
| 936 | \begin{verbatim}
|
---|
| 937 | ----------------------------
|
---|
| 938 | revision 1.62
|
---|
| 939 | date: 2003/11/27 10:51:58; author: ansari; state: Exp; lines: +45 -20
|
---|
| 940 | Suite modification/adaptations a la classe PIACmd qui herite maintenent de SOPHYA::Co
|
---|
| 941 | mmander - Reza 27/11/2003
|
---|
| 942 | ----------------------------
|
---|
| 943 | revision 1.61
|
---|
| 944 | date: 2003/11/26 23:01:55; author: ansari; state: Exp; lines: +20 -1755
|
---|
| 945 | Modification du code de PIACmd : La classe PIACmd herite maintenant de la classe Comm
|
---|
| 946 | ander (de SysTools) - Reza 26/11/2003
|
---|
| 947 | ----------------------------
|
---|
| 948 | revision 1.60
|
---|
| 949 | date: 2003/07/21 21:13:10; author: cmv; state: Exp; lines: +3 -3
|
---|
| 950 | - introduction notion de numero de ligne dans expression ntuple
|
---|
| 951 | modif prototype PlotExprFunc NTLoopExprFunc (add _nl _nstart _nend)
|
---|
| 952 | modif int_4 -> int_8_exprf (long long) pour _nl (DecodeLoopParameters,
|
---|
| 953 | PrepareNTExpressionCFile, LinkExprFunc,...)
|
---|
| 954 | - doc pour _nl _nstart _nend et arragement repartition RegisterHelp/RegisterCommand
|
---|
| 955 | (rz + cmv 21/7/2003)
|
---|
| 956 | ----------------------------
|
---|
| 957 | \end{verbatim}
|
---|
| 958 | \end{itemize}
|
---|
| 959 |
|
---|
| 960 | \section{Documentation (Manual/) }
|
---|
| 961 | Documentation des classes de SysTools. \\
|
---|
| 962 | Extrait message du 12 Aout 2004 : \\
|
---|
| 963 | \begin{verbatim}
|
---|
| 964 | ---> Au sujet de la doc (Manual/)
|
---|
| 965 | J'ai installe doxygen sur le Mac, version 1.3.8 -
|
---|
| 966 | Il faut updater le fichier de config de depart (dox_sophya.conf)
|
---|
| 967 | Pour ma part, j'ai du modifier mkmf (en version privee) -
|
---|
| 968 | En effet, il n'y avait pas le program doxysearch - Je ne sais pas si c'est general
|
---|
| 969 | ou specifique Mac.
|
---|
| 970 |
|
---|
| 971 | J'ai aussi modifie certaines options de doxygen (en version privee)
|
---|
| 972 | EXTRACT_LOCAL_CLASSES --> NO (au lieu de YES)
|
---|
| 973 | DETAILS_AT_TOP ---> YES (au lieu de No)
|
---|
| 974 | SORT_MEMBER_DOCS ---> NO (au lieu de YES)
|
---|
| 975 |
|
---|
[2829] | 976 | Si on est d'accord, on peut modifier ces options ds le fichier dox_sophya.conf et
|
---|
[2632] | 977 | utiliser la fonction update de doxygen (doxygen -u)
|
---|
| 978 | \end{verbatim}
|
---|
| 979 |
|
---|
[2829] | 980 | \section{Mgr}
|
---|
| 981 | {\large Avril-Mai 2005 : Basculement vers la nouvelle version de scripts
|
---|
| 982 | de gestion du code (module {\bf BuildMgr/ } ) }
|
---|
| 983 |
|
---|
| 984 | \subsection{Variables d'environnement SOPHYAxxx (17/9/2003) }
|
---|
| 985 | Septembre 2003 (17/9/2003) : Changement DPCDEVREP, DPCBASEREP
|
---|
| 986 | en SOPHYADEVREP , SOPHYABASEREP , EROSCXX en SOPHYACXX
|
---|
| 987 |
|
---|
| 988 | \subsection{Modifs Makefile - Message du 3 Mars 2004 }
|
---|
| 989 | \begin{verbatim}
|
---|
| 990 | Pour Les makefiles SOPHYA, je n'ai pas encore regarde ton makefile.h
|
---|
| 991 | modifie.
|
---|
| 992 | Voila qques propositions :
|
---|
| 993 | il y aura qu'une seule variable d'environnement : (SOPHYAROOT ou
|
---|
| 994 | SOPHYARACINE) par exemple
|
---|
| 995 | $SOPHYAROOT/Include
|
---|
| 996 | /Include/FitsIO/ FFTW/ (etc...) pour les .h extlibs
|
---|
| 997 | /Libs
|
---|
| 998 | /ShLibs
|
---|
| 999 | /Exec
|
---|
| 1000 | /Objs
|
---|
| 1001 | Un fichier Makefile.h ds $SOPHYAROOT/Include
|
---|
| 1002 | contiendra
|
---|
| 1003 | # Section generale
|
---|
| 1004 | SOPHYAROOT =
|
---|
| 1005 | SOPHYACXX=
|
---|
| 1006 | ...
|
---|
| 1007 | # Section compilation
|
---|
| 1008 | CC_COMPILER (nom du compilo cc)
|
---|
| 1009 | CXX_COMPILER ( c++)
|
---|
| 1010 | CPPFLAGS , (flag du preprocesseur), en particulier
|
---|
| 1011 | les -Iincludepath (chemin pour les includes SOPHYA
|
---|
| 1012 | CFLAGS flag de compilation c
|
---|
| 1013 | CXXFLAGS flags de compilation c++
|
---|
| 1014 | # Section Link
|
---|
| 1015 | LIBPATH -L... -L... (chemin pour les librairies et les lib externes (cfitsio, ...)
|
---|
| 1016 | LIBLIST -lm -lcfitsio ... (les librairies)
|
---|
| 1017 |
|
---|
| 1018 | Ces variables doivent pouvoir etre utilise par la classe CxxCompilerLinker.
|
---|
| 1019 | Il faut donc prevoir peut-etre un autre fichier cccpp_flags.h (ou qque chose
|
---|
| 1020 | du meme genre) avec la syntaxe C/C++ de chaines de caracteres
|
---|
| 1021 | pouvant etre include (par #include) ds cxxcmplnk.cc
|
---|
| 1022 |
|
---|
| 1023 | le fichier machdefs.h ds $SOPHYAROOT/Include est genere a partir du fichier
|
---|
| 1024 | machdefs_mkmf.h actuel (on pourra songer ulterieurement a le casser en
|
---|
| 1025 | plusieurs morceaux si necessaire) et contiendra en entete les flags
|
---|
| 1026 | qui modifie la generation du code
|
---|
| 1027 |
|
---|
| 1028 | exemple
|
---|
| 1029 | #define Linux
|
---|
| 1030 | #define SOPHYA_DEBUG
|
---|
| 1031 | ....
|
---|
| 1032 |
|
---|
| 1033 | Dans les fichier Makefile pour chaque module, on abandonnera
|
---|
| 1034 | les regles (et repertoire) de compilation par defaut et on aura
|
---|
| 1035 | donc:
|
---|
| 1036 | INC= $SOPHYAROOT/Include
|
---|
| 1037 | OBJ = $SOPHYAROOT/Objs
|
---|
| 1038 | LIB=...
|
---|
| 1039 | $(OBJ)toto.o : toto.cc $(INC)toto.h $(INC)titi.h ...
|
---|
| 1040 | $CXX $CXXFLAGS -c -o $(OBJ)toto.o toto.cc
|
---|
| 1041 | ....
|
---|
| 1042 |
|
---|
| 1043 | Il faudra voir ensuite pour le makefile de fabrication des shared-libs
|
---|
| 1044 | \end{verbatim}
|
---|
| 1045 |
|
---|
| 1046 | \subsection{ Modifs Makefile - Message du 8 Juillet 2004 }
|
---|
| 1047 | \begin{verbatim}
|
---|
| 1048 | A/ Makefile(s) (voir aussi mon message du 3 mars 2004)
|
---|
| 1049 | A-1/ Structures des repertoires
|
---|
| 1050 | >> On garde la structuration avec
|
---|
| 1051 | + un Makefile par module 'librairie'
|
---|
| 1052 | + un ensemble de modules librairies sans lib externe -> libsophya.slb
|
---|
| 1053 | + un ensemble de modules librairies avec lib externe -> libextsophya.slb
|
---|
| 1054 | + Des modules programmes (PrgUtil/ PrgMap/ ) avec un makefile par module programme
|
---|
| 1055 | + un Makefile de haut niveau (actuellement ds Mgr/Makefile
|
---|
| 1056 | Ce Makefile de haut niveau sera aussi simplifi - en particulier la partie
|
---|
| 1057 | concernant la fabrication des shared-libs (.slb) et Makefile.slb
|
---|
| 1058 | + On garde aussi la convention de generation automatique des GNUmakefile, qui sont
|
---|
| 1059 | ensuite renommes eventuellement en Makefile, conserves ds la base
|
---|
| 1060 | - Plus d'inclusion automatique du nom du system-compilo (Linux-g++ OSF1-cxx ...)
|
---|
| 1061 | dans les noms de repertoires
|
---|
| 1062 | - Plus de structure ExtLibDir obligatoire (remplace par des -Ipath -Lpath pour les
|
---|
| 1063 | compils/links
|
---|
| 1064 | - Si besoin, on fait subir le meme sort que Makefile.h a Makefile.slb
|
---|
| 1065 |
|
---|
| 1066 | On aura donc : (message du 3 mars 2004)
|
---|
| 1067 | il y aura qu'une seule variable d'environnement : (SOPHYAROOT ou
|
---|
| 1068 | SOPHYARACINE) par exemple
|
---|
| 1069 | $SOPHYAROOT/Include
|
---|
| 1070 | Attention le repertoire Include/ NE sera donc PLUS commun pour plusieurs
|
---|
| 1071 | systemes-compilo.
|
---|
| 1072 | /Libs
|
---|
| 1073 | /ShLibs
|
---|
| 1074 | /Exec
|
---|
| 1075 | /Objs
|
---|
| 1076 | Un fichier Makefile.h ds $SOPHYAROOT/Include
|
---|
| 1077 | contiendra les flags de compilation dfinis pour un systme/compilo.
|
---|
| 1078 | A la base, on aura ds Mgr/ un fichier Makefile.h pour chaque combinaison
|
---|
| 1079 | compilo-compilo;
|
---|
| 1080 | Mgr/makef_osf1_cxx.h
|
---|
| 1081 | Mgr/makef_linux_g++.h
|
---|
| 1082 | Mgr/makef_linux_KCC.h
|
---|
| 1083 | Mgr/makef_darwin_g++.h (Mac)
|
---|
| 1084 | Mgr/makef_sgi_CC.h
|
---|
| 1085 | etc ...
|
---|
| 1086 | C'est ce fichier qui est copi en Include/Makefile.h, ventuellement
|
---|
| 1087 | complete/modifie
|
---|
| 1088 |
|
---|
| 1089 | ----- Fichier Makefile.h
|
---|
| 1090 | # Section generale
|
---|
| 1091 | SOPHYAROOT =
|
---|
| 1092 | SOPHYACXX=
|
---|
| 1093 | ...
|
---|
| 1094 | # Section compilation
|
---|
| 1095 | CC_COMPILER (nom du compilo cc)
|
---|
| 1096 | CXX_COMPILER ( c++)
|
---|
| 1097 | CPPFLAGS , (flag du preprocesseur), en particulier
|
---|
| 1098 | les -Iincludepath (chemin pour les includes SOPHYA
|
---|
| 1099 | CFLAGS flag de compilation c
|
---|
| 1100 | CXXFLAGS flags de compilation c++
|
---|
| 1101 | # Section Link
|
---|
| 1102 | LIBPATH -L... -L... (chemin pour les librairies et les lib externes (cfitsio, ...)
|
---|
| 1103 | LIBLIST -lm -lcfitsio ... (les librairies)
|
---|
| 1104 |
|
---|
| 1105 | Ces variables doivent pouvoir etre utilise par la classe CxxCompilerLinker.
|
---|
| 1106 | Il faut donc prevoir peut-etre un autre fichier cccpp_flags.h (ou qque chose
|
---|
| 1107 | du meme genre) avec la syntaxe C/C++ de chaines de caracteres
|
---|
| 1108 | pouvant etre include (par #include) ds cxxcmplnk.cc
|
---|
| 1109 |
|
---|
| 1110 | le fichier machdefs.h ds $SOPHYAROOT/Include est genere a partir du fichier
|
---|
| 1111 | machdefs_mkmf.h actuel (on pourra songer ulterieurement a le casser en
|
---|
| 1112 | plusieurs morceaux si necessaire) et contiendra en entete les flags
|
---|
| 1113 | qui modifie la generation du code
|
---|
| 1114 |
|
---|
| 1115 | exemple
|
---|
| 1116 | #define Linux
|
---|
| 1117 | #define SOPHYA_DEBUG
|
---|
| 1118 | ....
|
---|
| 1119 |
|
---|
| 1120 | Dans les fichier Makefile pour chaque module, on abandonnera
|
---|
| 1121 | les regles (et repertoire) de compilation par defaut et on aura
|
---|
| 1122 | donc:
|
---|
| 1123 | INC= $SOPHYAROOT/Include
|
---|
| 1124 | OBJ = $SOPHYAROOT/Objs
|
---|
| 1125 | LIB=...
|
---|
| 1126 | $(OBJ)toto.o : toto.cc $(INC)toto.h $(INC)titi.h ...
|
---|
| 1127 | $CXX $CXXFLAGS -c -o $(OBJ)toto.o toto.cc
|
---|
| 1128 | ....
|
---|
| 1129 |
|
---|
| 1130 | \end{verbatim}
|
---|
| 1131 |
|
---|
| 1132 |
|
---|
[2632] | 1133 | \section{Plan de modifs pour SOPHYA V 2.0 PI/piapp V 4.0 (Septembre 2003) }
|
---|
| 1134 | \subsection{Gestion du code (Mgr/ ) }
|
---|
| 1135 | \begin{verbatim}
|
---|
| 1136 |
|
---|
| 1137 | o Chemins/variables d'environnement
|
---|
| 1138 | - Remplacer DPCDEVREP DPCBASEREP par SOPHYADEVREP et SOPHYABASEREP
|
---|
| 1139 | - Remplacer EROSCXX par SOPHYACXX (?)
|
---|
| 1140 | o Simplifier/rationaliser les makefiles
|
---|
| 1141 | - Mettre les flags de compils pour chaque compilo-systeme dans un fichier au lieu
|
---|
| 1142 | d'avoir tout Makefile.h
|
---|
| 1143 | Exemple fichier Mgr/linux_g++.flags
|
---|
| 1144 | CPPFLAGS = ...
|
---|
| 1145 | CXXFLAGS = ...
|
---|
| 1146 | LIBS = ...
|
---|
| 1147 |
|
---|
| 1148 | o Mettre un script pour chercher les lib externes (c-fitsio, FFTW, ...) et creer
|
---|
| 1149 | eventuellement l'arborescence ExtLibs
|
---|
| 1150 |
|
---|
| 1151 | o Inclure la definition des flags influant sur le code (comme
|
---|
| 1152 | -DOSF1/Linux/Darwin/IRIX64
|
---|
| 1153 | SO_BOUNDCHECKING a la fin du fichier machdefs.h que l'on fabriquera a
|
---|
| 1154 | partir de du machdef_mkmf.h )
|
---|
| 1155 | PB-> ce fichier deviendra alors dependant du systeme et de l'installation !
|
---|
| 1156 | Faut-il deplacer alors Include/ sous uname-$EROSCXX (Linux-g++)
|
---|
| 1157 | ou carrement considerer que la separation pour differents systemes doit se faire au
|
---|
| 1158 | niveau de SOPHYADEV/BASE/REP ?
|
---|
| 1159 |
|
---|
| 1160 | o Abandonner (?) les regles de compilation par defaut
|
---|
| 1161 | Inclure dans les Makefile la ligne de commande :
|
---|
| 1162 | $(OBJ)toto.o : toto.cc toto.h titi.h ...
|
---|
| 1163 | $(COMPILECXX) -$(CPPFLAGS) $(CXXFLAGS) -c -o $(OBJ)toto.o toto.cc
|
---|
| 1164 |
|
---|
| 1165 | o Garder les Makefile simple (eviter trop de tests et syntaxe complique)
|
---|
| 1166 |
|
---|
| 1167 | \end{verbatim}
|
---|
| 1168 |
|
---|
| 1169 | \subsection{Code/Librairie SOPHYA $\rightarrow$ V 2.0)}
|
---|
| 1170 | \begin{verbatim}
|
---|
| 1171 |
|
---|
| 1172 | o Fichiers PPersist (BaseTools) :
|
---|
| 1173 | - Ajouter la possibilite d'ecrire des complex(r_4> complex<r_8>
|
---|
| 1174 | (actuellement c'est ecrit sous forme de 2*r_4 ou 2*r_8)
|
---|
| 1175 | - Ajouter des tag de positionnement qui pourrait servir au cas
|
---|
| 1176 | ou on utiliserait le fichier PPF comme fichier de swap
|
---|
| 1177 | Ces tags ne peuvent pas etre les memes que les name-tag
|
---|
| 1178 | existant actuellement.
|
---|
| 1179 | Une utilisation annexe de ces tags peut etre alors un moyen
|
---|
| 1180 | de verifier que le fichier n'est pas corrompu
|
---|
| 1181 | Ce tag se presente alors sous forme de
|
---|
| 1182 | <tag (1 byte)><FilePosition (8 byte, long int)>
|
---|
| 1183 | On peut alors parcourir le fichier et verifier la coherence de
|
---|
| 1184 | ces tags.
|
---|
| 1185 | - Il faut aussi ajouter au niveau de POutPersist et PInPersist
|
---|
| 1186 | les services pour ecrire et lire une collection de tag de
|
---|
| 1187 | positionnement, afin qu'un objet puisse utiliser une liste de
|
---|
| 1188 | tag pour se positionner
|
---|
| 1189 |
|
---|
| 1190 | o BaseTools/ Voir autres remarques ds fichier Manual/sophya_afaire.txt
|
---|
| 1191 | concernant en particulier les NDataBlock<T> DataBlock<T> ...
|
---|
| 1192 |
|
---|
| 1193 | o Les tableaux : TArray/
|
---|
| 1194 | - Ajouter une classe de base abstraite GenericMatrix<T>
|
---|
| 1195 | avec methode d'acces aux elements, nb de lignes, nb de colonnes,
|
---|
| 1196 | ...
|
---|
| 1197 | - Introduire les TinyMatrix (TinyMatrix<T, int L, int C>)
|
---|
| 1198 | avec passage de/vers TMatrix<T> (et TinyVector<T, int N>) ?
|
---|
| 1199 |
|
---|
| 1200 | - Introduire des matrices creuses simples SpareMatrix<T>
|
---|
| 1201 |
|
---|
| 1202 | - Introduire les DiagonalMatrix<T>
|
---|
| 1203 |
|
---|
| 1204 | Remarque: Les TMatrix TinyMatrix et SparseMatrix heritent de GenericMatrix
|
---|
| 1205 |
|
---|
| 1206 | o HiStats
|
---|
| 1207 | - Faire une classe SuperNTuple (!), facile a utiliser, sachant swaper sur les
|
---|
| 1208 | PPF, avec des champs de differents type
|
---|
| 1209 |
|
---|
| 1210 | o IFFTW/
|
---|
| 1211 | - Passage a FFTW 3.x ?
|
---|
| 1212 |
|
---|
| 1213 | o Voir autres remarques pour l'ensemble des modules ds Manual/sophya_afaire.txt
|
---|
| 1214 | \end{verbatim}
|
---|
| 1215 |
|
---|
| 1216 | \subsection{Code/Librairie PI ($\rightarrow$ V 4.0)}
|
---|
| 1217 | \begin{verbatim}
|
---|
| 1218 |
|
---|
| 1219 | o Menu contextuel pour les Drawers
|
---|
| 1220 | - Ajouter a PIImage, PIScrDrawWdg(2D), PIDraw3DWdg(3D) un menu obtenu
|
---|
| 1221 | sur <Shift><Bouton-1> par exemple, avec la liste de tous les Drawers
|
---|
| 1222 | permettant d'afficher la fenetre des options graphiques, ou le fenetre
|
---|
| 1223 | des options ou la fenetre des options texte, activer deplacement/resize
|
---|
| 1224 | des drawers, suppression (delete) ou detach des drawers, et en fonction
|
---|
| 1225 | du widgets, la fenetre des axes ou de controle d'image
|
---|
| 1226 |
|
---|
| 1227 | o Mettre l'option auto-scale (rapport entre axes X,Y,Z) pour les Drawers3D
|
---|
| 1228 | verifer/debugger la definition de la boite 3D au niveau des Drawers3D
|
---|
| 1229 |
|
---|
| 1230 | o Traceur d'histos, NTuples, ...
|
---|
| 1231 | Remplacer le trace des lignes par morceau fait par appel multiples
|
---|
| 1232 | a DrawLine a un seul appel a DrawPolygon (si les lignes sont connectes
|
---|
| 1233 | bien sur) --> Ca ameliore sensiblement l'aspect pour le trace en pointille
|
---|
| 1234 |
|
---|
| 1235 | o Ajouter un traceur de Bar-chart 2D OU ApplePie (facile !)
|
---|
| 1236 | On donne une serie de nombres, serie de couleur, + serie de strings
|
---|
| 1237 | et on trace alors une sorte d'histo, avec des barres (rectangles) espaces
|
---|
| 1238 | Ou bien on trace un cercle divise en zones
|
---|
| 1239 |
|
---|
| 1240 | o Ajouter un traceur de Lego-Plot
|
---|
| 1241 |
|
---|
| 1242 | o PIImageWindow (Une fenetre avec une PIImage, un Zoom et une vue globale)
|
---|
| 1243 | Assemblage
|
---|
| 1244 |
|
---|
| 1245 | o (?) Une fonction pour faire facilement une fenetre d'alerte ou d'info (?)
|
---|
| 1246 |
|
---|
| 1247 | \end{verbatim}
|
---|
| 1248 |
|
---|
| 1249 | \subsection{(s)piapp ($\rightarrow$ V 4.0)}
|
---|
| 1250 | \begin{verbatim}
|
---|
| 1251 |
|
---|
| 1252 | o Verifier l'interpreteur et introduire le type de variable vecteur
|
---|
| 1253 | qui peut etre detecte par exemple lors de l'initialisation par set
|
---|
| 1254 | set a 'Bonjour CMV' # -> variable scalaire
|
---|
| 1255 | set va [ 12 14 hello ... ] # variable de type vecteur $va[]
|
---|
| 1256 |
|
---|
| 1257 | o Voir comment on pourrait "joindre" deux objets ayant l'interface NTupleInterface
|
---|
| 1258 | pour pouvoir plotter des objets, l'un vs l'autre
|
---|
| 1259 |
|
---|
| 1260 | o Separer la classe PIACmd en une classe de base (CShellLikeInterpreter)
|
---|
| 1261 | (a mettre ds SysTools) et la classe PIACmd a laisser ds PIext
|
---|
| 1262 |
|
---|
| 1263 | o (???) Introduire quelque chose du style
|
---|
| 1264 | AddDialogue("Cmd", "dialogue-description)
|
---|
| 1265 | qui pourrait fabriquer automatiquement une fenetre avec des champs a remplir
|
---|
| 1266 | pour les commandes usuelles (???)
|
---|
| 1267 |
|
---|
| 1268 | o Voir les autres commentaires ds Manual/spiapp_afaire.txt
|
---|
| 1269 |
|
---|
| 1270 | \end{verbatim}
|
---|
| 1271 |
|
---|
| 1272 |
|
---|
| 1273 | \end{document}
|
---|