/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        A P P L I C A T I O N   D E   L A   T R A N S F O R M A T I O N   C O N F O R M E   Z * * 2                                */
/*        D A N S   L E   P L A N   C O M P L E X E  :                                                                               */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Definition :                                                                                                               */
/*                                                                                                                                   */
/*                    Cette commande genere une image                                                                                */
/*                  dont le nom est le premier argument                                                                              */
/*                  d'appel ; elle est le resultat de                                                                                */
/*                  la transformation de la deuxieme                                                                                 */
/*                  image par la transformation z --> z**2.                                                                          */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Author of '$xci/z_carre.01$K' :                                                                                            */
/*                                                                                                                                   */
/*                    Jean-Francois COLONNA (LACTAMME, 1987??????????).                                                              */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        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   GENERER_LES_GET_ARGUMENTS_DE_CONTROLE_DE_L_ARITHMETIQUE_ETENDUE_DES_NOMBRES_FLOTTANTS
                                        /* Introduit le 20070127120557...                                                            */

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

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        P A R A M E T R E S  :                                                                                                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xci/coordonne.01.I"
                                        /* Introduit le 20050912130029...                                                            */

#define   TRAVAILLER_DANS_LE_PLAN_IMAGE                                                                                                 \
                    VRAI                                                                                                                \
                                        /* Indique s'il faut travailler dans le plan image ('VRAI') ou bien dans le plan complexe    */ \
                                        /* ("FAUX').                                                                                 */
#define   FACTEUR                                                                                                                       \
                    PARE(0.010)                                                                                                         \
                                        /* Facteur multiplicatif lorsqu'il faut 'TRAVAILLER_DANS_LE_PLAN_IMAGE'. Dans le cas         */ \
                                        /* contraire, on pourra prendre une valeur proche de '5.0', c'est a dire la valeur           */ \
                                        /* precedente 'FACTEUR' multipliee par 'CHOI(dimX,dimY)'...                                  */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        M A C R O S   U T I L E S  :                                                                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        A P P L I C A T I O N   D E   L A   T R A N S F O R M A T I O N   C O N F O R M E   Z * * 2                                */
/*        D A N S   L E   P L A N   C O M P L E X E  :                                                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
BCommande(nombre_d_arguments,arguments)
/*-----------------------------------------------------------------------------------------------------------------------------------*/
     Bblock
#include  xci/coordonne.02.I"
                                        /* Introduit le 20050912130029...                                                            */

     DEFV(CHAR,INIC(POINTERc(nom_imageR),NOM_PIPE));
     DEFV(CHAR,INIC(POINTERc(nom_imageA),NOM_PIPE));
     DEFV(Logical,INIT(travailler_dans_le_plan_image,TRAVAILLER_DANS_LE_PLAN_IMAGE));
                                        /* Indique s'il faut travailler dans le plan image ('VRAI') ou bien dans le plan complexe    */
                                        /* ("FAUX').                                                                                 */
     DEFV(Float,INIT(facteur,FACTEUR));
                                        /* Facteur multiplicatif.                                                                    */
     DEFV(deltaF_2D,Atranslation);
                                        /* Translation de l'image Argument,                                                          */
     DEFV(deltaF_2D,Rtranslation);
                                        /* Translation de l'image Resultat.                                                          */
     /*..............................................................................................................................*/

#include  xci/coordonne.04.I"
                                        /* Ceci a ete introduit le 20051218183445...                                                 */
#include  xci/conformes.01.I"
                                        /* Introduit le 20120521172255...                                                            */

     GET_ARGUMENTSi(nombre_d_arguments
                   ,BLOC(GET_ARGUMENT_C("imageA=""A=",nom_imageA);
                         GET_ARGUMENT_C("imageR=""R=",nom_imageR);
                         GET_ARGUMENT_L("standard=",les_images_sont_standards);
                                        /* Cette extension a ete introduite le 20041225180111...                                     */
                         GET_ARGUMENT_L("plan_image=""image=",travailler_dans_le_plan_image);
                         GET_ARGUMENT_N("plan_complexe=""complexe=",travailler_dans_le_plan_image);
                         GET_ARGUMENT_F("facteur=""f=",facteur);
                                        /* L'argument abrege "f=" a ete introduit le 20101029101703...                               */

                         ARGUMENTS_DES_TRANSFORMATIONS_CONFORMES;
                                        /* Arguments introduits sous cette forme le 20120521172255...                                */

                         CONTROLE_DE_L_ARITHMETIQUE_ETENDUE_DES_NOMBRES_COMPLEXES;
                                        /* Cette extension a ete introduite le 20070129104938...                                     */
                         )
                    );

#include  xci/coordonne.03.I"
                                        /* Introduit le 20050912130029...                                                            */

     CALi(gInettoyage(les_images_sont_standards,ImageR,IFmageR));
                                        /* Initialisation de l'image Resultat.                                                       */

     Test(PAS_D_ERREUR(CODE_ERROR(gIload_image(les_images_sont_standards,ImageA,IFmageA,nom_imageA))))
                                        /* Chargement de l'image a transformer.                                                      */
          Bblock
          INITIALISATION_ACCROISSEMENT_2D(Atranslation
                                         ,NEGA(SUPER_lNORMALISE_OX(MOIT(FLOT(dimX))))
                                         ,NEGA(SUPER_lNORMALISE_OY(MOIT(FLOT(dimY))))
                                          );
          INITIALISATION_ACCROISSEMENT_2D(Rtranslation
                                         ,ZERO
                                         ,ZERO
                                          );

          Test(IL_FAUT(travailler_dans_le_plan_image))
               Bblock
               CALS(gIz_au_carre_dans_le_plan_image(les_images_sont_standards
                                                   ,ImageR,IFmageR
                                                   ,ADRESSE(Rtranslation)
                                                   ,facteur
                                                   ,ImageA,IFmageA
                                                   ,ADRESSE(Atranslation)
                                                    )
                    );
                                        /* Et transformation de l'image Argument dans le plan image.                                 */
               Eblock
          ATes
               Bblock
               CALS(gIz_au_carre_dans_le_plan_complexe(les_images_sont_standards
                                                      ,ImageR,IFmageR
                                                      ,ADRESSE(Rtranslation)
                                                      ,facteur
                                                      ,ImageA,IFmageA
                                                      ,ADRESSE(Atranslation)
                                                       )
                    );
                                        /* Et transformation de l'image Argument dans le plan Complexe.                              */
               Eblock
          ETes

          CALi(gIupdate_image(les_images_sont_standards,nom_imageR,ImageR,IFmageR));
          Eblock
     ATes
          Bblock
          Test__CODE_ERREUR__ERREUR07;
          Eblock
     ETes

     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.