/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        S U P E R P O S I T I O N   D Y N A M I Q U E   D ' E T A T S                                                              */
/*        P R O P R E S   D E   L ' A T O M E   D ' H Y D R O G E N E  :                                                             */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Exemple de realisation :                                                                                                   */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                  ................................................................                                                 */
/*                  ................................................................                                                 */
/*                  ................................................................                                                 */
/*                  ..---------...........................................---------.                                                 */
/*                  --------------.....................................-------------                                                 */
/*                  -----------------...............................----------------                                                 */
/*                  -------------------.......-------------.......------------------                                                 */
/*                  --::::::::---------------------:::---------------------::::::::-                                                 */
/*                  ::::::::::::-------------:::::::o:::::::-------------:::::::::::                                                 */
/*                  :::::::::::::----------:::ooooOOOOOoooo:::----------::::::::::::                                                 */
/*                  ::::::::::::::-------:::oooOO%%%%%%OOOooo:::-------:::::::::::::                                                 */
/*                  ::ooooo:::::::-------::ooOO%%%#####%%%OOoo::-------:::::::ooooo:                                                 */
/*                  ooooooooo:::::------:::ooO%%########%%%Ooo::-------:::::oooooooo                                                 */
/*                  oooooooooo::::-------::ooO%%%%%%%%%%%%%Ooo::-------::::ooooooooo                                                 */
/*                  oooooooooo::::--------:ooOOOOOo:-:oOOOOOo::--------::::ooooooooo                                                 */
/*                  ooooooooooo:::---------:oooOo:-. .-:oOoo::---------:::oooooooooo                                                 */
/*                  ooooooooooo:::----....--::ooo::---::ooo::--....----:::oooooooooo                                                 */
/*                  oooooooooooo:::--.......---:::::::::::---......---:::ooooooooooo                                                 */
/*                  oooooooooooo:::---..........---------..........---::oooooooooooo                                                 */
/*                  ooooooooooooo:::--............................---:::oooooooooooo                                                 */
/*                  :ooooooooooooo:::---.........................---:::ooooooooooooo                                                 */
/*                  ::ooooooooooooo::::--.......................--:::oooooooooooooo:                                                 */
/*                  :::oooooooooooooo:::----.................---::::oooooooooooooo::                                                 */
/*                  :::::oooooooooooooo::::-----.........-----::::oooooooooooooo::::                                                 */
/*                  -::::::oooooooooooooo::::::----------:::::::oooooooooooooo:::::-                                                 */
/*                  ----::::::oooooooooooooo::::::::::::::::ooooooooooooooo::::::---                                                 */
/*                  ------::::::::ooooooooooooooooo:::ooooooooooooooooo::::::::-----                                                 */
/*                  ..--------:::::::::ooooooooooooooooooooooooooo:::::::::--------.                                                 */
/*                  ......--------:::::::::::::::::::::::::::::::::::::--------.....                                                 */
/*                  ..........-----------:::::::::::::::::::::::-----------.........                                                 */
/*                  ................---------------------------------...............                                                 */
/*                  ...........................-----------..........................                                                 */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                                      (A=1,B=1,C=1,D=1,E=1,F=1)                                                                    */
/*                                                (t=0)                                                                              */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                  ...... ......................................---.-...... .....--                                                 */
/*                  ....... .....------...........-----........--:::::::-........-::                                                 */
/*                  ::--........----::::--:oo-....--oo:-....-::::ooooOOo::-... ..:oo                                                 */
/*                  ooo:-... ..--:--OOo:::o:.:....--OOo:. ...-::ooooO%%%Oo:. ...-oOO                                                 */
/*                  OOOOo:-..--:::--O%Oo:-.......---O%%O:....-::oOooO%##%O:-...-oOOO                                                 */
/*                  %%%%%%Oooooo::-.O%%%Oo:-...----.O%%%%Oo::ooOOo:-O%%###%OOOOO%OOo                                                 */
/*                  O%%%%%%%OOo:--..OO%%OOOoo:::-...oOO%%%%OOOoo:--.:ooO%%%%%%OOo:--                                                 */
/*                  OOO%%OOOo::-....oooooooo::-.....::::ooo:::-.....----::::::--....                                                 */
/*                  ................  ..................   .............. ..........                                                 */
/*                  ..    .....   ..................................................                                                 */
/*                  .......---............................................-:::-.....                                                 */
/*                  ......--.--............. .......-------.........:--...-:.:-.....                                                 */
/*                  ................--..............::::----........oo:-............                                                 */
/*                  ---...........--::::----------..ooooo:--........OOOo:-..........                                                 */
/*                  ::::::-----:::::oOOoooooo::::::-OOOOOOoo::----..O%%OOoo:::---...                                                 */
/*                  OOOOOOOOOOOOOOOOO%%%%%%OOOOOoooo%%%%%%OOOoo:::--O%%%%OOOoo::--..                                                 */
/*                  .......... ................................  ..................                                                  */
/*                  .---...... .................................................. ..                                                 */
/*                  .----.........--......-:o:-................................. ...                                                 */
/*                  .--:--.. ...-:oo......-:.:-...--..........------................                                                 */
/*                  .--:::--..-:oOOO.............-::.........---::::...............-                                                 */
/*                  ..-::oooooOO%%%%...........-:ooO........--::oooo..------...---::                                                 */
/*                  ...--:oOOO%%%%%%....---:::ooOO%%..----:::ooOOOOO-:::::::::oooooo                                                 */
/*                  ....--:ooOOO%%%O..---::ooOOO%%%%--:::oooOO%%%%%%oooooOOOOO%%%%%O                                                 */
/*                  --............-----..... .......----............................                                                 */
/*                  :::-.........-:::::-........-:::-::---........-----...........--                                                 */
/*                  oo:---:O%O:--::oooo:-......-:oOO:::::::o:-...-::---....-:o::-:::                                                 */
/*                  oOo:..:o.o:.-:oOoOOo-... .-:O%%%:ooo::o:.-...:oO---.. .-.:o::ooO                                                 */
/*                  oOOo-.......-oOOoOOOo:-..-oO%##%::ooo:--....:oO%.---.....--:oO%%                                                 */
/*                  :oOOo:-...-:oOOo:oOO%%OOO%%###%%--:ooo:::::oO%%%..--------:oO%%%                                                 */
/*                  --:ooooooooooo:-.-::oOO%%%%%%Ooo..--:ooOOOO%%OOO...--::oooOO%%%O                                                 */
/*                  ....---------........--::::::--- ....--:::oooo::.....--::ooooOoo                                                 */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                                      (A=1,B=1,C=1,D=1,E=1,F=1)                                                                    */
/*                                          (pour  t E [0,8])                                                                        */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                  oOOOOO%OOOoOOoOO%%##############                                                                                 */
/*                  oOooOooOOOOoo:oO%###############                                                                                 */
/*                  %OOOOoOOOoo:-:OOOO%############%                %                                                                */
/*                  oOOOOOOOoo-.-oOOooo#############%%%%%%%#      oOoo#      %OO%%%%                                                 */
/*                  OOOOO%OOo-..:o%Oo::%#####%%####%oO%##########-%Oo:o#OOOOOOOOOO%%                                                 */
/*                  %OO%%OOO-..-:O%O:.-%#####%%%%%%%oO%#########.:%O-.:##OOooooooO%%                                                 */
/*                  %%%%O%%%:..-:o#%-.-%%###%%%%%#%%:OO%#####%O..:#%-.:###%OOo::o%%#                                                 */
/*                  %%%%%%%%O---:o#:-.o%%#%%%%%%%%%%ooOO%##O:-...-O:-.%%####O--o%###                                                 */
/*                  %%%%%%%%%o:-:ooO%O%%%%%%%%OOO%%%:ooOO%##::...-:oOO%%###O-o%%####                                                 */
/*                  %%%#%#%%%Oo:ooooOOO%%%%%%%OOO%O%:ooooOO%##-..-:ooOO%%#%O%%######                                                 */
/*                  %%%%%%##%%OoooooOOO%%%%%OOOOO%%%ooO:ooOOOOO%%%%ooO%%%%%%%%%%#%##                                                 */
/*                  %%%%%#####%%OooO%%%%%%%OOOOOOO%%O:oOOOoooO%O%OO%%%%%%%%%%%%%%###                                                 */
/*                  %%%%%%##%##%%%%O%%%%%%%oO%O%O%%%Oo:OOooooOoOOO%%%%%%%%%%%%%%%%%#                                                 */
/*                  %%%%%%%%#%%%%%%%%%%%OO%%OOOO%%%OoOOOoooOoOoOOOOO%OO%%%%%%%%%%%%#                                                 */
/*                  %%%%#%%%%%%##%%%%%%%%O%%O%%%O%%OOOOOOooOOOO...........%%%%%%%%#%                                                 */
/*                  %%%%%#%%%%%%%%%%%%%%%%OOO%%O%%%%OOOO........................:##%                                                 */
/*                                                                                                                                   */
/*                     (A=1,B=0,C=1,D=0,E=0,F=1)      (A=1,B=1.50,C=1,D=1,E=1,F=1)                                                   */
/*                                                                                                                                   */
/*                                                                oO%##                                                              */
/*                     OO%O%%%%%%%#%o::%%%%O%%#%%#           OOO-:OOOo%##%%%                                                         */
/*                  OOO%%%%%%%#%%.O%-.##OOOO%O%%%%## %OOOOOOOo-.-o%Oo:o%##########%#                                                 */
/*                  OO%%######%%%.-oo%%#%OOOOOOOO%##%OOOOooo:..-:O%Oo-:%############                                                 */
/*                  %%%#######%%...:oO%%#OOOooOOO%%%%ooOOOo--..-:%%O-..O############                                                 */
/*                  %%########%%...:oOO%#OooOoooOO%%OOoOoOOo:--::O#o-.-%%###########                                                 */
/*                  %%#########....:oOO%%#oOoooooO%O%OOooO%OOO:::o%:-.O%%#%%%#######                                                 */
/*                  %%#::::%##%...-:oOO%%#%OoooooOO%:Oo%%%%%OOoo:ooOOOOO%%%%%%%%%###                                                 */
/*                  %%#%:::::-....-ooOO%%###Oo::oo%%OoOO%%%#%%%ooooOOOOO%%%%OOO%##%#                                                 */
/*                  %%###::::.....:ooOO%%###%OoooOO#O%%%%#####%%OoooOOOO%%OOOOO%%%##                                                 */
/*                  %%O%%##::-...-:ooO%%%###%ooOO%%#oOOOO%%#####%OOOOOO%%OOoOO%%%###                                                 */
/*                  O%%OO%%##:--:oooOO%%###%oOO%#%%#OOOO%%%##%#####OOOOOOooOOO%%%###                                                 */
/*                  o%OOOO%%%%%%%OO%%%%#%OO%%#%#####O%oOO%OO%%%%%%#%%%OOO%%%%%######                                                 */
/*                  OOOOOOOO%OO::.......::%#%%%%%%%#%OOO%OOO%%%%%%%%%%%%%%%%%%#%%###                                                 */
/*                  O...............................O%OO%OOO%o.............%%%%###%#                                                 */
/*                                                                                                                                   */
/*                    (A=1,B=1.50,C=0,D=0,E=0,F=0)     (A=1,B=0,C=1,D=0,E=0,F=0)                                                     */
/*                                                                                                                                   */
/*                                                (t=8)                                                                              */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                  voir aussi 'v $xiaq/HYDR.6G$M$R16' et 'v $xiaq/HYDR.6d$R16$DROITE    p=$xiP/trou_noir.14'.                       */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Author of '$xrq/hydrogene.61$K' :                                                                                          */
/*                                                                                                                                   */
/*                    Jean-Francois COLONNA (LACTAMME, 1993??????????).                                                              */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        I N T E R F A C E   ' listG '  :                                                                                           */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        :Debut_listG:                                                                                                              */
/*        :Fin_listG:                                                                                                                */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D I R E C T I V E S   S P E C I F I Q U E S   D E   C O M P I L A T I O N  :                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
@define   PRAGMA_CPP_____MODULE_NON_DERIVABLE

