/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        O M B R A G E   D ' U N   A L B U M  :                                                                                     */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Author of '$xci/ombrage.11$K' :                                                                                            */
/*                                                                                                                                   */
/*                    Jean-Francois COLONNA (LACTAMME, 20100622172458).                                                              */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        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   CALCULER_LES_OMBRES                                                                                                           \
                    VRAI                                                                                                                \
                                        /* Introduire le 20180124093028 afin de pouvoir lors de phases de mise au point d'une        */ \
                                        /* image accelerer le processus en ne calculant pas les ombres. Ceci a ete utilise en        */ \
                                        /* particulier dans 'v $xiirc/.MANE.41.3.$U _____Ombrage'...                                 */

#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.            */ \
                                        /*                                                                                           */ \
                                        /* Ceci fut introduit le 20100623084932...                                                   */
#define   INCOMPLET_AXE_OZ                                                                                                              \
                    FAUX                                                                                                                \
                                        /* Indique s'il peut manquer des images (ceci fut introduit le 20120322085625)...            */
#define   INCOMPLET_AXE_OZ_VALEUR_STANDARD                                                                                              \
                    NOIR
#define   INCOMPLET_AXE_OZ_VALEUR_NON_STANDARD                                                                                          \
                    FLOT__NOIR
                                        /* Donne la valeur des images manquantes (ceci fut introduit le 20120322092744)...           */

#define   BINARISER_L_ALBUM                                                                                                             \
                    VRAI                                                                                                                \
                                        /* Faut-il binariser l'album ('VRAI') ou le laisser tel quel ? Ceci a ete introduit le       */ \
                                        /* 20100624170147...                                                                         */
#define   SEUIL_NOIR_BLANC                                                                                                              \
                    NOIR
#define   F_SEUIL_NOIR_BLANC                                                                                                            \
                    FLOT__NOIR
                                        /* Seuil de discrimination entre le 'NOIR' et le 'BLANC'...                                  */
#define   NIVEAU_INFERIEUR                                                                                                              \
                    NOIR
#define   NIVEAU_SUPERIEUR                                                                                                              \
                    BLANC
#define   F_NIVEAU_INFERIEUR                                                                                                            \
                    FLOT__NOIR
#define   F_NIVEAU_SUPERIEUR                                                                                                            \
                    FLOT__BLANC
                                        /* Niveaux jouant le role du 'NOIR' et du 'BLANC'...                                         */

#define   ROTATION_OX_IMPLICITE                                                                                                         \
                    FZERO
#define   ROTATION_OY_IMPLICITE                                                                                                         \
                    FZERO
#define   ROTATION_OZ_IMPLICITE                                                                                                         \
                    FZERO
                                        /* Angles de rotation de la source lumineuse (introduite le 20111124092854).                 */
#define   INVERSER_LES_ROTATIONS                                                                                                        \
                    VRAI                                                                                                                \
                                        /* Faut-il inverser les rotations (indicateur introduit le 20111126095341...).               */
#define   TRANSLATION_OX_IMPLICITE                                                                                                      \
                    FZERO
#define   TRANSLATION_OY_IMPLICITE                                                                                                      \
                    FZERO
#define   TRANSLATION_OZ_IMPLICITE                                                                                                      \
                    FZERO
                                        /* Translation de l'origine de la source lumineuse (introduite le 20111124092854).           */

