Bonjour à vous 2, merci de m'avoir répondu aussi vite.
Quand je parlais de DOS, je voulais dire une fenêtre de commande dos sous windows. En fait je programme avec visual C++, donc j'ai soit je fais un affichage dans une fenêtre DOS avec "printf" soit sous windows avec une boite de dialogue. En faisant un programme très simple qui n'affiche la valeur que d'un seul résolveur ça fonctionne bien, et j'ai quelque chose qui ressemble à du temps réel, même si je ne passe pas par RTX. Apres je me demandais si le problème pouvait venir du fait que je passe par des multiplexeurs, mais comme ils ont un temps de permutation de 16ns je me suis dit que ça pouvait pas etre ça ? Je pense qu'il faudrait que j'essais de faire un affichage sous DOS avec l'evolution des angles en passant d'un resolveur à l'autre ça peut, peut-être me permettre de voir où ça bug ?
Merci pour l'info sur les timer, je vais voir ce que je trouve la dessus.
Voila le code du prog simple, même si vous ne pourrez pas le compiler vu que vous n'avez pas la carte, mais ça peut vous donner une idée ?! #include "nidaqex.h" #include "stdio.h" #include "string.h" #include "stdlib.h" #include <iostream.h> #include "process.h"
void main(void) { i16 iStatus = 0; i16 iStatus_lec1 = 0; i16 iStatus_lec2 = 0;
i16 iRetVal = 0; i16 iDevice = 1; i16 iPort_0 = 0; //Numéro du port (0,1,2) i16 iPort_1 = 1; i16 iPort_2 = 2; i16 iMode = 0; //Activation ou désactivation handshake i16 iDir = 1; // idir= 1 ->écriture i16 iDir_lec = 0; //idir=0 -> lecture i32 iPattern = 0; // ipattern = variable à écrire sur le port ou lu sur le port i32 iPattern_1 = 0; i32 iPattern_2 = 0; i32 iNumLoops = 10000000000; i16 iIgnoreWarning = 0; i16 iYieldON = 1; f64 iresult =0;
int result=0;
iStatus = DIG_Prt_Config(iDevice, iPort_0, iMode, iDir); iStatus_lec1 = DIG_Prt_Config(iDevice, iPort_1, iMode, iDir_lec); iStatus_lec2 = DIG_Prt_Config(iDevice, iPort_2, iMode, iDir_lec);
iRetVal = NIDAQErrorHandler(iStatus, "DIG_Prt_Config", iIgnoreWarning); while ((iPattern < iNumLoops) && (iStatus == 0)) {
system("cls"); //on efface l'ecran
//ecrit sur port0 iStatus = DIG_Out_Prt(iDevice, iPort_0, 0); //ici que "val" entre en compte (choix resolveur) iRetVal = NIDAQErrorHandler(iStatus, "DIG_Out_Prt",iIgnoreWarning);
//on lit et affiche la valeur decimale du port1 iStatus_lec1 = DIG_In_Prt(iDevice, iPort_1, &iPattern_1); iRetVal = NIDAQErrorHandler(iStatus_lec1, "DIG_In_Prt",iIgnoreWarning);
//on lit et affiche la valeur port 2 iStatus_lec2 = DIG_In_Prt(iDevice, iPort_2, &iPattern_2); iRetVal = NIDAQErrorHandler(iStatus_lec2, "DIG_In_Prt",iIgnoreWarning);
result = (0.0054931640625)*((iPattern_2*256)+iPattern_1); //ipatern_2 = octet haut printf(" The digital pattern on port %d is (DECIMAL) %ld\n", iPort_0, iPattern); printf(" The digital pattern on port %d is (DECIMAL) %ld\n", iPort_1, iPattern_1); printf(" The digital pattern on port %d is (DECIMAL) %ld\n", iPort_2, iPattern_2); printf("l'angle est de %ld\n", result);
iRetVal = NIDAQDelay(0.2); iRetVal = NIDAQYield(iYieldON); } }
|