/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        C O N V O L U T I O N   D ' U N   A L B U M  :                                                                             */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Author of '$xci/convol_3D.01$K' :                                                                                          */
/*                                                                                                                                   */
/*                    Jean-Francois COLONNA (LACTAMME, 20180509101913).                                                              */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        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  :                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        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  image_image_DI_ALBUM_EXT

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        P A R A M E T R E S  :                                                                                                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xci/sequence.01.I"
                                        /* ATTENTION, on definit ainsi le symbole 'DERNIERE_IMAGE' qui ne sert a rien ici, puisque   */
                                        /* c'est en effet 'Zmax' qui joue ce role...                                                 */

#define   INVERSER_L_AXE_OZ                                                                                                             \
                    FAUX                                                                                                                \
                                        /* Indique s'il faut inverser l'ordre de parcours de l'ensemble des images. On a :           */ \
                                        /*                                                                                           */ \
                                        /*                  FAUX    : l'image d'arriere-plan est la premiere de la liste,            */ \
                                        /*                  VRAI    : l'image d'arriere-plan est la derniere de la liste.            */ \
                                        /*                                                                                           */
#define   INCOMPLET_AXE_OZ                                                                                                              \
                    FAUX                                                                                                                \
                                        /* Indique s'il peut manquer des images...                                                   */
#define   INCOMPLET_AXE_OZ_VALEUR_STANDARD                                                                                              \
                    NOIR
#define   INCOMPLET_AXE_OZ_VALEUR_NON_STANDARD                                                                                          \
                    FLOT__NOIR
                                        /* Donne la valeur des images manquantes...                                                  */

#define   BINARISER_L_ALBUM                                                                                                             \
                    FAUX
#define   SEUIL_NOIR_BLANC                                                                                                              \
                    NOIR
#define   NIVEAU_INFERIEUR                                                                                                              \
                    NOIR
#define   NIVEAU_SUPERIEUR                                                                                                              \
                    BLANC
#define   F_SEUIL_NOIR_BLANC                                                                                                            \
                    FLOT__NOIR
#define   F_NIVEAU_INFERIEUR                                                                                                            \
                    FLOT__NOIR
