/*************************************************************************************************************************************/
/* */
/* T E S T D U " S E N D " / " R E C E I V E " D A N S L E P A R A L L E L I S M E : */
/* */
/* */
/* Author of '$xtKg/parallele.03$K' : */
/* */
/* Jean-Francois COLONNA (LACTAMME, 1987??????????). */
/* */
/*************************************************************************************************************************************/
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* 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 PRAGMA_CPP_____MODULE_NON_DERIVABLE
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* F I C H I E R S D ' I N C L U D E S : */
/* */
/*************************************************************************************************************************************/
#include INCLUDES_BASE
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* P A R A M E T R E S : */
/* */
/*************************************************************************************************************************************/
/*************************************************************************************************************************************/
/* */
/* I D E N T I F I C A T E U R D U F I L S : */
/* */
/*************************************************************************************************************************************/
DEFV(Local,DEFV(processus,identificateur));
/* Identificateur du processus fils (mis en commun afin de permettre */
/* les echanges par "SEND"/"RECEIVE". */
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* F O N C T I O N A R B I T R A I R E : */
/* */
/*************************************************************************************************************************************/
BFonctionI
#define NOMBRE_DE_TOURS \
PARE(40)
DEFV(Local,DEFV(FonctionI,fonction()))
/*-----------------------------------------------------------------------------------------------------------------------------------*/
Bblock
INIT_ERROR;
DEFV(Int,INIT(numero,ZERO));
/* Numero d'iteration. */
DEFV(Float,INIT(pi,PI));
DEFV(Double,INIT(ce,EN));
/*..............................................................................................................................*/
DoIn(numero,W,NOMBRE_DE_TOURS,I)
Bblock
SEND_I(identificateur,numero);
SEND_F(identificateur,pi);
SEND_D(identificateur,ce);
Eblock
EDoI
RETU_ERROR;
Eblock
EFonctionI
/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/* */
/* T E S T D U " S E N D " / " R E C E I V E " D A N S L E P A R A L L E L I S M E : */
/* */
/*************************************************************************************************************************************/
BCommande(nombre_d_arguments,arguments)
/*-----------------------------------------------------------------------------------------------------------------------------------*/
Bblock
DEFV(Int,INIT(numero,ZERO));
/* Numero d'iteration. */
DEFV(Int,INIT(variable,UNDEF));
/* Valeur numerique de test envoye du fils vers le pere. */
DEFV(Float,INIT(pi,FLOT__UNDEF));
DEFV(Float,INIT(pix,PI));
DEFV(Double,INIT(ce,DPRE(UNDEF)));
DEFV(Double,INIT(cex,EN));
/*..............................................................................................................................*/
GET_ARGUMENTS_(nombre_d_arguments
,BLOC(VIDE;)
);
iPARALLELE(fonction(),identificateur);
DoIn(numero,W,NOMBRE_DE_TOURS,I)
Bblock
RECEIVE_I(identificateur,variable);
CAL2(Prin1("RECEIVE = %d\n",variable));
Test(IFNE(variable,numero))
Bblock
PRINT_ERREUR("erreur 'SEND'/'RECEIVE'");
Eblock
ATes
Bblock
Eblock
ETes
RECEIVE_F(identificateur,pi);
Test(IFNE(pi,pix))
Bblock
PRINT_ERREUR("erreur pi 'SEND'/'RECEIVE'");
Eblock
ATes
Bblock
Eblock
ETes
RECEIVE_D(identificateur,ce);
Test(IFNE(ce,cex))
Bblock
PRINT_ERREUR("erreur ce 'SEND'/'RECEIVE'");
Eblock
ATes
Bblock
Eblock
ETes
Eblock
EDoI
WAIT(identificateur);
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.