@define   PRAGMA_CL_____MODULE_NON_OPTIMISABLE

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        F I C H I E R S   D ' I N C L U D E S  :                                                                                   */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  INCLUDES_BASE

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D E F I N I T I O N   D E S   F O N C T I O N S   U T I L E S   ( C O M P A T I B I L I T E )  :                           */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xrk/attractor.11.I"
#include  xrv/particule.41.I"

#include  xrs/sphere.18.I"
#include  xrs/sphere.19.I"
                                        /* Inutile, mais pour la compatibilite (introduit le 20030130112733 a cause de               */
                                        /* 'v $xcc/cpp$Z INCLUDES_1.sed').                                                           */

#include  xrk/attractor.12.I"

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D E F I N I T I O N   D E   L ' A T O M E   D ' H Y D R O G E N E  :                                                       */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xrs/sphere.12.I"
#include  xrq/Hspherik.14.I"
                                        /* Introduit le 20060611085053 suite a 'v $xrs/surfaces.12$I 20060602134331'.                */
#include  xrs/sphere.14.I"
#include  xrq/Laguerre.31.I"
#include  xrq/Legendre.31.I"
#include  xrq/Hspherik.21.I"
#include  xrq/hydrogene.21.I"
#include  xrq/Hspherik.12.I"
#include  xrq/hydrogene.23.I"
#include  xrq/hydrogene.24.I"
#include  xrq/hydrogene.25.I"

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        C A L C U L   L O C A L   D ' U N E   F O N C T I O N   P R O P R E  :                                                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#define   CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre,ordre_n,ordre_l,ordre_m,coefficient)                                    \
                    Bblock                                                                                                              \
                    Test(IZNE(coefficient))                                                                                             \
                         Bblock                                                                                                         \
                         CALCUL_D_UNE_FONCTION_PROPRE_DE_NOM_QUELCONQUE(fonction_propre,ordre_n,ordre_l,ordre_m);                       \
                                        /* Calcul de la fonction propre locale pour un couple (n,l,m) de nom 'fonction_propre'       */ \
                                        /* quand sa ponderation ulterieure n'est pas nulle...                                        */ \
                         Eblock                                                                                                         \
                    ATes                                                                                                                \
                         Bblock                                                                                                         \
                         Cinitialisation(fonction_propre,FZERO,FZERO);                                                                  \
                                        /* Lorsque la ponderation ulterieure d'une fonction propre locale pour un couple (n,l,m)     */ \
                                        /* est nulle, on met cette derniere a zero par pure proprete (et peut-etre aussi pour        */ \
                                        /* eviter des problemes avec les nombres flottants, on ne sait jamais...).                   */ \
                         Eblock                                                                                                         \
                    ETes                                                                                                                \
                    Eblock                                                                                                              \
                                        /* Calcul de la fonction propre locale pour un couple (n,l,m) de nom 'fonction_propre'       */ \
                                        /* lorsque sa ponderation ulterieure n'est pas nulle...                                      */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D E F I N I T I O N   D U   T E M P S  :                                                                                   */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xrq/hydrogene.61.I"
                                        /* Forcage de la definition de 'ZOOM_IMPLICITE' afin d'assurer la compatibilite avec les     */
                                        /* sequences deja generees...                                                                */

#include  xrs/surfaces.11.I"

#define   TEMPS                                                                                                                         \
                    FZERO
DEFV(Local,DEFV(Float,INIT(temps,TEMPS)));
                                        /* Definition du temps.                                                                      */

dfTRANSFORMAT_31(liste_PARAMETRE_TEMPS,fichier_PARAMETRE_TEMPS,PARAMETRE_TEMPS_IMPLICITE,TEMPS)
                                        /* Definition du fichier du parametre 't'.                                                   */
#define   sPARAMETRE_TEMPS(numero_de_la_periode)                                                                                        \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_PARAMETRE_TEMPS))
                                        /* Formule generale definissant les variations de 't' au cours du temps.                     */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D E F I N I T I O N   D E S   C O O R D O N N E E S  :                                                                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#define   caXf                                                                                                                          \
                    MUL2(ASD1(echelle_courante,cx)                                                                                      \
                        ,CARRE_OX_PAR_RAPPORT_A_OY(_____cNORMALISE_OX(SOUS(X,_lDENORMALISE_OX(ASD1(translation,dx)))))                  \
                         )
#define   caYf                                                                                                                          \
                    MUL2(ASD1(echelle_courante,cy)                                                                                      \
                        ,CARRE_OY_PAR_RAPPORT_A_OY(_____cNORMALISE_OY(SOUS(Y,_lDENORMALISE_OY(ASD1(translation,dy)))))                  \
                         )
#define   caZf                                                                                                                          \
                    MUL2(ASD1(echelle_courante,cz)                                                                                      \
                        ,SOUS(profondeur,ASD1(translation,dz))                                                                          \
                         )
                                        /* Definition des coordonnees cartesiennes. On notera que l'on utilise (cXf,cYf,cZf) afin    */
                                        /* de ne pas rentrer en conflit avec la procedure 'coordonnees_flottantes_X_et_Y_et_Z' qui   */
                                        /* definit {Xf,Yf,Zf} et qui est appelee dans '$xrv/champs_5.12$I' via '$xrs/surfaces.11$I'  */
                                        /* et '$xrk/attractor.17$I', et tout cela pour des raisons de compatibilite...               */

#define   PERMUTATION_XY                                                                                                                \
                    FAUX
DEFV(Local,DEFV(Logical,INIT(permutation_XY,PERMUTATION_XY)));
                                        /* Faut-il permuter 'X' et 'Y' ?                                                             */
#define   PERMUTATION_YZ                                                                                                                \
                    FAUX
DEFV(Local,DEFV(Logical,INIT(permutation_YZ,PERMUTATION_YZ)));
                                        /* Faut-il permuter 'Y' et 'Z' ?                                                             */
#define   PERMUTATION_ZX                                                                                                                \
                    FAUX
DEFV(Local,DEFV(Logical,INIT(permutation_ZX,PERMUTATION_ZX)));
                                        /* Faut-il permuter 'Z' et 'X' ?                                                             */

