/*************************************************************************************************************************************/ /* */ /* 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 G A U S S I E N G E N E R A L I S E : */ /* */ /* */ /* Author of '$xci/gaussg$K' : */ /* */ /* Jean-Francois COLONNA (LACTAMME, 20050208085214). */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 20071224112726... */ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 COEFFICIENT_GAUSS_GENERALISE \ FLOT(HUIT) \ /* Efficacite du gaussien generalise. */ #define COEFFICIENT_GAUSS_GENERALISE_X \ FU #define COEFFICIENT_GAUSS_GENERALISE_Y \ FU #define COEFFICIENT_GAUSS_GENERALISE_Z \ FU /* Ponderation des puissances des coordonnees 'X', 'Y' et 'Z'. */ #define EXPOSANT_GAUSS_GENERALISE_X \ FDEUX #define EXPOSANT_GAUSS_GENERALISE_Y \ FDEUX #define EXPOSANT_GAUSS_GENERALISE_Z \ FDEUX /* Exposant des coordonnees 'X', 'Y' et 'Z'. */ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 G A U S S I E N G E N E R A L I S E : */ /* */ /*************************************************************************************************************************************/ BCommande(nombre_d_arguments,arguments) /*-----------------------------------------------------------------------------------------------------------------------------------*/ Bblock DEFV(CHAR,INIC(POINTERc(nom_imageR),NOM_PIPE)); #include xci/genere_ch.02.I" /*..............................................................................................................................*/ EGAL(Fgaussien_generalise_____coefficient,COEFFICIENT_GAUSS_GENERALISE); EGAL(Fgaussien_generalise_____coefficient_X,COEFFICIENT_GAUSS_GENERALISE_X); EGAL(Fgaussien_generalise_____coefficient_Y,COEFFICIENT_GAUSS_GENERALISE_Y); EGAL(Fgaussien_generalise_____coefficient_Z,COEFFICIENT_GAUSS_GENERALISE_Z); EGAL(Fgaussien_generalise_____exposant_X,EXPOSANT_GAUSS_GENERALISE_X); EGAL(Fgaussien_generalise_____exposant_Y,EXPOSANT_GAUSS_GENERALISE_Y); EGAL(Fgaussien_generalise_____exposant_Z,EXPOSANT_GAUSS_GENERALISE_Z); /* Definition du champ gaussien generalise... */ #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_gaussien_generalise=""ariegg=""ariec=" ,Fgaussien_generalise____`use_arithmetique_etendue_et_non_basique ,BLOC(VIDE;) ,BLOC(Bblock EGAL(si_le_GooF_est_activable`use_arithmetique_etendue_et_non_basique ,Fgaussien_generalise____`use_arithmetique_etendue_et_non_basique ); Eblock ) ); PROCESS_ARGUMENT_N("arithmetique_de_base_gaussien_generalise=""aribgg=""aribc=" ,Fgaussien_generalise____`use_arithmetique_etendue_et_non_basique ,BLOC(VIDE;) ,BLOC(Bblock EGAL(si_le_GooF_est_activable`use_arithmetique_etendue_et_non_basique ,NOTL(Fgaussien_generalise____`use_arithmetique_etendue_et_non_basique) ); /* Le 20071226163048 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 20071224112726... */ GET_ARGUMENT_F("c=",Fgaussien_generalise_____coefficient); GET_ARGUMENT_F("cx=",Fgaussien_generalise_____coefficient_X); GET_ARGUMENT_F("cy=",Fgaussien_generalise_____coefficient_Y); GET_ARGUMENT_F("cz=",Fgaussien_generalise_____coefficient_Z); GET_ARGUMENT_F("ex=",Fgaussien_generalise_____exposant_X); GET_ARGUMENT_F("ey=",Fgaussien_generalise_____exposant_Y); GET_ARGUMENT_F("ez=",Fgaussien_generalise_____exposant_Z); PROCESS_ARGUMENTS_DE_PARAMETRAGE_3D_DE_____ACCES_A_UN_CHAMP_3D; /* Introduit le 20060516113053... */ ) ); #include xci/genere_ch.04.I" GENERATION_DU_CHAMP_DEMANDE(Fgaussien_generalise,nom_imageR,AXPB(facteur_Zf,Zf,translation_Zf),Tf_ARGUMENT_INUTILE,UPD_CHAMP_S); /* On notera que 'Fgaussien(...)' et 'Fgaussien_generalise(...)' ne donne pas exactement */ /* les memes valeurs a cause du fait que la premiere utilise 'EXP2(...)' alors que la */ /* seconde utilise 'PUIX(...)'. Malgre tout la difference est minime ; ainsi, en mode */ /* "standard=FAUX", '$xci/soustraction$X' entre deux champs generes par l'une et par l'autre */ /* respectivement donne les extrema {-1.110223024625157e-16,+1.110223024625157e-16} en */ /* utilisant toutes les options par defaut... */ /* */ /* L'argument 'Tf_ARGUMENT_INUTILE' a ete introduit le 20100209105935. */ RETU_Commande; Eblock ECommande