#define   F_NIVEAU_SUPERIEUR                                                                                                            \
                    FLOT__BLANC
                                        /* Faut-il binariser l'album Resultat ('VRAI') ou le laisser tel quel ('FAUX') ?             */
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        M A C R O S   U T I L E S  :                                                                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xci/transformation_3D.11.I"

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        C O N V O L U T I O N   D ' U N   A L B U M  :                                                                             */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
BCommande(nombre_d_arguments,arguments)
/*-----------------------------------------------------------------------------------------------------------------------------------*/
     Bblock
     DEFV(CHAR,INIC(POINTERc(nom_albumR),NOM_PIPE));
     DEFV(CHAR,INIC(POINTERc(nom_albumA),NOM_PIPE));

     DEFV(CHAR,INIC(POINTERc(nom_postfixe),NOM_UNDEF_VIDE));
                                        /* Nom d'un eventuel postfixe a placer derriere <nom_albumA><numero> (par exemple '$ROUGE'). */
     DEFV(Int,INIT(premiere_image,PREMIERE_IMAGE));
                                        /* Numero de la premiere image,                                                              */
     DEFV(Int,INIT(pas_des_images,PAS_DES_IMAGES));
                                        /* Pas de passage d'un numero d'image a une autre.                                           */
     DEFV(Int,INIT(nombre_de_chiffres,NOMBRE_DE_CHIFFRES));
                                        /* Nombre de chiffres codant le numero des images de la serie...                             */

     DEFV(Logical,INIT(inverser_l_axe_OZ,INVERSER_L_AXE_OZ));
                                        /* Indique s'il faut inverser l'ordre de parcours de l'ensemble des images. On a :           */
                                        /*                                                                                           */
                                        /*                  FAUX    : l'image d'arriere-plan est la premiere de la liste,            */
                                        /*                  VRAI    : l'image d'arriere-plan est la derniere de la liste.            */
                                        /*                                                                                           */
     DEFV(Logical,INIT(incomplet_axe_OZ,INCOMPLET_AXE_OZ));
                                        /* Indique s'il peut manquer des images...                                                   */
     DEFV(genere_p,INIT(incomplet_axe_OZ_valeur_standard,INCOMPLET_AXE_OZ_VALEUR_STANDARD));
     DEFV(genere_Float,INIT(incomplet_axe_OZ_valeur_non_standard,INCOMPLET_AXE_OZ_VALEUR_NON_STANDARD));
                                        /* Donne la valeur des images manquantes...                                                  */

     DEFV(Logical,INIT(binariser_l_album,BINARISER_L_ALBUM));
     DEFV(genere_p,INIT(seuil,SEUIL_NOIR_BLANC));
     DEFV(genere_Float,INIT(Fseuil,F_SEUIL_NOIR_BLANC));
     DEFV(genere_p,INIT(niveau_inferieur,NIVEAU_INFERIEUR));
     DEFV(genere_p,INIT(niveau_superieur,NIVEAU_SUPERIEUR));
     DEFV(genere_Float,INIT(Fniveau_inferieur,F_NIVEAU_INFERIEUR));
     DEFV(genere_Float,INIT(Fniveau_superieur,F_NIVEAU_SUPERIEUR));
                                        /* Faut-il binariser l'album Resultat ('VRAI') ou le laisser tel quel ('FAUX') ?             */
     /*..............................................................................................................................*/
     GET_ARGUMENTSi(nombre_d_arguments
                   ,BLOC(GET_ARGUMENT_C("imageA=""A=",nom_albumA);
                         GET_ARGUMENT_C("imageR=""R=",nom_albumR);
                         GET_ARGUMENT_C("postfixe=",nom_postfixe);
                         GET_ARGUMENT_I("premiere=",premiere_image);
                         GET_ARGUMENTS2_I("pas=",pas_des_images,pasZ);
                         GET_ARGUMENT_I("chiffres=",nombre_de_chiffres);

                         GET_ARGUMENT_L("inverser_Z=""inv_Z=",inverser_l_axe_OZ);
                         GET_ARGUMENT_L("incomplet_Z=""inc_Z=",incomplet_axe_OZ);
                         GET_ARGUMENT_P("valeur_standard_incomplet_Z=""vsinc_Z=",incomplet_axe_OZ_valeur_standard);
                         GET_ARGUMENT_F("valeur_non_standard_incomplet_Z=""vnsinc_Z=",incomplet_axe_OZ_valeur_non_standard);

                         GET_ARGUMENT_L("standardA=",les_imagesA_sont_standards);
                         GET_ARGUMENT_L("standardR=""standard=",les_imagesR_sont_standards);

                         GET_ARGUMENTS2_L("parallelepipedique=""para="
                                         ,Aconvolution_____le_noyau_est_parallelepipedique
                                         ,AFconvolution_____le_noyau_est_parallelepipedique
                                          );
                         GET_ARGUMENTS2_N("spherique=""sph="
                                         ,Aconvolution_____le_noyau_est_parallelepipedique
                                         ,AFconvolution_____le_noyau_est_parallelepipedique
                                          );

                         GET_ARGUMENTS2_L("sphere_minimale=""sm="
                                         ,Aconvolution_____le_rayon_de_la_sphere_du_noyau_est_minimal
                                         ,AFconvolution_____le_rayon_de_la_sphere_du_noyau_est_minimal
                                          );
                         GET_ARGUMENTS2_N("sphere_maximale=""sM="
                                         ,Aconvolution_____le_rayon_de_la_sphere_du_noyau_est_minimal
                                         ,AFconvolution_____le_rayon_de_la_sphere_du_noyau_est_minimal
                                          );
                                        /* Parametres introduits le 20220221105438...                                                */

                         GET_ARGUMENTS2_I("ddnX=""dX="
                                         ,Aconvolution_____demi_dimension_du_noyau_X
                                         ,AFconvolution_____demi_dimension_du_noyau_X
                                          );
                         GET_ARGUMENTS2_I("ddnY=""dY="
                                         ,Aconvolution_____demi_dimension_du_noyau_Y
                                         ,AFconvolution_____demi_dimension_du_noyau_Y
                                          );
                         GET_ARGUMENTS2_I("ddnZ=""dZ="
                                         ,Aconvolution_____demi_dimension_du_noyau_Z
                                         ,AFconvolution_____demi_dimension_du_noyau_Z
                                          );

                         GET_ARGUMENTS2_L("convoluer_tous_points=""tous="
                                         ,Aconvolution_____convoluer_tous_les_points
                                         ,AFconvolution_____convoluer_tous_les_points
                                          );
                         GET_ARGUMENTS2_N("optimiser="
                                         ,Aconvolution_____convoluer_tous_les_points
                                         ,AFconvolution_____convoluer_tous_les_points
                                          );
                         PROCESS_ARGUMENT_F("niveau_ignore=""ignore="
                                           ,AFconvolution_____niveau_des_points_a_ne_pas_convoluer
                                           ,BLOC(VIDE;)
                                           ,BLOC(Bblock
                                                 EGAL(Aconvolution_____niveau_des_points_a_ne_pas_convoluer
                                                     ,GENP(AFconvolution_____niveau_des_points_a_ne_pas_convoluer)
                                                      );
                                        /* Le type de 'Aconvolution_____niveau_des_points_a_ne_pas_convoluer' etant different        */
                                        /* de celui de 'AFconvolution_____niveau_des_points_a_ne_pas_convoluer' implique             */
                                        /* 'PROCESS_ARGUMENT_F(...)'...                                                              */
                                                 Eblock
                                                 )
                                            );

                         PROCESS_ARGUMENT_F("niveau_indefini=""ni="
                                           ,AFconvolution_____niveau_indefini
                                           ,BLOC(VIDE;)
                                           ,BLOC(Bblock
                                                 EGAL(Aconvolution_____niveau_indefini
                                                     ,GENP(AFconvolution_____niveau_indefini)
                                                      );
                                        /* Le type de 'Aconvolution_____niveau_indefini' etant different de celui de                 */
                                        /* 'AFconvolution_____niveau_indefini' implique 'PROCESS_ARGUMENT_F(...)'...                 */
                                                 Eblock
                                                 )
                                            );

                         GET_ARGUMENT_L("binariser_album=""binariser=",binariser_l_album);
                         GET_ARGUMENT_P("Pseuil=""Ps=",seuil);
                         GET_ARGUMENT_P("Pinferieur=""Pinf=",niveau_inferieur);
                         GET_ARGUMENT_P("Psuperieur=""Psup=",niveau_superieur);
                         GET_ARGUMENT_F("Fseuil=""Fs=""seuil=""s=",Fseuil);
                         GET_ARGUMENT_F("Finferieur=""Finf=""inferieur=""inf=",Fniveau_inferieur);
                         GET_ARGUMENT_F("Fsuperieur=""Fsup=""superieur=""sup=",Fniveau_superieur);
                         )
                    );

     TRANSFORMATION_QUELCONQUE_D_UN_ALBUM(Aconvolution,AFconvolution);

     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.