DEFV(Local,DEFV(Float,INIT(cXf,FLOT__UNDEF)));
DEFV(Local,DEFV(Float,INIT(cYf,FLOT__UNDEF)));
DEFV(Local,DEFV(Float,INIT(cZf,FLOT__UNDEF)));
                                        /* Definition des coordonnees cartesiennes apres permutation eventuelle des axes...          */

#define   PROFONDEUR                                                                                                                    \
                    FZERO
DEFV(Local,DEFV(Float,INIT(profondeur,PROFONDEUR)));
                                        /* Definition de la profondeur de la coupe a effectuer (du type [0,1] ou [-0.5,+0.5]).       */

dfTRANSFORMAT_31(liste_PARAMETRE_Z,fichier_PARAMETRE_Z,PARAMETRE_Z_IMPLICITE,PROFONDEUR)
                                        /* Definition du fichier du parametre 'z'.                                                   */
#define   sPARAMETRE_Z(numero_de_la_periode)                                                                                            \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_PARAMETRE_Z))
                                        /* Formule generale definissant les variations de 'z' au cours du temps.                     */

                                        /* ATTENTION, il y a eu pendant longtemps :                                                  */
                                        /*                                                                                           */
                                        /*                  #define   cRHO                                                        \  */
                                        /*                                      Rho_3D(cXf,cYf,cZf)                                  */
                                        /*                  #define   cPHI                                                        \  */
                                        /*                                      Theta_3D(cXf,cYf,cZf)                                */
                                        /*                  #define   cTHETA                                                      \  */
                                        /*                                      Phi_3D(cXf,cYf,cZf)                                  */
                                        /*                                                                                           */
                                        /* mais en fait cela etait faux car nous ne sommes pas en coordonnees spheriques relatives   */
                                        /* aux axes (OX,OY,OZ), mais par rapport aux axes (OY,OZ,OX). Il faut donc permuter les      */
                                        /* trois axes ainsi que les fonction 'Theta_3D(...)' et 'Phi_3D(...)'...                     */

#define   cRHO                                                                                                                          \
                    Rho_3D(cYf,cZf,cXf)                                                                                                 \
                                        /* Definition du rayon polaire.                                                              */
#define   cPHI                                                                                                                          \
                    Phi_3D(cYf,cZf,cXf)                                                                                                 \
                                        /* Definition de la coordonnee 'phi'.                                                        */
#define   cTHETA                                                                                                                        \
                    Theta_3D(cYf,cZf,cXf)                                                                                               \
                                        /* Definition de la coordonnee 'theta'.                                                      */

                                        /*                                                               ,,   ,,   ,,                */
                                        /* Definition des coordonnees spheriques par rapport aux axes (OX  ,OY  ,OZ  ), alors que    */
                                        /* les axes du modele sont (OX,OY,OZ). On notera que l'angle 'phi' mesure une rotation par   */
                                        /* rapport a l'axe 'OX'.                                                                     */
                                        /*                                                                                           */
                                        /*                                             ,,                                            */
                                        /*                                    Y * ==> X                                              */
                                        /*                                      *                                                    */
                                        /*                   ,                  *                                                    */
                                        /*                  Y +                 C - - - - - - - - B                                  */
                                        /*                     +              . *               .                                    */
                                        /*                      +           .   * \           .   |                                  */
                                        /*                       +        .     *           .                                        */
                                        /*                        +     .       *   \     .       |                                  */
                                        /*                         +  .         *       .                                            */
                                        /*                          E - - - - - - - - P(X,Y,Z)    |                                  */
                                        /*                           +          *                                                    */
                                        /*                          | +         *    +|           |                                  */
                                        /*                             +        *                                                    */
                                        /*                          |   +--phi--*   + |           |                                  */
                                        /*                               +      *   |                                                */
                                        /*                          |     +     *  +t |           |                                  */
                                        /*                                 +    *   e                                                */
                                        /*                          |       +   * + t |           |                                  */
                                        /*                                   +  *   a                                                */
                                        /*                          |         + *+  | |           |                                  */
                                        /*                                     +*   |                                     ,     ,,   */
                                        /*                          |           O* * *|* * * * * *A* * * * * * * * * * X=X ==> Z     */
                                        /*                                    *                 .                                    */
                                        /*                          |       *  .  \   |       .                                      */
                                        /*                                *                 .                                        */
                                        /*                          |   *     .     \ |   .                                          */
                                        /*                            *                 .                                            */
                                        /*                          F - - - -.- - - - D                                              */
                                        /*                        *                                                                  */
                                        /*                      *           .                                                        */
                                        /*                    *                                                                      */
                                        /*                  *              .                                                         */
                                        /*                *                                                                          */
                                        /*              *                 .                                                          */
                                        /*            *                                                                              */
                                        /*          *    ,,              .                                                           */
                                        /*      Z * ==> Y                                                                            */
                                        /*                              .                                                            */
                                        /*                            ,                                                              */
                                        /*                           Z .                                                             */
                                        /*                                                                                           */
                                        /*                                                                                           */
                                        /* On a les proprietes suivantes :                                                           */
                                        /*                         ,   ,                                                             */
                                        /*                  P E (OX ,OY ), car 'OP' est la diagonale du quadrilatere plan OAPE.      */
                                        /*                                                                                           */
                                        /*                   ^     ^     pi                                                          */
                                        /*                  OCE = OEP = ----                                                         */
                                        /*                               2                                                           */
                                        /*                                                                                           */
                                        /*                   ^                                                                       */
                                        /*                  COE = phi                                                                */
                                        /*                                                                                           */
                                        /*                   ^     ^                                                                 */
                                        /*                  OPE = POA = theta                                                        */
                                        /*                                                                                           */
                                        /*                  OP = rho                                                                 */
                                        /*                                                                                           */
                                        /* d'ou :                                                                                    */
                                        /*                                                                                           */
                                        /*                                  ^      CE     Z                                          */
                                        /*                  tan(phi) = tan(COE) = ---- = ---                                         */
                                        /*                                         OC     Y                                          */
                                        /*                                                                                           */
                                        /*                              Z                                                            */
                                        /*                  phi = atan(---) = Theta_2D(Y,Z) = Phi_3D(Y,Z,X)                          */
                                        /*                              Y                                                            */
                                        /*                                                     ________                              */
                                        /*                                                    / 2    2                               */
                                        /*                                    ^      EO     \/ Y  + Z                                */
                                        /*                  tan(theta) = tan(OPE) = ---- = -------------                             */
                                        /*                                           PE          X                                   */
                                        /*                                                                                           */
                                        /*                                   ________                                                */
                                        /*                                  / 2    2                                                 */
                                        /*                                \/ Y  + Z                                                  */
                                        /*                  theta = atan(-------------) = Theta_3D(Y,Z,X)                            */
                                        /*                                     X                                                     */
                                        /*                                                                                           */
                                        /*                           -------------                                                   */
                                        /*                          / 2    2    2                                                    */
                                        /*                  rho = \/ X  + Y  + Z   = Rho_3D(Y,Z,X)                                   */
                                        /*                                                                                           */
                                        /* Enfin, on voit ainsi qu'il suffit de permuter les axes de la facon suivante :             */
                                        /*                                                                                           */
                                        /*                  {X,Y,Z} --> {Y,Z,X}                                                      */
                                        /*                                                                                           */
                                        /* soit :                                                                                    */
                                        /*                                                                                           */
                                        /*                  X --> Z                                                                  */
                                        /*                  Y --> X                                                                  */
                                        /*                  Z --> Y                                                                  */
                                        /*                                                                                           */

                                        /* ATTENTION, il y a eu pendant longtemps :                                                  */
                                        /*                                                                                           */
                                        /*                  #define   cRHO                                                        \  */
                                        /*                                      Rho_3D(cXf,cYf,cZf)                                  */
                                        /*                  #define   cPHI                                                        \  */
                                        /*                                      Theta_3D(cXf,cYf,cZf)                                */
                                        /*                  #define   cTHETA                                                      \  */
                                        /*                                      Phi_3D(cXf,cYf,cZf)                                  */
                                        /*                                                                                           */
                                        /* mais en fait cela etait faux car nous ne sommes pas en coordonnees spheriques relatives   */
                                        /* aux axes (OX,OY,OZ), mais par rapport aux axes (OY,OZ,OX). Il faut donc permuter les      */
                                        /* trois axes ainsi que les fonction 'Theta_3D(...)' et 'Phi_3D(...)'...                     */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D E F I N I T I O N   D E S   C O M B I N A I S O N S   L I N E A I R E S  :                                               */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Definition :                                                                                                               */