#define   COMPATIBILITE_20140929                                                                                                        \
                    FAUX                                                                                                                \
                                        /* Permet de proceder a des calculs compatibles a ceux qui furent effectues anterieurement   */ \
                                        /* au 20140929114148.                                                                        */

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        M A C R O S   U T I L E S  :                                                                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  xci/ombrage.11.I"

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        O M B R A G E   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(calculer_les_ombres,CALCULER_LES_OMBRES));
                                        /* Introduire le 20180124093028 afin de pouvoir lors de phases de mise au point d'une        */
                                        /* image accelerer le processus en ne calculant pas les ombres. Ceci a ete utilise en        */
                                        /* particulier dans 'v $xiirc/.MANE.41.3.$U _____Ombrage'...                                 */

     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.            */
                                        /*                                                                                           */
                                        /* Ceci fut introduit le 20100623084932...                                                   */
     DEFV(Logical,INIT(incomplet_axe_OZ,INCOMPLET_AXE_OZ));
                                        /* Indique s'il peut manquer des images (ceci fut introduit le 20120322085625)...            */
     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 (ceci fut introduit le 20120322092744)...           */

     DEFV(Logical,INIT(binariser_l_album,BINARISER_L_ALBUM));
                                        /* Faut-il binariser l'album ('VRAI') ou le laisser tel quel ? Ceci a ete introduit le       */
                                        /* 20100624170147...                                                                         */
     DEFV(genere_p,INIT(seuil,SEUIL_NOIR_BLANC));
     DEFV(genere_Float,INIT(Fseuil,F_SEUIL_NOIR_BLANC));
                                        /* Seuil de discrimination flottant (introduit le 20040908165025)...                         */
     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));
                                        /* Niveaux flottants jouant le role du 'NOIR' et du 'BLANC'.                                 */

     DEFV(Float,INIT(angle_de_ROTATION_OX,ROTATION_OX_IMPLICITE));
     DEFV(Float,INIT(angle_de_ROTATION_OY,ROTATION_OY_IMPLICITE));
     DEFV(Float,INIT(angle_de_ROTATION_OZ,ROTATION_OZ_IMPLICITE));
                                        /* Angles de rotation de la source lumineuse (introduite le 20111124092854).                 */
     DEFV(Logical,INIT(inverser_les_rotations,INVERSER_LES_ROTATIONS));
                                        /* Faut-il inverser les rotations (indicateur introduit le 20111126095341...).               */
     DEFV(Float,INIT(translation_OX,TRANSLATION_OX_IMPLICITE));
     DEFV(Float,INIT(translation_OY,TRANSLATION_OY_IMPLICITE));
     DEFV(Float,INIT(translation_OZ,TRANSLATION_OZ_IMPLICITE));
                                        /* Translation de l'origine de la source lumineuse (introduite le 20111124092854).           */
     DEFV(Common,DEFV(Float,SINT(source_lumineuse_X,AFombrage_____source_lumineuse_X)));
     DEFV(Common,DEFV(Float,SINT(source_lumineuse_Y,AFombrage_____source_lumineuse_Y)));
     DEFV(Common,DEFV(Float,SINT(source_lumineuse_Z,AFombrage_____source_lumineuse_Z)));
                                        /* Position de la source lumineuse avant rotation (introduite le 20111124092854).            */

     DEFV(Logical,INIT(compatibilite_20140929,COMPATIBILITE_20140929));
                                        /* Permet de proceder a des calculs compatibles a ceux qui furent effectues anterieurement   */
                                        /* au 20140929114148.                                                                        */
     /*..............................................................................................................................*/
     BSaveModifyVariable(Logical,S_ACCELERATEUR__ALOAD_POINT_COORDONNEES_01_____utiliser_l_accelerateur,FAUX);
                                        /* Introduit le 20120620092557...                                                            */
                                        /*                                                                                           */
                                        /* Le 20150309134739, suite aux experiences 'v $xiirc/.MANE.41.3.$U 20150309120210', la      */
                                        /* valeur par defaut est passee de 'VRAI' a 'FAUX' car, en effet, ces experiences ont        */
                                        /* montre que l'accelerateur etait penalisant pour l'ombrage...                              */

     EGAL(valider_les_axes_OX_OY_OZ,VRAI);
     EGAL(coefficient_de_forme_de_l_espace_tridimensionnel,COEFFICIENT_DE_FORME_DE_L_ESPACE_TRIDIMENSIONNEL);
                                        /* Introduit le 20140105182600 lors de la mise au point de 'v $xiirv/PIPO.F1.21' a cause     */
                                        /* du probleme 'v $xiii/di_album$FON 20120321113814' qui se manifeste, par exemple, si       */
                                        /* l'axe 'OZ' est beaucoup plus "court" que les axes 'OX' et/ou 'OY'.                        */

     GET_ARGUMENTSi(nombre_d_arguments
                   ,BLOC(GET_ARGUMENT_L("compatibilite_20140929=",compatibilite_20140929);
                                        /* Argument introduit le 20140929114148...                                                   */

                         GET_ARGUMENTS2_L(chain_Aconcaten3("Aombrage_____compatibilite_20101008="
                                                          ,"AFombrage_____compatibilite_20101008="
                                                          ,"compatibilite_20101008="
                                                           )
                                         ,Aombrage_____compatibilite_20101008
                                         ,AFombrage_____compatibilite_20101008
                                          );
                                        /* Arguments introduits le 20101008122657...                                                 */
                         GET_ARGUMENTS2_L(chain_Aconcaten3("Aombrage_____compatibilite_20110816="
                                                          ,"AFombrage_____compatibilite_20110816="
                                                          ,"compatibilite_20110816="
                                                           )
                                         ,Aombrage_____compatibilite_20110816
                                         ,AFombrage_____compatibilite_20110816
                                          );
                                        /* Arguments introduits le 20110816111247...                                                 */
                         GET_ARGUMENTS2_L(chain_Aconcaten3("Aombrage_____compatibilite_20140917="
                                                          ,"AFombrage_____compatibilite_20140917="
                                                          ,"compatibilite_20140917="
                                                           )
                                         ,Aombrage_____compatibilite_20140917
                                         ,AFombrage_____compatibilite_20140917
                                          );
                                        /* Arguments introduits le 20140917151121...                                                 */
                         GET_ARGUMENTS2_L(chain_Aconcaten4("Aombrage_____compatibilite_20170517="
                                                          ,"AFombrage_____compatibilite_20170517="
                                                          ,"compatibilite_20170517="
                                                          ,"optimiser1="
                                                           )
                                         ,Aombrage_____compatibilite_20170517
                                         ,AFombrage_____compatibilite_20170517
                                          );
                                        /* Arguments introduits le 20170517115229 et completes le 20170826100804 avec "optimiser1=", */
                                        /* car c'est bien de cela qu'il s'agit...                                                    */
                         GET_ARGUMENTS2_L(chain_Aconcaten3("Aombrage_____optimisation_2="
                                                          ,"AFombrage_____optimisation_2="
                                                          ,"optimiser2="
                                                           )
                                         ,Aombrage_____optimisation_2
                                         ,AFombrage_____optimisation_2
                                          );
                                        /* Arguments introduits le 20170826104014...                                                 */

                         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);
                                        /* L'argument 'pasZ' fut introduit le 20110119140029...                                      */
                         GET_ARGUMENT_I("chiffres=",nombre_de_chiffres);

                         GET_ARGUMENT_L("ombres=""ombrage=",calculer_les_ombres);
                         GET_ARGUMENT_N("soleil=",calculer_les_ombres);
                                        /* Arguments introduits le 20180124093028...                                                 */

                         GET_ARGUMENT_L("inverser_Z=""inv_Z=",inverser_l_axe_OZ);
                                        /* Argument introduit le 20100623084932...                                                   */
                         GET_ARGUMENT_L("incomplet_Z=""inc_Z=",incomplet_axe_OZ);
                                        /* Argument introduit le 20120322085625...                                                   */
                         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);
                                        /* Argument introduit le 20120322092744...                                                   */

                         GET_ARGUMENT_L("standardA=",les_imagesA_sont_standards);
                         GET_ARGUMENT_L("standardR=""standard=",les_imagesR_sont_standards);
                                        /* Arguments introduits le 20100624173304...                                                 */

                         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);
                                        /* Arguments introduits le 20140929111454...                                                 */
                         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);
                                        /* Arguments introduits le 20100624170147...                                                 */

                         GET_ARGUMENTS2_F("facteur_increment_lambda=""fil=""lambda="
                                         ,Aombrage_____facteur_de_l_increment_de_lambda
                                         ,AFombrage_____facteur_de_l_increment_de_lambda
                                          );
                                        /* Argument introduit le 20100622185409...                                                   */

                         PROCESS_ARGUMENT_F("ROTATION_OX=",angle_de_ROTATION_OX
                                           ,BLOC(VIDE;)
                                           ,BLOC(EGAL(vecteurs_____ordre_de_la_ROTATION_0X,nombre_d_arguments_recuperes);
                                                 )
                                            );
                         PROCESS_ARGUMENT_F("ROTATION_OY=",angle_de_ROTATION_OY
                                           ,BLOC(VIDE;)
                                           ,BLOC(EGAL(vecteurs_____ordre_de_la_ROTATION_0Y,nombre_d_arguments_recuperes);
                                                 )
                                            );
                         PROCESS_ARGUMENT_F("ROTATION_OZ=",angle_de_ROTATION_OZ
                                           ,BLOC(VIDE;)
                                           ,BLOC(EGAL(vecteurs_____ordre_de_la_ROTATION_0Z,nombre_d_arguments_recuperes);
                                                 )
                                            );
                         GET_ARGUMENT_L("inverser_rotations=""inv_R=",inverser_les_rotations);
                                        /* Argument introduit le 20111126095341...                                                   */
                         GET_ARGUMENT_F("tX=""TRANSLATION_OX=",translation_OX);
                         GET_ARGUMENT_F("tY=""TRANSLATION_OY=",translation_OY);
                         GET_ARGUMENT_F("tZ=""TRANSLATION_OZ=",translation_OZ);
                                        /* Arguments introduits le 20111124092854...                                                 */
                         GET_ARGUMENT_F("source_lumineuse_X=""slX=""slx=",source_lumineuse_X);
                         GET_ARGUMENT_F("source_lumineuse_Y=""slY=""sly=",source_lumineuse_Y);
                         GET_ARGUMENT_F("source_lumineuse_Z=""slZ=""slz=",source_lumineuse_Z);

                         GET_ARGUMENTS2_F("attenuation_globale=""attenuation="
                                         ,Aombrage_____attenuation_globale_des_points
                                         ,AFombrage_____attenuation_globale_des_points
                                          );
                                        /* Arguments introduits le 20120904125317...                                                 */
                         GET_ARGUMENTS2_F("attenuation_ombre=""ombre="
                                         ,Aombrage_____attenuation_des_points_a_l_ombre
                                         ,AFombrage_____attenuation_des_points_a_l_ombre
                                          );
                         GET_ARGUMENTS2_F("detecteur_vide=""detecteur=""dv="
                                         ,Aombrage_____detecteur_du_vide
                                         ,AFombrage_____detecteur_du_vide
                                          );
                         PROCESS_ARGUMENT_F("niveau_vide=""vide="
                                           ,AFombrage_____niveau_du_vide_dans_l_album
                                           ,BLOC(VIDE;)
                                           ,BLOC(Bblock
                                                 EGAL(Aombrage_____niveau_du_vide_dans_l_album
                                                     ,GENP(AFombrage_____niveau_du_vide_dans_l_album)
                                                      );
                                        /* Le type de 'Aombrage_____niveau_du_vide_dans_l_album' etant different de celui de         */
                                        /* 'AFombrage_____niveau_du_vide_dans_l_album' implique 'PROCESS_ARGUMENT_F(...)'...         */
                                                 Eblock
                                                 )
                                            );

                         GET_ARGUMENTS2_L("periodiser_X=""periodX="
                                         ,Aombrage_____periodiser_X
                                         ,AFombrage_____periodiser_X
                                          );
                         GET_ARGUMENTS2_L("periodiser_Y=""periodY="
                                         ,Aombrage_____periodiser_Y
                                         ,AFombrage_____periodiser_Y
                                          );
                         GET_ARGUMENTS2_L("periodiser_Z=""periodZ="
                                         ,Aombrage_____periodiser_Z
                                         ,AFombrage_____periodiser_Z
                                          );
                         GET_ARGUMENTS2_L("symetriser_X=""symetrX="
                                         ,Aombrage_____symetriser_X
                                         ,AFombrage_____symetriser_X
                                          );
                         GET_ARGUMENTS2_L("symetriser_Y=""symetrY="
                                         ,Aombrage_____symetriser_Y
                                         ,AFombrage_____symetriser_Y
                                          );
                         GET_ARGUMENTS2_L("symetriser_Z=""symetrZ="
                                         ,Aombrage_____symetriser_Z
                                         ,AFombrage_____symetriser_Z
                                          );
                         GET_ARGUMENTS2_L("prolonger_X=""prolX="
                                         ,Aombrage_____prolonger_X
                                         ,AFombrage_____prolonger_X
                                          );
                         GET_ARGUMENTS2_L("prolonger_Y=""prolY="
                                         ,Aombrage_____prolonger_Y
                                         ,AFombrage_____prolonger_Y
                                          );
                         GET_ARGUMENTS2_L("prolonger_Z=""prolZ="
                                         ,Aombrage_____prolonger_Z
                                         ,AFombrage_____prolonger_Z
                                          );
                         PROCESS_ARGUMENT_F("niveau_hors_album=""nha=""niveau_hors_image=""nhi=""niveau="
                                           ,AFombrage_____niveau_hors_album
                                           ,BLOC(VIDE;)
                                           ,BLOC(Bblock
                                                 EGAL(Aombrage_____niveau_hors_album
                                                     ,GENP(AFombrage_____niveau_hors_album)
                                                      );
                                        /* Le type de 'Aombrage_____niveau_hors_album' etant different de celui de                   */
                                        /* 'AFombrage_____niveau_hors_album' implique 'PROCESS_ARGUMENT_F(...)'...                   */
                                                 Eblock
                                                 )
                                            );

                         GET_ARGUMENT_L("AccelerateurALoadPoint=""AccALP="
                                       ,S_ACCELERATEUR__ALOAD_POINT_COORDONNEES_01_____utiliser_l_accelerateur
                                        );
                                        /* Arguments introduits le 20120310145414...                                                 */

                         GET_ARGUMENTS2_L("appliquer_une_matrice_de_transformation=""matrice=""transformation="
                                         ,FAload_point_coordonnees_01_____appliquer_une_matrice_de_transformation
                                         ,FFAload_point_coordonnees_01_____appliquer_une_matrice_de_transformation
                                          );
                         GET_ARGUMENTS2_F("mxx=""mtxx="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cx,cx)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cx,cx)
                                          );
                         GET_ARGUMENTS2_F("mxy=""mtxy="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cx,cy)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cx,cy)
                                          );
                         GET_ARGUMENTS2_F("mxz=""mtxz="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cx,cz)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cx,cz)
                                          );
                         GET_ARGUMENTS2_F("myx=""mtyx="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cy,cx)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cy,cx)
                                          );
                         GET_ARGUMENTS2_F("myy=""mtyy="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cy,cy)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cy,cy)
                                          );
                         GET_ARGUMENTS2_F("myz=""mtyz="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cy,cz)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cy,cz)
                                          );
                         GET_ARGUMENTS2_F("mzx=""mtzx="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cz,cx)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cz,cx)
                                          );
                         GET_ARGUMENTS2_F("mzy=""mtzy="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cz,cy)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cz,cy)
                                          );
                         GET_ARGUMENTS2_F("mzz=""mtzz="
                                         ,ASD2(FAload_point_coordonnees_01_____matrice_de_transformation,cz,cz)
                                         ,ASD2(FFAload_point_coordonnees_01_____matrice_de_transformation,cz,cz)
                                          );

                         GET_ARGUMENTS2_F("pre_atrx="
                                         ,FAload_point_coordonnees_01_____PreAntiTranslation_Xf
                                         ,FFAload_point_coordonnees_01_____PreAntiTranslation_Xf
                                          );
                         GET_ARGUMENTS2_F("post_trx="
                                         ,FAload_point_coordonnees_01_____Post___Translation_Xf
                                         ,FFAload_point_coordonnees_01_____Post___Translation_Xf
                                          );
                         GET_ARGUMENTS2_F("pre_atry="
                                         ,FAload_point_coordonnees_01_____PreAntiTranslation_Yf
                                         ,FFAload_point_coordonnees_01_____PreAntiTranslation_Yf
                                          );
                         GET_ARGUMENTS2_F("post_try="
                                         ,FAload_point_coordonnees_01_____Post___Translation_Yf
                                         ,FFAload_point_coordonnees_01_____Post___Translation_Yf
                                          );

                         GET_ARGUMENTS2_L("interpoler=""inter="
                                         ,FAload_point_coordonnees_01_____interpoler_bilineairement_ou_bicubiquement
                                         ,FFAload_point_coordonnees_01_____interpoler_bilineairement_ou_bicubiquement
                                          );
                         GET_ARGUMENTS2_F("interpolerX=""interX="
                                         ,FAload_point_coordonnees_01_____ponderation_du_barycentre_d_interpolation_X
                                         ,FFAload_point_coordonnees_01_____ponderation_du_barycentre_d_interpolation_X
                                          );
                         GET_ARGUMENTS2_F("interpolerY=""interY="
                                         ,FAload_point_coordonnees_01_____ponderation_du_barycentre_d_interpolation_Y
                                         ,FFAload_point_coordonnees_01_____ponderation_du_barycentre_d_interpolation_Y
                                          );
                         GET_ARGUMENTS2_F("interpolerZ=""interZ="
                                         ,FAload_point_coordonnees_01_____ponderation_du_barycentre_d_interpolation_Z
                                         ,FFAload_point_coordonnees_01_____ponderation_du_barycentre_d_interpolation_Z
                                          );
                         GET_ARGUMENTS2_L("interpoler_lineairement=""lineaire=""bilineaire="
                                         ,FAload_point_coordonnees_01_____utiliser_l_interpolation_bilineaire
                                         ,FFAload_point_coordonnees_01_____utiliser_l_interpolation_bilineaire
                                          );
                                        /* Arguments completes ("interpoler_lineairement=") le 20150305104710 pour ameliorer         */
                                        /* les sorties de "use"...                                                                   */
                         GET_ARGUMENTS2_N("interpoler_cubiquement=""cubique=""bicubique="
                                         ,FAload_point_coordonnees_01_____utiliser_l_interpolation_bilineaire
                                         ,FFAload_point_coordonnees_01_____utiliser_l_interpolation_bilineaire
                                          );
                                        /* Arguments completes ("interpoler_cubiquement=") le 20150305104710 pour ameliorer          */
                                        /* les sorties de "use"...                                                                   */
                         )
                    );

     DEFINITION_DE_LA_MATRICE_DE_ROTATION_POUR_L_OMBRAGE;
                                        /* Definition de la matrice de rotation introduite sous cette forme le 20111126100425...     */
                                        /*                                                                                           */
                                        /* ATTENTION : on notera l'usage de 'DEFINITION_DE_LA_MATRICE_DE_ROTATION_POUR_L_OMBRAGE'    */
                                        /* definie dans 'v $xci/ombrage.11$I' a cause de l'operateur 'OPC1(...)' que cette           */
                                        /* definition contient et qui ne peut figurer au premier niveau (celui d'un '$K'...).        */

     EGAL(AFombrage_____source_lumineuse_X
         ,TRANSFORMATION_GEOMETRIQUE_3D_Fx(source_lumineuse_X,source_lumineuse_Y,source_lumineuse_Z
                                          ,translation_OX
                                           )
          );
     EGAL(AFombrage_____source_lumineuse_Y
         ,TRANSFORMATION_GEOMETRIQUE_3D_Fy(source_lumineuse_X,source_lumineuse_Y,source_lumineuse_Z
                                          ,translation_OY
                                           )
          );
     EGAL(AFombrage_____source_lumineuse_Z
         ,TRANSFORMATION_GEOMETRIQUE_3D_Fz(source_lumineuse_X,source_lumineuse_Y,source_lumineuse_Z
                                          ,translation_OZ
                                           )
          );
     EGAL(Aombrage_____source_lumineuse_X,AFombrage_____source_lumineuse_X);
     EGAL(Aombrage_____source_lumineuse_Y,AFombrage_____source_lumineuse_Y);
     EGAL(Aombrage_____source_lumineuse_Z,AFombrage_____source_lumineuse_Z);
                                        /* La rotation de la source lumineuse a ete introduite le 20111124092854. On notera          */
                                        /* qu'evidemment cela pourrait etre fait a l'exterieur de ce programme, mais c'est pour      */
                                        /* faciliter son utilisation, par exemple, dans une boucle de rotation d'un champ afin       */
                                        /* d'obtenir des couples de stereogrammes, auquel cas, le champ d'ombres devra etre          */
                                        /* recalcule pour chaque nouvelle position et non pas une fois pour toute comme cela         */
                                        /* est fait jusqu'a cette date ('v $xiirc/.MANE.41.3.$U .xci.ombrage.11.X'...                */
                                        /*                                                                                           */
                                        /* On notera, si je ne dis pas de betises, que lorsque l'on fait tourner un champ a          */
                                        /* visualiser, il convient de faire tourner de la meme facon (meme angle et meme signe)      */
                                        /* la source lumineuse. Ainsi, les ombres seront les memes par rapport au champ et ce        */
                                        /* quel que soit le point de vue...                                                          */

     Test(IFET(IL_NE_FAUT_PAS(compatibilite_20140929)
              ,IFET(EST_VRAI(les_imagesA_sont_standards)
                   ,EST_VRAI(les_imagesR_sont_standards)
                    )
               )
          )
                                        /* Test introduit le 20140929104756...                                                       */
          Bblock
          BDEFV(album,album_d_imagesA);
          BDEFV(album,album_d_imagesR);
                                        /* Definition des albums d'images Argument et Resultat...                                    */

          CALS(dAnoir(album_d_imagesR));
                                        /* Initialisation de l'image Resultat.                                                       */

          CALi(idAload_album(album_d_imagesA
                            ,nom_albumA
                            ,nom_postfixe
                            ,premiere_image
                            ,pas_des_images
                            ,nombre_de_chiffres
                            ,FAUX
                            ,UNDEF
                            ,inverser_l_axe_OZ
                            ,incomplet_axe_OZ
                            ,incomplet_axe_OZ_valeur_standard
                             )
               );
                                        /* Chargement de l'album Argument...                                                         */

          Test(PAS_D_ERREUR(CODE_ERREUR))
               Bblock
               Test(IL_FAUT(binariser_l_album))
                    Bblock
                    BDEFV(album,album_d_imagesA_binarise);
                                        /* Definition de l'album d'images Argument binarise...                                       */

                    CALS(Abinarisation_generale(album_d_imagesA_binarise
                                               ,album_d_imagesA
                                               ,seuil
                                               ,niveau_inferieur,niveau_superieur
                                                )
                         );
                    CALS(Amove(album_d_imagesA,album_d_imagesA_binarise));
                                        /* Binarisation de l'album d'images Argument...                                              */

                    EDEFV(album,album_d_imagesA_binarise);
                                        /* Definition de l'album d'images Argument binarise...                                       */
                    Eblock
               ATes
                    Bblock
                    Eblock
               ETes

               Test(IL_FAUT(calculer_les_ombres))
                    Bblock
                    CALS(Aombrage(album_d_imagesR,album_d_imagesA));
                                        /* Ombrage...                                                                                */
                    Eblock
               ATes
                    Bblock
                    CALS(dAinitialisation(album_d_imagesR,POINT_A_PRIORI_AU_SOLEIL));
                                        /* Lorsque l'ombrage n'est pas calcule tous les points sont au soleil (ceci a ete            */
                                        /* introduit le 20180124093028....).                                                         */
                    Eblock
               ETes
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          CALi(dAupdate_album(nom_albumR
                             ,nom_postfixe
                             ,premiere_image
                             ,pas_des_images
                             ,album_d_imagesR
                             ,nombre_de_chiffres
                             ,FAUX
                              )
               );

          EDEFV(album,album_d_imagesR);
          EDEFV(album,album_d_imagesA);
                                        /* Definition des albums d'images Argument et Resultat...                                    */
          Eblock
     ATes
          Bblock
          BDEFV(albumF,album_d_imagesA);
          BDEFV(albumF,album_d_imagesR);
                                        /* Definition des albums d'images Argument et Resultat...                                    */

          CALS(dAFinitialisation(album_d_imagesR,FZERO));
                                        /* Initialisation de l'album Resultat.                                                       */

          Test(EST_VRAI(les_imagesA_sont_standards))
                                        /* Possibilite introduite le 20100623092431...                                               */
               Bblock
               BDEFV(album,album_d_imagesA_standard);
                                        /* Definition de l'album d'images Argument...                                                */

               CALi(idAload_album(album_d_imagesA_standard
                                 ,nom_albumA
                                 ,nom_postfixe
                                 ,premiere_image
                                 ,pas_des_images
                                 ,nombre_de_chiffres
                                 ,FAUX
                                 ,UNDEF
                                 ,inverser_l_axe_OZ
                                 ,incomplet_axe_OZ
                                 ,incomplet_axe_OZ_valeur_standard
                                  )
                    );
                                        /* Chargement de l'album Argument...                                                         */


               CALS(Astd_float_brutal(album_d_imagesA,album_d_imagesA_standard));
                                        /* Conversion de l'album Argument standard en un album non standard...                       */

               EDEFV(album,album_d_imagesA_standard);
                                        /* Definition de l'album d'images Argument...                                                */
               Eblock
          ATes
               Bblock
               CALi(idAloadF_album(album_d_imagesA
                                  ,nom_albumA
                                  ,nom_postfixe
                                  ,premiere_image
                                  ,pas_des_images
                                  ,nombre_de_chiffres
                                  ,FAUX
                                  ,UNDEF
                                  ,inverser_l_axe_OZ
                                  ,incomplet_axe_OZ
                                  ,incomplet_axe_OZ_valeur_non_standard
                                   )
                    );
                                        /* Chargement de l'album Argument...                                                         */
                                        /*                                                                                           */
                                        /* L'argument 'Inv' (='FAUX') a ete parametre le 20100623084938 par 'inverser_l_axe_OZ'...   */
               Eblock
          ETes

          Test(PAS_D_ERREUR(CODE_ERREUR))
               Bblock
               Test(IL_FAUT(binariser_l_album))
                                        /* Possibilite introduite le 20100624170147...                                               */
                    Bblock
                    BDEFV(albumF,album_d_imagesA_binarise);
                                        /* Definition de l'album d'images Argument binarise...                                       */

                    CALS(AFbinarisation_generale(album_d_imagesA_binarise
                                                ,album_d_imagesA
                                                ,Fseuil
                                                ,Fniveau_inferieur,Fniveau_superieur
                                                 )
                         );
                    CALS(AFmove(album_d_imagesA,album_d_imagesA_binarise));
                                        /* Binarisation de l'album d'images Argument...                                              */

                    EDEFV(albumF,album_d_imagesA_binarise);
                                        /* Definition de l'album d'images Argument binarise...                                       */
                    Eblock
               ATes
                    Bblock
                    Eblock
               ETes

               CALS(AFombrage(album_d_imagesR,album_d_imagesA));
                                        /* Ombrage...                                                                                */
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          Test(EST_VRAI(les_imagesR_sont_standards))
                                        /* Possibilite introduite le 20100624081619...                                               */
               Bblock
               BDEFV(album,album_d_imagesR_standard);
                                        /* Definition de l'album d'images Resultat...                                                */

               CALS(Afloat_std_brutal(album_d_imagesR_standard,album_d_imagesR));
                                        /* Conversion de l'album Resultat non standard en un album standard...                       */

               CALi(dAupdate_album(nom_albumR
                                  ,nom_postfixe
                                  ,premiere_image
                                  ,pas_des_images
                                  ,album_d_imagesR_standard
                                  ,nombre_de_chiffres
                                  ,FAUX
                                   )
                    );
                                        /* L'argument 'Inv' (='FAUX') a ete introduit le 20100624090629...                           */

               EDEFV(album,album_d_imagesR_standard);
                                        /* Definition de l'album d'images Resultat...                                                */
               Eblock
          ATes
               Bblock
               CALi(dAupdateF_album(nom_albumR
                                   ,nom_postfixe
                                   ,premiere_image
                                   ,pas_des_images
                                   ,album_d_imagesR
                                   ,nombre_de_chiffres
                                   ,FAUX
                                    )
                    );
                                        /* L'argument 'Inv' (='FAUX') a ete introduit le 20100624090629...                           */
               Eblock
          ETes

          EDEFV(albumF,album_d_imagesR);
          EDEFV(albumF,album_d_imagesA);
                                        /* Definition des albums d'images Argument et Resultat...                                    */
          Eblock
     ETes

     ESaveModifyVariable(Logical,S_ACCELERATEUR__ALOAD_POINT_COORDONNEES_01_____utiliser_l_accelerateur);

     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.