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