/*                                                                                                                                   */
/*                    On etudie une combinaison lineaire                                                                             */
/*                  de plusieurs fonctions propres 'PSI(n,l,m)'                                                                      */
/*                  telle qu'elle evolue au cours du temps de                                                                        */
/*                  la facon suivante :                                                                                              */
/*                                                                                                                                   */
/*                                          2.i.pi.t                                                                                 */
/*                                         ----------                                                                                */
/*                                              2                                                                                    */
/*                                             1                                                                                     */
/*                                      = e          .[A.PSI   ]                                                                     */
/*                                                          100                                                                      */
/*                                                                                                                                   */
/*                                          2.i.pi.t                                                                                 */
/*                                         ----------                                                                                */
/*                                              2                                                                                    */
/*                                             2                                                                                     */
/*                                      + e          .[B.PSI    + C.PSI   ]                                                          */
/*                                                          200        211                                                           */
/*                                                                                                                                   */
/*                                          2.i.pi.t                                                                                 */
/*                                         ----------                                                                                */
/*                                              2                                                                                    */
/*                                             3                                                                                     */
/*                                      + e          .[D.PSI    + E.PSI    + F.PSI   ]                                               */
/*                                                          300        311        322                                                */
/*                                             /\                                                                                    */
/*                                             ||           .          .          .                                                  */
/*                                             ||          /|\        /|\        /|\                                                 */
/*                                             ||           |          |          |                                                  */
/*                                             ||           |          |          |                                                  */
/*                                                          |          |          |                                                  */
/*                                                2                                                                                  */
/*                                           T = n          n          n          n                                                  */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                    On notera qu'en regle generale la periode                                                                      */
/*                  'T' des exponentielles est egale au carre du                                                                     */
/*                  nombre quantique 'n' des fonctions propres                                                                       */
/*                  associees. Cela peut etre outrepasse avec                                                                        */
/*                  les arguments d'appels ; en effet, si l'on                                                                       */
/*                  souhaite observer une periode complete du                                                                        */
/*                  phenomene, il faut faire varier le temps 't'                                                                     */
/*                  dans l'intervalle [0,36], ou '36' est en fait                                                                    */
/*                  le 'PPCM' des nombres (1,4,9). Or cet intervalle                                                                 */
/*                  est enorme par rapport au nombre d'images en                                                                     */
/*                  general calculees (128...). Le mouvement obtenu                                                                  */
/*                  sera tres saccade, et pire l'axe des 't' ne sera                                                                 */
/*                  pas echantillonne regulierement. Ceci est tres                                                                   */
/*                  visible sur la sequence :                                                                                        */
/*                                                                                                                                   */
/*                                      xivPdf 1 2 / 004677_004804                                                                   */
/*                                                                                                                                   */
/*                    On sera donc amene a tricher un peu, en                                                                        */
/*                  choisissant par exemple :                                                                                        */
/*                                                                                                                                   */
/*                                      T1=1                                                                                         */
/*                                      T2=4                                                                                         */
/*                                      T3=8 (au lieu de 9, mais en restant tres proche de cette valeur)                             */
/*                                                                                                                                   */
/*                  La sequence :                                                                                                    */
/*                                                                                                                                   */
/*                                      xivPdf 1 2 / 006597_006724                                                                   */
/*                                                                                                                                   */
/*                  est ainsi generee dans [0,8]...                                                                                  */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*                    Enfin, on notera que les ordres 'n', 'l'                                                                       */
/*                  et 'm' reellement utilises sont en fait                                                                          */
/*                  parametres ci-dessous...                                                                                         */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#define   ORDRE_n_A                                                                                                                     \
                    ORDRE_n_01
DEFV(Local,DEFV(Int,INIT(ordre_n_A,ORDRE_n_A)));
#define   ORDRE_l_A                                                                                                                     \
                    ORDRE_l_00
DEFV(Local,DEFV(Int,INIT(ordre_l_A,ORDRE_l_A)));
#define   ORDRE_m_A                                                                                                                     \
                    ORDRE_m_00
DEFV(Local,DEFV(Int,INIT(ordre_m_A,ORDRE_m_A)));

#define   COEFFICIENT_A                                                                                                                 \
                    FU
DEFV(Local,DEFV(Float,INIT(coefficient_A,COEFFICIENT_A)));
                                        /* Fonction propre 'A'.                                                                      */
dfTRANSFORMAT_31(liste_COEFFICIENT_A,fichier_COEFFICIENT_A,COEFFICIENT_A_IMPLICITE,COEFFICIENT_A)
                                        /* Definition du coefficient 'A'.                                                            */
#define   sCOEFFICIENT_A(numero_de_la_periode)                                                                                          \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_COEFFICIENT_A))
                                        /* Formule generale definissant les variations de 'A' au cours du temps.                     */

#define   ORDRE_n_B                                                                                                                     \
                    ORDRE_n_02
DEFV(Local,DEFV(Int,INIT(ordre_n_B,ORDRE_n_B)));
#define   ORDRE_l_B                                                                                                                     \
                    ORDRE_l_00
DEFV(Local,DEFV(Int,INIT(ordre_l_B,ORDRE_l_B)));
#define   ORDRE_m_B                                                                                                                     \
                    ORDRE_m_00
DEFV(Local,DEFV(Int,INIT(ordre_m_B,ORDRE_m_B)));

#define   COEFFICIENT_B                                                                                                                 \
                    FU
DEFV(Local,DEFV(Float,INIT(coefficient_B,COEFFICIENT_B)));
                                        /* Fonction propre 'B'.                                                                      */
dfTRANSFORMAT_31(liste_COEFFICIENT_B,fichier_COEFFICIENT_B,COEFFICIENT_B_IMPLICITE,COEFFICIENT_B)
                                        /* Definition du coefficient 'B'.                                                            */
#define   sCOEFFICIENT_B(numero_de_la_periode)                                                                                          \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_COEFFICIENT_B))
                                        /* Formule generale definissant les variations de 'B' au cours du temps.                     */

#define   ORDRE_n_C                                                                                                                     \
                    ORDRE_n_B
DEFV(Local,DEFV(Int,INIT(ordre_n_C,ORDRE_n_C)));
#define   ORDRE_l_C                                                                                                                     \
                    ORDRE_l_01
DEFV(Local,DEFV(Int,INIT(ordre_l_C,ORDRE_l_C)));
#define   ORDRE_m_C                                                                                                                     \
                    ORDRE_m_01
DEFV(Local,DEFV(Int,INIT(ordre_m_C,ORDRE_m_C)));

#define   COEFFICIENT_C                                                                                                                 \
                    FU
DEFV(Local,DEFV(Float,INIT(coefficient_C,COEFFICIENT_C)));
                                        /* Fonction propre 'C'.                                                                      */
dfTRANSFORMAT_31(liste_COEFFICIENT_C,fichier_COEFFICIENT_C,COEFFICIENT_C_IMPLICITE,COEFFICIENT_C)
                                        /* Definition du coefficient 'B'.                                                            */
#define   sCOEFFICIENT_C(numero_de_la_periode)                                                                                          \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_COEFFICIENT_C))
                                        /* Formule generale definissant les variations de 'B' au cours du temps.                     */

#define   ORDRE_n_D                                                                                                                     \
                    ORDRE_n_03
DEFV(Local,DEFV(Int,INIT(ordre_n_D,ORDRE_n_D)));
#define   ORDRE_l_D                                                                                                                     \
                    ORDRE_l_00
DEFV(Local,DEFV(Int,INIT(ordre_l_D,ORDRE_l_D)));
#define   ORDRE_m_D                                                                                                                     \
                    ORDRE_m_00
DEFV(Local,DEFV(Int,INIT(ordre_m_D,ORDRE_m_D)));

#define   COEFFICIENT_D                                                                                                                 \
                    FU
DEFV(Local,DEFV(Float,INIT(coefficient_D,COEFFICIENT_D)));
                                        /* Fonction propre 'D'.                                                                      */
dfTRANSFORMAT_31(liste_COEFFICIENT_D,fichier_COEFFICIENT_D,COEFFICIENT_D_IMPLICITE,COEFFICIENT_D)
                                        /* Definition du coefficient 'D'.                                                            */
#define   sCOEFFICIENT_D(numero_de_la_periode)                                                                                          \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_COEFFICIENT_D))
                                        /* Formule generale definissant les variations de 'D' au cours du temps.                     */

#define   ORDRE_n_E                                                                                                                     \
                    ORDRE_n_D
DEFV(Local,DEFV(Int,INIT(ordre_n_E,ORDRE_n_E)));
#define   ORDRE_l_E                                                                                                                     \
                    ORDRE_l_01
DEFV(Local,DEFV(Int,INIT(ordre_l_E,ORDRE_l_E)));
#define   ORDRE_m_E                                                                                                                     \
                    ORDRE_m_01
DEFV(Local,DEFV(Int,INIT(ordre_m_E,ORDRE_m_E)));

#define   COEFFICIENT_E                                                                                                                 \
                    FU
DEFV(Local,DEFV(Float,INIT(coefficient_E,COEFFICIENT_E)));
                                        /* Fonction propre 'E'.                                                                      */
dfTRANSFORMAT_31(liste_COEFFICIENT_E,fichier_COEFFICIENT_E,COEFFICIENT_E_IMPLICITE,COEFFICIENT_E)
                                        /* Definition du coefficient 'E'.                                                            */
#define   sCOEFFICIENT_E(numero_de_la_periode)                                                                                          \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_COEFFICIENT_E))
                                        /* Formule generale definissant les variations de 'E' au cours du temps.                     */

#define   ORDRE_n_F                                                                                                                     \
                    ORDRE_n_D
DEFV(Local,DEFV(Int,INIT(ordre_n_F,ORDRE_n_F)));
#define   ORDRE_l_F                                                                                                                     \
                    ORDRE_l_02
DEFV(Local,DEFV(Int,INIT(ordre_l_F,ORDRE_l_F)));
#define   ORDRE_m_F                                                                                                                     \
                    ORDRE_m_02
