/*************************************************************************************************************************************/ /* */ /* I N I T I A L I S A T I O N D ' U N E I M A G E P A R U N C H A M P S I N U S O I D A L : */ /* */ /* */ /* Author of '$xci/sinus$K' : */ /* */ /* Jean-Francois COLONNA (LACTAMME, 1988??????????). */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 20071224112921... */ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* P A R A M E T R E S : */ /* */ /*************************************************************************************************************************************/ #include xci/genere_ch.01.I" #define PONDERATION_X \ GRO8(PI) \ /* Ponderation de X, */ #define PONDERATION_Y \ GRO8(PI) \ /* Ponderation de Y, */ #define PONDERATION_RHO \ FZERO \ /* Ponderation du module 'Rho_2D(X,Y)' (introduite le 20080218153118). */ #define PONDERATION_THETA \ FZERO \ /* Ponderation du module 'Theta_2D(X,Y)' (introduite le 20080916095005). */ #define PHASE \ FZERO \ /* Phase... */ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* M A C R O S U T I L E S : */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* I N I T I A L I S A T I O N D ' U N E I M A G E P A R U N C H A M P S I N U S O I D A L : */ /* */ /*************************************************************************************************************************************/ BCommande(nombre_d_arguments,arguments) /*-----------------------------------------------------------------------------------------------------------------------------------*/ Bblock DEFV(CHAR,INIC(POINTERc(nom_imageR),NOM_PIPE)); #include xci/genere_ch.02.I" /*..............................................................................................................................*/ EGAL(Fsinusoidal_____coefficient_X,PONDERATION_X); EGAL(Fsinusoidal_____coefficient_Y,PONDERATION_Y); EGAL(Fsinusoidal_____coefficient_Rho,PONDERATION_RHO); EGAL(Fsinusoidal_____coefficient_Theta,PONDERATION_THETA); EGAL(Fsinusoidal_____coefficient_phase,PHASE); /* Definition du champ sinusoidal... */ #include xci/genere_ch.03.I" #include xci/genere_ch.11.I" GET_ARGUMENTSi(nombre_d_arguments ,BLOC(GET_ARGUMENT_C("imageR=""R=",nom_imageR); GET_ARGUMENT_L("standard=",les_images_sont_standards); PROCESS_ARGUMENT_L("arithmetique_etendue_sinusoidal=""aries=""ariec=" ,Fsinusoidal____`use_arithmetique_etendue_et_non_basique ,BLOC(VIDE;) ,BLOC(Bblock EGAL(si_le_GooF_est_activable`use_arithmetique_etendue_et_non_basique ,Fsinusoidal____`use_arithmetique_etendue_et_non_basique ); Eblock ) ); PROCESS_ARGUMENT_N("arithmetique_de_base_sinusoidal=""aribs=""aribc=" ,Fsinusoidal____`use_arithmetique_etendue_et_non_basique ,BLOC(VIDE;) ,BLOC(Bblock EGAL(si_le_GooF_est_activable`use_arithmetique_etendue_et_non_basique ,NOTL(Fsinusoidal____`use_arithmetique_etendue_et_non_basique) ); /* Le 20071226163223 fut introduit le 'NOTL(...)' a cause de 'PROCESS_ARGUMENT_N(...)' car, */ /* en effet, lorsque le 'EGAL(...)' est execute, le parametre logique en cours de traitement */ /* est alors inverse ('v $xig/fonct$vv$DEF NOTL.valeur_L_par_defaut'). */ Eblock ) ); /* Parametres d'arithmetique etendue introduits le 20071224112921... */ GET_ARGUMENT_F("cx=""cX=",Fsinusoidal_____coefficient_X); GET_ARGUMENT_F("cy=""cY=",Fsinusoidal_____coefficient_Y); GET_ARGUMENT_F("cr=""cR=",Fsinusoidal_____coefficient_Rho); GET_ARGUMENT_F("ct=""cT=",Fsinusoidal_____coefficient_Theta); /* Introduit le 20080916095005... */ GET_ARGUMENT_F("phase=""c=",Fsinusoidal_____coefficient_phase); GET_ARGUMENT_L("dephaser=""cosinus=",Fsinusoidal_____dephaser_coefficient_phase); GET_ARGUMENT_N("sinus=",Fsinusoidal_____dephaser_coefficient_phase); GET_ARGUMENT_F("translation=",Fsinusoidal_____coefficient_translation); GET_ARGUMENT_F("echelle=",Fsinusoidal_____coefficient_echelle); PROCESS_ARGUMENTS_DE_PARAMETRAGE_2D_DE_____ACCES_A_UN_CHAMP_3D; /* Introduit le 20060516111804... */ ) ); #include xci/genere_ch.04.I" GENERATION_DU_CHAMP_DEMANDE(Fsinusoidal,nom_imageR,Zf_ARGUMENT_INUTILE,Tf_ARGUMENT_INUTILE,UPD_CHAMP_S); /* On notera le 20041108102302 que si l'on souhaite qu'un nombre precis de periodes */ /* occupe 'dimX' et/ou 'dimY', il conviendra d'utiliser les nouvelles options : */ /* */ /* carre_X_CHAMP_3D=FAUX (pour 'dimX'), */ /* carre_Y_CHAMP_3D=FAUX (pour 'dimY'), */ /* */ /* ('v $xiii/mono_image$DEF ACCES_A_LA_COORDONNEE_._D_UN_CHAMP_3D_____coordonnees_dans_un'). */ /* */ /* De plus, on rappelle que faire : */ /* */ /* phase=$pis2 */ /* */ /* permet de generer un champ "cosinusoidal", mais que le 20041109232950 l'option */ /* "dephaser=" a ete introduite pour simplifier cela... */ /* */ /* L'argument 'Tf_ARGUMENT_INUTILE' a ete introduit le 20100209111515. */ RETU_Commande; Eblock ECommande