DEFV(Local,DEFV(Int,INIT(ordre_m_F,ORDRE_m_F)));

#define   COEFFICIENT_F                                                                                                                 \
                    FU
DEFV(Local,DEFV(Float,INIT(coefficient_F,COEFFICIENT_F)));
                                        /* Fonction propre 'F'.                                                                      */
dfTRANSFORMAT_31(liste_COEFFICIENT_F,fichier_COEFFICIENT_F,COEFFICIENT_F_IMPLICITE,COEFFICIENT_F)
                                        /* Definition du coefficient 'F'.                                                            */
#define   sCOEFFICIENT_F(numero_de_la_periode)                                                                                          \
                    FLOT(sTRANSFORMAT_31(numero_de_la_periode,liste_COEFFICIENT_F))
                                        /* Formule generale definissant les variations de 'F' au cours du temps.                     */

DEFV(Local,DEFV(Int,INIT(plus_grand_des_ordres_n,UNDEF)));
                                        /* Plus grand des 6 ordres 'n' relatifs aux 6 fonctions propres 'A', 'B', 'C', 'D, 'E' et    */
                                        /* 'F' lorsque l'ajustement automatique par 'CORRECTION_DE_L_ECHELLE(...)' est demande...    */

#define   PERIODE_1                                                                                                                     \
                    FLOT(EXP2(ORDRE_n_A))
DEFV(Local,DEFV(Float,INIT(periode_1,PERIODE_1)));
                                        /* Premiere periode.                                                                         */
#define   PERIODE_2                                                                                                                     \
                    FLOT(EXP2(ORDRE_n_B))
DEFV(Local,DEFV(Float,INIT(periode_2,PERIODE_2)));
                                        /* Seconde periode.                                                                          */
#define   PERIODE_3                                                                                                                     \
                    FLOT(EXP2(ORDRE_n_D))
DEFV(Local,DEFV(Float,INIT(periode_3,PERIODE_3)));
                                        /* Troisieme periode.                                                                        */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        C H O I X   D E   C E   Q U I   S E R A   V I S U A L I S E  :                                                             */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#define   CALCULER_AUSSI_LA_PARTIE_IMAGINAIRE                                                                                           \
                    VRAI
DEFV(Local,DEFV(Logical,INIT(calculer_aussi_la_partie_Imaginaire,CALCULER_AUSSI_LA_PARTIE_IMAGINAIRE)));
                                        /* Faut-il calculer la partie Imaginaire :                                                   */
                                        /*                                                                                           */
                                        /* VRAI : c'est le module de la fonction propre qui sera visualise,                          */
                                        /* FAUX : c'est uniquement la partie Reelle de la fonction propre qui sera visualise.        */
                                        /*                                                                                           */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        P A R A M E T R E S  :                                                                                                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#define   X_ECHELLE                                                                                                                     \
                    FU                                                                                                                  \
                                        /* Echelle horizontale du champ,                                                             */
#define   Y_ECHELLE                                                                                                                     \
                    FU                                                                                                                  \
                                        /* Echelle verticale du champ,                                                               */
#define   Z_ECHELLE                                                                                                                     \
                    FU                                                                                                                  \
                                        /* Echelle de profondeur du champ.                                                           */

#define   AJUSTEMENT_AUTOMATIQUE_DES_ECHELLES                                                                                           \
                    VRAI                                                                                                                \
                                        /* Indique si les echelles horizontales et verticales doivent etre ajustees automatiquement  */ \
                                        /* en fonction des ordres 'n' ('VRAI') ou pas ('FAUX')...                                    */

#define   X_TRANSLATION                                                                                                                 \
                    FDU                                                                                                                 \
                                        /* Translation horizontale du champ,                                                         */
#define   Y_TRANSLATION                                                                                                                 \
                    FDU                                                                                                                 \
                                        /* Translation verticale du champ,                                                           */
#define   Z_TRANSLATION                                                                                                                 \
                    FZERO                                                                                                               \
                                        /* Translation de profondeur du champ.                                                       */

#define   RENORMALISER_CHAQUE_CHAMP_INDEPENDAMMENT                                                                                      \
                    FAUX                                                                                                                \
                                        /* Faut-il renormaliser chaque champ independamment des autres ('VRAI') ou bien faire une    */ \
                                        /* renormalisation globale de l'ensemble des champs ('FAUX') ?                               */

#define   PRENDRE_UNE_DYNAMIQUE_LOGARITHMIQUE                                                                                           \
                    FAUX                                                                                                                \
                                        /* Faut-il prendre une dynamique logarithmique ('VRAI') ou laisser le champ des fonctions    */ \
                                        /* propres tel qu'il a ete calcule ('FAUX') ?                                                */
#define   NOMBRE_D_ITERATIONS_DE_LA_DYNAMIQUE_LOGARITHMIQUE                                                                             \
                    UN                                                                                                                  \
                                        /* S'il faut prendre une dynamique logarithmique, combien de fois faut-il iterer cela ?      */

#define   EDITER_LES_EXTREMA_DE_LA_DENSITE_DE_PROBABILITE                                                                               \
                    FAUX                                                                                                                \
                                        /* Faut-il editer les extrema de la densite de probabilite ('VRAI') ou pas ('FAUX') ?        */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        M A C R O S   U T I L E S  :                                                                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#define   CORRECTION_DE_L_ECHELLE(echelle)                                                                                              \
                    COND(IL_FAUT(ajustement_automatique_des_echelles)                                                                   \
                        ,MUL2(DIVI(ADD3(MUL2(FLOT(NEUT(DEUX)),EXP2(plus_grand_des_ordres_n))                                            \
                                       ,MUL2(FLOT(NEUT(SEPT)),EXP1(plus_grand_des_ordres_n))                                            \
                                       ,MUL2(FLOT(NEGA(CINQ)),EXP0(plus_grand_des_ordres_n))                                            \
                                        )                                                                                               \
                                  ,FLOT(CINQ)                                                                                           \
                                   )                                                                                                    \
                             ,echelle                                                                                                   \
                              )                                                                                                         \
                        ,echelle                                                                                                        \
                         )                                                                                                              \
                                        /* Correction de l'echelle du champ a generer en fonction de l'ordre 'n' a l'aide de la      */ \
                                        /* formule relativement arbitraire :                                                         */ \
                                        /*                                                                                           */ \
                                        /*                       2                                                                   */ \
                                        /*                   (2.n  + 7.n - 5).echelle                                                */ \
                                        /*                  --------------------------                                               */ \
                                        /*                               5                                                           */ \
                                        /*                                                                                           */ \
                                        /* (ou 'n' represente le plus grand des 6 ordres 'n' relatifs aux 6 fonctions propres 'A',   */ \
                                        /* 'B', 'C', 'D, 'E' et 'F') lorsque cet ajustement automatique est demande... On notera     */ \
                                        /* un facteur diviseur egal a 5 par rapport a la meme procedure de '$xrq/hydrogene.41$K'.    */ \
                                        /* Celui-ci est approximativement egal a :                                                   */ \
                                        /*                                                                                           */ \
                                        /*                   f(3)     034                                                            */ \
                                        /*                  ------ = ----- ~ 5                                                       */ \
                                        /*                   f(8)     179                                                            */ \
                                        /*                                                                                           */ \
                                        /* ou 'f(...)' designe 'CORRECTION_DE_L_ECHELLE(...)' dans '$xrq/hydrogene.41$K'. En effet   */ \
                                        /* dans ce programme 'n' peut aller jusqu'a 8, alors qu'ici, on s'arrete a 3, d'ou ce        */ \
                                        /* rapport...                                                                                */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        S U P E R P O S I T I O N   D Y N A M I Q U E   D ' E T A T S                                                              */
/*        P R O P R E S   D E   L ' A T O M E   D ' H Y D R O G E N E  :                                                             */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
BCommande(nombre_d_arguments,arguments)
/*-----------------------------------------------------------------------------------------------------------------------------------*/
     Bblock
     DEFV(CHAR,INIC(POINTERc(nom_imageR),NOM_PIPE));
                                        /* Nom de la sequence d'images a generer.                                                    */
     DEFV(CHAR,INIT(POINTERc(nom_image),NOM_UNDEF));
                                        /* Nom courant des images.                                                                   */
     DEFV(Logical,INIT(ajustement_automatique_des_echelles,AJUSTEMENT_AUTOMATIQUE_DES_ECHELLES));
                                        /* Indique si les echelles horizontales et verticales doivent etre ajustees automatiquement  */
                                        /* en fonction des ordres 'n' ('VRAI') ou pas ('FAUX')...                                    */
     DEFV(coeffF_3D,echelle);
     DEFV(coeffF_3D,echelle_courante);
                                        /* Echelle du champ a generer (valeur initiale et valeur courante).                          */
     DEFV(deltaF_3D,translation);
                                        /* Translation du champ a generer.                                                           */
     DEFV(Float,INIT(densite_de_probabilite_de_presence,FLOT__UNDEF));
                                        /* Definition de la densite de probabilite de presence...                                    */
     DEFV(Logical,INIT(renormaliser_chaque_champ_independamment,RENORMALISER_CHAQUE_CHAMP_INDEPENDAMMENT));
                                        /* Faut-il renormaliser chaque champ independamment des autres ('VRAI') ou bien faire une    */
                                        /* renormalisation globale de l'ensemble des champs ('FAUX') ?                               */
     DEFV(Logical,INIT(prendre_une_dynamique_logarithmique,PRENDRE_UNE_DYNAMIQUE_LOGARITHMIQUE));
                                        /* Faut-il prendre une dynamique logarithmique ('VRAI') ou laisser le champ des fonctions    */
                                        /* propres tel qu'il a ete calcule ('FAUX') ?                                                */
     DEFV(Positive,INIT(nombre_d_iterations_de_la_dynamique_logarithmique,NOMBRE_D_ITERATIONS_DE_LA_DYNAMIQUE_LOGARITHMIQUE));
                                        /* S'il faut prendre une dynamique logarithmique, combien de fois faut-il iterer cela ?      */
     DEFV(Logical,INIT(editer_les_extrema_de_la_densite_de_probabilite,EDITER_LES_EXTREMA_DE_LA_DENSITE_DE_PROBABILITE));
                                        /* Faut-il editer les extrema de la densite de probabilite ('VRAI') ou pas ('FAUX') ?        */
     /*..............................................................................................................................*/
     DEBUT_DE_L_INITIALISATION_DES_INTERPOLATIONS_GEOMETRIQUES;
                                        /* Et ceci afin de pouvoir tourner dans le champ de densite de probabilite de presence...    */

     iTRANSFORMAT_31(liste_PARAMETRE_TEMPS,PARAMETRE_TEMPS_IMPLICITE);
                                        /* Initialisation du parametre 't'.                                                          */

     iTRANSFORMAT_31(liste_PARAMETRE_Z,PARAMETRE_Z_IMPLICITE);
                                        /* Initialisation du parametre 'z'.                                                          */

     iTRANSFORMAT_31(liste_COEFFICIENT_A,COEFFICIENT_A_IMPLICITE);
                                        /* Initialisation du parametre 'A'.                                                          */
     iTRANSFORMAT_31(liste_COEFFICIENT_B,COEFFICIENT_B_IMPLICITE);
                                        /* Initialisation du parametre 'B'.                                                          */
     iTRANSFORMAT_31(liste_COEFFICIENT_C,COEFFICIENT_C_IMPLICITE);
                                        /* Initialisation du parametre 'C'.                                                          */
     iTRANSFORMAT_31(liste_COEFFICIENT_D,COEFFICIENT_D_IMPLICITE);
                                        /* Initialisation du parametre 'D'.                                                          */
     iTRANSFORMAT_31(liste_COEFFICIENT_E,COEFFICIENT_E_IMPLICITE);
                                        /* Initialisation du parametre 'E'.                                                          */
     iTRANSFORMAT_31(liste_COEFFICIENT_F,COEFFICIENT_F_IMPLICITE);
                                        /* Initialisation du parametre 'F'.                                                          */

     INITIALISATION_COEFFICIENT_3D(echelle,X_ECHELLE,Y_ECHELLE,Z_ECHELLE);
                                        /* Initialisation de l'echelle du champ a generer.                                           */
     INITIALISATION_ACCROISSEMENT_3D(translation,X_TRANSLATION,Y_TRANSLATION,Z_TRANSLATION);
                                        /* Initialisation de la translation du champ a generer.                                      */

#include  xrv/champs_5.1A.I"

     GET_ARGUMENTSi(nombre_d_arguments
                   ,BLOC(PROCESS_ARGUMENTS_GEOMETRIQUES;

                         PROCESS_ARGUMENT_FICHIER("PARAMETRE_TEMPS="
                                                 ,fichier_PARAMETRE_TEMPS
                                                 ,liste_PARAMETRE_TEMPS
                                                 ,PARAMETRE_TEMPS_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );

                         PROCESS_ARGUMENT_FICHIER("PARAMETRE_Z="
                                                 ,fichier_PARAMETRE_Z
                                                 ,liste_PARAMETRE_Z
                                                 ,PARAMETRE_Z_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );

                         PROCESS_ARGUMENT_FICHIER("COEFFICIENT_A="
                                                 ,fichier_COEFFICIENT_A
                                                 ,liste_COEFFICIENT_A
                                                 ,COEFFICIENT_A_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );
                         PROCESS_ARGUMENT_FICHIER("COEFFICIENT_B="
                                                 ,fichier_COEFFICIENT_B
                                                 ,liste_COEFFICIENT_B
                                                 ,COEFFICIENT_B_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );
                         PROCESS_ARGUMENT_FICHIER("COEFFICIENT_C="
                                                 ,fichier_COEFFICIENT_C
                                                 ,liste_COEFFICIENT_C
                                                 ,COEFFICIENT_C_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );
                         PROCESS_ARGUMENT_FICHIER("COEFFICIENT_D="
                                                 ,fichier_COEFFICIENT_D
                                                 ,liste_COEFFICIENT_D
                                                 ,COEFFICIENT_D_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );
                         PROCESS_ARGUMENT_FICHIER("COEFFICIENT_E="
                                                 ,fichier_COEFFICIENT_E
                                                 ,liste_COEFFICIENT_E
                                                 ,COEFFICIENT_E_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );
                         PROCESS_ARGUMENT_FICHIER("COEFFICIENT_F="
                                                 ,fichier_COEFFICIENT_F
                                                 ,liste_COEFFICIENT_F
                                                 ,COEFFICIENT_F_IMPLICITE
                                                 ,gTRANSFORMAT_31
                                                  );

                         GET_ARGUMENT_C("imageR=""R=",nom_imageR);
                         GET_ARGUMENT_L("standard=",les_images_sont_standards);

                         GET_ARGUMENT_L("XY=",permutation_XY);
                         GET_ARGUMENT_L("YZ=",permutation_YZ);
                         GET_ARGUMENT_L("ZX=",permutation_ZX);

                         GET_ARGUMENT_L("automatique=""auto=",ajustement_automatique_des_echelles);
                         GET_ARGUMENT_F("Ex=",ASD1(echelle,cx));
                         GET_ARGUMENT_F("Ey=",ASD1(echelle,cy));
                         GET_ARGUMENT_F("Ez=",ASD1(echelle,cz));
                         GET_ARGUMENT_F("Tx=",ASD1(translation,dx));
                         GET_ARGUMENT_F("Ty=",ASD1(translation,dy));
                         GET_ARGUMENT_F("Tz=",ASD1(translation,dz));

                         GET_ARGUMENT_F("z=""profondeur=""coupe=""Z=",profondeur);
                         GET_ARGUMENT_F("temps=""t=""T=",temps);

                         GET_ARGUMENT_F("T1=",periode_1);
                         GET_ARGUMENT_F("T2=",periode_2);
                         GET_ARGUMENT_F("T3=",periode_3);

                         GET_ARGUMENT_I("ordre_n_A=""nA=",ordre_n_A);
                         GET_ARGUMENT_I("ordre_m_A=""mA=",ordre_m_A);
                         GET_ARGUMENT_I("ordre_l_A=""lA=",ordre_l_A);
                         GET_ARGUMENT_F("A=",coefficient_A);

                         GET_ARGUMENT_I("ordre_n_B=""nB=",ordre_n_B);
                         GET_ARGUMENT_I("ordre_m_B=""mB=",ordre_m_B);
                         GET_ARGUMENT_I("ordre_l_B=""lB=",ordre_l_B);
                         GET_ARGUMENT_F("B=",coefficient_B);

                         GET_ARGUMENT_I("ordre_n_C=""nC=",ordre_n_C);
                         GET_ARGUMENT_I("ordre_m_C=""mC=",ordre_m_C);
                         GET_ARGUMENT_I("ordre_l_C=""lC=",ordre_l_C);
                         GET_ARGUMENT_F("C=",coefficient_C);

                         GET_ARGUMENT_I("ordre_n_D=""nD=",ordre_n_D);
                         GET_ARGUMENT_I("ordre_m_D=""mD=",ordre_m_D);
                         GET_ARGUMENT_I("ordre_l_D=""lD=",ordre_l_D);
                         GET_ARGUMENT_F("D=",coefficient_D);

                         GET_ARGUMENT_I("ordre_n_E=""nE=",ordre_n_E);
                         GET_ARGUMENT_I("ordre_m_E=""mE=",ordre_m_E);
                         GET_ARGUMENT_I("ordre_l_E=""lE=",ordre_l_E);
                         GET_ARGUMENT_F("E=",coefficient_E);

                         GET_ARGUMENT_I("ordre_n_F=""nF=",ordre_n_F);
                         GET_ARGUMENT_I("ordre_m_F=""mF=",ordre_m_F);
                         GET_ARGUMENT_I("ordre_l_F=""lF=",ordre_l_F);
                         GET_ARGUMENT_F("F=",coefficient_F);

                         GET_ARGUMENT_L("spheriques=",calculer_la_probabilite_en_coordonnees_spheriques);
                         GET_ARGUMENT_F("tr=""Tr=",translation_du_carre_du_rayon);

                         GET_ARGUMENT_L("imaginaire=",calculer_aussi_la_partie_Imaginaire);

                         GET_ARGUMENT_L("independant=",renormaliser_chaque_champ_independamment);

                         GET_ARGUMENT_L("logarithmique=""log=",prendre_une_dynamique_logarithmique);
                         GET_ARGUMENT_I("iterations=",nombre_d_iterations_de_la_dynamique_logarithmique);

                         GET_ARGUMENT_L("editer=",editer_les_extrema_de_la_densite_de_probabilite);
                         )
                    );

#include  xrq/synapse.11.I"

     begin_nouveau_block
          Bblock
          DONNEES_DE_RECHERCHE_DES_EXTREMA_GLOBAUX_D_UNE_SEQUENCE_D_IMAGES;
                                        /* Extrema globaux de l'ensemble de la sequence...                                           */

          BDEFV(imageF,champ_des_fonctions_propres);
                                        /* Image flottante dans laquelle on trouve les fonctions propres avant renormalisation.      */

          EGAL(plus_grand_des_ordres_n
              ,MAX3(MAX1(ordre_n_A)
                   ,MAX2(ordre_n_B,ordre_n_C)
                   ,MAX3(ordre_n_D,ordre_n_E,ordre_n_F)
                    )
               );
                                        /* Plus grand des 6 ordres 'n' relatifs aux 6 fonctions propres 'A', 'B', 'C', 'D, 'E' et    */
                                        /* 'F' lorsque l'ajustement automatique par 'CORRECTION_DE_L_ECHELLE(...)' est demande...    */

          CALi(Inoir(ImageR));
                                        /* Initialisation de l'image Resultat.                                                       */

          Komp(numero_de_la_periode_courante_de_la_simulation,nombre_de_periodes_de_la_simulation)
               Bblock
               DONNEES_DE_RECHERCHE_DES_EXTREMA_LOCAUX_D_UNE_SEQUENCE_D_IMAGES;
                                        /* Extrema locaux de la sequence...                                                          */

               CHANGEMENT_DU_POINT_DE_VUE_GEOMETRIQUE;
                                        /* Et ceci afin de pouvoir tourner dans le champ de densite de probabilite de presence...    */

               INITIALISATION_COEFFICIENT_3D(echelle_courante
                                            ,CORRECTION_DE_L_ECHELLE(ASD1(echelle,cx))
                                            ,CORRECTION_DE_L_ECHELLE(ASD1(echelle,cy))
                                            ,CORRECTION_DE_L_ECHELLE(ASD1(echelle,cz))
                                             );
                                        /* Correction de l'echelle du champ a generer en fonction des ordres 'n'...                  */

               vTRANSFORMAT_31(temps,sPARAMETRE_TEMPS,numero_de_la_periode_courante,fichier_PARAMETRE_TEMPS);
                                        /* Definition du temps courant...                                                            */

               vTRANSFORMAT_31(profondeur,sPARAMETRE_Z,numero_de_la_periode_courante,fichier_PARAMETRE_Z);
                                        /* Definition de la profondeur courante...                                                   */

               vTRANSFORMAT_31(coefficient_A,sCOEFFICIENT_A,numero_de_la_periode_courante,fichier_COEFFICIENT_A);
               vTRANSFORMAT_31(coefficient_B,sCOEFFICIENT_B,numero_de_la_periode_courante,fichier_COEFFICIENT_B);
               vTRANSFORMAT_31(coefficient_C,sCOEFFICIENT_C,numero_de_la_periode_courante,fichier_COEFFICIENT_C);
               vTRANSFORMAT_31(coefficient_D,sCOEFFICIENT_D,numero_de_la_periode_courante,fichier_COEFFICIENT_D);
               vTRANSFORMAT_31(coefficient_E,sCOEFFICIENT_E,numero_de_la_periode_courante,fichier_COEFFICIENT_E);
               vTRANSFORMAT_31(coefficient_F,sCOEFFICIENT_F,numero_de_la_periode_courante,fichier_COEFFICIENT_F);
                                        /* Definition des coefficients 'A, 'B', 'C', 'D', 'E' et 'F' courants.                       */

               begin_image
                    Bblock
                    DEFV(complexe,fonction_propre_A);
                    DEFV(complexe,fonction_propre_B);
                    DEFV(complexe,fonction_propre_C);
                    DEFV(complexe,fonction_propre_D);
                    DEFV(complexe,fonction_propre_E);
                    DEFV(complexe,fonction_propre_F);
                                        /* Definition des six fonctions propres que l'on va combiner...                              */
                    DEFV(complexe,exponentielle_1);
                    DEFV(complexe,exponentielle_2);
                    DEFV(complexe,exponentielle_3);
                                        /* Definition des trois exponentielles complexes...                                          */
                    DEFV(complexe,intermediaire_eA);
                    DEFV(complexe,intermediaire_BC);
                    DEFV(complexe,intermediaire_eBC);
                    DEFV(complexe,intermediaire_DE);
                    DEFV(complexe,intermediaire_DEF);
                    DEFV(complexe,intermediaire_eDEF);
                    DEFV(complexe,intermediaire_eA_eBC);
                    DEFV(complexe,intermediaire_eA_eBC_eDEF);
                                        /* Definition de nombres complexes intermediaires...                                         */

                    EGAL(cXf
                        ,TRANSFORMATION_GEOMETRIQUE_3D_Fx(caXf,caYf,caZf
                                                         ,ASD1(translation_de_l_origine,dx)
                                                          )
                         );
                    EGAL(cYf
                        ,TRANSFORMATION_GEOMETRIQUE_3D_Fy(caXf,caYf,caZf
                                                         ,ASD1(translation_de_l_origine,dy)
                                                          )
                         );
                    EGAL(cZf
                        ,TRANSFORMATION_GEOMETRIQUE_3D_Fz(caXf,caYf,caZf
                                                         ,ASD1(translation_de_l_origine,dz)
                                                          )
                         );
                                        /* Calcul des coordonnees cartesiennes. On notera les 'TRANSFORMATION_GEOMETRIQUE_3D' qui    */
                                        /* ne sont pas des rotations de la scene a proprement parler, mais plutot des rotations      */
                                        /* dans le champ de densite de probabilite de presence...                                    */

                    Test(IL_FAUT(permutation_XY))
                         Bblock
                         fSWAP(cXf,cYf);
                                        /* Permutation eventuelle des coordonnees cartesiennes...                                    */
                         Eblock
                    ATes
                         Bblock
                         Eblock
                    ETes
                    Test(IL_FAUT(permutation_YZ))
                         Bblock
                         fSWAP(cYf,cZf);
                                        /* Permutation eventuelle des coordonnees cartesiennes...                                    */
                         Eblock
                    ATes
                         Bblock
                         Eblock
                    ETes
                    Test(IL_FAUT(permutation_ZX))
                         Bblock
                         fSWAP(cZf,cXf);
                                        /* Permutation eventuelle des coordonnees cartesiennes...                                    */
                         Eblock
                    ATes
                         Bblock
                         Eblock
                    ETes

                    EGAL(parametre_r,cRHO);
                    EGAL(u,cTHETA);
                    EGAL(v,cPHI);
                                        /* Definition des coordonnees spheriques apres avoir defini la profondeur...                 */

                    Cinitialisation(exponentielle_1
                                   ,COSX(DIVI(MUL2(CERCLE_TRIGONOMETRIQUE,temps),periode_1))
                                   ,SINX(DIVI(MUL2(CERCLE_TRIGONOMETRIQUE,temps),periode_1))
                                    );
                    Cinitialisation(exponentielle_2
                                   ,COSX(DIVI(MUL2(CERCLE_TRIGONOMETRIQUE,temps),periode_2))
                                   ,SINX(DIVI(MUL2(CERCLE_TRIGONOMETRIQUE,temps),periode_2))
                                    );
                    Cinitialisation(exponentielle_3
                                   ,COSX(DIVI(MUL2(CERCLE_TRIGONOMETRIQUE,temps),periode_3))
                                   ,SINX(DIVI(MUL2(CERCLE_TRIGONOMETRIQUE,temps),periode_3))
                                    );
                                        /* Calcul des trois exponentielles complexes :                                               */
                                        /*                                                                                           */
                                        /*                    2.i.pi.t                                                               */
                                        /*                   ----------                                                              */
                                        /*                        2                                                                  */
                                        /*                       1                                                                   */
                                        /*                  e                                                                        */
                                        /*                                                                                           */
                                        /*                                                                                           */
                                        /*                    2.i.pi.t                                                               */
                                        /*                   ----------                                                              */
                                        /*                        2                                                                  */
                                        /*                       2                                                                   */
                                        /*                  e                                                                        */
                                        /*                                                                                           */
                                        /*                                                                                           */
                                        /*                    2.i.pi.t                                                               */
                                        /*                   ----------                                                              */
                                        /*                        2                                                                  */
                                        /*                       3                                                                   */
                                        /*                  e                                                                        */
                                        /*                                                                                           */

                    CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre_A,ordre_n_A,ordre_l_A,ordre_m_A,coefficient_A);
                    CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre_B,ordre_n_B,ordre_l_B,ordre_m_B,coefficient_B);
                    CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre_C,ordre_n_C,ordre_l_C,ordre_m_C,coefficient_C);
                    CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre_D,ordre_n_D,ordre_l_D,ordre_m_D,coefficient_D);
                    CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre_E,ordre_n_E,ordre_l_E,ordre_m_E,coefficient_E);
                    CALCUL_EVENTUEL_D_UNE_FONCTION_PROPRE(fonction_propre_F,ordre_n_F,ordre_l_F,ordre_m_F,coefficient_F);
                                        /* Calcul des six fonctions propres que l'on va combiner, lorsque cela est necessaire...     */

                    Cforme_lineaire(fonction_propre_A,coefficient_A,fonction_propre_A,FZERO);
                    Cforme_lineaire(fonction_propre_B,coefficient_B,fonction_propre_B,FZERO);
                    Cforme_lineaire(fonction_propre_C,coefficient_C,fonction_propre_C,FZERO);
                    Cforme_lineaire(fonction_propre_D,coefficient_D,fonction_propre_D,FZERO);
                    Cforme_lineaire(fonction_propre_E,coefficient_E,fonction_propre_E,FZERO);
                    Cforme_lineaire(fonction_propre_F,coefficient_F,fonction_propre_F,FZERO);
                                        /* Modulation des six fonctions propres que l'on va combiner...                              */

                    Cproduit(intermediaire_eA,exponentielle_1,fonction_propre_A);
                                        /* Calcul du premier terme :                                                                 */
                                        /*                                                                                           */
                                        /*                    2.i.pi.t                                                               */
                                        /*                   ----------                                                              */
                                        /*                        2                                                                  */
                                        /*                       1                                                                   */
                                        /*                  e          .[A.PSI  ]                                                    */
                                        /*                                    100                                                    */
                                        /*                                                                                           */

                    Csomme(intermediaire_BC,fonction_propre_B,fonction_propre_C);
                    Cproduit(intermediaire_eBC,exponentielle_2,intermediaire_BC);
                                        /* Calcul du deuxieme terme :                                                                */
                                        /*                                                                                           */
                                        /*                    2.i.pi.t                                                               */
                                        /*                   ----------                                                              */
                                        /*                        2                                                                  */
                                        /*                       2                                                                   */
                                        /*                  e          .[B.PSI    + C.PSI   ]                                        */
                                        /*                                    200        211                                         */
                                        /*                                                                                           */

                    Csomme(intermediaire_DE,fonction_propre_D,fonction_propre_E);
                    Csomme(intermediaire_DEF,intermediaire_DE,fonction_propre_F);
                    Cproduit(intermediaire_eDEF,exponentielle_3,intermediaire_DEF);
                                        /* Calcul du troisieme terme :                                                               */
                                        /*                                                                                           */
                                        /*                    2.i.pi.t                                                               */
                                        /*                   ----------                                                              */
                                        /*                        2                                                                  */
                                        /*                       3                                                                   */
                                        /*                  e          .[D.PSI    + E.PSI    + F.PSI   ]                             */
                                        /*                                    300        311        322                              */
                                        /*                                                                                           */

                    Csomme(intermediaire_eA_eBC,intermediaire_eA,intermediaire_eBC);
                    Csomme(intermediaire_eA_eBC_eDEF,intermediaire_eA_eBC,intermediaire_eDEF);
                                        /* Enfin, calcul de la combinaison lineaire,                                                 */

                    CALCUL_D_UNE_DENSITE_DE_PROBABILITE_DE_PRESENCE_QUELCONQUE(intermediaire_eA_eBC_eDEF);
                                        /* Et du carre de son module...                                                              */

                    storeF_point(densite_de_probabilite_de_presence
                                ,champ_des_fonctions_propres
                                ,X,Y
                                 );
                                        /* Et memorisation...                                                                        */
                    Eblock
               end_image

               Test(IL_FAUT(prendre_une_dynamique_logarithmique))
                    Bblock
                    Repe(nombre_d_iterations_de_la_dynamique_logarithmique)
                         Bblock
                         CALS(IFdynamique_logarithmique_avec_translation_dynamique(champ_des_fonctions_propres
                                                                                  ,champ_des_fonctions_propres
                                                                                   )
                              );
                                        /* S'il le faut, la dynamique du champ des fonctions propres est reduite par application     */
                                        /* d'une fonction logarithme, et ce 'N' fois...                                              */
                         Eblock
                    ERep
                    Eblock
               ATes
                    Bblock
                    Eblock
               ETes

               RECHERCHE_DES_EXTREMA_D_UNE_SEQUENCE_D_IMAGES(champ_des_fonctions_propres);
                                        /* Recherche des extrema locaux et globaux de l'ensemble de la sequence...                   */

               Test(IL_FAUT(editer_les_extrema_de_la_densite_de_probabilite))
                    Bblock
                    CAL2(Prin2("extrema locaux de la densite de probabilite : (min,max) = (%g,%g)\n"
                              ,niveau_minimum_de_l_image
                              ,niveau_maximum_de_l_image
                               )
                         );
                    Eblock
               ATes
                    Bblock
                    Eblock
               ETes

               EGAL(nom_image
                   ,chain_Aconcaten2_sauf_nom_pipe(nom_imageR
                                                  ,ChaineNumero(numero_de_la_periode_courante
                                                               ,NOMBRE_DE_CHIFFRES
                                                                )
                                                   )
                    );
                                        /* Le 20080602135139 fut introduit 'ChaineNumero(...)' afin de pouvoir parametrer            */
                                        /* aisement le nombre de chiffres des numeros...                                             */
               CALi(IupdateF_image(nom_image,champ_des_fonctions_propres));
                                        /* Sauvegarde du champ sans renormalisation...                                               */
               CALZ_FreCC(nom_image);

               INCR(numero_de_la_periode_courante,I);
                                        /* Et passage a l'image suivante...                                                          */
               Eblock
          EKom

          Test(IL_FAUT(editer_les_extrema_de_la_densite_de_probabilite))
               Bblock
               CAL2(Prin2("\n extrema globaux du carre du module de la combinaison lineaire : (min,max) = (%g,%g)\n\n"
                         ,niveau_minimum_de_la_sequence
                         ,niveau_maximum_de_la_sequence
                          )
                    );
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          Test(EST_VRAI(les_images_sont_standards))
               Bblock
                                        /* Cas ou l'on genere des images de type 'image' :                                           */
               EGAL(files_____editer_les_messages_d_erreur_de_lecture_des_fichiers,NE_PAS_EDITER_LES_MESSAGES_D_ERREUR_DES_FICHIERS);
                                        /* ATTENTION : ce n'est plus une erreur que l'image courante n'existe pas puisque            */
                                        /* dorenavant, il peut y avoir des trous dans la sequence, d'ou l'inhibition des messages    */
                                        /* d'erreur...                                                                               */

               EGAL(numero_de_la_periode_courante,NUMERO_DE_LA_PREMIERE_PERIODE_DE_LA_SIMULATION);
                                        /* Reinitialisation...                                                                       */

               Komp(numero_de_la_periode_courante_de_la_simulation,nombre_de_periodes_de_la_simulation)
                    Bblock
                    EGAL(nom_image
                        ,chain_Aconcaten2_sauf_nom_pipe(nom_imageR
                                                       ,ChaineNumero(numero_de_la_periode_courante
                                                                    ,NOMBRE_DE_CHIFFRES
                                                                     )
                                                        )
                         );
                                        /* Le 20080602135139 fut introduit 'ChaineNumero(...)' afin de pouvoir parametrer            */
                                        /* aisement le nombre de chiffres des numeros...                                             */
                    Test(PAS_D_ERREUR(CODE_ERROR(IloadF_image(champ_des_fonctions_propres,nom_image))))
                         Bblock
                         Test(IL_NE_FAUT_PAS(renormaliser_chaque_champ_independamment))
                              Bblock
                              CALS(Ifloat_std(ImageR
                                             ,champ_des_fonctions_propres
                                             ,niveau_minimum_de_la_sequence
                                             ,niveau_maximum_de_la_sequence
                                              )
                                   );
                                        /* Renormalisation globale des images de la sequence...                                      */
                              Eblock
                         ATes
                              Bblock
                              CALS(Ifloat_std_avec_renormalisation(ImageR
                                                                  ,champ_des_fonctions_propres
                                                                   )
                                   );
                                        /* Renormalisation locale des images de la sequence...                                       */
                              Eblock
                         ETes

                         CALi(Iupdate_image(nom_image,ImageR));
                         Eblock
                    ATes
                         Bblock
                         PRINT_ERREUR("le fichier recupere n'existe pas, ou n'est pas de type 'image'");
                         Eblock
                    ETes
                    CALZ_FreCC(nom_image);

                    INCR(numero_de_la_periode_courante,I);
                                        /* Et passage a l'image suivante...                                                          */
                    Eblock
               EKom
               Eblock
          ATes
               Bblock
                                        /* Cas ou l'on genere des images de type 'imageF' :                                          */
               Eblock
          ETes

          EDEFV(imageF,champ_des_fonctions_propres);
                                        /* Image flottante dans laquelle on trouve les fonctions propres avant renormalisation.      */
          Eblock
     end_nouveau_block

     RETU_Commande;
     Eblock
ECommande



Copyright © Jean-François COLONNA, 2019-2024.
Copyright © CMAP (Centre de Mathématiques APpliquées) UMR CNRS 7641 / École polytechnique, Institut Polytechnique de Paris, 2019-2024.